Security News
Fluent Assertions Faces Backlash After Abandoning Open Source Licensing
Fluent Assertions is facing backlash after dropping the Apache license for a commercial model, leaving users blindsided and questioning contributor rights.
gulp-grunt-pinterest
Advanced tools
What if your favorite grunt plugin isn't available for gulp yet? Don't fret, there is nothing to worry about! Why don't you just hook in your grunt configuration?
This plugin is a bit different from most other gulp plugins. You cannot use it inline, because it does not create a stream. Rather, use it at the top of your gulpfile, calling it with your gulp as an argument. This classifies gulp-grunt as gulpfriendly, not a gulpplugin.
var gulp = require('gulp');
require('gulp-grunt')(gulp); // add all the gruntfile tasks to gulp
// continue defining tasks...
gulp.task('do-this', function() {
...
});
// run them like any other task
gulp.task('default', [
// run complete grunt tasks
'grunt-minify',
'grunt-test',
// or run specific targets
'grunt-sass:dist',
'grunt-browserify:dev'
]);
Note that all the grunt tasks that were added begin with the prefix 'grunt-'.
This is for usability, so that your grunt tasks do not clash with your gulp tasks.
Also note that require('gulp-grunt')(gulp)
does not have to be at the top of your file.
It could very well be at the bottom, except that then it could possibly overwrite some of your
gulp tasks.
To run specific targets, use the regular grunt syntax [task]:[target]
, as in the example above. (To learn more about Grunt targets, check out the Grunt documentation.)
Takes (gulp, options)
Configuration is done with the function call:
require('gulp-grunt')(gulp, {
base: ...,
prefix: ...
});
This function appends all the grunt tasks it has found to your gulp object as normal gulp tasks.
Your gulp object that you imported with the code:
var gulp = require('gulp');
Pass it in and gulp-grunt will add all the tasks.
options
is the configuration object you pass in.
This tells grunt where to look for your gruntfile.
Set it to some absolute path.
This may require you to use path.join
for relative paths:
require('gulp-grunt')(gulp, {
base: require('path').join(__dirname, 'yourrelativepathhere')
});
This tells gulp-grunt how to prefix your tasks. For instance, if in the gruntfile you define the tasks 'minify' and 'compile', and if you pass gulp-grunt this configuration:
require('gulp-grunt')(gulp, {
prefix: 'theknightswhosay-'
})
The grunt tasks can be called from gulp, except they would have the prefix, so 'theknightswhosay-minify' and 'theknightswhosay-compile'.
You can simply pass in an empty string(''
) if you wish to have no prefix.
If this option is enabled(true), then gulp-grunt will tell you when it starts running a Grunt task or stops it. This option is mainly for debugging.
{
base: null, // this is just the directory that your Gulpfile is in
prefix: 'grunt-',
verbose: false
}
Takes (options)
This just returns all the grunt tasks found, along with their associated functions. Calling is essentially the same as with the main function:
var gulp_grunt = require('gulp-grunt')
var tasks = gulp_grunt.tasks({
base: ...,
prefix: ...
});
Output is something like:
{
'grunt-test': [Function],
'grunt-minify': [Function]
// etc...
}
This object is the exact same as for gulp-grunt() above. This tells gulp-grunt what prefix to use and what base to search for, among other things.
Have fun grunting and gulping! :D
FAQs
Run grunt tasks from gulp
We found that gulp-grunt-pinterest 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
Fluent Assertions is facing backlash after dropping the Apache license for a commercial model, leaving users blindsided and questioning contributor rights.
Research
Security News
Socket researchers uncover the risks of a malicious Python package targeting Discord developers.
Security News
The UK is proposing a bold ban on ransomware payments by public entities to disrupt cybercrime, protect critical services, and lead global cybersecurity efforts.