Difference between revisions of "Autobuild/Package Layout"
Rand Linden (talk | contribs) |
m (→Gotchas) |
||
(2 intermediate revisions by one other user not shown) | |||
Line 6: | Line 6: | ||
|} | |} | ||
=== | === Package layout === | ||
The basic layout for a typical package archive is: | The basic layout for a typical package archive is: | ||
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 | ||
[[Category:Autobuild]] [[Category:Open Source Portal]] | [[Category:Autobuild]] [[Category:Open Source Portal]] |
Latest revision as of 09:56, 19 March 2015
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.
|
Package 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