A good workspace setup makes all the difference in the development cycle. Since a workspace can contain many projects, creating new workspaces is relatively rare. However, a workspace tends to consist of many aspects. There is the gradle setup, the OSGi release, maybe the maven layout etc. Initially, we attempted to use a single GitHub repository as a template for new workspaces, but this approach quickly became complex.
For example, if someone created a library for bnd, to make it easy for the user to setup his functionality, the author of the library had to maintain a full workspace with gradle, etc. This put the burden on chasing the OSGi release, the gradle releases, on the people that were willing to spread the gospel around OSGi/bndtools.
Instead, we developed fragment templates. A fragment models one aspect of a workspace and is maintained in Github repository, but one repository can hold many fragments. Multiple template fragments can be combined by the end-user to enrich the workspace with various aspects. During workspace creation there is a wizard where one can select template fragments via checkboxes.
The workspace is already prepared for this model of fragments. The merged instructions mean that
we can extend the properties and instructions from many different sources. However, the most important
feature here is the cnf/ext
folder. Any bnd
or special fragment file placed in this folder will automatically
be ready before the build.bnd
file is read. For example, a fragment could contain the
index for OSGi R8. See build.
There is a single master index for all template fragments hosted on
https://github.com/bndtools/workspace-templates/blob/master/index.bnd
This index is open for any person or organization that maintains one or more fragment and seeks an easy way to make them available to bndtools users. All that is needed is to host the fragment somewhere and provide a pull request (PR) to add it to this index file.
The format of the index file is like all Parameters.
key
– The key is the identity of the fragment. It is either a URL or provides the following structure:
id ::= [organization ['/' repository [ '/' path ] ['#' git-ref ]]
The id is resolved against bndtools/workspace-templates#master
. Therefore, in the example
organization,
the example
is a valid id that resolves to example/workspace-templates#master
. Since the ID has a path,
it is possible to host multiple fragments in a single repository.
The index has the following attributes for a clause:
name
– The human readable name for the template fragmentdescription
– A human readable description for the template fragmentrequire
– A comma separated list of fragment ids. Do not forget to quote when multiple fragments are requiredtag
– A comma separated list of tags, quotes are needed when there are multiple.For example consider this index.bnd
:
-workspace-templates \
bndtools/workspace-templates/gradle; \
name=gradle; \
description="Setup gradle build for bnd workspace", \
bndtools/workspace-templates/maven; \
name=maven; \
description="Use the maven directory layout for sources and binaries", \
bndtools/workspace-templates/osgi; \
name=osgi; \
description="OSGi R8 with Felix distribution"
The id must resolve to a folder in the repository. By default, bnd will recursively copy the
content to the new workspace. However, if there is a file tool.bnd
present it will use this to
guide the copying process. This bnd file looks like:
-tool \
.*;tool.bnd;readme.md;skip=true, \
gradle.properties;macro=true;append=true,\
gradlew;exec=true, \
*
The -tool
instruction is a SELECT that is matched against the file paths (not names!) in the fragment template folder.
The attributes that can be set are:
skip=true
– Skip the selected file,append=true
– Allow duplicates, appendexec=true
– Set the execute bit on non-windows systemspreprocess=true
– Preprocess the file (this uses the tool file and the current workspace as domain.delete=true
– Deletes an existing file in the target. Cannot be wildcardedIt is possible to define the -workspace-templates
instruction in the build.bnd
file.
It must contain the same format as the index. This local index is merged with the main index. In the
Bndtools GUI, it is possible to add an additional index from a URL or file.