a1adfc8706
new file: archetypes/default.md new file: config.toml new file: content/about/_index.md new file: content/access/_index.md new file: content/background.jpg new file: content/background.mp4 new file: content/blog/_index.md new file: content/manifesto/_index.md new file: content/posts/_index.md new file: content/posts/apple-breaks-privacy.md new file: content/posts/main_street_against_big_tech.md new file: content/posts/template.md new file: content/posts/what_is_done_with_personal_data.md new file: content/projects/_index.md new file: node_modules/.bin/nanoid new file: node_modules/.bin/postcss new file: node_modules/.package-lock.json new file: node_modules/@nodelib/fs.scandir/LICENSE new file: node_modules/@nodelib/fs.scandir/README.md new file: node_modules/@nodelib/fs.scandir/out/adapters/fs.d.ts new file: node_modules/@nodelib/fs.scandir/out/adapters/fs.js new file: node_modules/@nodelib/fs.scandir/out/constants.d.ts new file: node_modules/@nodelib/fs.scandir/out/constants.js new file: node_modules/@nodelib/fs.scandir/out/index.d.ts new file: node_modules/@nodelib/fs.scandir/out/index.js new file: node_modules/@nodelib/fs.scandir/out/providers/async.d.ts new file: node_modules/@nodelib/fs.scandir/out/providers/async.js new file: node_modules/@nodelib/fs.scandir/out/providers/common.d.ts new file: node_modules/@nodelib/fs.scandir/out/providers/common.js new file: node_modules/@nodelib/fs.scandir/out/providers/sync.d.ts new file: node_modules/@nodelib/fs.scandir/out/providers/sync.js new file: node_modules/@nodelib/fs.scandir/out/settings.d.ts new file: node_modules/@nodelib/fs.scandir/out/settings.js new file: node_modules/@nodelib/fs.scandir/out/types/index.d.ts new file: node_modules/@nodelib/fs.scandir/out/types/index.js new file: node_modules/@nodelib/fs.scandir/out/utils/fs.d.ts new file: node_modules/@nodelib/fs.scandir/out/utils/fs.js new file: node_modules/@nodelib/fs.scandir/out/utils/index.d.ts new file: node_modules/@nodelib/fs.scandir/out/utils/index.js new file: node_modules/@nodelib/fs.scandir/package.json new file: node_modules/@nodelib/fs.stat/LICENSE new file: node_modules/@nodelib/fs.stat/README.md new file: node_modules/@nodelib/fs.stat/out/adapters/fs.d.ts new file: node_modules/@nodelib/fs.stat/out/adapters/fs.js new file: node_modules/@nodelib/fs.stat/out/index.d.ts new file: node_modules/@nodelib/fs.stat/out/index.js new file: node_modules/@nodelib/fs.stat/out/providers/async.d.ts new file: node_modules/@nodelib/fs.stat/out/providers/async.js new file: node_modules/@nodelib/fs.stat/out/providers/sync.d.ts new file: node_modules/@nodelib/fs.stat/out/providers/sync.js new file: node_modules/@nodelib/fs.stat/out/settings.d.ts new file: node_modules/@nodelib/fs.stat/out/settings.js new file: node_modules/@nodelib/fs.stat/out/types/index.d.ts new file: node_modules/@nodelib/fs.stat/out/types/index.js new file: node_modules/@nodelib/fs.stat/package.json new file: node_modules/@nodelib/fs.walk/LICENSE new file: node_modules/@nodelib/fs.walk/README.md new file: node_modules/@nodelib/fs.walk/out/index.d.ts new file: node_modules/@nodelib/fs.walk/out/index.js new file: node_modules/@nodelib/fs.walk/out/providers/async.d.ts new file: node_modules/@nodelib/fs.walk/out/providers/async.js new file: node_modules/@nodelib/fs.walk/out/providers/index.d.ts new file: node_modules/@nodelib/fs.walk/out/providers/index.js new file: node_modules/@nodelib/fs.walk/out/providers/stream.d.ts new file: node_modules/@nodelib/fs.walk/out/providers/stream.js new file: node_modules/@nodelib/fs.walk/out/providers/sync.d.ts new file: node_modules/@nodelib/fs.walk/out/providers/sync.js new file: node_modules/@nodelib/fs.walk/out/readers/async.d.ts new file: node_modules/@nodelib/fs.walk/out/readers/async.js new file: node_modules/@nodelib/fs.walk/out/readers/common.d.ts new file: node_modules/@nodelib/fs.walk/out/readers/common.js new file: node_modules/@nodelib/fs.walk/out/readers/reader.d.ts new file: node_modules/@nodelib/fs.walk/out/readers/reader.js new file: node_modules/@nodelib/fs.walk/out/readers/sync.d.ts new file: node_modules/@nodelib/fs.walk/out/readers/sync.js new file: node_modules/@nodelib/fs.walk/out/settings.d.ts new file: node_modules/@nodelib/fs.walk/out/settings.js new file: node_modules/@nodelib/fs.walk/out/types/index.d.ts new file: node_modules/@nodelib/fs.walk/out/types/index.js new file: node_modules/@nodelib/fs.walk/package.json new file: node_modules/ansi-regex/index.d.ts new file: node_modules/ansi-regex/index.js new file: node_modules/ansi-regex/license new file: node_modules/ansi-regex/package.json new file: node_modules/ansi-regex/readme.md new file: node_modules/ansi-styles/index.d.ts new file: node_modules/ansi-styles/index.js new file: node_modules/ansi-styles/license new file: node_modules/ansi-styles/package.json new file: node_modules/ansi-styles/readme.md new file: node_modules/anymatch/LICENSE new file: node_modules/anymatch/README.md new file: node_modules/anymatch/index.d.ts new file: node_modules/anymatch/index.js new file: node_modules/anymatch/package.json new file: node_modules/array-union/index.d.ts new file: node_modules/array-union/index.js new file: node_modules/array-union/license new file: node_modules/array-union/package.json new file: node_modules/array-union/readme.md new file: node_modules/binary-extensions/binary-extensions.json new file: node_modules/binary-extensions/binary-extensions.json.d.ts new file: node_modules/binary-extensions/index.d.ts new file: node_modules/binary-extensions/index.js new file: node_modules/binary-extensions/license new file: node_modules/binary-extensions/package.json new file: node_modules/binary-extensions/readme.md new file: node_modules/braces/CHANGELOG.md new file: node_modules/braces/LICENSE new file: node_modules/braces/README.md new file: node_modules/braces/index.js new file: node_modules/braces/lib/compile.js new file: node_modules/braces/lib/constants.js new file: node_modules/braces/lib/expand.js new file: node_modules/braces/lib/parse.js new file: node_modules/braces/lib/stringify.js new file: node_modules/braces/lib/utils.js new file: node_modules/braces/package.json new file: node_modules/chokidar/LICENSE new file: node_modules/chokidar/README.md new file: node_modules/chokidar/index.js new file: node_modules/chokidar/lib/constants.js new file: node_modules/chokidar/lib/fsevents-handler.js new file: node_modules/chokidar/lib/nodefs-handler.js new file: node_modules/chokidar/package.json new file: node_modules/chokidar/types/index.d.ts new file: node_modules/cliui/CHANGELOG.md new file: node_modules/cliui/LICENSE.txt new file: node_modules/cliui/README.md new file: node_modules/cliui/build/index.cjs new file: node_modules/cliui/build/lib/index.js new file: node_modules/cliui/build/lib/string-utils.js new file: node_modules/cliui/index.mjs new file: node_modules/cliui/package.json new file: node_modules/color-convert/CHANGELOG.md new file: node_modules/color-convert/LICENSE new file: node_modules/color-convert/README.md new file: node_modules/color-convert/conversions.js new file: node_modules/color-convert/index.js new file: node_modules/color-convert/package.json new file: node_modules/color-convert/route.js new file: node_modules/color-name/LICENSE new file: node_modules/color-name/README.md new file: node_modules/color-name/index.js new file: node_modules/color-name/package.json new file: node_modules/dependency-graph/CHANGELOG.md new file: node_modules/dependency-graph/LICENSE new file: node_modules/dependency-graph/README.md new file: node_modules/dependency-graph/lib/dep_graph.js new file: node_modules/dependency-graph/lib/index.d.ts new file: node_modules/dependency-graph/package.json new file: node_modules/dependency-graph/specs/dep_graph_spec.js new file: node_modules/dir-glob/index.js new file: node_modules/dir-glob/license new file: node_modules/dir-glob/package.json new file: node_modules/dir-glob/readme.md new file: node_modules/emoji-regex/LICENSE-MIT.txt new file: node_modules/emoji-regex/README.md new file: node_modules/emoji-regex/es2015/index.js new file: node_modules/emoji-regex/es2015/text.js new file: node_modules/emoji-regex/index.d.ts new file: node_modules/emoji-regex/index.js new file: node_modules/emoji-regex/package.json new file: node_modules/emoji-regex/text.js new file: node_modules/escalade/dist/index.js new file: node_modules/escalade/dist/index.mjs new file: node_modules/escalade/index.d.ts new file: node_modules/escalade/license new file: node_modules/escalade/package.json new file: node_modules/escalade/readme.md new file: node_modules/escalade/sync/index.d.ts new file: node_modules/escalade/sync/index.js new file: node_modules/escalade/sync/index.mjs new file: node_modules/fast-glob/LICENSE new file: node_modules/fast-glob/README.md new file: node_modules/fast-glob/out/index.d.ts new file: node_modules/fast-glob/out/index.js new file: node_modules/fast-glob/out/managers/patterns.d.ts new file: node_modules/fast-glob/out/managers/patterns.js new file: node_modules/fast-glob/out/managers/tasks.d.ts new file: node_modules/fast-glob/out/managers/tasks.js new file: node_modules/fast-glob/out/providers/async.d.ts new file: node_modules/fast-glob/out/providers/async.js new file: node_modules/fast-glob/out/providers/filters/deep.d.ts new file: node_modules/fast-glob/out/providers/filters/deep.js new file: node_modules/fast-glob/out/providers/filters/entry.d.ts new file: node_modules/fast-glob/out/providers/filters/entry.js new file: node_modules/fast-glob/out/providers/filters/error.d.ts new file: node_modules/fast-glob/out/providers/filters/error.js new file: node_modules/fast-glob/out/providers/matchers/matcher.d.ts new file: node_modules/fast-glob/out/providers/matchers/matcher.js new file: node_modules/fast-glob/out/providers/matchers/partial.d.ts new file: node_modules/fast-glob/out/providers/matchers/partial.js new file: node_modules/fast-glob/out/providers/provider.d.ts new file: node_modules/fast-glob/out/providers/provider.js new file: node_modules/fast-glob/out/providers/stream.d.ts new file: node_modules/fast-glob/out/providers/stream.js new file: node_modules/fast-glob/out/providers/sync.d.ts new file: node_modules/fast-glob/out/providers/sync.js new file: node_modules/fast-glob/out/providers/transformers/entry.d.ts new file: node_modules/fast-glob/out/providers/transformers/entry.js new file: node_modules/fast-glob/out/readers/reader.d.ts new file: node_modules/fast-glob/out/readers/reader.js new file: node_modules/fast-glob/out/readers/stream.d.ts new file: node_modules/fast-glob/out/readers/stream.js new file: node_modules/fast-glob/out/readers/sync.d.ts new file: node_modules/fast-glob/out/readers/sync.js new file: node_modules/fast-glob/out/settings.d.ts new file: node_modules/fast-glob/out/settings.js new file: node_modules/fast-glob/out/types/index.d.ts new file: node_modules/fast-glob/out/types/index.js new file: node_modules/fast-glob/out/utils/array.d.ts new file: node_modules/fast-glob/out/utils/array.js new file: node_modules/fast-glob/out/utils/errno.d.ts new file: node_modules/fast-glob/out/utils/errno.js new file: node_modules/fast-glob/out/utils/fs.d.ts new file: node_modules/fast-glob/out/utils/fs.js new file: node_modules/fast-glob/out/utils/index.d.ts new file: node_modules/fast-glob/out/utils/index.js new file: node_modules/fast-glob/out/utils/path.d.ts new file: node_modules/fast-glob/out/utils/path.js new file: node_modules/fast-glob/out/utils/pattern.d.ts new file: node_modules/fast-glob/out/utils/pattern.js new file: node_modules/fast-glob/out/utils/stream.d.ts new file: node_modules/fast-glob/out/utils/stream.js new file: node_modules/fast-glob/out/utils/string.d.ts new file: node_modules/fast-glob/out/utils/string.js new file: node_modules/fast-glob/package.json new file: node_modules/fastq/.github/dependabot.yml new file: node_modules/fastq/.github/workflows/ci.yml new file: node_modules/fastq/LICENSE new file: node_modules/fastq/README.md new file: node_modules/fastq/bench.js new file: node_modules/fastq/example.js new file: node_modules/fastq/example.mjs new file: node_modules/fastq/index.d.ts new file: node_modules/fastq/package.json new file: node_modules/fastq/queue.js new file: node_modules/fastq/test/example.ts new file: node_modules/fastq/test/promise.js new file: node_modules/fastq/test/test.js new file: node_modules/fastq/test/tsconfig.json new file: node_modules/fill-range/LICENSE new file: node_modules/fill-range/README.md new file: node_modules/fill-range/index.js new file: node_modules/fill-range/package.json new file: node_modules/fs-extra/CHANGELOG.md new file: node_modules/fs-extra/LICENSE new file: node_modules/fs-extra/README.md new file: node_modules/fs-extra/lib/copy-sync/copy-sync.js new file: node_modules/fs-extra/lib/copy-sync/index.js new file: node_modules/fs-extra/lib/copy/copy.js new file: node_modules/fs-extra/lib/copy/index.js new file: node_modules/fs-extra/lib/empty/index.js new file: node_modules/fs-extra/lib/ensure/file.js new file: node_modules/fs-extra/lib/ensure/index.js new file: node_modules/fs-extra/lib/ensure/link.js new file: node_modules/fs-extra/lib/ensure/symlink-paths.js new file: node_modules/fs-extra/lib/ensure/symlink-type.js new file: node_modules/fs-extra/lib/ensure/symlink.js new file: node_modules/fs-extra/lib/fs/index.js new file: node_modules/fs-extra/lib/index.js new file: node_modules/fs-extra/lib/json/index.js new file: node_modules/fs-extra/lib/json/jsonfile.js new file: node_modules/fs-extra/lib/json/output-json-sync.js new file: node_modules/fs-extra/lib/json/output-json.js new file: node_modules/fs-extra/lib/mkdirs/index.js new file: node_modules/fs-extra/lib/mkdirs/make-dir.js new file: node_modules/fs-extra/lib/mkdirs/utils.js new file: node_modules/fs-extra/lib/move-sync/index.js new file: node_modules/fs-extra/lib/move-sync/move-sync.js new file: node_modules/fs-extra/lib/move/index.js new file: node_modules/fs-extra/lib/move/move.js new file: node_modules/fs-extra/lib/output/index.js new file: node_modules/fs-extra/lib/path-exists/index.js new file: node_modules/fs-extra/lib/remove/index.js new file: node_modules/fs-extra/lib/remove/rimraf.js new file: node_modules/fs-extra/lib/util/stat.js new file: node_modules/fs-extra/lib/util/utimes.js new file: node_modules/fs-extra/package.json new file: node_modules/get-caller-file/LICENSE.md new file: node_modules/get-caller-file/README.md new file: node_modules/get-caller-file/index.d.ts new file: node_modules/get-caller-file/index.js new file: node_modules/get-caller-file/index.js.map new file: node_modules/get-caller-file/package.json new file: node_modules/get-stdin/index.d.ts new file: node_modules/get-stdin/index.js new file: node_modules/get-stdin/license new file: node_modules/get-stdin/package.json new file: node_modules/get-stdin/readme.md new file: node_modules/glob-parent/CHANGELOG.md new file: node_modules/glob-parent/LICENSE new file: node_modules/glob-parent/README.md new file: node_modules/glob-parent/index.js new file: node_modules/glob-parent/package.json new file: node_modules/globby/gitignore.js new file: node_modules/globby/index.d.ts new file: node_modules/globby/index.js new file: node_modules/globby/license new file: node_modules/globby/package.json new file: node_modules/globby/readme.md new file: node_modules/globby/stream-utils.js new file: node_modules/globby/to-path.js new file: node_modules/graceful-fs/LICENSE new file: node_modules/graceful-fs/README.md new file: node_modules/graceful-fs/clone.js new file: node_modules/graceful-fs/graceful-fs.js new file: node_modules/graceful-fs/legacy-streams.js new file: node_modules/graceful-fs/package.json new file: node_modules/graceful-fs/polyfills.js new file: node_modules/ignore/LICENSE-MIT new file: node_modules/ignore/README.md new file: node_modules/ignore/index.d.ts new file: node_modules/ignore/index.js new file: node_modules/ignore/legacy.js new file: node_modules/ignore/package.json new file: node_modules/is-binary-path/index.d.ts new file: node_modules/is-binary-path/index.js new file: node_modules/is-binary-path/license new file: node_modules/is-binary-path/package.json new file: node_modules/is-binary-path/readme.md new file: node_modules/is-extglob/LICENSE new file: node_modules/is-extglob/README.md new file: node_modules/is-extglob/index.js new file: node_modules/is-extglob/package.json new file: node_modules/is-fullwidth-code-point/index.d.ts new file: node_modules/is-fullwidth-code-point/index.js new file: node_modules/is-fullwidth-code-point/license new file: node_modules/is-fullwidth-code-point/package.json new file: node_modules/is-fullwidth-code-point/readme.md new file: node_modules/is-glob/LICENSE new file: node_modules/is-glob/README.md new file: node_modules/is-glob/index.js new file: node_modules/is-glob/package.json new file: node_modules/is-number/LICENSE new file: node_modules/is-number/README.md new file: node_modules/is-number/index.js new file: node_modules/is-number/package.json new file: node_modules/jsonfile/CHANGELOG.md new file: node_modules/jsonfile/LICENSE new file: node_modules/jsonfile/README.md new file: node_modules/jsonfile/index.js new file: node_modules/jsonfile/package.json new file: node_modules/jsonfile/utils.js new file: node_modules/lilconfig/dist/index.d.ts new file: node_modules/lilconfig/dist/index.js new file: node_modules/lilconfig/package.json new file: node_modules/lilconfig/readme.md new file: node_modules/merge2/LICENSE new file: node_modules/merge2/README.md new file: node_modules/merge2/index.js new file: node_modules/merge2/package.json new file: node_modules/micromatch/CHANGELOG.md new file: node_modules/micromatch/LICENSE new file: node_modules/micromatch/README.md new file: node_modules/micromatch/index.js new file: node_modules/micromatch/package.json new file: node_modules/nanoid/LICENSE new file: node_modules/nanoid/README.md new file: node_modules/nanoid/async/index.browser.cjs new file: node_modules/nanoid/async/index.browser.js new file: node_modules/nanoid/async/index.cjs new file: node_modules/nanoid/async/index.d.ts new file: node_modules/nanoid/async/index.js new file: node_modules/nanoid/async/index.native.js new file: node_modules/nanoid/async/package.json new file: node_modules/nanoid/bin/nanoid.cjs new file: node_modules/nanoid/index.browser.cjs new file: node_modules/nanoid/index.browser.js new file: node_modules/nanoid/index.cjs new file: node_modules/nanoid/index.d.ts new file: node_modules/nanoid/index.dev.js new file: node_modules/nanoid/index.js new file: node_modules/nanoid/index.prod.js new file: node_modules/nanoid/nanoid.js new file: node_modules/nanoid/non-secure/index.cjs new file: node_modules/nanoid/non-secure/index.d.ts new file: node_modules/nanoid/non-secure/index.js new file: node_modules/nanoid/non-secure/package.json new file: node_modules/nanoid/package.json new file: node_modules/nanoid/url-alphabet/index.cjs new file: node_modules/nanoid/url-alphabet/index.js new file: node_modules/nanoid/url-alphabet/package.json new file: node_modules/normalize-path/LICENSE new file: node_modules/normalize-path/README.md new file: node_modules/normalize-path/index.js new file: node_modules/normalize-path/package.json new file: node_modules/path-type/index.d.ts new file: node_modules/path-type/index.js new file: node_modules/path-type/license new file: node_modules/path-type/package.json new file: node_modules/path-type/readme.md new file: node_modules/picocolors/LICENSE new file: node_modules/picocolors/README.md new file: node_modules/picocolors/package.json new file: node_modules/picocolors/picocolors.browser.js new file: node_modules/picocolors/picocolors.d.ts new file: node_modules/picocolors/picocolors.js new file: node_modules/picocolors/types.ts new file: node_modules/picomatch/CHANGELOG.md new file: node_modules/picomatch/LICENSE new file: node_modules/picomatch/README.md new file: node_modules/picomatch/index.js new file: node_modules/picomatch/lib/constants.js new file: node_modules/picomatch/lib/parse.js new file: node_modules/picomatch/lib/picomatch.js new file: node_modules/picomatch/lib/scan.js new file: node_modules/picomatch/lib/utils.js new file: node_modules/picomatch/package.json new file: node_modules/pify/index.js new file: node_modules/pify/license new file: node_modules/pify/package.json new file: node_modules/pify/readme.md new file: node_modules/postcss-cli/LICENSE new file: node_modules/postcss-cli/README.md new file: node_modules/postcss-cli/index.js new file: node_modules/postcss-cli/lib/DependencyGraph.js new file: node_modules/postcss-cli/lib/args.js new file: node_modules/postcss-cli/lib/getMapfile.js new file: node_modules/postcss-cli/package.json new file: node_modules/postcss-load-config/LICENSE new file: node_modules/postcss-load-config/README.md new file: node_modules/postcss-load-config/package.json new file: node_modules/postcss-load-config/src/index.d.ts new file: node_modules/postcss-load-config/src/index.js new file: node_modules/postcss-load-config/src/options.js new file: node_modules/postcss-load-config/src/plugins.js new file: node_modules/postcss-load-config/src/req.js new file: node_modules/postcss-reporter/LICENSE new file: node_modules/postcss-reporter/README.md new file: node_modules/postcss-reporter/index.js new file: node_modules/postcss-reporter/lib/formatter.js new file: node_modules/postcss-reporter/lib/reporter.js new file: node_modules/postcss-reporter/lib/util.js new file: node_modules/postcss-reporter/package.json new file: node_modules/postcss/LICENSE new file: node_modules/postcss/README.md new file: node_modules/postcss/lib/at-rule.d.ts new file: node_modules/postcss/lib/at-rule.js new file: node_modules/postcss/lib/comment.d.ts new file: node_modules/postcss/lib/comment.js new file: node_modules/postcss/lib/container.d.ts new file: node_modules/postcss/lib/container.js new file: node_modules/postcss/lib/css-syntax-error.d.ts new file: node_modules/postcss/lib/css-syntax-error.js new file: node_modules/postcss/lib/declaration.d.ts new file: node_modules/postcss/lib/declaration.js new file: node_modules/postcss/lib/document.d.ts new file: node_modules/postcss/lib/document.js new file: node_modules/postcss/lib/fromJSON.d.ts new file: node_modules/postcss/lib/fromJSON.js new file: node_modules/postcss/lib/input.d.ts new file: node_modules/postcss/lib/input.js new file: node_modules/postcss/lib/lazy-result.d.ts new file: node_modules/postcss/lib/lazy-result.js new file: node_modules/postcss/lib/list.d.ts new file: node_modules/postcss/lib/list.js new file: node_modules/postcss/lib/map-generator.js new file: node_modules/postcss/lib/no-work-result.d.ts new file: node_modules/postcss/lib/no-work-result.js new file: node_modules/postcss/lib/node.d.ts new file: node_modules/postcss/lib/node.js new file: node_modules/postcss/lib/parse.d.ts new file: node_modules/postcss/lib/parse.js new file: node_modules/postcss/lib/parser.js new file: node_modules/postcss/lib/postcss.d.ts new file: node_modules/postcss/lib/postcss.js new file: node_modules/postcss/lib/postcss.mjs new file: node_modules/postcss/lib/previous-map.d.ts new file: node_modules/postcss/lib/previous-map.js new file: node_modules/postcss/lib/processor.d.ts new file: node_modules/postcss/lib/processor.js new file: node_modules/postcss/lib/result.d.ts new file: node_modules/postcss/lib/result.js new file: node_modules/postcss/lib/root.d.ts new file: node_modules/postcss/lib/root.js new file: node_modules/postcss/lib/rule.d.ts new file: node_modules/postcss/lib/rule.js new file: node_modules/postcss/lib/stringifier.d.ts new file: node_modules/postcss/lib/stringifier.js new file: node_modules/postcss/lib/stringify.d.ts new file: node_modules/postcss/lib/stringify.js new file: node_modules/postcss/lib/symbols.js new file: node_modules/postcss/lib/terminal-highlight.js new file: node_modules/postcss/lib/tokenize.js new file: node_modules/postcss/lib/warn-once.js new file: node_modules/postcss/lib/warning.d.ts new file: node_modules/postcss/lib/warning.js new file: node_modules/postcss/package.json new file: node_modules/pretty-hrtime/.jshintignore new file: node_modules/pretty-hrtime/.npmignore new file: node_modules/pretty-hrtime/LICENSE new file: node_modules/pretty-hrtime/README.md new file: node_modules/pretty-hrtime/index.js new file: node_modules/pretty-hrtime/package.json new file: node_modules/queue-microtask/LICENSE new file: node_modules/queue-microtask/README.md new file: node_modules/queue-microtask/index.d.ts new file: node_modules/queue-microtask/index.js new file: node_modules/queue-microtask/package.json new file: node_modules/read-cache/LICENSE new file: node_modules/read-cache/README.md new file: node_modules/read-cache/index.js new file: node_modules/read-cache/package.json new file: node_modules/readdirp/LICENSE new file: node_modules/readdirp/README.md new file: node_modules/readdirp/index.d.ts new file: node_modules/readdirp/index.js new file: node_modules/readdirp/package.json new file: node_modules/require-directory/.jshintrc new file: node_modules/require-directory/.npmignore new file: node_modules/require-directory/.travis.yml new file: node_modules/require-directory/LICENSE new file: node_modules/require-directory/README.markdown new file: node_modules/require-directory/index.js new file: node_modules/require-directory/package.json new file: node_modules/reusify/.coveralls.yml new file: node_modules/reusify/.travis.yml new file: node_modules/reusify/LICENSE new file: node_modules/reusify/README.md new file: node_modules/reusify/benchmarks/createNoCodeFunction.js new file: node_modules/reusify/benchmarks/fib.js new file: node_modules/reusify/benchmarks/reuseNoCodeFunction.js new file: node_modules/reusify/package.json new file: node_modules/reusify/reusify.js new file: node_modules/reusify/test.js new file: node_modules/run-parallel/LICENSE new file: node_modules/run-parallel/README.md new file: node_modules/run-parallel/index.js new file: node_modules/run-parallel/package.json new file: node_modules/slash/index.d.ts new file: node_modules/slash/index.js new file: node_modules/slash/license new file: node_modules/slash/package.json new file: node_modules/slash/readme.md new file: node_modules/source-map-js/CHANGELOG.md new file: node_modules/source-map-js/LICENSE new file: node_modules/source-map-js/README.md new file: node_modules/source-map-js/lib/array-set.js new file: node_modules/source-map-js/lib/base64-vlq.js new file: node_modules/source-map-js/lib/base64.js new file: node_modules/source-map-js/lib/binary-search.js new file: node_modules/source-map-js/lib/mapping-list.js new file: node_modules/source-map-js/lib/quick-sort.js new file: node_modules/source-map-js/lib/source-map-consumer.js new file: node_modules/source-map-js/lib/source-map-generator.js new file: node_modules/source-map-js/lib/source-node.js new file: node_modules/source-map-js/lib/util.js new file: node_modules/source-map-js/package.json new file: node_modules/source-map-js/source-map.d.ts new file: node_modules/source-map-js/source-map.js new file: node_modules/string-width/index.d.ts new file: node_modules/string-width/index.js new file: node_modules/string-width/license new file: node_modules/string-width/package.json new file: node_modules/string-width/readme.md new file: node_modules/strip-ansi/index.d.ts new file: node_modules/strip-ansi/index.js new file: node_modules/strip-ansi/license new file: node_modules/strip-ansi/package.json new file: node_modules/strip-ansi/readme.md new file: node_modules/thenby/LICENSE.TXT new file: node_modules/thenby/README.md new file: node_modules/thenby/package.json new file: node_modules/thenby/thenBy.min.js new file: node_modules/thenby/thenBy.module.d.ts new file: node_modules/thenby/thenBy.module.js new file: node_modules/to-regex-range/LICENSE new file: node_modules/to-regex-range/README.md new file: node_modules/to-regex-range/index.js new file: node_modules/to-regex-range/package.json new file: node_modules/universalify/LICENSE new file: node_modules/universalify/README.md new file: node_modules/universalify/index.js new file: node_modules/universalify/package.json new file: node_modules/wrap-ansi/index.js new file: node_modules/wrap-ansi/license new file: node_modules/wrap-ansi/package.json new file: node_modules/wrap-ansi/readme.md new file: node_modules/y18n/CHANGELOG.md new file: node_modules/y18n/LICENSE new file: node_modules/y18n/README.md new file: node_modules/y18n/build/index.cjs new file: node_modules/y18n/build/lib/cjs.js new file: node_modules/y18n/build/lib/index.js new file: node_modules/y18n/build/lib/platform-shims/node.js new file: node_modules/y18n/index.mjs new file: node_modules/y18n/package.json new file: node_modules/yaml/LICENSE new file: node_modules/yaml/README.md new file: node_modules/yaml/browser/dist/PlainValue-b8036b75.js new file: node_modules/yaml/browser/dist/Schema-e94716c8.js new file: node_modules/yaml/browser/dist/index.js new file: node_modules/yaml/browser/dist/legacy-exports.js new file: node_modules/yaml/browser/dist/package.json new file: node_modules/yaml/browser/dist/parse-cst.js new file: node_modules/yaml/browser/dist/resolveSeq-492ab440.js new file: node_modules/yaml/browser/dist/types.js new file: node_modules/yaml/browser/dist/util.js new file: node_modules/yaml/browser/dist/warnings-df54cb69.js new file: node_modules/yaml/browser/index.js new file: node_modules/yaml/browser/map.js new file: node_modules/yaml/browser/pair.js new file: node_modules/yaml/browser/parse-cst.js new file: node_modules/yaml/browser/scalar.js new file: node_modules/yaml/browser/schema.js new file: node_modules/yaml/browser/seq.js new file: node_modules/yaml/browser/types.js new file: node_modules/yaml/browser/types/binary.js new file: node_modules/yaml/browser/types/omap.js new file: node_modules/yaml/browser/types/pairs.js new file: node_modules/yaml/browser/types/set.js new file: node_modules/yaml/browser/types/timestamp.js new file: node_modules/yaml/browser/util.js new file: node_modules/yaml/dist/Document-9b4560a1.js new file: node_modules/yaml/dist/PlainValue-ec8e588e.js new file: node_modules/yaml/dist/Schema-88e323a7.js new file: node_modules/yaml/dist/index.js new file: node_modules/yaml/dist/legacy-exports.js new file: node_modules/yaml/dist/parse-cst.js new file: node_modules/yaml/dist/resolveSeq-d03cb037.js new file: node_modules/yaml/dist/test-events.js new file: node_modules/yaml/dist/types.js new file: node_modules/yaml/dist/util.js new file: node_modules/yaml/dist/warnings-1000a372.js new file: node_modules/yaml/index.d.ts new file: node_modules/yaml/index.js new file: node_modules/yaml/map.js new file: node_modules/yaml/package.json new file: node_modules/yaml/pair.js new file: node_modules/yaml/parse-cst.d.ts new file: node_modules/yaml/parse-cst.js new file: node_modules/yaml/scalar.js new file: node_modules/yaml/schema.js new file: node_modules/yaml/seq.js new file: node_modules/yaml/types.d.ts new file: node_modules/yaml/types.js new file: node_modules/yaml/types.mjs new file: node_modules/yaml/types/binary.js new file: node_modules/yaml/types/omap.js new file: node_modules/yaml/types/pairs.js new file: node_modules/yaml/types/set.js new file: node_modules/yaml/types/timestamp.js new file: node_modules/yaml/util.d.ts new file: node_modules/yaml/util.js new file: node_modules/yaml/util.mjs new file: node_modules/yargs-parser/CHANGELOG.md new file: node_modules/yargs-parser/LICENSE.txt new file: node_modules/yargs-parser/README.md new file: node_modules/yargs-parser/browser.js new file: node_modules/yargs-parser/build/index.cjs new file: node_modules/yargs-parser/build/lib/index.js new file: node_modules/yargs-parser/build/lib/string-utils.js new file: node_modules/yargs-parser/build/lib/tokenize-arg-string.js new file: node_modules/yargs-parser/build/lib/yargs-parser-types.js new file: node_modules/yargs-parser/build/lib/yargs-parser.js new file: node_modules/yargs-parser/package.json new file: node_modules/yargs/LICENSE new file: node_modules/yargs/README.md new file: node_modules/yargs/browser.mjs new file: node_modules/yargs/build/index.cjs new file: node_modules/yargs/build/lib/argsert.js new file: node_modules/yargs/build/lib/command.js new file: node_modules/yargs/build/lib/completion-templates.js new file: node_modules/yargs/build/lib/completion.js new file: node_modules/yargs/build/lib/middleware.js new file: node_modules/yargs/build/lib/parse-command.js new file: node_modules/yargs/build/lib/typings/common-types.js new file: node_modules/yargs/build/lib/typings/yargs-parser-types.js new file: node_modules/yargs/build/lib/usage.js new file: node_modules/yargs/build/lib/utils/apply-extends.js new file: node_modules/yargs/build/lib/utils/is-promise.js new file: node_modules/yargs/build/lib/utils/levenshtein.js new file: node_modules/yargs/build/lib/utils/maybe-async-result.js new file: node_modules/yargs/build/lib/utils/obj-filter.js new file: node_modules/yargs/build/lib/utils/process-argv.js new file: node_modules/yargs/build/lib/utils/set-blocking.js new file: node_modules/yargs/build/lib/utils/which-module.js new file: node_modules/yargs/build/lib/validation.js new file: node_modules/yargs/build/lib/yargs-factory.js new file: node_modules/yargs/build/lib/yerror.js new file: node_modules/yargs/helpers/helpers.mjs new file: node_modules/yargs/helpers/index.js new file: node_modules/yargs/helpers/package.json new file: node_modules/yargs/index.cjs new file: node_modules/yargs/index.mjs new file: node_modules/yargs/lib/platform-shims/browser.mjs new file: node_modules/yargs/lib/platform-shims/esm.mjs new file: node_modules/yargs/locales/be.json new file: node_modules/yargs/locales/de.json new file: node_modules/yargs/locales/en.json new file: node_modules/yargs/locales/es.json new file: node_modules/yargs/locales/fi.json new file: node_modules/yargs/locales/fr.json new file: node_modules/yargs/locales/hi.json new file: node_modules/yargs/locales/hu.json new file: node_modules/yargs/locales/id.json new file: node_modules/yargs/locales/it.json new file: node_modules/yargs/locales/ja.json new file: node_modules/yargs/locales/ko.json new file: node_modules/yargs/locales/nb.json new file: node_modules/yargs/locales/nl.json new file: node_modules/yargs/locales/nn.json new file: node_modules/yargs/locales/pirate.json new file: node_modules/yargs/locales/pl.json new file: node_modules/yargs/locales/pt.json new file: node_modules/yargs/locales/pt_BR.json new file: node_modules/yargs/locales/ru.json new file: node_modules/yargs/locales/th.json new file: node_modules/yargs/locales/tr.json new file: node_modules/yargs/locales/uk_UA.json new file: node_modules/yargs/locales/uz.json new file: node_modules/yargs/locales/zh_CN.json new file: node_modules/yargs/locales/zh_TW.json new file: node_modules/yargs/package.json new file: node_modules/yargs/yargs new file: package-lock.json new file: package.json new file: public/about/index.html new file: public/about/index.xml new file: public/access/index.html new file: public/access/index.xml new file: public/background.jpg new file: public/background.mp4 new file: public/blog/index.html new file: public/blog/index.xml new file: public/categories/index.html new file: public/categories/index.xml new file: public/css/default-skin.css new file: public/css/default-skin.png new file: public/css/default-skin.svg new file: public/css/photoswipe.css new file: public/css/preloader.gif new file: public/css/style.css new file: public/index.html new file: public/index.xml new file: public/js/photoswipe-ui-default.min.js new file: public/js/photoswipe.min.js new file: public/manifesto/index.html new file: public/manifesto/index.xml new file: public/posts/apple-breaks-privacy/index.html new file: public/posts/index.html new file: public/posts/index.xml new file: public/posts/main_street_against_big_tech/index.html new file: public/posts/manifesto/index.html new file: public/posts/what_is_done_with_personal_data/index.html new file: public/projects/index.html new file: public/projects/index.xml new file: public/sam.ico new file: public/sitemap.xml new file: public/tags/index.html new file: public/tags/index.xml new file: public/tn.png new file: resources/_gen/assets/css/ananke/css/main.css_bb5467e0521bbea6b1e66429f6ec028e.content new file: resources/_gen/assets/css/ananke/css/main.css_bb5467e0521bbea6b1e66429f6ec028e.json new file: resources/_gen/assets/sass/sass/style.sass_7642ba43b3212fd7d7ba324df3b88b0c.content new file: resources/_gen/assets/sass/sass/style.sass_7642ba43b3212fd7d7ba324df3b88b0c.json
796 lines
23 KiB
Markdown
796 lines
23 KiB
Markdown
# fast-glob
|
||
|
||
> It's a very fast and efficient [glob][glob_definition] library for [Node.js][node_js].
|
||
|
||
This package provides methods for traversing the file system and returning pathnames that matched a defined set of a specified pattern according to the rules used by the Unix Bash shell with some simplifications, meanwhile results are returned in **arbitrary order**. Quick, simple, effective.
|
||
|
||
## Table of Contents
|
||
|
||
<details>
|
||
<summary><strong>Details</strong></summary>
|
||
|
||
* [Highlights](#highlights)
|
||
* [Donation](#donation)
|
||
* [Old and modern mode](#old-and-modern-mode)
|
||
* [Pattern syntax](#pattern-syntax)
|
||
* [Basic syntax](#basic-syntax)
|
||
* [Advanced syntax](#advanced-syntax)
|
||
* [Installation](#installation)
|
||
* [API](#api)
|
||
* [Asynchronous](#asynchronous)
|
||
* [Synchronous](#synchronous)
|
||
* [Stream](#stream)
|
||
* [patterns](#patterns)
|
||
* [[options]](#options)
|
||
* [Helpers](#helpers)
|
||
* [generateTasks](#generatetaskspatterns-options)
|
||
* [isDynamicPattern](#isdynamicpatternpattern-options)
|
||
* [escapePath](#escapepathpattern)
|
||
* [Options](#options-3)
|
||
* [Common](#common)
|
||
* [concurrency](#concurrency)
|
||
* [cwd](#cwd)
|
||
* [deep](#deep)
|
||
* [followSymbolicLinks](#followsymboliclinks)
|
||
* [fs](#fs)
|
||
* [ignore](#ignore)
|
||
* [suppressErrors](#suppresserrors)
|
||
* [throwErrorOnBrokenSymbolicLink](#throwerroronbrokensymboliclink)
|
||
* [Output control](#output-control)
|
||
* [absolute](#absolute)
|
||
* [markDirectories](#markdirectories)
|
||
* [objectMode](#objectmode)
|
||
* [onlyDirectories](#onlydirectories)
|
||
* [onlyFiles](#onlyfiles)
|
||
* [stats](#stats)
|
||
* [unique](#unique)
|
||
* [Matching control](#matching-control)
|
||
* [braceExpansion](#braceexpansion)
|
||
* [caseSensitiveMatch](#casesensitivematch)
|
||
* [dot](#dot)
|
||
* [extglob](#extglob)
|
||
* [globstar](#globstar)
|
||
* [baseNameMatch](#basenamematch)
|
||
* [FAQ](#faq)
|
||
* [What is a static or dynamic pattern?](#what-is-a-static-or-dynamic-pattern)
|
||
* [How to write patterns on Windows?](#how-to-write-patterns-on-windows)
|
||
* [Why are parentheses match wrong?](#why-are-parentheses-match-wrong)
|
||
* [How to exclude directory from reading?](#how-to-exclude-directory-from-reading)
|
||
* [How to use UNC path?](#how-to-use-unc-path)
|
||
* [Compatible with `node-glob`?](#compatible-with-node-glob)
|
||
* [Benchmarks](#benchmarks)
|
||
* [Server](#server)
|
||
* [Nettop](#nettop)
|
||
* [Changelog](#changelog)
|
||
* [License](#license)
|
||
|
||
</details>
|
||
|
||
## Highlights
|
||
|
||
* Fast. Probably the fastest.
|
||
* Supports multiple and negative patterns.
|
||
* Synchronous, Promise and Stream API.
|
||
* Object mode. Can return more than just strings.
|
||
* Error-tolerant.
|
||
|
||
## Donation
|
||
|
||
Do you like this project? Support it by donating, creating an issue or pull request.
|
||
|
||
[![Donate](https://img.shields.io/badge/Donate-PayPal-green.svg)][paypal_mrmlnc]
|
||
|
||
## Old and modern mode
|
||
|
||
This package works in two modes, depending on the environment in which it is used.
|
||
|
||
* **Old mode**. Node.js below 10.10 or when the [`stats`](#stats) option is *enabled*.
|
||
* **Modern mode**. Node.js 10.10+ and the [`stats`](#stats) option is *disabled*.
|
||
|
||
The modern mode is faster. Learn more about the [internal mechanism][nodelib_fs_scandir_old_and_modern_modern].
|
||
|
||
## Pattern syntax
|
||
|
||
> :warning: Always use forward-slashes in glob expressions (patterns and [`ignore`](#ignore) option). Use backslashes for escaping characters.
|
||
|
||
There is more than one form of syntax: basic and advanced. Below is a brief overview of the supported features. Also pay attention to our [FAQ](#faq).
|
||
|
||
> :book: This package uses a [`micromatch`][micromatch] as a library for pattern matching.
|
||
|
||
### Basic syntax
|
||
|
||
* An asterisk (`*`) — matches everything except slashes (path separators), hidden files (names starting with `.`).
|
||
* A double star or globstar (`**`) — matches zero or more directories.
|
||
* Question mark (`?`) – matches any single character except slashes (path separators).
|
||
* Sequence (`[seq]`) — matches any character in sequence.
|
||
|
||
> :book: A few additional words about the [basic matching behavior][picomatch_matching_behavior].
|
||
|
||
Some examples:
|
||
|
||
* `src/**/*.js` — matches all files in the `src` directory (any level of nesting) that have the `.js` extension.
|
||
* `src/*.??` — matches all files in the `src` directory (only first level of nesting) that have a two-character extension.
|
||
* `file-[01].js` — matches files: `file-0.js`, `file-1.js`.
|
||
|
||
### Advanced syntax
|
||
|
||
* [Escapes characters][micromatch_backslashes] (`\\`) — matching special characters (`$^*+?()[]`) as literals.
|
||
* [POSIX character classes][picomatch_posix_brackets] (`[[:digit:]]`).
|
||
* [Extended globs][micromatch_extglobs] (`?(pattern-list)`).
|
||
* [Bash style brace expansions][micromatch_braces] (`{}`).
|
||
* [Regexp character classes][micromatch_regex_character_classes] (`[1-5]`).
|
||
* [Regex groups][regular_expressions_brackets] (`(a|b)`).
|
||
|
||
> :book: A few additional words about the [advanced matching behavior][micromatch_extended_globbing].
|
||
|
||
Some examples:
|
||
|
||
* `src/**/*.{css,scss}` — matches all files in the `src` directory (any level of nesting) that have the `.css` or `.scss` extension.
|
||
* `file-[[:digit:]].js` — matches files: `file-0.js`, `file-1.js`, …, `file-9.js`.
|
||
* `file-{1..3}.js` — matches files: `file-1.js`, `file-2.js`, `file-3.js`.
|
||
* `file-(1|2)` — matches files: `file-1.js`, `file-2.js`.
|
||
|
||
## Installation
|
||
|
||
```console
|
||
npm install fast-glob
|
||
```
|
||
|
||
## API
|
||
|
||
### Asynchronous
|
||
|
||
```js
|
||
fg(patterns, [options])
|
||
```
|
||
|
||
Returns a `Promise` with an array of matching entries.
|
||
|
||
```js
|
||
const fg = require('fast-glob');
|
||
|
||
const entries = await fg(['.editorconfig', '**/index.js'], { dot: true });
|
||
|
||
// ['.editorconfig', 'services/index.js']
|
||
```
|
||
|
||
### Synchronous
|
||
|
||
```js
|
||
fg.sync(patterns, [options])
|
||
```
|
||
|
||
Returns an array of matching entries.
|
||
|
||
```js
|
||
const fg = require('fast-glob');
|
||
|
||
const entries = fg.sync(['.editorconfig', '**/index.js'], { dot: true });
|
||
|
||
// ['.editorconfig', 'services/index.js']
|
||
```
|
||
|
||
### Stream
|
||
|
||
```js
|
||
fg.stream(patterns, [options])
|
||
```
|
||
|
||
Returns a [`ReadableStream`][node_js_stream_readable_streams] when the `data` event will be emitted with matching entry.
|
||
|
||
```js
|
||
const fg = require('fast-glob');
|
||
|
||
const stream = fg.stream(['.editorconfig', '**/index.js'], { dot: true });
|
||
|
||
for await (const entry of stream) {
|
||
// .editorconfig
|
||
// services/index.js
|
||
}
|
||
```
|
||
|
||
#### patterns
|
||
|
||
* Required: `true`
|
||
* Type: `string | string[]`
|
||
|
||
Any correct pattern(s).
|
||
|
||
> :1234: [Pattern syntax](#pattern-syntax)
|
||
>
|
||
> :warning: This package does not respect the order of patterns. First, all the negative patterns are applied, and only then the positive patterns. If you want to get a certain order of records, use sorting or split calls.
|
||
|
||
#### [options]
|
||
|
||
* Required: `false`
|
||
* Type: [`Options`](#options-3)
|
||
|
||
See [Options](#options-3) section.
|
||
|
||
### Helpers
|
||
|
||
#### `generateTasks(patterns, [options])`
|
||
|
||
Returns the internal representation of patterns ([`Task`](./src/managers/tasks.ts) is a combining patterns by base directory).
|
||
|
||
```js
|
||
fg.generateTasks('*');
|
||
|
||
[{
|
||
base: '.', // Parent directory for all patterns inside this task
|
||
dynamic: true, // Dynamic or static patterns are in this task
|
||
patterns: ['*'],
|
||
positive: ['*'],
|
||
negative: []
|
||
}]
|
||
```
|
||
|
||
##### patterns
|
||
|
||
* Required: `true`
|
||
* Type: `string | string[]`
|
||
|
||
Any correct pattern(s).
|
||
|
||
##### [options]
|
||
|
||
* Required: `false`
|
||
* Type: [`Options`](#options-3)
|
||
|
||
See [Options](#options-3) section.
|
||
|
||
#### `isDynamicPattern(pattern, [options])`
|
||
|
||
Returns `true` if the passed pattern is a dynamic pattern.
|
||
|
||
> :1234: [What is a static or dynamic pattern?](#what-is-a-static-or-dynamic-pattern)
|
||
|
||
```js
|
||
fg.isDynamicPattern('*'); // true
|
||
fg.isDynamicPattern('abc'); // false
|
||
```
|
||
|
||
##### pattern
|
||
|
||
* Required: `true`
|
||
* Type: `string`
|
||
|
||
Any correct pattern.
|
||
|
||
##### [options]
|
||
|
||
* Required: `false`
|
||
* Type: [`Options`](#options-3)
|
||
|
||
See [Options](#options-3) section.
|
||
|
||
#### `escapePath(pattern)`
|
||
|
||
Returns a path with escaped special characters (`*?|(){}[]`, `!` at the beginning of line, `@+!` before the opening parenthesis).
|
||
|
||
```js
|
||
fg.escapePath('!abc'); // \\!abc
|
||
fg.escapePath('C:/Program Files (x86)'); // C:/Program Files \\(x86\\)
|
||
```
|
||
|
||
##### pattern
|
||
|
||
* Required: `true`
|
||
* Type: `string`
|
||
|
||
Any string, for example, a path to a file.
|
||
|
||
## Options
|
||
|
||
### Common options
|
||
|
||
#### concurrency
|
||
|
||
* Type: `number`
|
||
* Default: `os.cpus().length`
|
||
|
||
Specifies the maximum number of concurrent requests from a reader to read directories.
|
||
|
||
> :book: The higher the number, the higher the performance and load on the file system. If you want to read in quiet mode, set the value to a comfortable number or `1`.
|
||
|
||
#### cwd
|
||
|
||
* Type: `string`
|
||
* Default: `process.cwd()`
|
||
|
||
The current working directory in which to search.
|
||
|
||
#### deep
|
||
|
||
* Type: `number`
|
||
* Default: `Infinity`
|
||
|
||
Specifies the maximum depth of a read directory relative to the start directory.
|
||
|
||
For example, you have the following tree:
|
||
|
||
```js
|
||
dir/
|
||
└── one/ // 1
|
||
└── two/ // 2
|
||
└── file.js // 3
|
||
```
|
||
|
||
```js
|
||
// With base directory
|
||
fg.sync('dir/**', { onlyFiles: false, deep: 1 }); // ['dir/one']
|
||
fg.sync('dir/**', { onlyFiles: false, deep: 2 }); // ['dir/one', 'dir/one/two']
|
||
|
||
// With cwd option
|
||
fg.sync('**', { onlyFiles: false, cwd: 'dir', deep: 1 }); // ['one']
|
||
fg.sync('**', { onlyFiles: false, cwd: 'dir', deep: 2 }); // ['one', 'one/two']
|
||
```
|
||
|
||
> :book: If you specify a pattern with some base directory, this directory will not participate in the calculation of the depth of the found directories. Think of it as a [`cwd`](#cwd) option.
|
||
|
||
#### followSymbolicLinks
|
||
|
||
* Type: `boolean`
|
||
* Default: `true`
|
||
|
||
Indicates whether to traverse descendants of symbolic link directories when expanding `**` patterns.
|
||
|
||
> :book: Note that this option does not affect the base directory of the pattern. For example, if `./a` is a symlink to directory `./b` and you specified `['./a**', './b/**']` patterns, then directory `./a` will still be read.
|
||
|
||
> :book: If the [`stats`](#stats) option is specified, the information about the symbolic link (`fs.lstat`) will be replaced with information about the entry (`fs.stat`) behind it.
|
||
|
||
#### fs
|
||
|
||
* Type: `FileSystemAdapter`
|
||
* Default: `fs.*`
|
||
|
||
Custom implementation of methods for working with the file system.
|
||
|
||
```ts
|
||
export interface FileSystemAdapter {
|
||
lstat?: typeof fs.lstat;
|
||
stat?: typeof fs.stat;
|
||
lstatSync?: typeof fs.lstatSync;
|
||
statSync?: typeof fs.statSync;
|
||
readdir?: typeof fs.readdir;
|
||
readdirSync?: typeof fs.readdirSync;
|
||
}
|
||
```
|
||
|
||
#### ignore
|
||
|
||
* Type: `string[]`
|
||
* Default: `[]`
|
||
|
||
An array of glob patterns to exclude matches. This is an alternative way to use negative patterns.
|
||
|
||
```js
|
||
dir/
|
||
├── package-lock.json
|
||
└── package.json
|
||
```
|
||
|
||
```js
|
||
fg.sync(['*.json', '!package-lock.json']); // ['package.json']
|
||
fg.sync('*.json', { ignore: ['package-lock.json'] }); // ['package.json']
|
||
```
|
||
|
||
#### suppressErrors
|
||
|
||
* Type: `boolean`
|
||
* Default: `false`
|
||
|
||
By default this package suppress only `ENOENT` errors. Set to `true` to suppress any error.
|
||
|
||
> :book: Can be useful when the directory has entries with a special level of access.
|
||
|
||
#### throwErrorOnBrokenSymbolicLink
|
||
|
||
* Type: `boolean`
|
||
* Default: `false`
|
||
|
||
Throw an error when symbolic link is broken if `true` or safely return `lstat` call if `false`.
|
||
|
||
> :book: This option has no effect on errors when reading the symbolic link directory.
|
||
|
||
### Output control
|
||
|
||
#### absolute
|
||
|
||
* Type: `boolean`
|
||
* Default: `false`
|
||
|
||
Return the absolute path for entries.
|
||
|
||
```js
|
||
fg.sync('*.js', { absolute: false }); // ['index.js']
|
||
fg.sync('*.js', { absolute: true }); // ['/home/user/index.js']
|
||
```
|
||
|
||
> :book: This option is required if you want to use negative patterns with absolute path, for example, `!${__dirname}/*.js`.
|
||
|
||
#### markDirectories
|
||
|
||
* Type: `boolean`
|
||
* Default: `false`
|
||
|
||
Mark the directory path with the final slash.
|
||
|
||
```js
|
||
fg.sync('*', { onlyFiles: false, markDirectories: false }); // ['index.js', 'controllers']
|
||
fg.sync('*', { onlyFiles: false, markDirectories: true }); // ['index.js', 'controllers/']
|
||
```
|
||
|
||
#### objectMode
|
||
|
||
* Type: `boolean`
|
||
* Default: `false`
|
||
|
||
Returns objects (instead of strings) describing entries.
|
||
|
||
```js
|
||
fg.sync('*', { objectMode: false }); // ['src/index.js']
|
||
fg.sync('*', { objectMode: true }); // [{ name: 'index.js', path: 'src/index.js', dirent: <fs.Dirent> }]
|
||
```
|
||
|
||
The object has the following fields:
|
||
|
||
* name (`string`) — the last part of the path (basename)
|
||
* path (`string`) — full path relative to the pattern base directory
|
||
* dirent ([`fs.Dirent`][node_js_fs_class_fs_dirent]) — instance of `fs.Dirent`
|
||
|
||
> :book: An object is an internal representation of entry, so getting it does not affect performance.
|
||
|
||
#### onlyDirectories
|
||
|
||
* Type: `boolean`
|
||
* Default: `false`
|
||
|
||
Return only directories.
|
||
|
||
```js
|
||
fg.sync('*', { onlyDirectories: false }); // ['index.js', 'src']
|
||
fg.sync('*', { onlyDirectories: true }); // ['src']
|
||
```
|
||
|
||
> :book: If `true`, the [`onlyFiles`](#onlyfiles) option is automatically `false`.
|
||
|
||
#### onlyFiles
|
||
|
||
* Type: `boolean`
|
||
* Default: `true`
|
||
|
||
Return only files.
|
||
|
||
```js
|
||
fg.sync('*', { onlyFiles: false }); // ['index.js', 'src']
|
||
fg.sync('*', { onlyFiles: true }); // ['index.js']
|
||
```
|
||
|
||
#### stats
|
||
|
||
* Type: `boolean`
|
||
* Default: `false`
|
||
|
||
Enables an [object mode](#objectmode) with an additional field:
|
||
|
||
* stats ([`fs.Stats`][node_js_fs_class_fs_stats]) — instance of `fs.Stats`
|
||
|
||
```js
|
||
fg.sync('*', { stats: false }); // ['src/index.js']
|
||
fg.sync('*', { stats: true }); // [{ name: 'index.js', path: 'src/index.js', dirent: <fs.Dirent>, stats: <fs.Stats> }]
|
||
```
|
||
|
||
> :book: Returns `fs.stat` instead of `fs.lstat` for symbolic links when the [`followSymbolicLinks`](#followsymboliclinks) option is specified.
|
||
>
|
||
> :warning: Unlike [object mode](#objectmode) this mode requires additional calls to the file system. On average, this mode is slower at least twice. See [old and modern mode](#old-and-modern-mode) for more details.
|
||
|
||
#### unique
|
||
|
||
* Type: `boolean`
|
||
* Default: `true`
|
||
|
||
Ensures that the returned entries are unique.
|
||
|
||
```js
|
||
fg.sync(['*.json', 'package.json'], { unique: false }); // ['package.json', 'package.json']
|
||
fg.sync(['*.json', 'package.json'], { unique: true }); // ['package.json']
|
||
```
|
||
|
||
If `true` and similar entries are found, the result is the first found.
|
||
|
||
### Matching control
|
||
|
||
#### braceExpansion
|
||
|
||
* Type: `boolean`
|
||
* Default: `true`
|
||
|
||
Enables Bash-like brace expansion.
|
||
|
||
> :1234: [Syntax description][bash_hackers_syntax_expansion_brace] or more [detailed description][micromatch_braces].
|
||
|
||
```js
|
||
dir/
|
||
├── abd
|
||
├── acd
|
||
└── a{b,c}d
|
||
```
|
||
|
||
```js
|
||
fg.sync('a{b,c}d', { braceExpansion: false }); // ['a{b,c}d']
|
||
fg.sync('a{b,c}d', { braceExpansion: true }); // ['abd', 'acd']
|
||
```
|
||
|
||
#### caseSensitiveMatch
|
||
|
||
* Type: `boolean`
|
||
* Default: `true`
|
||
|
||
Enables a [case-sensitive][wikipedia_case_sensitivity] mode for matching files.
|
||
|
||
```js
|
||
dir/
|
||
├── file.txt
|
||
└── File.txt
|
||
```
|
||
|
||
```js
|
||
fg.sync('file.txt', { caseSensitiveMatch: false }); // ['file.txt', 'File.txt']
|
||
fg.sync('file.txt', { caseSensitiveMatch: true }); // ['file.txt']
|
||
```
|
||
|
||
#### dot
|
||
|
||
* Type: `boolean`
|
||
* Default: `false`
|
||
|
||
Allow patterns to match entries that begin with a period (`.`).
|
||
|
||
> :book: Note that an explicit dot in a portion of the pattern will always match dot files.
|
||
|
||
```js
|
||
dir/
|
||
├── .editorconfig
|
||
└── package.json
|
||
```
|
||
|
||
```js
|
||
fg.sync('*', { dot: false }); // ['package.json']
|
||
fg.sync('*', { dot: true }); // ['.editorconfig', 'package.json']
|
||
```
|
||
|
||
#### extglob
|
||
|
||
* Type: `boolean`
|
||
* Default: `true`
|
||
|
||
Enables Bash-like `extglob` functionality.
|
||
|
||
> :1234: [Syntax description][micromatch_extglobs].
|
||
|
||
```js
|
||
dir/
|
||
├── README.md
|
||
└── package.json
|
||
```
|
||
|
||
```js
|
||
fg.sync('*.+(json|md)', { extglob: false }); // []
|
||
fg.sync('*.+(json|md)', { extglob: true }); // ['README.md', 'package.json']
|
||
```
|
||
|
||
#### globstar
|
||
|
||
* Type: `boolean`
|
||
* Default: `true`
|
||
|
||
Enables recursively repeats a pattern containing `**`. If `false`, `**` behaves exactly like `*`.
|
||
|
||
```js
|
||
dir/
|
||
└── a
|
||
└── b
|
||
```
|
||
|
||
```js
|
||
fg.sync('**', { onlyFiles: false, globstar: false }); // ['a']
|
||
fg.sync('**', { onlyFiles: false, globstar: true }); // ['a', 'a/b']
|
||
```
|
||
|
||
#### baseNameMatch
|
||
|
||
* Type: `boolean`
|
||
* Default: `false`
|
||
|
||
If set to `true`, then patterns without slashes will be matched against the basename of the path if it contains slashes.
|
||
|
||
```js
|
||
dir/
|
||
└── one/
|
||
└── file.md
|
||
```
|
||
|
||
```js
|
||
fg.sync('*.md', { baseNameMatch: false }); // []
|
||
fg.sync('*.md', { baseNameMatch: true }); // ['one/file.md']
|
||
```
|
||
|
||
## FAQ
|
||
|
||
## What is a static or dynamic pattern?
|
||
|
||
All patterns can be divided into two types:
|
||
|
||
* **static**. A pattern is considered static if it can be used to get an entry on the file system without using matching mechanisms. For example, the `file.js` pattern is a static pattern because we can just verify that it exists on the file system.
|
||
* **dynamic**. A pattern is considered dynamic if it cannot be used directly to find occurrences without using a matching mechanisms. For example, the `*` pattern is a dynamic pattern because we cannot use this pattern directly.
|
||
|
||
A pattern is considered dynamic if it contains the following characters (`…` — any characters or their absence) or options:
|
||
|
||
* The [`caseSensitiveMatch`](#casesensitivematch) option is disabled
|
||
* `\\` (the escape character)
|
||
* `*`, `?`, `!` (at the beginning of line)
|
||
* `[…]`
|
||
* `(…|…)`
|
||
* `@(…)`, `!(…)`, `*(…)`, `?(…)`, `+(…)` (respects the [`extglob`](#extglob) option)
|
||
* `{…,…}`, `{…..…}` (respects the [`braceExpansion`](#braceexpansion) option)
|
||
|
||
## How to write patterns on Windows?
|
||
|
||
Always use forward-slashes in glob expressions (patterns and [`ignore`](#ignore) option). Use backslashes for escaping characters. With the [`cwd`](#cwd) option use a convenient format.
|
||
|
||
**Bad**
|
||
|
||
```ts
|
||
[
|
||
'directory\\*',
|
||
path.join(process.cwd(), '**')
|
||
]
|
||
```
|
||
|
||
**Good**
|
||
|
||
```ts
|
||
[
|
||
'directory/*',
|
||
path.join(process.cwd(), '**').replace(/\\/g, '/')
|
||
]
|
||
```
|
||
|
||
> :book: Use the [`normalize-path`][npm_normalize_path] or the [`unixify`][npm_unixify] package to convert Windows-style path to a Unix-style path.
|
||
|
||
Read more about [matching with backslashes][micromatch_backslashes].
|
||
|
||
## Why are parentheses match wrong?
|
||
|
||
```js
|
||
dir/
|
||
└── (special-*file).txt
|
||
```
|
||
|
||
```js
|
||
fg.sync(['(special-*file).txt']) // []
|
||
```
|
||
|
||
Refers to Bash. You need to escape special characters:
|
||
|
||
```js
|
||
fg.sync(['\\(special-*file\\).txt']) // ['(special-*file).txt']
|
||
```
|
||
|
||
Read more about [matching special characters as literals][picomatch_matching_special_characters_as_literals].
|
||
|
||
## How to exclude directory from reading?
|
||
|
||
You can use a negative pattern like this: `!**/node_modules` or `!**/node_modules/**`. Also you can use [`ignore`](#ignore) option. Just look at the example below.
|
||
|
||
```js
|
||
first/
|
||
├── file.md
|
||
└── second/
|
||
└── file.txt
|
||
```
|
||
|
||
If you don't want to read the `second` directory, you must write the following pattern: `!**/second` or `!**/second/**`.
|
||
|
||
```js
|
||
fg.sync(['**/*.md', '!**/second']); // ['first/file.md']
|
||
fg.sync(['**/*.md'], { ignore: ['**/second/**'] }); // ['first/file.md']
|
||
```
|
||
|
||
> :warning: When you write `!**/second/**/*` it means that the directory will be **read**, but all the entries will not be included in the results.
|
||
|
||
You have to understand that if you write the pattern to exclude directories, then the directory will not be read under any circumstances.
|
||
|
||
## How to use UNC path?
|
||
|
||
You cannot use [Uniform Naming Convention (UNC)][unc_path] paths as patterns (due to syntax), but you can use them as [`cwd`](#cwd) directory.
|
||
|
||
```ts
|
||
fg.sync('*', { cwd: '\\\\?\\C:\\Python27' /* or //?/C:/Python27 */ });
|
||
fg.sync('Python27/*', { cwd: '\\\\?\\C:\\' /* or //?/C:/ */ });
|
||
```
|
||
|
||
## Compatible with `node-glob`?
|
||
|
||
| node-glob | fast-glob |
|
||
| :----------: | :-------: |
|
||
| `cwd` | [`cwd`](#cwd) |
|
||
| `root` | – |
|
||
| `dot` | [`dot`](#dot) |
|
||
| `nomount` | – |
|
||
| `mark` | [`markDirectories`](#markdirectories) |
|
||
| `nosort` | – |
|
||
| `nounique` | [`unique`](#unique) |
|
||
| `nobrace` | [`braceExpansion`](#braceexpansion) |
|
||
| `noglobstar` | [`globstar`](#globstar) |
|
||
| `noext` | [`extglob`](#extglob) |
|
||
| `nocase` | [`caseSensitiveMatch`](#casesensitivematch) |
|
||
| `matchBase` | [`baseNameMatch`](#basenamematch) |
|
||
| `nodir` | [`onlyFiles`](#onlyfiles) |
|
||
| `ignore` | [`ignore`](#ignore) |
|
||
| `follow` | [`followSymbolicLinks`](#followsymboliclinks) |
|
||
| `realpath` | – |
|
||
| `absolute` | [`absolute`](#absolute) |
|
||
|
||
## Benchmarks
|
||
|
||
### Server
|
||
|
||
Link: [Vultr Bare Metal][vultr_pricing_baremetal]
|
||
|
||
* Processor: E3-1270v6 (8 CPU)
|
||
* RAM: 32GB
|
||
* Disk: SSD ([Intel DC S3520 SSDSC2BB240G7][intel_ssd])
|
||
|
||
You can see results [here][github_gist_benchmark_server] for latest release.
|
||
|
||
### Nettop
|
||
|
||
Link: [Zotac bi323][zotac_bi323]
|
||
|
||
* Processor: Intel N3150 (4 CPU)
|
||
* RAM: 8GB
|
||
* Disk: SSD ([Silicon Power SP060GBSS3S55S25][silicon_power_ssd])
|
||
|
||
You can see results [here][github_gist_benchmark_nettop] for latest release.
|
||
|
||
## Changelog
|
||
|
||
See the [Releases section of our GitHub project][github_releases] for changelog for each release version.
|
||
|
||
## License
|
||
|
||
This software is released under the terms of the MIT license.
|
||
|
||
[bash_hackers_syntax_expansion_brace]: https://wiki.bash-hackers.org/syntax/expansion/brace
|
||
[github_gist_benchmark_nettop]: https://gist.github.com/mrmlnc/f06246b197f53c356895fa35355a367c#file-fg-benchmark-nettop-product-txt
|
||
[github_gist_benchmark_server]: https://gist.github.com/mrmlnc/f06246b197f53c356895fa35355a367c#file-fg-benchmark-server-product-txt
|
||
[github_releases]: https://github.com/mrmlnc/fast-glob/releases
|
||
[glob_definition]: https://en.wikipedia.org/wiki/Glob_(programming)
|
||
[glob_linux_man]: http://man7.org/linux/man-pages/man3/glob.3.html
|
||
[intel_ssd]: https://ark.intel.com/content/www/us/en/ark/products/93012/intel-ssd-dc-s3520-series-240gb-2-5in-sata-6gb-s-3d1-mlc.html
|
||
[micromatch_backslashes]: https://github.com/micromatch/micromatch#backslashes
|
||
[micromatch_braces]: https://github.com/micromatch/braces
|
||
[micromatch_extended_globbing]: https://github.com/micromatch/micromatch#extended-globbing
|
||
[micromatch_extglobs]: https://github.com/micromatch/micromatch#extglobs
|
||
[micromatch_regex_character_classes]: https://github.com/micromatch/micromatch#regex-character-classes
|
||
[micromatch]: https://github.com/micromatch/micromatch
|
||
[node_js_fs_class_fs_dirent]: https://nodejs.org/api/fs.html#fs_class_fs_dirent
|
||
[node_js_fs_class_fs_stats]: https://nodejs.org/api/fs.html#fs_class_fs_stats
|
||
[node_js_stream_readable_streams]: https://nodejs.org/api/stream.html#stream_readable_streams
|
||
[node_js]: https://nodejs.org/en
|
||
[nodelib_fs_scandir_old_and_modern_modern]: https://github.com/nodelib/nodelib/blob/master/packages/fs/fs.scandir/README.md#old-and-modern-mode
|
||
[npm_normalize_path]: https://www.npmjs.com/package/normalize-path
|
||
[npm_unixify]: https://www.npmjs.com/package/unixify
|
||
[paypal_mrmlnc]:https://paypal.me/mrmlnc
|
||
[picomatch_matching_behavior]: https://github.com/micromatch/picomatch#matching-behavior-vs-bash
|
||
[picomatch_matching_special_characters_as_literals]: https://github.com/micromatch/picomatch#matching-special-characters-as-literals
|
||
[picomatch_posix_brackets]: https://github.com/micromatch/picomatch#posix-brackets
|
||
[regular_expressions_brackets]: https://www.regular-expressions.info/brackets.html
|
||
[silicon_power_ssd]: https://www.silicon-power.com/web/product-1
|
||
[unc_path]: https://docs.microsoft.com/en-us/openspecs/windows_protocols/ms-dtyp/62e862f4-2a51-452e-8eeb-dc4ff5ee33cc
|
||
[vultr_pricing_baremetal]: https://www.vultr.com/pricing/baremetal
|
||
[wikipedia_case_sensitivity]: https://en.wikipedia.org/wiki/Case_sensitivity
|
||
[zotac_bi323]: https://www.zotac.com/ee/product/mini_pcs/zbox-bi323
|