Build a chain of transforms
Provides a means of managing a list of transforms.
Built with require.extensions
transforms in mind, but not limited to that use case.
$ npm install --save transform-chain
import TransformChain from 'transform-chain';
const chain = new TransformChain();
chain.appendTransform((code, filename, next) => {
// true if downstream transforms want to manipulate this file too.
next.hasMatch(filename);
// transform the code - no additional transforms applied
return doTransform(code);
// transform the code and forward it down the chain
return next(doTransform(code), filename);
// forward down the chain, and perform the transform after
return doTransform(next(code, filename));
});
This module is also my first attempt at auto generating documentation using documentation.js and JSDoc.
HTML Documentation: http://jamestalmage.github.io/transform-chain/
Creates a new transform chain.
Appends a transform to the end of the chain.
Parameters
transform
Transform or TransformDefinition the transform to append.
Check if the chain has a matching transform for a particular file.
Parameters
filename
string the path to the file.
Returns boolean true if at least one transform in the chain matches the file.
Notify every transform that a file has been loaded. Included for legacy istanbul support.
Parameters
filename
string Passed to every transformspostLoadHook
(regardless of whether the transform matches the loaded file).
Prepends a transform at the beginning of the chain.
Parameters
transform
Transform or TransformDefinition the transform to prepend.
Transform an input using the matching transforms from the chain.
Parameters
code
Any The object to be transformed using the chain. Usually this will always be a string, but it is not required. Whatever type it is. All transforms in the chain must support it.filename
string
Returns Any The transformed results. Again, this is almost always going to be a string.
A callback that performs a transform
Parameters
code
string or Any The input to be transformed.filename
string The name of the file being transformed.next
Function Execute the rest of the transform synchronouslynext.hasNext
Function Check if any of the transforms remaining in the chain can handle the file. You can optionally pass a string to change the name of the file.
Create a new transform.
Parameters
opts
Object or transformCallbackopts.transform
[transformCallback] The transform function. (optional, defaultnoop
)opts.match
[Function or string or Array<string> or RegExp] Used to filter whether or not this transform is applied to a given file.opts.extensions
[Array<string>] List of file extensions this transform applies to. (optional, default'.js'
)opts.verbose
[boolean] If true, every invocation of the transform will be logged. (optional, defaultfalse
)opts.name
[string] The name of this transform, used in logging and error reporting.
Returns Transform A new transform instance
Check whether this transform should be applied to a given file. transformCallback
Parameters
filename
string The name of the file
Returns boolean true if this transform should be applied to the file.
Perform the transform. Called with the same parameters as transformCallback
.
Parameters
code
string or Anyfilename
stringnext
Function
Returns string or Any
MIT © James Talmage