read-vinyl-file-stream

process a vinyl file stream with minimal code

Usage no npm install needed!

<script type="module">
  import readVinylFileStream from 'https://cdn.skypack.dev/read-vinyl-file-stream';
</script>

README

read vinyl file stream

Build Test Coverage Code Climate Downloads Version Dependency Status

Turns out that reading all the files in a vinyl stream is cumbersome, and supporting all of the options is a little bit annoying. I decided that I don't want to write that code more than once. So here is a library that does that. This is most useful for gulp plugins that need to transform all the files in a stream, though I am sure you can figure out other ways to use it too.

Install

npm install read-vinyl-file-stream

API

read-vinyl-file-stream(iterator {Function} [, flush {Function}] [, encoding {String}])

The module is a function that creates a transform stream. It will read the vinyl file, whether it is a buffer or a stream internally. It takes the following parameters, in order:

  • iterator {Function} Required - the method that will process the files.
  • flush {Function} Optional - the method to call before the stream ends.
  • encoding {String} Optional - the encoding to use for the content provided to the iterator function. By default, this is a UTF-8 string. The following options are supported:
    • 'utf8' - provide the content in a UTF-8 string.
    • 'buffer' - provide the content in a raw buffer. This is useful if you are processing binary files, for example.

iterator(content, file, stream, cb)

The function that you provide to it has the following parameters, in order:

  • content - the content of the file.
  • file - the vinyl file itself.
  • stream - the transform stream that is being iterated.
  • cb - a callback to call once you are done processing the file. You must call this in order for the stream to continue.

flush(stream, cb)

This is a function that will allow you to execute some code after all the files have been read but before the stream ends. It has the following parameters, in order:

  • stream - the transform stream that is being iterated.
  • cb - a callback to call once you are done with the flush actions. You must call this in order for the stream to end.

Examples

Observe all of the files:

var readFiles = require('read-vinyl-file-stream');

var input = getVinylStream();

var hashOfFiles = {};

input.pipe(readFiles(function (content, file, stream, cb) {
    hashOfFiles[file.path] = content;

    cb();
}));

Transform the content of the file and output it back to the stream:

var readFiles = require('read-vinyl-file-stream');

var input = getVinylStream();

input.pipe(readFiles(function (content, file, stream, cb) {
    var newContent = doWorkToTheContent(content);

    cb(null, newContent);
}));

Split the file into multiple files and output all of them to the stream:

var readFiles = require('read-vinyl-file-stream');
var File = require('vinyl');

var input = getVinylStream();

input.pipe(readFiles(function (content, file, stream, cb) {
    var lines = content.split('\n');

    lines.forEach(function (line, idx) {
        stream.push(new File({
            contents: new Buffer(line),
            path: file.path + 'line' + idx
        }));
    });

    cb();
}));

Use inside gulp (to create a filter):

var gulp = require('gulp');
var readFiles = require('read-vinyl-file-stream');

gulp.task('mytask', function() {
    return gulp.src('*.ext')
        .pipe(readFiles(function (content, file, stream, cb) {
            if (/^n/.test(content)) {
                return cb(null, content);
            }

            cb();
        }))
        .pipe(gulp.dest('filesThatStartWithN'));
});