Append or prepend the file content with the corresponding file in a dir
$ npm install gulp-append-prepend-dir --save-dev
Like 'gulp-append-prepend', this plugin loads content of a file from the file system and append, prepend, or insert the loaded content into the streamed files (pipe). However, this plugin works in 'relative' mode by default, loads the content from not a fixed file (like gulp-append-prepend), but a file with the same relative path of the streamed file from a given base dir. For example, if the current streamed file is sourced from 'src/*.txt', whereas the 'relative' property (see gulp Vinyl API) is 'a.txt', then when the base dir is given 'dest/', the plugin loads contents to be appended/prepended/inserted from 'dest/a.txt'.
This plugin can be used with slush to append various contents from a template dir to the existing files in the working dir, whereas the to be appended contents are in the template dir with the same relative path and file name with the corresponding files in the working dir.
const gulp = require('gulp');
const gapd = require('gulp-append-prepend-dir');
gulp.task('myTask', () => {
gulp.src(['srcDir/**.txt'])
.pipe(gapd.append('./destDir'))
.pipe(gulp.dest('destDir'));
});
All functions accept an optional object parameter as options. Defaults are:
{
ignoreMissingFile: true,
separator:'\n',
useRelative:true,
ignoreMissingMark: false
}
ignoreMissingFile: default true, if the file from which content is to be appended/prepended/inserted cannot be found, simply ignore and does not throw an error.
separator: default new line
useRelative: default true, use 'relative' mode, where the given dir is used as the base dir and full path of the file to load is calculated from the base dir and the 'relative' property of the streamed file. If useRelative is specified false, use the given dir as full path to a file and append/prepend/insert the content of this file to all streamed files.
ignoreMissingMark: when the content is to be inserted before or after a mark and when the mark is missing, ignore and does not throw an error. Default false.
The exported functions are:
append(dir:string, opt:options={})
prepend(dir:string, opt:options={})
Return a node stream Transform that append contents read from file in dir (or file specified by dir, depending on relative mode).
insertAfter(dir:string, mark:string, opt:options={})
insertBefore(dir:string, mark:string, opt:options={})
Return a node stream Transform that insert the contents read from file in (or specified by) dir after/before the mark string in the streamed content.
Also check the unit test for example usages.
Run the unit tests with mocha:
$ npm run test
Calculate the coverage with Istanbul:
$ npm run cover
To keep better organization of releases we follow the Semantic Versioning 2.0.0 guidelines.
Find on our issues the next steps of the project ;)
Want to contribute? Follow these recommendations.
See Releases for detailed changelog.
MIT License © bingtimren