Fire up your node app and automatically restart it when the underlying source changes. This pairs nicely with the 6to5 plugin to give you decent ES6 support along with auto-reloading on changes.
First, you need to have gobble installed - see the gobble readme for details. Then, simply reference 'node-server'
in a transform
, and gobble will take care of getting the plugin installed.
node-server masquerades as a directory transformer, but what it actually does is launch the node script that you specify in the output of its upstream. This should be the last step in a chain, as it does not deposit any files into its destination directory.
If your gobblefile.js
changes and gobble reloads, node-server will be reloaded and lose its handle on the last running server. In this case, it will attempt to kill the old server by PID before continuing. This seems to work fairly well on Unixen, but it may not work at all on Windows.
STDOUT and STDERR from the spawned process will be automatically dumped to the console using console.log
.
gobble(builtSource).transform('node-server', { entry: 'app.js', flags: ['--harmony'], appflags: ['--foo'] });
entry
- the script to pass to the spawned node to start the appflags
- an array of arguments to pass to the spawned nodeappflags
- an array of arguments to pass to the spawned node after the scriptexec
- defaults toprocess.execPath
- the executable to launch with the given flags and entrytimeout
- defaults to 1000 - the number of milliseconds to wait to finish this phase. If the spawned process exits before this timeout has elapsed you will be warned that it looks like your app died unexpectedly and this phase will die.init
- function - a function that receives the options object that is used for node-server so that you can change settings and flags based on environment, calculated paths, etc.
Copyright (c) 2014 Chris Reeves. Released under an MIT license.