Difference between revisions of "Autobuild/Package Layout"
Rand Linden (talk | contribs) |
m |
||
Line 33: | Line 33: | ||
*Some existing packages have their libraries located directly under lib, some have them under lib/{debug,relwithdebinfo,release} | *Some existing packages have their libraries located directly under lib, some have them under lib/{debug,relwithdebinfo,release} | ||
*Python | *Python packages are not fully supported, as we have not determined how to cleanly organize python module directories for compatibility with multiple python versions | ||
*This is not compatible with the legacy package layout used in the indra codebase for non autobuild enabled builds. Packages for these builds need to be converted to the legacy layout to be used with install.py for now. UPDATE: {{User|Brad_Linden}} has gotten TeamCity to do this for us by using a BuildParam value to configure this (build_legacy_package can be set to true). | *This is not compatible with the legacy package layout used in the indra codebase for non autobuild enabled builds. Packages for these builds need to be converted to the legacy layout to be used with install.py for now. UPDATE: {{User|Brad_Linden}} has gotten TeamCity to do this for us by using a BuildParam value to configure this (build_legacy_package can be set to true). | ||
[[Category:Autobuild]] [[Category:Open Source Portal]] | [[Category:Autobuild]] [[Category:Open Source Portal]] |
Revision as of 13:51, 4 April 2011
Autobuild does not place much in the way of restrictions on how a package is bundled into an archive. The autobuild package command will simply create an archive from the build directory gathering all the files which match manifest entries. When that package is installed using autobuild install , it is just expanded into the packages subdirectory of the build directory. That said, there is a recommended layout of various build products which has (mostly) been followed by Linden apps. On this page we give the details of that recommended layout.
|
Pakage layout
The basic layout for a typical package archive is:
- bin
- include
- include/<packagename>
- lib
- lib/debug
- lib/relwithdebinfo
- lib/release
- LICENSES
binaries
Package executables in the bin directory of the archive.
headers
Package header files in the include directory of the archive typically in a subdirectory named after the package. For example one might include the header foo.h" for the foo package in include/foo/foo.h.
libraries
Package static and shared libraries in the lib directory in a subdirectory which matches the build configuration (all lower case). This is especially important for packages built for windows where debug and release libraries are binary incompatible. As an example, if the foo package produces a library foo.lib, the version built with debugging enabled should be bundled in lib/debug whereas the optimized version should be bundled in lib/release.
License files
Include a copy of the package's license in the LICENSES directory. By convention, license files are named packagename
.txt
.
Gotchas
- Some existing packages have their libraries located directly under lib, some have them under lib/{debug,relwithdebinfo,release}
- Python packages are not fully supported, as we have not determined how to cleanly organize python module directories for compatibility with multiple python versions
- This is not compatible with the legacy package layout used in the indra codebase for non autobuild enabled builds. Packages for these builds need to be converted to the legacy layout to be used with install.py for now. UPDATE: Brad_Linden has gotten TeamCity to do this for us by using a BuildParam value to configure this (build_legacy_package can be set to true).