fast-ignore

A fast parser and processor for .gitignore files.

MIT 6 个版本
安装
npm install fast-ignore
yarn add fast-ignore
pnpm add fast-ignore
bun add fast-ignore
README

Fast Ignore

A fast parser and processor for .gitignore files.

Install

npm install fast-ignore

Usage

import fastIgnore from 'fast-ignore';

// Let's create the content of a .gitignore file

const gitignore = `
# Some always-ignore files
*~
*.err
*.log
._*
.cache
.fseventsd
.DocumentRevisions*
.DS_Store
.TemporaryItems
.Trashes
Thumbs.db

# Some project-specific ignores
dist
node_modules

# Some directory-only ignores
dir/
`;

// Let's create our ignore function

const ignore = fastIgnore ( gitignore );

// Now we can check if a relative path should be ignored

ignore ( 'foo/bar.js' ); // false
ignore ( 'node_modules/foo/bar.js' ); // true
ignore ( 'dist/foo/bar.js' ); // true

// Directory-only globs are supported _automatically_ when the situation is unambiguous
// In the following scenario we know for sure that "dir" must be a directory, so it's ignored

ignore ( 'dir/foo.js' ); // true

// Directory-only globs are supported _manually_ when the situation is ambiguous
// In the following scenario we can't know for sure if "dir" is a file or a directory
// We are going to assume it's not a directory, but if it is then you need to tell the library via the options object

ignore ( 'dir' ); // false
ignore ( 'dir', { isDirectory: true } ); // true

// We can also work with multiple ignore files at once, which is faster than handling them individually
// This goes roughly as fast as just concatenating the files together, but with the semantics of separate files
// The difference is that an ignore file that comes later won't be able to un-ignore something that was ignored by a previous one
// As a result please note that writing `fastIgnore ([ 'dist', '!dist' ])` may work differently than you expected

const prettierignore = `
**/test
**/__test__

# The following globs are effectively useless
# because they can't un-ignore something that was ignored by any previous ignore files
!dist
!node_modules
`;

const comboIgnore = fastIgnore ([ gitignore, prettierignore ]);

comboIgnore ( 'foo/bar.js' ); // false
comboIgnore ( 'node_modules/foo/bar.js' ); // true
comboIgnore ( 'dist/foo/bar.js' ); // true
comboIgnore ( 'test/foo/bar.js' ); // true

License

MIT © Fabio Spampinato

版本列表
2.0.0 2026-02-15
1.1.3 2024-03-29
1.1.2 2024-03-28
1.1.1 2023-12-09
1.1.0 2023-12-09
1.0.0 2023-12-09