gulpjs
Published in

gulpjs

Gulp Sips: How We Use Streams

Plugins strictly spooky.

This is part of our Gulp Sips series: bringing you easily-digestible bits of information on our advanced or unknown features.

Two Types of Streams

In Node, streams can operate in one of two modes; for the purposes of gulp, the two modes are incompatible.

  • Buffer mode: Operates exclusively on buffered data. If we stream a file in this mode, it would only contain the content of the file. We’d even lose the filename.
  • Object mode: Accepts any object flowing through it. A file streamed in object mode can contain all sorts of metadata (filename, stats, etc.), along with the content.

Benefits of Object Mode

In buffer mode, using something like fs.createReadStream('index.js'), you’d have to operate on a singular file.

Instead, we utilize streams in object mode so we can operate on multiple files using a single stream. For example, gulp.src('*.js') reads all files ending in .js and emits each as an object on the stream.

For every file, we track a lot of metadata along with the content. This allows plugins to operate upon any of that metadata before we write it out to disk.

There are ways to convert between types, but they require external modules, like vinyl-source-stream.

Utilizing Gulp Plugins

Every gulp plugin should be a Transform stream in object mode. These streams understand and operate on gulp’s data, while streams operating in buffer mode would throw an error.

Generally, a gulp stream begins with gulp.src() and terminates with gulp.dest(). For best results, streams between should be a gulp plugin or a stream that understands Vinyl objects.

--

--

Get the Medium app

A button that says 'Download on the App Store', and if clicked it will lead you to the iOS App store
A button that says 'Get it on, Google Play', and if clicked it will lead you to the Google Play store
Janiceilene

Janiceilene

Technical writer at GitHub. Content writer for gulp. Former Outreachy Intern for Systers. Mom to two tiny humans. (Views are my own)