Copy files or directories using globs.
(TOC generated by verb using markdown-toc)
Install with npm:
$ npm install --save copy
var copy = require('copy');
See the API documentation for usage details and available methods.
The main export is a function that takes:
src
- glob pattern or file path(s)dest
- the destination directorycb
- callback function
copy('*.js', 'foo', function(err, files) {
if (err) throw err;
// `files` is an array of the files that were copied
});
Usage with gulp
In your project's gulpfile.js:
var gulp = require('gulp');
var copy = require('copy');
gulp.task('default', function (cb) {
copy('fixtures/*.txt', 'actual', cb);
});
Copy a filepath, vinyl file, array of files, or glob of files to the given destination directory
, with options
and callback function that exposes err
and the array of vinyl files that are created by the copy operation.
Params
patterns
{String|Object|Array}: Filepath(s), vinyl file(s) or glob of files.dir
{String}: Destination directoryoptions
{Object|Function}: or callback functioncb
{Function}: Callback function if no options are specified
Example
copy('*.js', 'dist', function(err, file) {
// exposes the vinyl `file` created when the file is copied
});
Copy an array of files to the given destination directory
, with options
and callback function that exposes err
and the array of vinyl files that are created by the copy operation.
Params
files
{Array}: Filepaths or vinyl files.dir
{String}: Destination directoryoptions
{Object|Function}: or callback functioncb
{Function}: Callback function if no options are specified
Example
copy.each(['foo.txt', 'bar.txt', 'baz.txt'], 'dist', function(err, files) {
// exposes the vinyl `files` created when the files are copied
});
Copy a single file
to the given dest
directory, using the specified options and callback function.
Params
file
{String|Object}: Filepath or vinyl filedir
{String}: Destination directoryoptions
{Object|Function}: or callback functioncb
{Function}: Callback function if no options are specified
Example
copy.one('foo.txt', 'dist', function(err, file) {
if (err) throw err;
// exposes the vinyl `file` that is created when the file is copied
});
To use the CLI, install copy
globally with the following command:
$ npm install --global copy
This adds copy
to your system path, allowing the copy
command to be executed anywhere.
CLI usage
$ copy <patterns> <dir>
patterns
: glob pattern or array of file pathsdir
: destination directory
Example
Copy* all files with the .js
extension to the foo
directory
$ copy *.js foo
*Note that glob patterns may need to be wrapped in quotes depending on the shell you're using.
v0.2.0 - breaking changes
- The API was changed in 0.2.0. please review the API documentation
- expand-config: Expand tasks, targets and files in a declarative configuration. | homepage
- expand-files: Expand glob patterns in a declarative configuration into src-dest mappings. | homepage
- expand-target: Expand target definitions in a declarative configuration. | homepage
- expand-task: Expand and normalize task definitions in a declarative configuration. | homepage
- export-files: node.js utility for exporting a directory of files as modules. | homepage
- write: Write data to a file, replacing the file if it already exists and creating any… more | homepage
Pull requests and stars are always welcome. For bugs and feature requests, please create an issue.
Commits | Contributor |
---|---|
61 | jonschlinkert |
2 | joakimbeng |
1 | bleathem |
1 | doowb |
1 | gsantiago |
1 | SoulRIver2015 |
(This project's readme.md is generated by verb, please don't edit the readme directly. Any changes to the readme must be made in the .verb.md readme template.)
To generate the readme, run the following command:
$ npm install -g verbose/verb#dev verb-generate-readme && verb
Running and reviewing unit tests is a great way to get familiarized with a library and its API. You can install dependencies and run tests with the following command:
$ npm install && npm test
Jon Schlinkert
Copyright © 2017, Jon Schlinkert. Released under the MIT License.
This file was generated by verb-generate-readme, v0.6.0, on September 01, 2017.