JSPM

  • ESM via JSPM
  • ES Module Entrypoint
  • Export Map
  • Keywords
  • License
  • Repository URL
  • TypeScript Types
  • README
  • Created
  • Published
  • Downloads 933
  • Score
    100M100P100Q108907F
  • License MIT

Recursively copy files from one folder to another folder (CLI tool designed for use in npm scripts)

Package Exports

  • copy-folder-util
  • copy-folder-util/copy-folder.d.ts
  • copy-folder-util/copy-folder.js
  • copy-folder-util/copy-folder.umd.cjs

Readme

copy-folder-util

logo

Recursively copy files from one folder to another folder (CLI tool designed for use in npm scripts)

License:MIT npm Vulnerabilities Build

copy-folder-util takes a source folder and copies its files and subfolders to a new destination.  The command's console output includes a timestamp and formatting helpful in build systems.

screenshot

A) Setup

Install package for node:

$ npm install --save-dev copy-folder-util

B) Usage

1. npm scripts

Run copy-folder from the "scripts" section of your package.json file.

Parameters:

  • The first parameter is the source folder.
  • The second parameter is the target folder.

Example package.json scripts:

   "scripts": {
      "make-dist": "copy-folder build dist",
      "make-docs": "copy-folder src/web --ext=.html docs/api-manual"
   },

2. Global

You can install copy-folder-util globally and then run it anywhere directly from the terminal.

Example terminal commands:

$ npm install --global copy-folder-util
$ copy-folder src/web ext=.html docs/api-manual

3. CLI Flags

Command-line flags:

Flag Description Value
--basename Filter files by filename ignoring the file extension. string
--cd Change working directory before starting copy. string
--ext Filter files by file extension, such as .js.
Use a comma to specify multiple extensions.
string
--note Place to add a comment only for humans. string
--quiet Suppress informational messages. N/A
--summary Only print out the single line summary message. N/A

Examples:

  • copy-folder build --basename=index dist   Only copy files with filenames matching index.*.
  • copy-folder -cd=spec fixtures mock1   Copy the folder spec/fixtures to spec/mock1.
  • copy-folder build dist --summary   Displays the summary but not the individual files copied.
  • copy-folder src/web --ext=.js,.html docs   Copy only the JavaScript and HTML files to the docs folder.

C) Application Code

Even though copy-folder-util is primarily intended for build scripts, the package can easily be used programmatically in ESM and TypeScript projects.

Example:

import { copyFolder } from 'copy-folder-util';
const options = { fileExtensions: ['.html', '.js'] };
const results = copyFolder.cp('src/web', 'docs/api-manual', options);
console.log('Number of files copied:', results.count);

See the TypeScript Declarations at the top of copy-folder.ts for documentation.



CLI Build Tools

  • 🎋 add-dist-headerPrepend a one-line banner comment (with license notice) to distribution files
  • 📄 copy-file-utilCopy or rename a file with optional package version number
  • 📂 copy-folder-utilRecursively copy files from one folder to another folder
  • 🔍 replacer-utilFind and replace strings or template outputs in text files
  • 🔢 rev-web-assetsRevision web asset filenames with cache busting content hash fingerprints
  • 🚆 run-scripts-utilOrganize npm scripts into named groups of easy to manage commands
  • 🚦 w3c-html-validatorCheck the markup validity of HTML files using the W3C validator

Feel free to submit questions at:
github.com/center-key/copy-folder-util/issues

MIT License