europa-build v6.0.0
Europa Build is a tool for generating and maintaining Europa plugin and preset packages.
Install
Install using your preferred package manager. For example;
$ npm install --save-dev europa-build
You'll need to have at least Node.js 12.22.0 or newer.
This package is intended for generating Europa plugins and preset packages as well as also being used by those generated packages to ensure a smooth and consistent maintenance.
While it does come with an API, the primary intended usage is its CLI. If you want to use the command line interface to
generate plugins and/or presets, you'll most likely want to install it globally so that you can run europa-build
from
anywhere:
$ npm install --global europa-build
API
Since the primary usage of this package is the CLI the API is simply what is used to help support the CLI.
You can generate plugin/preset packages:
import { TemplateManager, TemplateProviderType } from 'europa-build';
const templateManager = new TemplateManager();
console.log(templateManager.getProvidersForType(TemplateProviderType.Plugin));
//=> ["contrib", "official"]
const templateProvider = manager.getProvider('contrib', TemplateProviderType.Plugin);
const templateGenerator = templateProvider.createGenerator();
(async () => {
const templateContext = await templateProvider.createContext({
authorName: 'ghost',
name: 'example', // Transformed to "europa-plugin-example"
repositoryUrl: 'https://github.com/ghost/europa-plugin-example.git',
authorEmail: 'ghost@github.com', // Optional
authorUrl: 'https://github.com/ghost', // Optional
bugsUrl: 'https://github.com/ghost/europa-plugin-example/issues', // Optional
description: 'Europa plugin example', // Optional; defaults to "TODO: Description"
homepageUrl: 'https://github.com/ghost/europa-plugin-example', // Optional
keywords: ['example'], // Optional; defaults to empty array
version: '1.2.3', // Optional; defaults to "1.0.0"
});
await templateGenerator.generate(templateContext, 'path/to/parent');
})();
Or run scripts to maintain your plugin/preset package:
import { ScriptRunner } from 'europa-build';
const scriptRunner = new ScriptRunner();
console.log(scriptManager.getScriptNames());
//=> ["build", "flint", "format", "lint", "test"]
(async () => {
await scriptRunner.run('build', {
cwd: 'path/to/parent/europa-plugin-example', // Optional; defaults to process.cwd()
});
})();
CLI
Usage: europa-build [options] [command]
Options:
-V, --version output the version number
-h, --help display help for command
Commands:
generate-plugin [options] <template> generate a plugin package
generate-preset [options] <template> generate a preset package
run-script [options] <name> run the named script
help [command] display help for command
Typically, you'll only generate plugins/presets using the contrib
template as the official
assumes the package will
be maintained with the Europa monorepo.
Bugs
If you have any problems with Europa Build or would like to see changes currently in development you can do so here.
Contributors
If you want to contribute, you're a legend! Information on how you can do so can be found in CONTRIBUTING.md. We want your suggestions and pull requests!
A list of Europa contributors can be found in AUTHORS.md.
License
Copyright © 2022 neocotic
See LICENSE.md for more information on our MIT license.
2 years ago