Loading and managing code configurations with Metacello
Metacello is the code configuration management engine for Pharo. It's like NPM for JavaScript or Maven for Java. It essentially has two abilities: (1) define what packages a project consists of in a so called Metacello baseline, and (2) offer a way to load a given baseline from a remote repository.
Consider the following script:
Metacello new baseline: 'GToolkit4P3'; repository: 'github://feenkcom/gt4p3'; load.
Executing the script will load the GTooklit4P3
project from https://github.com/feenkcom/gt4p3. This will load the package GToolkit4P3
and the baseline called BaselineOfP3ForGToolkit
. Go ahead and try. And then browse BaselineOfGToolkit4P3
.
A baseline is defined in plain Pharo code through a fluent API.
Consider BaselineOfDeepTraverser
. It is a subclass of BaselineOf
defines a BaselineOfDeepTraverser>>#baseline:
method that is annotated with a <baseline>
pragma. The method defines a dependency to BaselineOfGToolkitExamplesEngine
and it specifies that there are several package in the project, such as DeepTraverser
.
A contained package is defined like this:
data:image/s3,"s3://crabby-images/fa119/fa119bf5315ab20c491de7a1c20c31b0851a506c" alt=""
Sometimes, we want to specify that a package is to be loaded after another package. For example, DeepTraverser-MemoryTraversal
depends on DeepTraverser
, so we want it loaded afterwards. This is achieved with:
data:image/s3,"s3://crabby-images/9b1e8/9b1e8ccfc450ae827b9adedac3cb958fdf2d7b0f" alt=""
A baseline dependency is defined similarly:
data:image/s3,"s3://crabby-images/a3854/a3854a20d9ab21a22cb4a065c1011c7bf3758dbd" alt=""
Evaluating the dependencies between packages and projects is easier when seen through a visualization. You can see it in Coder when browsing a baseline. For example, for the baseline of BaselineOfDeepTraverser
we can see this view showing how packages depend on each other and on external projects:
data:image/s3,"s3://crabby-images/2cf97/2cf9719acd5dae5f5f36800c6c8739c02d4069ce" alt=""