Security News
Node.js EOL Versions CVE Dubbed the "Worst CVE of the Year" by Security Experts
Critics call the Node.js EOL CVE a misuse of the system, sparking debate over CVE standards and the growing noise in vulnerability databases.
gulp-progeny
Advanced tools
A dependency-resolving plugin for Gulp. It grabs all files related to one modification to building system.
##Introduction
Gulp provides incremental building.
However it is agnostic about the dependencies among files.
Say, if child.jade
depends on parent.jade
, then whenever parent
changes child
should be recompiled as well.
Existing gulp plugins do not support this. Or one could fall back on edit-wait-10s-view
loop.
gulp-progeny
aims to solve this. If parent.jade
is edited and passed to gulp-progeny
, all files that recursively depends on that file will be collected by progeny
and are passed to succesive building stream.
##What does gulp-progeny do
This plugin brings the agility of brunch to gulp world.
It provides generic dependency detection to various file types.
progeny
parses files by grepping specific import statements
, and builds dependency trees for building tasks.
So it just use Regular Expression to extract dependency information. This simple solution is fast and dirty, but also working.
##Usage
gulp-progeny
out of box supports jade
, less
, sass
and stylus
.
To exploit the power of gulp-progeny
, use gulp-cached
in tandem.
var cache = require('gulp-cached');
var progeny = require('gulp-progeny');
var stylus = require('gulp-stylus');
gulp.task('style', function(){
return gulp.src('*.styl')
.pipe(cache('style'))
.pipe(progeny())
.pipe(stylus())
});
gulp.task('watch', function(){
gulp.watch('*.styl', ['style']);
});
cached
will pass all files to progeny
in the first run, which enables dependency tree building,
just pass changed files later for incremental building.
As gulp-progeny
includes progeny
in its core, please see their configuration docs for the options that can be used with this plugin.
gulp-progeny
, by the virtue of its design, has following limitations.
Filenames must be static in source code. Otherwise regexp fails to work.
Sass/Scss filenames should not contain apostrophes. This limitation is due toSass's multiple import feature. Matching filenames with '"
is far beyond the reach of regular expressions with only one match, which is the format used in this plug in.
Limitations above are almost ineluctable for this simple plugin. To keep API and extension simple and generic, some features are doomed to be dropped. This plugin does not fill the chasm between a single one Regexp and full-bloom parsers.
FAQs
Gulp plugin for dependencies building
The npm package gulp-progeny receives a total of 3,063 weekly downloads. As such, gulp-progeny popularity was classified as popular.
We found that gulp-progeny demonstrated a not healthy version release cadence and project activity because the last version was released a year ago. It has 1 open source maintainer collaborating on the project.
Did you know?
Socket for GitHub automatically highlights issues in each pull request and monitors the health of all your open source dependencies. Discover the contents of your packages and block harmful activity before you install or update your dependencies.
Security News
Critics call the Node.js EOL CVE a misuse of the system, sparking debate over CVE standards and the growing noise in vulnerability databases.
Security News
cURL and Go security teams are publicly rejecting CVSS as flawed for assessing vulnerabilities and are calling for more accurate, context-aware approaches.
Security News
Bun 1.2 enhances its JavaScript runtime with 90% Node.js compatibility, built-in S3 and Postgres support, HTML Imports, and faster, cloud-first performance.