CopperSpice Overview
|
Deploying on Unix and Linux systems can be complex. Programs compiled for one Unix flavor will probably not run on a different Unix system. For example, unless you use a cross-compiler, you can not compile your application on Linux and distribute it on for example, FreeBSD. Care must also be taken when setting up Unix packages for distribution.
When deploying your application using shared libraries the correct CopperSpice libraries must be distributed with your application. In addition, any plugins must be included and installed on the target system in the correct folders.
Refer to our sample project files for details about how to compile and link your application.
To deploy your application include all the files in your 'deploy' folder. This folder was created during the 'make install' process. If your application depends on compiler specific libraries, these must also be distributed with your application. Normally the CopperSpice libraries will be installed on your target Unix system to /usr/lib
. On most systems the extension for shared libraries is .so.
A CopperSpice application may also need to load plugin libraries which must be distributed with your application. Some of the plugins are created when building CopperSpice and others may be ones you developed. If a required plugin is not installed your application will build however it may not load or run properly.
These additional plugin libraries must be located in directories with a specific name in a specific path as defined in CopperSpice. By default the path is your application executable. You can change both the path and the directory name by using a cs.conf file.
The path can be changed using QApplication::addLibraryPath()or QApplication::setLibraryPaths().
As an example, the platform plugin for Unix must be located in myApplication/platforms, unless this is changed by cs.conf or one of the methods mentioned above.
myapplication
platforms
For a complete list of the default directory names refer to the CopperSpice API. From the API main page look under the category of "Concepts" for the topic named "Plugins". Alternatively, use the following link.
It is advisable to link dynamically with the regular X11 libraries.
Some implementations of X11 may cause a statically linked application to crash by calling dlopen()
.
Your application may also depend on one or more plugins, such as the JPEG image format plugin or a SQL driver plugin. Be sure to distribute any plugins which are required for your application. Each type of plugin should be located within a specific subdirectory (such as imageformats
or sqldrivers
) within your distribution directory.
For more information about creating and deploying a plugin refer to the CopperSpice API. From the API main page look under the category of "Concepts" for the topic named "Plugins". Alternatively, use the following link.