gulp-watch
    Overview
    Dependencies
    Versions
    Playground
    Code
    Documentation
    Issues
    Find an Expert
    Career Opportunities
    Alternatives
    Insights & Analysis

gulp-watch

Watch, that actually is an endless stream

5.0.1  •  Published 1 years ago  •  by Vsevolod Strukchinsky  •  MIT License

gulp-watch Build Status: Linux Build Status: Windows Dependency Status

File watcher that uses super-fast chokidar and emits vinyl objects.

Installation

npm install --save-dev gulp-watch

Usage

var gulp = require('gulp'),
    watch = require('gulp-watch');

gulp.task('stream', function () {
	// Endless stream mode
    return watch('css/**/*.css', { ignoreInitial: false })
        .pipe(gulp.dest('build'));
});

gulp.task('callback', function () {
	// Callback mode, useful if any plugin in the pipeline depends on the `end`/`flush` event
    return watch('css/**/*.css', function () {
        gulp.src('css/**/*.css')
            .pipe(gulp.dest('build'));
    });
});

Protip: until gulpjs 4.0 is released, you can use gulp-plumber to prevent stops on errors.

More examples can be found in docs/readme.md.

API

watch(glob, [options, callback])

Creates a watcher that will spy on files that are matched by glob which can be a glob string or array of glob strings.

Returns a pass through stream that will emit vinyl files (with additional event property) that corresponds to event on file-system.

Callback function(vinyl)

This function is called when events happen on the file-system. All incoming files that are piped in are grouped and passed to the events stream as is.

  • vinyl — is vinyl object that corresponds to the file that caused the event. Additional event field is added to determine what caused changes.

Possible events:

  • add - file was added to watch or created
  • change - file was changed
  • unlink - file was deleted

Options

This object is passed to the chokidar options directly. Options for gulp.src are also available. If you do not want content from watch, then add read: false to the options object.

options.ignoreInitial

Type: Boolean
Default: true

Indicates whether chokidar should ignore the initial add events or not.

options.events

Type: Array
Default: ['add', 'change', 'unlink']

List of events, that should be watched by gulp-watch. Contains event names from chokidar.

options.base

Type: String
Default: undefined

Use explicit base path for files from glob. Read more about base and cwd in gulpjs docs.

options.name

Type: String
Default: undefined

Name of the watcher. If it is present in options, you will get more readable output.

options.verbose

Type: Boolean
Default: false

This option will enable verbose output.

options.readDelay

Type: Number
Default: 10

Wait for readDelay milliseconds before reading the file.

options.read

Type: Boolean
Default: true

Setting this to false will return file.contents as null and not read the file at all. Most useful as an optimization if your plugins pipeline doesn’t make use of the file contents (e.g. gulp-clean), or to avoid reading the file twice if you use gulp.src() inside the callback instead of the file object that is passed as argument.

Methods

Returned Stream from constructor has some useful methods:

  • add(path / paths)
  • unwatch(path / paths)
  • close()

Events

All events from chokidar:

  • add, change, unlink, addDir, unlinkDir, error, ready, raw

Changelog

License

MIT © 2014 Vsevolod Strukchinsky (floatdrop@gmail.com)

Dependencies

ansi-colors  ·  anymatch  ·  chokidar  ·  fancy-log  ·  glob-parent  ·  object-assign  ·  path-is-absolute  ·  plugin-error  ·  readable-stream  ·  slash  ·  vinyl  ·  vinyl-file  ·  coveralls  ·  istanbul  ·  mocha  ·  mocha-lcov-reporter  ·  proxyquire  ·  rimraf  ·  should  ·  sinon  ·  stream-assert  ·  strip-ansi  ·  xo

Tags

gulp
watch
gulpplugin
Keep your dependencies fresh!
Upgrade your packages safely and continuously.
We run your CI tests and compatability tests on new versions of your packages - to determine which upgrades are safe
Just $9/month per developer

Popularity

Weekly Downloads
169.0K
Stars
643

Issues and PRs

Activity

Last ver 1 year ago
Created 6 years ago
Last commit 8 months ago
6 days between commits

Sustainability

33 contributors

Technology

Node version: 8.10.0
12.1K unpacked

Legal and Compliance

MIT License
OSI Approved
0 vulnerabilities

Top Experts

Vsevolod Strukchinsky
Maintainer, 220 commits, 30 merges, 2 PRs
Works at Yandex
UltCombo
Maintainer, 27 commits, 9 merges, 12 PRs
Works at BairesDev
Joscha Feth
5 commits, 2 PRs
Works at Canva
Bjorn Tipling
2 commits, 1 PRs
Nicolas Gallagher
2 commits, 2 PRs
Works at Facebook
alex4k
2 commits