Gulp Recipes - Part Two: You might not need this plugin
03 May 2015 by @ddprrt | Posted in: gulp, tools
One month has passed, many questions on StackOverflow have been answered, so here’s yet another round of common Gulp issues with a simple and repeatable solution to them. Be sure to check out last month’s edition, as well as my articles on Gulp, PHP and BrowserSync and multiple Browserify bundles.
Confirm prompts in Gulp
Imagine a Gulp task that actually takes long and has a lot of file operations going on. Or even one which deploys to some cloud storage in the end. Sometimes you want to really make sure that you or your co-workers want to run this task or execute the following steps. Just pop up a command line prompt and let the user confirm his action.
There are actually two plugins out there doing this, the one being gulp-confirm and the other being gulp-prompt, both with their own idea of how this should work. The latter one is actually a wrapper to inquirer and passes through all options unfiltered and unchanged.
So why not use
inquirer directly? The API is pretty straight forward, so give it a go:
One important piece in here is the
done callback. This one has to be passed and called in
inquirer’s callback function to let Gulp know when this task has stopped. Otherwise it would end the task directly after calling it.
Sync directories on your harddisk
This problem has come up multiple times on StackOverflow recently: People wanting to sync two folders, having all contents available in one folder also available in another. They have been searching for the best plugin, but didn’t find anything really fitting their needs.
Before I came up with solutions, I asked a few things back:
- Do you really want to keep both folders in sync, which means having changes in folder A appear in folder B, and vice versa?
- Do you need this sync as part of some deployment on a remote location (if so, use gulp-rsync), or during development process, where you have a watcher running.
Turned out that the true
A <-> B scenario actually never happened, it was more of an
A -> B scenario during development. And for this scenario the solution was strangely easy. If you want to have your contents in another folder, you don’t need any Gulp plugin whatsoever. In fact, you don’t need any Gulp plugin at all:
This line will copy all files from folder
a to folder
b. Include the gulp-newer plugin to boost up performance as you go:
But this is just half of the story. A real sync also deletes files in B should they’ve been deleted in A. For that we would need a change in our watcher:
Everytime a file changes in our selected glob, we call
sync. But before
sync happens, the
change event is called, where we dive in and do the following: Should the file have been deleted, we change its path to the corresponding file in the other folder and delete it!
There it is. Your one-way sync without any fancy Gulp plugin required.
Pass command line arguments to Gulp
One question coming up a lot is how to handle different environments and destinations. This comes probably from a Grunt-y mindset, where it was all about handling different configurations for the same task. The more I use Gulp, the less I do have the need for different configurations, because somehow everything can be handled in-stream, but there might still be some occassions where it’s necessary to flip some switches. And it would be great if we could do that directly from the command-line.
Let’s assume we want to change the output directory based on a command-line switch. Usually we want to have it in the
dist folder, but based on the command-line argument
destination we want to change that.
There’s a wonderful Node.js package out there called yargs, which parses everything that happens on the CLI and gives it to you in an easily devourable way:
Line 3 is the important one. If we have the destination switch set, we set our value to it, otherwise we use the default
Run it via
gulp --destination=prod on your CLI,
yargs will do the rest for you.
Once more I saw that the best Gulp extras are the ones which don’t require a plugin. That’s the biggest strength of Gulp, but also its greatest weakness: You have to have a good understanding of what the Node.js ecosystem looks like and where to get the right tool for the right job. With Grunt it’s easy: There is a Grunt plugin, and that’s everything you have to know. With Gulp, the less you use it, the more you are on the right way (I know how that sounds).
Everytime you face a certain task and are in search for a Gulp plugin, ask yourself:
- Does it have anything to do with processing and transforming my files?
- Is it something that has to occur between the globbing my files and saving it?
If you can answer one of those questions with “No”, you are most likely not in the need of yet another Gulp plugin. Try searching the Node.js ecosystem instead.
Me again. The Gulp, Yeoman, Bower book is pretty sweet. Just saying.
Comments? Shoot me a tweet!