Overview
The page goes into details about how the build system is configured.
The default ant target (“build-default”) will build the OMERO system and copy the necessary components for a binary distribution to the /dist directory. Below is a comparison of what is taken from the build, where it is put, and what role it plays in the distribution.
Note
By default, OMERO C++ language bindings is not built. Use build-all for that.
OMERO_SOURCE_PREFIX | OMERO_SOURCE_PREFIX/dist | Comments |
---|---|---|
components/blitz/target/blitz.jar | lib/server | Primary Ice servants |
components/blitz/target/server.jar | lib/server | Primary server logic |
components/tools/OmeroCpp/lib* | lib/ | Native shared libraries |
components/tools/OmeroPy/build/lib | lib/python | Python libraries |
lib/repository/<some> | lib/client & lib/server | Libraries needed for the build |
etc/ | etc/ | Configuration |
sql/*.sql | sql/ | SQL scripts to prepare the database |
<javadoc/> | docs/api | (Optional) Javadocs produced with “java omero javadoc” |
These files are then zipped to OMERO.server-<version>.zip via “java omero release-zip”
The OMERO source tree includes a self-signed certificate for testing OMERO.insight webstart. This is not used by default to avoid problems with double signing official releases. The “release-webstart-signed” target can be used, alternatively see docs/hudson/OMERO.sh and/or OMERO.insight webstart security and code-signing.
The OME project currently uses Jenkins as a continuous integration server available here, so many binary packages can be downloaded without compiling them yourself.
Hudson checks for git changes every 15 minutes and executes:
(cd docs/hudson; python launcher.py)
which invokes the “build-all”, “javadoc” “findbugs”, “coverage”, and “release-zip” targets.
The Javadocs are always made available here as well as several build metrics.
OMERO mostly uses an ant-based build with dependency management provided by Ivy. Native code is built using SCons and Python uses the traditional distutils/setuptools tools.
This is an (abbreviated) snapshot of the structure of the filesystem for OMERO:
OMERO_SOURCE_PREFIX
|
|-- build.xml .......................... Top-level build driver
|
|-- build.py ........................... Python wrapper to handle OS-specific configuration
|
|-- omero.class ........................ Self-contained Ant launcher
|
|--etc/ ................................ All configuration
| |-- grid/* ......................... Deployment files
| |-- ivysettings.xml
| |-- hibernate.properties
| |-- local.properties.example
| |-- log4j.xml
| |-- omero.properties
| \-- profiles
|
|-- examples ............................ User examples
|
\components
|
|
|--<component-name> ................... Each component has this same basic structure.
| |-- build.xml Main scripts
| |-- ivy.xml Jar dependencies
| |-- test.xml Test dependencies
| |-- src Source code
| |-- resources Other files of interest
| |-- test Test source code and test resources
| \-- target Output of build (deleted on clean)
|
|-- model ............................. The model component is special in that in produces
| a jar specific to your database choice: model-psql.jar
| The generated `ome.model.*` files contain Hibernate
| annotations for object-relational mapping.
|
|-- blitz ............................. The blitz component also performs code generation
| | producing artifacts for Java, Python, and C++.
| |
| \ blitz_tools.py ................. OMERO-specific SCons Environment definition
| and other build tools.
|
|--tools .............................. Other server-components with special build needs.
| |--build.xml
| \--<tool-name>
| |--build.xml
| `--ivy.xml
|
\--antlib ............................. Special component which is not built, but referenced by the build
|
\--resources
|--global.xml
|--directories.xml
|--lifecycle.xml
\--depdendencies.xml
Note
User examples are explained under Working with OMERO
Each of the components can also be built directly. For example,
./build.py -f components/server/build.xml
Unfortunately, just the above snapshot of the code repository omits some of the most important code. Many MB of source code is generated both by our own DSLTask as well as by the Ice slice2java, slice2cpp, and slice2py code generators. These take an intermediate representation of the OME-Model and generate our OME-Remote Objects. This code is not available in git, but once built, can be found in all the directories named “generated”.
Similarly, the ant build alone is not enough to describe all the products which get built. Namely, the builds for the non-Java components stored under components/tools are a bit more complex. Each tools component installs its artifacts to the tools/target directory which is copied on top of the OMERO_HOME/dist top-level distribution directory. Current tools include:
Ant-based builds | Ice-based builds | Scons-based builds | |
OMERO C++ language bindings | X | ||
OMERO.web framework | X | ||
OMERO.fs | X | ||
OMERO Python language bindings | X | ||
LicenseService | X | X |
./build.py is a complete replacement for your local ant install. In many cases on and on most OS, you will be fine running ant. If you have any issues (for example OutOfMemory) , please use ./build.py instead. *However*, only use one or the other. Do not mix calls between the two.