Layout distributions are archives that can be created by describing their internal layout. For example:
suite = {
"distributions": {
"EXAMPLE_DIST1": {
"layout": {
"lib/": "file:libs/*",
"include/": [
"file:include/*",
"extracted-dependency:DEVEL/include/*"
],
"LICENCE": "file:misc/license",
}
}
}
}
A distribution uses the "layout" mechanism as soon as it has a layout
attribute.
The example above would create a distribution that contains 2 directories: lib
and include
.
The lib
directory contains the files matched by <suite-dir>/libs/*
.
The include
directory contains the files matched by <suite-dir>/include/*
as well as all the files contained in the
DEVEL
archive matching include/*
(DEVEL
can be a library or another distribution).
The distribution also contains a LICENCE
file at the root which is copied from <suite-dir>/misc/license
.
The layout dictionary contains destinations as keys and sources as values.
With the above example, lib/
is a destination directory in the archive while file:libs/*
is the source of the files
that are added to this directory.
If the destination ends with a /
, a directory with that name will be created in the archive and all the source files
will be copied into this directory.
On the contrary, if the destination does not end with a /
then it is the name which should be used when copying the source.
In this case there can be only a single source (similar to the -T
flag of cp
).
The values in the layout dictionary can either be a string or a list if there are multiple sources. Each source is usually a string with a prefix denoting the type of source.
The following types are available:
-
file
copies files from the suite directory into the archive. Thefile:
prefix is followed by a glob pattern describing which files should be copied. For example:file:libs/*
. -
dependency
copies the result of another dependency (distributions, libraries, projects, etc.). Thedependency:
prefix is followed by a dependency name. Like in the rest of the suite definition, dependencies from other suites should be qualified (<suite-name>:<dependency-name>
).If that dependency produces multiple files they can be selected by appending
/
followed by a glob pattern e.g.,dependency:SOME_JAR/*.src.zip
. Some distributions produce multiple files but logically have a "main" output file, in this case, if the/<pattern>
is omitted, that "main" output is selected. For exampledependency:SOME_JAR
selectssome-jar.jar
. -
extracted-dependency
extracts the contents of a tar or jar dependency (distributions & libraries). Theextracted-dependency:
prefix is followed by a dependency name (potentially qualified by the suite name).If only certain files should be extracted, a
/
followed by a glob pattern can be appended. -
link
creates a symbolic link. Thelink:
prefix should be followed by the content of the link (a relative path from the directory containing the link). -
string
creates a file with the content following thestring:
prefix.
Note that glob patterns do not match .*
files by default.
Note that when using a glob pattern to select a source, every element matched by the pattern will be (recursively) copied like cp
would.
In particular "lib/": "file:libs/libz.so"
will produce lib/libz.so
in the archive, not lib/libs/libz.so
!
The same is true for dependency
and extracted-dependency
.
The initial source is de-referenced if it is a symlink while they are not de-referenced during recursion.
extracted-dependency
support a alternative dereference modes to prevent that (see below).
The simple string syntax for source is complemented by a dict syntax which explicitly splits the different parts of the source
and sometimes provides additional functionality. For example extracted-dependency:DEVEL/include/*
expands to:
{
"source_type": "extracted-dependency",
"dependency": "DEVEL",
"path": "include/*",
}
The argument to file
and link
are expanded into a path
property.
The argument to string
is expanded into value
property.
In their expanded forms, the file
, dependency
and extracted-dependency
support an exclude
attribute which can be used to exclude elements.
It is a glob pattern or a list of glob patterns.
If any pattern matches, the element is excluded.
The pattern is rooted at the same level as the inclusion pattern.
For extracted-dependency
, the dereference
property can set to:
"never"
to copy without any de-referencing the source (likecp -P
)"root"
(default) to only de-reference the root matches of the recursive copy (likecp -H
)"always"
always follow symlinks in the source before copying (likecp -L
)
The default of the dereference
property can be overridden for all sources with the defaultDereference
property on the layout distribution.
By default, the distribution containing the layout
will be a JAR. If it has native
attribute set to True
, it will be a TAR.
The type of archive can also be set explicitly with the type
attribute. It can be set to "zip"
, "jar"
, or "tar"
.
TAR distributions are kept locally uncompressed and are uploaded (mx maven-deploy
etc.) in gzip form (tar.gz
).
JAR and ZIP distributions have two attributes to control compression: localCompress
and remoteCompress
.
- If
localCompress
isTrue
then the archive contains deflated entries. It defaults toFalse
. - If
remoteCompress
isTrue
, then the archive is compressed when it is uploaded. It defaults toTrue
.
Note that local compression requires remote compression.
Putting all this together, here is a more complete example:
suite = {
"distributions": {
"EXAMPLE_DIST2": {
"layout": {
"./": [
"file:foo/bar"
"file:baz/*"
],
"LICENCE": "misc/license",
"lib/": [
"dependency:GEO",
"extracted-dependency:GIS-DB/data/*",
{
"source_type": "extracted-dependency",
"dependency": "GIS-DB2",
"path": "share/*",
"exclude": ['share/*.o', 'share/*.b']
},
],
"share/lib": "link:../lib",
"VERSION": "string:0.42",
}
}
}
}
This would result in an archive with the following contents:
- LICENCE
- VERSION
- bar
'- ... (the contents of <suite-dir>/foo/bar)
- ... (the files and directories found in <suite-dir>/baz)
- lib
|- geo.jar
|- ... (the files under data in GIS-DB)
'- ... (the files under share in GIS-DB2 which do not end in .o ir .b)
- share
'- lib -> ../lib
If the LINKY_LAYOUT
environment variable is set, it is used as a single
glob pattern.
Files matching that pattern will be linked into the output
directory of layout distributions rather than copied.
When using "compile on save" in Eclipse or a similar workflow, having
LINKY_LAYOUT=*.jar
in ~/.mx/env
will allow automated update of the JARs in layout
distributions.