@simpo/gulp-augment

1.3.2 • Public • Published

gulp-augment

Augment gulp with:

  • Task importing
  • Multiple roots
  • Gulp cli detection and automatic loading
  • Desktop notifications (Gulp4 only)
  • Dependency injection
  • Settings import

Install

Using NPM:

npm install --save-dev "@simpo/gulp-augment"

Using Yarn:

yarn add "@simpo/gulp-augment"

Using PNPM:

pnpm install --save-dev "@simpo/gulp-augment"

What is gulp-augment

Gulp is great! However, I've found myself repeatedly writing extra helper functions and modules. When you start to write the same code over and over again, it is time to formalise that code it into a module.

Gulp Augment is a collection of additions and tools for gulp. It is not an attempt to improve gulp, but rather a collection of helpful extras.

Can I help?

I will always look favourably at PR requests and suggestions for improvements. This is especially true for bug fixes and code improvement.

If you have any great additions that you use in your gulp workflow, I'd be interested to hear from you. I can't promise to include them as we have to avoid bloat; as well as, functionality that is to too bespoke. However, anything that makes gulping quicker, nicer or more efficient will be considered.

Project status

Permanent beta - aka Google style

This module is stable. I will not be add anything that breaks current functionality (unless tagged as experimental/beta). However, I am looking to add more and better functionality over time; hence, we are still in beta. The module may expand a considerably before we reach true 'stable'.

Gulp Versions

This module should work seamlessly in either gulp3 or gulp4. There is some minor functionality does not work in gulp3 (these are non-essential and non-breaking).

One of the core ideas with this module is cut across the differences between the two gulps so you don't have to remember what you used on a particular project.

Getting started

Once you've installed the module you can simply use it as follows:

// gulpfile.js
const {Augment_Registry} = require('gulp-augment');
const gulp4 = require('gulp4');

gulp.registry(new Augment_Registry());

...or using gulp3

// gulpfile.js
const {augmentGulp} = require('gulp-augment');
const gulp = require('gulp');

augmentGulp(__dirname, gulp);

If you can't be bothered with detecting your gulp version you can simply do this:

// gulpfile.js
const {augment} = require('gulp-augment');
const gulp = augment();

Obviously, this only works if you are loading via the cli and it is an experimental feature.

Task importing

Gulp files quickly become large and difficult to decipher, dividing code into separate files is just sensible. It also allows for better code sharing.

You could just divide your code up and then do a bunch of requires; but, who can be bothered with that? If you put your file in the right place it would be nice if they just loaded. No need for config and no need for extra code.

Augment will load all tasks in the gulp folder of your project root (the folder with gulpfile in it). You can supply your root folder path or let augment assume it is the directory of the calling script (if that is gulpfile.js then your project root).

Each file in the gulp directory should export a function, array or object.

Example:

function task(done) {
	// do something
	done()
}

module.exports = task;

In this example a new task will be added with the same name as the filename. This task will run the above task() function. If your script was stored at ./gulp/test then your task will be called 'test' and you can access it from the cli as normal:

gulp test

...or

npx gulp test

If the file was stored at ./gulp/test/browser then your gulp task will be called 'test:browser'. Augment will also respect the displayName property of your task function (as gulp does), so you can override the task name with:

function task(done) {
	// do something
	done()
}

task.displayName = 'my-task';

module.exports = task;

If you export an object, augment is looking for the task function in the fn property. So, this it identical to the above.

function task(done) {
	// do something
	done()
}

module.exports = {fn:task, displayName:'my-task'};

Task dependencies

You can fire dependent tasks before your main task before supplying a deps property.

Example:

function fn(done) {
	// do something
	done()
}

module.exports = {
	fn,
	displayName:'my-task',
	deps:['first-task', 'second-task']
};

This will run 'first-task' then 'second-task', followed by 'my-task'. This works in both gulp3 and gulp4 and is similar to the dependency property in gulp3 (except tasks run in series).

The tasks run in series as I think that is what most people will expect. You can run parallel tasks by setting arrays of arrays. Eg:

function fn(done) {
	// do something
	done()
}

module.exports = {
	fn, 
	displayName:'my-task', 
	deps:[['first-task', 'second-task'],['third-task', 'fourth-task']]
};

This will run: 'first-task' and 'second-task' in parallel, then after them complete, run 'third-task' and 'fourth-task' in parallel, after these complete, run 'my-task'.

If there is no main task but this task is simply a means to run other tasks you can export an array:

module.exports = [['first-task', 'second-task'],['third-task', 'fourth-task']];

Here the task just runs the deps but has no main task function. The task will be named after its filename. Since, it is an array, you can also just have a json file instead and it'll run.

[["first-task", "second-task"],["third-task", "fourth-task"]]

Glob dependencies

Task deps can also be expressed as globs

["test:*"]

This will run all the tasks starting with 'test:' in series. To run the same in parallel:

[["test:*"]]

This is useful when may have a collection of tasks in a sub-directory that are related (eg. build or test tasks). You can add new tasks and they will always be ran without have to specially add them to a parent task dependency.

Multiple Roots

Augment can load from multiple roots simple by providing an an array as the root option. This can be useful if you have a global collection of tasks or in project where gulp is being called outside of the normal cli.

// gulpfile.js
const {augment} = require('gulp-augment');
const gulp = augment({root:[__dirname, '~/']});

or, specifically in gulp3

// gulpfile.js
const {augmentGulp} = require('gulp-augment');
const gulp = require('gulp');

augmentGulp([__dirname, '~/', gulp);

In these the tasks in __dirname/gulp and ~/gulp are loaded.

NB: The node require() function will be local to the task, so you may need to install dependant modules in your other roots. This is what you'd expect but it is easy to forget and wonder why the task keeps error-ing.

Gulp cli detection and automatic loading (experimental)

Augment can attempt to detect the version of gulp the cli is expecting and try to load that gulp.

Two methods are exported for this purpose:

// gulpfile.js
const {getGulpCliVersion, getCliGulp} = require('gulp-augment');

// get the gulp version expected by the cli.
// will return either 3 or 4 as numbers.
const version = getGulpCliVersion();

// use getGulpCliVersion() internally and then load the correct gulp.
// will load relative to the calling script (usually gulpfile.js).
const gulp = getCliGulp();

You can also use these two methods transparently and apply augment the same time:

// gulpfile.js
const {augment} = require('gulp-augment');
const gulp = augment();

Here, augment is applied to either gulp3 or gulp4, depending on what the cli is expecting. This smooths out the different ways of calling gulp that might result in a different version. If your tasks work in both (as most do), no need worry about gulp versions.

NB: These features are experimental but is safe to use. They are not going to go anywhere but it is possible there are methods of calling gulp it dose not detect correctly (yet). If you find any please raise an issue.

Desktop notifications (gulp4 only)

When a parent task is complete a desktop notification will fire to inform you. This is useful in lon-running tasks or watchers. You can keep the terminal minimised and be notified when it is done (every little helps!) It should work on Linux, Mac and Windows.

NB: This only fires in gulp4 but we will push it to gulp3 as soon as possible.

Dependency injection

Requiring all those gulp plugins can be quite a pain. Augment provides dependency injection (aka. angular style) on your task functions. Parameters for your task function are parsed and modules required in accordingly.

Example:

function fn(done, gulp, replace, babel, rollup) {
	// Do something
}

module.exports = fn;

In the augment will supply a done() function for async done signalling (this is one gulp supplies itself but must be called done in augment to differentiate it from other dependencies). It then supplies the gulp it is using, followed by 'gulp-replace', 'gulp-rollup' and finally 'rollup' (assuming 'gulp-rollup' is not available).

It works by first supplying any static dependencies it has set (usually, gulp, settings or done) and then looking for kebab-case versions of gulp plugins of that name. If these are not found it looks for simply kebab-case modules of that name, followed by camel-case. This sounds complicated but is actually quite simple.

So, if we are we have a parameter called betterRollup:

  • Look for any static modules defined internally in augment called betterRollup.
  • Look for any modules called 'gulp-better-rollup'.
  • Look for any modules called 'better-rollup'.
  • Look for any modules called 'betterRollup'.

The first module found is loaded.

NB: All requiring is done locally to the task file (rather than gulpfile.js), so if the task is located outside the scope of your gulpfile.js node_modules directory you might need to install dependencies locally. This is what you'd expect and want but worth remembering.

Settings import

Augment has an internal static module (available via dependency injection) called settings. Settings will be an objects of settings retrieved from the following locations andf merged together:

  • The commandline arguments parsed for objects.
  • The gulp property of package.json.
  • The name property of package.json.
  • The contents of gulp.json.
  • The contents of local.json.

The data in each of these locations is loaded and merged together to supply the settings object. The files do not need to be supplied, if they are not available they are not loaded.

You can use these settings files how you like but the is:

  • pasckage.json has your settings in
  • gulp.json can be used if settings in package.json are becoming too large and you need to separate it out. In this case package.json can be use for settings thhat are solid and to do with the other-all project (eg. naming and versioning).
  • local.json is for local overrides (it loads last and will override previous settings) and can be used for user or machine overrides. It is best in this case to keep local.json out of .gitignore.

The settings are loaded from the local root. So each task might have different settings if loaded from different root directories.

Templating in settings

The settings loader will parse any ${variable} text (ES6 Template style) using the settings object as its source. So the following json:

{
	"param1": "HELLO BIG WIDE WORLD",
	"param3": {
		"param3.1": "HELLO WORLD!"
	},
	"param2": "${param1}"
	"param4": "${param3['param3.1']}"
}

...will become

{
	"param1": "HELLO BIG WIDE WORLD",
	"param3": {
		"param3.1": "HELLO WORLD!"
	},
	"param2": "HELLO BIG WIDE WORLD",
	"param4": "HELLO WORLD"
}

Readme

Keywords

none

Package Sidebar

Install

npm i @simpo/gulp-augment

Weekly Downloads

0

Version

1.3.2

License

MIT

Unpacked Size

136 kB

Total Files

19

Last publish

Collaborators

  • simpo