postdoc 0.1.2 → 0.2.0.beta4
Sign up to get free protection for your applications and to get access to all the features.
- checksums.yaml +5 -5
- data/lib/pdf.js +27 -0
- data/lib/postdoc.rb +3 -7
- data/node_modules/agent-base/History.md +113 -0
- data/node_modules/agent-base/README.md +145 -0
- data/node_modules/agent-base/index.js +160 -0
- data/node_modules/agent-base/package.json +35 -0
- data/node_modules/agent-base/patch-core.js +37 -0
- data/node_modules/agent-base/test/ssl-cert-snakeoil.key +15 -0
- data/node_modules/agent-base/test/ssl-cert-snakeoil.pem +12 -0
- data/node_modules/agent-base/test/test.js +673 -0
- data/node_modules/async-limiter/LICENSE +8 -0
- data/node_modules/async-limiter/coverage/coverage.json +1 -0
- data/node_modules/async-limiter/coverage/lcov-report/async-throttle/index.html +73 -0
- data/node_modules/async-limiter/coverage/lcov-report/async-throttle/index.js.html +246 -0
- data/node_modules/async-limiter/coverage/lcov-report/base.css +182 -0
- data/node_modules/async-limiter/coverage/lcov-report/index.html +73 -0
- data/node_modules/async-limiter/coverage/lcov-report/prettify.css +1 -0
- data/node_modules/async-limiter/coverage/lcov-report/prettify.js +1 -0
- data/node_modules/async-limiter/coverage/lcov-report/sort-arrow-sprite.png +0 -0
- data/node_modules/async-limiter/coverage/lcov-report/sorter.js +156 -0
- data/node_modules/async-limiter/coverage/lcov.info +74 -0
- data/node_modules/async-limiter/index.js +67 -0
- data/node_modules/async-limiter/package.json +35 -0
- data/node_modules/async-limiter/readme.md +132 -0
- data/node_modules/balanced-match/LICENSE.md +21 -0
- data/node_modules/balanced-match/README.md +91 -0
- data/node_modules/balanced-match/index.js +59 -0
- data/node_modules/balanced-match/package.json +49 -0
- data/node_modules/brace-expansion/LICENSE +21 -0
- data/node_modules/brace-expansion/README.md +129 -0
- data/node_modules/brace-expansion/index.js +201 -0
- data/node_modules/brace-expansion/package.json +47 -0
- data/node_modules/buffer-from/index.js +69 -0
- data/node_modules/buffer-from/package.json +16 -0
- data/node_modules/buffer-from/readme.md +69 -0
- data/node_modules/buffer-from/test.js +12 -0
- data/node_modules/concat-map/LICENSE +18 -0
- data/node_modules/concat-map/README.markdown +62 -0
- data/node_modules/concat-map/example/map.js +6 -0
- data/node_modules/concat-map/index.js +13 -0
- data/node_modules/concat-map/package.json +43 -0
- data/node_modules/concat-map/test/map.js +39 -0
- data/node_modules/concat-stream/LICENSE +24 -0
- data/node_modules/concat-stream/index.js +144 -0
- data/node_modules/concat-stream/package.json +55 -0
- data/node_modules/concat-stream/readme.md +102 -0
- data/node_modules/core-util-is/LICENSE +19 -0
- data/node_modules/core-util-is/README.md +3 -0
- data/node_modules/core-util-is/float.patch +604 -0
- data/node_modules/core-util-is/lib/util.js +107 -0
- data/node_modules/core-util-is/package.json +32 -0
- data/node_modules/core-util-is/test.js +68 -0
- data/node_modules/debug/CHANGELOG.md +395 -0
- data/node_modules/debug/LICENSE +19 -0
- data/node_modules/debug/Makefile +58 -0
- data/node_modules/debug/README.md +368 -0
- data/node_modules/debug/karma.conf.js +70 -0
- data/node_modules/debug/node.js +1 -0
- data/node_modules/debug/package.json +43 -0
- data/node_modules/debug/src/browser.js +195 -0
- data/node_modules/debug/src/debug.js +225 -0
- data/node_modules/debug/src/index.js +10 -0
- data/node_modules/debug/src/node.js +186 -0
- data/node_modules/es6-promise/CHANGELOG.md +151 -0
- data/node_modules/es6-promise/LICENSE +19 -0
- data/node_modules/es6-promise/README.md +97 -0
- data/node_modules/es6-promise/auto.js +4 -0
- data/node_modules/es6-promise/dist/es6-promise.auto.js +1181 -0
- data/node_modules/es6-promise/dist/es6-promise.auto.map +1 -0
- data/node_modules/es6-promise/dist/es6-promise.auto.min.js +1 -0
- data/node_modules/es6-promise/dist/es6-promise.auto.min.map +1 -0
- data/node_modules/es6-promise/dist/es6-promise.js +1179 -0
- data/node_modules/es6-promise/dist/es6-promise.map +1 -0
- data/node_modules/es6-promise/dist/es6-promise.min.js +1 -0
- data/node_modules/es6-promise/dist/es6-promise.min.map +1 -0
- data/node_modules/es6-promise/es6-promise.d.ts +81 -0
- data/node_modules/es6-promise/lib/es6-promise/-internal.js +266 -0
- data/node_modules/es6-promise/lib/es6-promise/asap.js +119 -0
- data/node_modules/es6-promise/lib/es6-promise/enumerator.js +113 -0
- data/node_modules/es6-promise/lib/es6-promise/polyfill.js +35 -0
- data/node_modules/es6-promise/lib/es6-promise/promise/all.js +52 -0
- data/node_modules/es6-promise/lib/es6-promise/promise/race.js +84 -0
- data/node_modules/es6-promise/lib/es6-promise/promise/reject.js +46 -0
- data/node_modules/es6-promise/lib/es6-promise/promise/resolve.js +48 -0
- data/node_modules/es6-promise/lib/es6-promise/promise.js +427 -0
- data/node_modules/es6-promise/lib/es6-promise/then.js +32 -0
- data/node_modules/es6-promise/lib/es6-promise/utils.js +21 -0
- data/node_modules/es6-promise/lib/es6-promise.auto.js +3 -0
- data/node_modules/es6-promise/lib/es6-promise.js +7 -0
- data/node_modules/es6-promise/package.json +75 -0
- data/node_modules/es6-promisify/README.md +89 -0
- data/node_modules/es6-promisify/dist/promise.js +73 -0
- data/node_modules/es6-promisify/dist/promisify.js +85 -0
- data/node_modules/es6-promisify/package.json +41 -0
- data/node_modules/extract-zip/CONTRIBUTING.md +1 -0
- data/node_modules/extract-zip/LICENSE +23 -0
- data/node_modules/extract-zip/cli.js +20 -0
- data/node_modules/extract-zip/index.js +205 -0
- data/node_modules/extract-zip/node_modules/debug/CHANGELOG.md +362 -0
- data/node_modules/extract-zip/node_modules/debug/LICENSE +19 -0
- data/node_modules/extract-zip/node_modules/debug/Makefile +50 -0
- data/node_modules/extract-zip/node_modules/debug/README.md +312 -0
- data/node_modules/extract-zip/node_modules/debug/component.json +19 -0
- data/node_modules/extract-zip/node_modules/debug/karma.conf.js +70 -0
- data/node_modules/extract-zip/node_modules/debug/node.js +1 -0
- data/node_modules/extract-zip/node_modules/debug/package.json +49 -0
- data/node_modules/extract-zip/node_modules/debug/src/browser.js +185 -0
- data/node_modules/extract-zip/node_modules/debug/src/debug.js +202 -0
- data/node_modules/extract-zip/node_modules/debug/src/index.js +10 -0
- data/node_modules/extract-zip/node_modules/debug/src/inspector-log.js +15 -0
- data/node_modules/extract-zip/node_modules/debug/src/node.js +248 -0
- data/node_modules/extract-zip/package.json +35 -0
- data/node_modules/extract-zip/readme.md +49 -0
- data/node_modules/fd-slicer/CHANGELOG.md +49 -0
- data/node_modules/fd-slicer/LICENSE +21 -0
- data/node_modules/fd-slicer/README.md +189 -0
- data/node_modules/fd-slicer/index.js +277 -0
- data/node_modules/fd-slicer/package.json +36 -0
- data/node_modules/fd-slicer/test/test.js +350 -0
- data/node_modules/fs.realpath/LICENSE +43 -0
- data/node_modules/fs.realpath/README.md +33 -0
- data/node_modules/fs.realpath/index.js +66 -0
- data/node_modules/fs.realpath/old.js +303 -0
- data/node_modules/fs.realpath/package.json +26 -0
- data/node_modules/glob/LICENSE +15 -0
- data/node_modules/glob/README.md +368 -0
- data/node_modules/glob/changelog.md +67 -0
- data/node_modules/glob/common.js +240 -0
- data/node_modules/glob/glob.js +790 -0
- data/node_modules/glob/package.json +43 -0
- data/node_modules/glob/sync.js +486 -0
- data/node_modules/https-proxy-agent/History.md +124 -0
- data/node_modules/https-proxy-agent/README.md +137 -0
- data/node_modules/https-proxy-agent/index.js +229 -0
- data/node_modules/https-proxy-agent/package.json +35 -0
- data/node_modules/https-proxy-agent/test/ssl-cert-snakeoil.key +15 -0
- data/node_modules/https-proxy-agent/test/ssl-cert-snakeoil.pem +12 -0
- data/node_modules/https-proxy-agent/test/test.js +342 -0
- data/node_modules/inflight/LICENSE +15 -0
- data/node_modules/inflight/README.md +37 -0
- data/node_modules/inflight/inflight.js +54 -0
- data/node_modules/inflight/package.json +29 -0
- data/node_modules/inherits/LICENSE +16 -0
- data/node_modules/inherits/README.md +42 -0
- data/node_modules/inherits/inherits.js +7 -0
- data/node_modules/inherits/inherits_browser.js +23 -0
- data/node_modules/inherits/package.json +29 -0
- data/node_modules/isarray/Makefile +6 -0
- data/node_modules/isarray/README.md +60 -0
- data/node_modules/isarray/component.json +19 -0
- data/node_modules/isarray/index.js +5 -0
- data/node_modules/isarray/package.json +45 -0
- data/node_modules/isarray/test.js +20 -0
- data/node_modules/mime/CHANGELOG.md +225 -0
- data/node_modules/mime/CONTRIBUTING.md +5 -0
- data/node_modules/mime/LICENSE +21 -0
- data/node_modules/mime/Mime.js +89 -0
- data/node_modules/mime/README.md +188 -0
- data/node_modules/mime/cli.js +10 -0
- data/node_modules/mime/index.js +4 -0
- data/node_modules/mime/lite.js +4 -0
- data/node_modules/mime/package.json +43 -0
- data/node_modules/mime/src/README_js.md +179 -0
- data/node_modules/mime/src/build.js +71 -0
- data/node_modules/mime/src/test.js +257 -0
- data/node_modules/mime/types/other.json +1 -0
- data/node_modules/mime/types/standard.json +1 -0
- data/node_modules/minimatch/LICENSE +15 -0
- data/node_modules/minimatch/README.md +209 -0
- data/node_modules/minimatch/minimatch.js +923 -0
- data/node_modules/minimatch/package.json +30 -0
- data/node_modules/minimist/LICENSE +18 -0
- data/node_modules/minimist/example/parse.js +2 -0
- data/node_modules/minimist/index.js +187 -0
- data/node_modules/minimist/package.json +40 -0
- data/node_modules/minimist/readme.markdown +73 -0
- data/node_modules/minimist/test/dash.js +24 -0
- data/node_modules/minimist/test/default_bool.js +20 -0
- data/node_modules/minimist/test/dotted.js +16 -0
- data/node_modules/minimist/test/long.js +31 -0
- data/node_modules/minimist/test/parse.js +318 -0
- data/node_modules/minimist/test/parse_modified.js +9 -0
- data/node_modules/minimist/test/short.js +67 -0
- data/node_modules/minimist/test/whitespace.js +8 -0
- data/node_modules/mkdirp/LICENSE +21 -0
- data/node_modules/mkdirp/bin/cmd.js +33 -0
- data/node_modules/mkdirp/bin/usage.txt +12 -0
- data/node_modules/mkdirp/examples/pow.js +6 -0
- data/node_modules/mkdirp/index.js +98 -0
- data/node_modules/mkdirp/package.json +27 -0
- data/node_modules/mkdirp/readme.markdown +100 -0
- data/node_modules/mkdirp/test/chmod.js +41 -0
- data/node_modules/mkdirp/test/clobber.js +38 -0
- data/node_modules/mkdirp/test/mkdirp.js +28 -0
- data/node_modules/mkdirp/test/opts_fs.js +29 -0
- data/node_modules/mkdirp/test/opts_fs_sync.js +27 -0
- data/node_modules/mkdirp/test/perm.js +32 -0
- data/node_modules/mkdirp/test/perm_sync.js +36 -0
- data/node_modules/mkdirp/test/race.js +37 -0
- data/node_modules/mkdirp/test/rel.js +32 -0
- data/node_modules/mkdirp/test/return.js +25 -0
- data/node_modules/mkdirp/test/return_sync.js +24 -0
- data/node_modules/mkdirp/test/root.js +19 -0
- data/node_modules/mkdirp/test/sync.js +32 -0
- data/node_modules/mkdirp/test/umask.js +28 -0
- data/node_modules/mkdirp/test/umask_sync.js +32 -0
- data/node_modules/ms/index.js +152 -0
- data/node_modules/ms/license.md +21 -0
- data/node_modules/ms/package.json +37 -0
- data/node_modules/ms/readme.md +51 -0
- data/node_modules/once/LICENSE +15 -0
- data/node_modules/once/README.md +79 -0
- data/node_modules/once/once.js +42 -0
- data/node_modules/once/package.json +33 -0
- data/node_modules/path-is-absolute/index.js +20 -0
- data/node_modules/path-is-absolute/license +21 -0
- data/node_modules/path-is-absolute/package.json +43 -0
- data/node_modules/path-is-absolute/readme.md +59 -0
- data/node_modules/pend/LICENSE +23 -0
- data/node_modules/pend/README.md +41 -0
- data/node_modules/pend/index.js +55 -0
- data/node_modules/pend/package.json +18 -0
- data/node_modules/pend/test.js +137 -0
- data/node_modules/process-nextick-args/index.js +44 -0
- data/node_modules/process-nextick-args/license.md +19 -0
- data/node_modules/process-nextick-args/package.json +25 -0
- data/node_modules/process-nextick-args/readme.md +18 -0
- data/node_modules/progress/CHANGELOG.md +115 -0
- data/node_modules/progress/LICENSE +22 -0
- data/node_modules/progress/Makefile +8 -0
- data/node_modules/progress/README.md +146 -0
- data/node_modules/progress/index.js +1 -0
- data/node_modules/progress/lib/node-progress.js +231 -0
- data/node_modules/progress/package.json +25 -0
- data/node_modules/proxy-from-env/README.md +131 -0
- data/node_modules/proxy-from-env/index.js +103 -0
- data/node_modules/proxy-from-env/package.json +35 -0
- data/node_modules/proxy-from-env/test.js +393 -0
- data/node_modules/puppeteer/CONTRIBUTING.md +206 -0
- data/node_modules/puppeteer/DeviceDescriptors.js +704 -0
- data/node_modules/puppeteer/LICENSE +202 -0
- data/node_modules/puppeteer/README.md +306 -0
- data/node_modules/puppeteer/index.js +28 -0
- data/node_modules/puppeteer/install.js +122 -0
- data/node_modules/puppeteer/lib/Browser.js +186 -0
- data/node_modules/puppeteer/lib/BrowserFetcher.js +279 -0
- data/node_modules/puppeteer/lib/Connection.js +246 -0
- data/node_modules/puppeteer/lib/Coverage.js +301 -0
- data/node_modules/puppeteer/lib/Dialog.js +84 -0
- data/node_modules/puppeteer/lib/ElementHandle.js +328 -0
- data/node_modules/puppeteer/lib/EmulationManager.js +89 -0
- data/node_modules/puppeteer/lib/ExecutionContext.js +232 -0
- data/node_modules/puppeteer/lib/FrameManager.js +997 -0
- data/node_modules/puppeteer/lib/Input.js +309 -0
- data/node_modules/puppeteer/lib/Launcher.js +310 -0
- data/node_modules/puppeteer/lib/Multimap.js +95 -0
- data/node_modules/puppeteer/lib/NavigatorWatcher.js +137 -0
- data/node_modules/puppeteer/lib/NetworkManager.js +796 -0
- data/node_modules/puppeteer/lib/Page.js +1098 -0
- data/node_modules/puppeteer/lib/Pipe.js +69 -0
- data/node_modules/puppeteer/lib/Puppeteer.js +60 -0
- data/node_modules/puppeteer/lib/Target.js +88 -0
- data/node_modules/puppeteer/lib/TaskQueue.js +17 -0
- data/node_modules/puppeteer/lib/Tracing.js +99 -0
- data/node_modules/puppeteer/lib/USKeyboardLayout.js +281 -0
- data/node_modules/puppeteer/lib/helper.js +248 -0
- data/node_modules/puppeteer/node6/lib/Browser.js +394 -0
- data/node_modules/puppeteer/node6/lib/BrowserFetcher.js +357 -0
- data/node_modules/puppeteer/node6/lib/Connection.js +350 -0
- data/node_modules/puppeteer/node6/lib/Coverage.js +561 -0
- data/node_modules/puppeteer/node6/lib/Dialog.js +136 -0
- data/node_modules/puppeteer/node6/lib/ElementHandle.js +796 -0
- data/node_modules/puppeteer/node6/lib/EmulationManager.js +115 -0
- data/node_modules/puppeteer/node6/lib/ExecutionContext.js +414 -0
- data/node_modules/puppeteer/node6/lib/FrameManager.js +1621 -0
- data/node_modules/puppeteer/node6/lib/Input.js +569 -0
- data/node_modules/puppeteer/node6/lib/Launcher.js +362 -0
- data/node_modules/puppeteer/node6/lib/Multimap.js +95 -0
- data/node_modules/puppeteer/node6/lib/NavigatorWatcher.js +163 -0
- data/node_modules/puppeteer/node6/lib/NetworkManager.js +1108 -0
- data/node_modules/puppeteer/node6/lib/Page.js +2242 -0
- data/node_modules/puppeteer/node6/lib/Pipe.js +69 -0
- data/node_modules/puppeteer/node6/lib/Puppeteer.js +60 -0
- data/node_modules/puppeteer/node6/lib/Target.js +114 -0
- data/node_modules/puppeteer/node6/lib/TaskQueue.js +17 -0
- data/node_modules/puppeteer/node6/lib/Tracing.js +177 -0
- data/node_modules/puppeteer/node6/lib/USKeyboardLayout.js +281 -0
- data/node_modules/puppeteer/node6/lib/helper.js +274 -0
- data/node_modules/puppeteer/package.json +61 -0
- data/node_modules/readable-stream/CONTRIBUTING.md +38 -0
- data/node_modules/readable-stream/GOVERNANCE.md +136 -0
- data/node_modules/readable-stream/LICENSE +47 -0
- data/node_modules/readable-stream/README.md +58 -0
- data/node_modules/readable-stream/doc/wg-meetings/2015-01-30.md +60 -0
- data/node_modules/readable-stream/duplex-browser.js +1 -0
- data/node_modules/readable-stream/duplex.js +1 -0
- data/node_modules/readable-stream/lib/_stream_duplex.js +131 -0
- data/node_modules/readable-stream/lib/_stream_passthrough.js +47 -0
- data/node_modules/readable-stream/lib/_stream_readable.js +1019 -0
- data/node_modules/readable-stream/lib/_stream_transform.js +214 -0
- data/node_modules/readable-stream/lib/_stream_writable.js +687 -0
- data/node_modules/readable-stream/lib/internal/streams/BufferList.js +79 -0
- data/node_modules/readable-stream/lib/internal/streams/destroy.js +74 -0
- data/node_modules/readable-stream/lib/internal/streams/stream-browser.js +1 -0
- data/node_modules/readable-stream/lib/internal/streams/stream.js +1 -0
- data/node_modules/readable-stream/package.json +52 -0
- data/node_modules/readable-stream/passthrough.js +1 -0
- data/node_modules/readable-stream/readable-browser.js +7 -0
- data/node_modules/readable-stream/readable.js +19 -0
- data/node_modules/readable-stream/transform.js +1 -0
- data/node_modules/readable-stream/writable-browser.js +1 -0
- data/node_modules/readable-stream/writable.js +8 -0
- data/node_modules/rimraf/LICENSE +15 -0
- data/node_modules/rimraf/README.md +101 -0
- data/node_modules/rimraf/bin.js +50 -0
- data/node_modules/rimraf/package.json +26 -0
- data/node_modules/rimraf/rimraf.js +364 -0
- data/node_modules/safe-buffer/LICENSE +21 -0
- data/node_modules/safe-buffer/README.md +584 -0
- data/node_modules/safe-buffer/index.d.ts +187 -0
- data/node_modules/safe-buffer/index.js +62 -0
- data/node_modules/safe-buffer/package.json +37 -0
- data/node_modules/string_decoder/LICENSE +48 -0
- data/node_modules/string_decoder/README.md +47 -0
- data/node_modules/string_decoder/lib/string_decoder.js +296 -0
- data/node_modules/string_decoder/package.json +31 -0
- data/node_modules/typedarray/LICENSE +35 -0
- data/node_modules/typedarray/example/tarray.js +4 -0
- data/node_modules/typedarray/index.js +630 -0
- data/node_modules/typedarray/package.json +55 -0
- data/node_modules/typedarray/readme.markdown +61 -0
- data/node_modules/typedarray/test/server/undef_globals.js +19 -0
- data/node_modules/typedarray/test/tarray.js +10 -0
- data/node_modules/ultron/LICENSE +22 -0
- data/node_modules/ultron/README.md +113 -0
- data/node_modules/ultron/index.js +136 -0
- data/node_modules/ultron/package.json +41 -0
- data/node_modules/util-deprecate/History.md +16 -0
- data/node_modules/util-deprecate/LICENSE +24 -0
- data/node_modules/util-deprecate/README.md +53 -0
- data/node_modules/util-deprecate/browser.js +67 -0
- data/node_modules/util-deprecate/node.js +6 -0
- data/node_modules/util-deprecate/package.json +27 -0
- data/node_modules/wrappy/LICENSE +15 -0
- data/node_modules/wrappy/README.md +36 -0
- data/node_modules/wrappy/package.json +29 -0
- data/node_modules/wrappy/wrappy.js +33 -0
- data/node_modules/ws/LICENSE +21 -0
- data/node_modules/ws/README.md +341 -0
- data/node_modules/ws/index.js +15 -0
- data/node_modules/ws/lib/BufferUtil.js +71 -0
- data/node_modules/ws/lib/Constants.js +10 -0
- data/node_modules/ws/lib/ErrorCodes.js +28 -0
- data/node_modules/ws/lib/EventTarget.js +151 -0
- data/node_modules/ws/lib/Extensions.js +203 -0
- data/node_modules/ws/lib/PerMessageDeflate.js +507 -0
- data/node_modules/ws/lib/Receiver.js +553 -0
- data/node_modules/ws/lib/Sender.js +412 -0
- data/node_modules/ws/lib/Validation.js +17 -0
- data/node_modules/ws/lib/WebSocket.js +717 -0
- data/node_modules/ws/lib/WebSocketServer.js +326 -0
- data/node_modules/ws/package.json +46 -0
- data/node_modules/yauzl/LICENSE +21 -0
- data/node_modules/yauzl/README.md +467 -0
- data/node_modules/yauzl/index.js +626 -0
- data/node_modules/yauzl/package.json +36 -0
- data/package.json +5 -0
- data/yarn.lock +240 -0
- metadata +372 -7
- data/app/assets/stylesheets/default.css +0 -4
- data/lib/postdoc/postdoc_view_helper.rb +0 -22
@@ -0,0 +1,368 @@
|
|
1
|
+
# Glob
|
2
|
+
|
3
|
+
Match files using the patterns the shell uses, like stars and stuff.
|
4
|
+
|
5
|
+
[![Build Status](https://travis-ci.org/isaacs/node-glob.svg?branch=master)](https://travis-ci.org/isaacs/node-glob/) [![Build Status](https://ci.appveyor.com/api/projects/status/kd7f3yftf7unxlsx?svg=true)](https://ci.appveyor.com/project/isaacs/node-glob) [![Coverage Status](https://coveralls.io/repos/isaacs/node-glob/badge.svg?branch=master&service=github)](https://coveralls.io/github/isaacs/node-glob?branch=master)
|
6
|
+
|
7
|
+
This is a glob implementation in JavaScript. It uses the `minimatch`
|
8
|
+
library to do its matching.
|
9
|
+
|
10
|
+
![](oh-my-glob.gif)
|
11
|
+
|
12
|
+
## Usage
|
13
|
+
|
14
|
+
Install with npm
|
15
|
+
|
16
|
+
```
|
17
|
+
npm i glob
|
18
|
+
```
|
19
|
+
|
20
|
+
```javascript
|
21
|
+
var glob = require("glob")
|
22
|
+
|
23
|
+
// options is optional
|
24
|
+
glob("**/*.js", options, function (er, files) {
|
25
|
+
// files is an array of filenames.
|
26
|
+
// If the `nonull` option is set, and nothing
|
27
|
+
// was found, then files is ["**/*.js"]
|
28
|
+
// er is an error object or null.
|
29
|
+
})
|
30
|
+
```
|
31
|
+
|
32
|
+
## Glob Primer
|
33
|
+
|
34
|
+
"Globs" are the patterns you type when you do stuff like `ls *.js` on
|
35
|
+
the command line, or put `build/*` in a `.gitignore` file.
|
36
|
+
|
37
|
+
Before parsing the path part patterns, braced sections are expanded
|
38
|
+
into a set. Braced sections start with `{` and end with `}`, with any
|
39
|
+
number of comma-delimited sections within. Braced sections may contain
|
40
|
+
slash characters, so `a{/b/c,bcd}` would expand into `a/b/c` and `abcd`.
|
41
|
+
|
42
|
+
The following characters have special magic meaning when used in a
|
43
|
+
path portion:
|
44
|
+
|
45
|
+
* `*` Matches 0 or more characters in a single path portion
|
46
|
+
* `?` Matches 1 character
|
47
|
+
* `[...]` Matches a range of characters, similar to a RegExp range.
|
48
|
+
If the first character of the range is `!` or `^` then it matches
|
49
|
+
any character not in the range.
|
50
|
+
* `!(pattern|pattern|pattern)` Matches anything that does not match
|
51
|
+
any of the patterns provided.
|
52
|
+
* `?(pattern|pattern|pattern)` Matches zero or one occurrence of the
|
53
|
+
patterns provided.
|
54
|
+
* `+(pattern|pattern|pattern)` Matches one or more occurrences of the
|
55
|
+
patterns provided.
|
56
|
+
* `*(a|b|c)` Matches zero or more occurrences of the patterns provided
|
57
|
+
* `@(pattern|pat*|pat?erN)` Matches exactly one of the patterns
|
58
|
+
provided
|
59
|
+
* `**` If a "globstar" is alone in a path portion, then it matches
|
60
|
+
zero or more directories and subdirectories searching for matches.
|
61
|
+
It does not crawl symlinked directories.
|
62
|
+
|
63
|
+
### Dots
|
64
|
+
|
65
|
+
If a file or directory path portion has a `.` as the first character,
|
66
|
+
then it will not match any glob pattern unless that pattern's
|
67
|
+
corresponding path part also has a `.` as its first character.
|
68
|
+
|
69
|
+
For example, the pattern `a/.*/c` would match the file at `a/.b/c`.
|
70
|
+
However the pattern `a/*/c` would not, because `*` does not start with
|
71
|
+
a dot character.
|
72
|
+
|
73
|
+
You can make glob treat dots as normal characters by setting
|
74
|
+
`dot:true` in the options.
|
75
|
+
|
76
|
+
### Basename Matching
|
77
|
+
|
78
|
+
If you set `matchBase:true` in the options, and the pattern has no
|
79
|
+
slashes in it, then it will seek for any file anywhere in the tree
|
80
|
+
with a matching basename. For example, `*.js` would match
|
81
|
+
`test/simple/basic.js`.
|
82
|
+
|
83
|
+
### Empty Sets
|
84
|
+
|
85
|
+
If no matching files are found, then an empty array is returned. This
|
86
|
+
differs from the shell, where the pattern itself is returned. For
|
87
|
+
example:
|
88
|
+
|
89
|
+
$ echo a*s*d*f
|
90
|
+
a*s*d*f
|
91
|
+
|
92
|
+
To get the bash-style behavior, set the `nonull:true` in the options.
|
93
|
+
|
94
|
+
### See Also:
|
95
|
+
|
96
|
+
* `man sh`
|
97
|
+
* `man bash` (Search for "Pattern Matching")
|
98
|
+
* `man 3 fnmatch`
|
99
|
+
* `man 5 gitignore`
|
100
|
+
* [minimatch documentation](https://github.com/isaacs/minimatch)
|
101
|
+
|
102
|
+
## glob.hasMagic(pattern, [options])
|
103
|
+
|
104
|
+
Returns `true` if there are any special characters in the pattern, and
|
105
|
+
`false` otherwise.
|
106
|
+
|
107
|
+
Note that the options affect the results. If `noext:true` is set in
|
108
|
+
the options object, then `+(a|b)` will not be considered a magic
|
109
|
+
pattern. If the pattern has a brace expansion, like `a/{b/c,x/y}`
|
110
|
+
then that is considered magical, unless `nobrace:true` is set in the
|
111
|
+
options.
|
112
|
+
|
113
|
+
## glob(pattern, [options], cb)
|
114
|
+
|
115
|
+
* `pattern` `{String}` Pattern to be matched
|
116
|
+
* `options` `{Object}`
|
117
|
+
* `cb` `{Function}`
|
118
|
+
* `err` `{Error | null}`
|
119
|
+
* `matches` `{Array<String>}` filenames found matching the pattern
|
120
|
+
|
121
|
+
Perform an asynchronous glob search.
|
122
|
+
|
123
|
+
## glob.sync(pattern, [options])
|
124
|
+
|
125
|
+
* `pattern` `{String}` Pattern to be matched
|
126
|
+
* `options` `{Object}`
|
127
|
+
* return: `{Array<String>}` filenames found matching the pattern
|
128
|
+
|
129
|
+
Perform a synchronous glob search.
|
130
|
+
|
131
|
+
## Class: glob.Glob
|
132
|
+
|
133
|
+
Create a Glob object by instantiating the `glob.Glob` class.
|
134
|
+
|
135
|
+
```javascript
|
136
|
+
var Glob = require("glob").Glob
|
137
|
+
var mg = new Glob(pattern, options, cb)
|
138
|
+
```
|
139
|
+
|
140
|
+
It's an EventEmitter, and starts walking the filesystem to find matches
|
141
|
+
immediately.
|
142
|
+
|
143
|
+
### new glob.Glob(pattern, [options], [cb])
|
144
|
+
|
145
|
+
* `pattern` `{String}` pattern to search for
|
146
|
+
* `options` `{Object}`
|
147
|
+
* `cb` `{Function}` Called when an error occurs, or matches are found
|
148
|
+
* `err` `{Error | null}`
|
149
|
+
* `matches` `{Array<String>}` filenames found matching the pattern
|
150
|
+
|
151
|
+
Note that if the `sync` flag is set in the options, then matches will
|
152
|
+
be immediately available on the `g.found` member.
|
153
|
+
|
154
|
+
### Properties
|
155
|
+
|
156
|
+
* `minimatch` The minimatch object that the glob uses.
|
157
|
+
* `options` The options object passed in.
|
158
|
+
* `aborted` Boolean which is set to true when calling `abort()`. There
|
159
|
+
is no way at this time to continue a glob search after aborting, but
|
160
|
+
you can re-use the statCache to avoid having to duplicate syscalls.
|
161
|
+
* `cache` Convenience object. Each field has the following possible
|
162
|
+
values:
|
163
|
+
* `false` - Path does not exist
|
164
|
+
* `true` - Path exists
|
165
|
+
* `'FILE'` - Path exists, and is not a directory
|
166
|
+
* `'DIR'` - Path exists, and is a directory
|
167
|
+
* `[file, entries, ...]` - Path exists, is a directory, and the
|
168
|
+
array value is the results of `fs.readdir`
|
169
|
+
* `statCache` Cache of `fs.stat` results, to prevent statting the same
|
170
|
+
path multiple times.
|
171
|
+
* `symlinks` A record of which paths are symbolic links, which is
|
172
|
+
relevant in resolving `**` patterns.
|
173
|
+
* `realpathCache` An optional object which is passed to `fs.realpath`
|
174
|
+
to minimize unnecessary syscalls. It is stored on the instantiated
|
175
|
+
Glob object, and may be re-used.
|
176
|
+
|
177
|
+
### Events
|
178
|
+
|
179
|
+
* `end` When the matching is finished, this is emitted with all the
|
180
|
+
matches found. If the `nonull` option is set, and no match was found,
|
181
|
+
then the `matches` list contains the original pattern. The matches
|
182
|
+
are sorted, unless the `nosort` flag is set.
|
183
|
+
* `match` Every time a match is found, this is emitted with the specific
|
184
|
+
thing that matched. It is not deduplicated or resolved to a realpath.
|
185
|
+
* `error` Emitted when an unexpected error is encountered, or whenever
|
186
|
+
any fs error occurs if `options.strict` is set.
|
187
|
+
* `abort` When `abort()` is called, this event is raised.
|
188
|
+
|
189
|
+
### Methods
|
190
|
+
|
191
|
+
* `pause` Temporarily stop the search
|
192
|
+
* `resume` Resume the search
|
193
|
+
* `abort` Stop the search forever
|
194
|
+
|
195
|
+
### Options
|
196
|
+
|
197
|
+
All the options that can be passed to Minimatch can also be passed to
|
198
|
+
Glob to change pattern matching behavior. Also, some have been added,
|
199
|
+
or have glob-specific ramifications.
|
200
|
+
|
201
|
+
All options are false by default, unless otherwise noted.
|
202
|
+
|
203
|
+
All options are added to the Glob object, as well.
|
204
|
+
|
205
|
+
If you are running many `glob` operations, you can pass a Glob object
|
206
|
+
as the `options` argument to a subsequent operation to shortcut some
|
207
|
+
`stat` and `readdir` calls. At the very least, you may pass in shared
|
208
|
+
`symlinks`, `statCache`, `realpathCache`, and `cache` options, so that
|
209
|
+
parallel glob operations will be sped up by sharing information about
|
210
|
+
the filesystem.
|
211
|
+
|
212
|
+
* `cwd` The current working directory in which to search. Defaults
|
213
|
+
to `process.cwd()`.
|
214
|
+
* `root` The place where patterns starting with `/` will be mounted
|
215
|
+
onto. Defaults to `path.resolve(options.cwd, "/")` (`/` on Unix
|
216
|
+
systems, and `C:\` or some such on Windows.)
|
217
|
+
* `dot` Include `.dot` files in normal matches and `globstar` matches.
|
218
|
+
Note that an explicit dot in a portion of the pattern will always
|
219
|
+
match dot files.
|
220
|
+
* `nomount` By default, a pattern starting with a forward-slash will be
|
221
|
+
"mounted" onto the root setting, so that a valid filesystem path is
|
222
|
+
returned. Set this flag to disable that behavior.
|
223
|
+
* `mark` Add a `/` character to directory matches. Note that this
|
224
|
+
requires additional stat calls.
|
225
|
+
* `nosort` Don't sort the results.
|
226
|
+
* `stat` Set to true to stat *all* results. This reduces performance
|
227
|
+
somewhat, and is completely unnecessary, unless `readdir` is presumed
|
228
|
+
to be an untrustworthy indicator of file existence.
|
229
|
+
* `silent` When an unusual error is encountered when attempting to
|
230
|
+
read a directory, a warning will be printed to stderr. Set the
|
231
|
+
`silent` option to true to suppress these warnings.
|
232
|
+
* `strict` When an unusual error is encountered when attempting to
|
233
|
+
read a directory, the process will just continue on in search of
|
234
|
+
other matches. Set the `strict` option to raise an error in these
|
235
|
+
cases.
|
236
|
+
* `cache` See `cache` property above. Pass in a previously generated
|
237
|
+
cache object to save some fs calls.
|
238
|
+
* `statCache` A cache of results of filesystem information, to prevent
|
239
|
+
unnecessary stat calls. While it should not normally be necessary
|
240
|
+
to set this, you may pass the statCache from one glob() call to the
|
241
|
+
options object of another, if you know that the filesystem will not
|
242
|
+
change between calls. (See "Race Conditions" below.)
|
243
|
+
* `symlinks` A cache of known symbolic links. You may pass in a
|
244
|
+
previously generated `symlinks` object to save `lstat` calls when
|
245
|
+
resolving `**` matches.
|
246
|
+
* `sync` DEPRECATED: use `glob.sync(pattern, opts)` instead.
|
247
|
+
* `nounique` In some cases, brace-expanded patterns can result in the
|
248
|
+
same file showing up multiple times in the result set. By default,
|
249
|
+
this implementation prevents duplicates in the result set. Set this
|
250
|
+
flag to disable that behavior.
|
251
|
+
* `nonull` Set to never return an empty set, instead returning a set
|
252
|
+
containing the pattern itself. This is the default in glob(3).
|
253
|
+
* `debug` Set to enable debug logging in minimatch and glob.
|
254
|
+
* `nobrace` Do not expand `{a,b}` and `{1..3}` brace sets.
|
255
|
+
* `noglobstar` Do not match `**` against multiple filenames. (Ie,
|
256
|
+
treat it as a normal `*` instead.)
|
257
|
+
* `noext` Do not match `+(a|b)` "extglob" patterns.
|
258
|
+
* `nocase` Perform a case-insensitive match. Note: on
|
259
|
+
case-insensitive filesystems, non-magic patterns will match by
|
260
|
+
default, since `stat` and `readdir` will not raise errors.
|
261
|
+
* `matchBase` Perform a basename-only match if the pattern does not
|
262
|
+
contain any slash characters. That is, `*.js` would be treated as
|
263
|
+
equivalent to `**/*.js`, matching all js files in all directories.
|
264
|
+
* `nodir` Do not match directories, only files. (Note: to match
|
265
|
+
*only* directories, simply put a `/` at the end of the pattern.)
|
266
|
+
* `ignore` Add a pattern or an array of glob patterns to exclude matches.
|
267
|
+
Note: `ignore` patterns are *always* in `dot:true` mode, regardless
|
268
|
+
of any other settings.
|
269
|
+
* `follow` Follow symlinked directories when expanding `**` patterns.
|
270
|
+
Note that this can result in a lot of duplicate references in the
|
271
|
+
presence of cyclic links.
|
272
|
+
* `realpath` Set to true to call `fs.realpath` on all of the results.
|
273
|
+
In the case of a symlink that cannot be resolved, the full absolute
|
274
|
+
path to the matched entry is returned (though it will usually be a
|
275
|
+
broken symlink)
|
276
|
+
* `absolute` Set to true to always receive absolute paths for matched
|
277
|
+
files. Unlike `realpath`, this also affects the values returned in
|
278
|
+
the `match` event.
|
279
|
+
|
280
|
+
## Comparisons to other fnmatch/glob implementations
|
281
|
+
|
282
|
+
While strict compliance with the existing standards is a worthwhile
|
283
|
+
goal, some discrepancies exist between node-glob and other
|
284
|
+
implementations, and are intentional.
|
285
|
+
|
286
|
+
The double-star character `**` is supported by default, unless the
|
287
|
+
`noglobstar` flag is set. This is supported in the manner of bsdglob
|
288
|
+
and bash 4.3, where `**` only has special significance if it is the only
|
289
|
+
thing in a path part. That is, `a/**/b` will match `a/x/y/b`, but
|
290
|
+
`a/**b` will not.
|
291
|
+
|
292
|
+
Note that symlinked directories are not crawled as part of a `**`,
|
293
|
+
though their contents may match against subsequent portions of the
|
294
|
+
pattern. This prevents infinite loops and duplicates and the like.
|
295
|
+
|
296
|
+
If an escaped pattern has no matches, and the `nonull` flag is set,
|
297
|
+
then glob returns the pattern as-provided, rather than
|
298
|
+
interpreting the character escapes. For example,
|
299
|
+
`glob.match([], "\\*a\\?")` will return `"\\*a\\?"` rather than
|
300
|
+
`"*a?"`. This is akin to setting the `nullglob` option in bash, except
|
301
|
+
that it does not resolve escaped pattern characters.
|
302
|
+
|
303
|
+
If brace expansion is not disabled, then it is performed before any
|
304
|
+
other interpretation of the glob pattern. Thus, a pattern like
|
305
|
+
`+(a|{b),c)}`, which would not be valid in bash or zsh, is expanded
|
306
|
+
**first** into the set of `+(a|b)` and `+(a|c)`, and those patterns are
|
307
|
+
checked for validity. Since those two are valid, matching proceeds.
|
308
|
+
|
309
|
+
### Comments and Negation
|
310
|
+
|
311
|
+
Previously, this module let you mark a pattern as a "comment" if it
|
312
|
+
started with a `#` character, or a "negated" pattern if it started
|
313
|
+
with a `!` character.
|
314
|
+
|
315
|
+
These options were deprecated in version 5, and removed in version 6.
|
316
|
+
|
317
|
+
To specify things that should not match, use the `ignore` option.
|
318
|
+
|
319
|
+
## Windows
|
320
|
+
|
321
|
+
**Please only use forward-slashes in glob expressions.**
|
322
|
+
|
323
|
+
Though windows uses either `/` or `\` as its path separator, only `/`
|
324
|
+
characters are used by this glob implementation. You must use
|
325
|
+
forward-slashes **only** in glob expressions. Back-slashes will always
|
326
|
+
be interpreted as escape characters, not path separators.
|
327
|
+
|
328
|
+
Results from absolute patterns such as `/foo/*` are mounted onto the
|
329
|
+
root setting using `path.join`. On windows, this will by default result
|
330
|
+
in `/foo/*` matching `C:\foo\bar.txt`.
|
331
|
+
|
332
|
+
## Race Conditions
|
333
|
+
|
334
|
+
Glob searching, by its very nature, is susceptible to race conditions,
|
335
|
+
since it relies on directory walking and such.
|
336
|
+
|
337
|
+
As a result, it is possible that a file that exists when glob looks for
|
338
|
+
it may have been deleted or modified by the time it returns the result.
|
339
|
+
|
340
|
+
As part of its internal implementation, this program caches all stat
|
341
|
+
and readdir calls that it makes, in order to cut down on system
|
342
|
+
overhead. However, this also makes it even more susceptible to races,
|
343
|
+
especially if the cache or statCache objects are reused between glob
|
344
|
+
calls.
|
345
|
+
|
346
|
+
Users are thus advised not to use a glob result as a guarantee of
|
347
|
+
filesystem state in the face of rapid changes. For the vast majority
|
348
|
+
of operations, this is never a problem.
|
349
|
+
|
350
|
+
## Contributing
|
351
|
+
|
352
|
+
Any change to behavior (including bugfixes) must come with a test.
|
353
|
+
|
354
|
+
Patches that fail tests or reduce performance will be rejected.
|
355
|
+
|
356
|
+
```
|
357
|
+
# to run tests
|
358
|
+
npm test
|
359
|
+
|
360
|
+
# to re-generate test fixtures
|
361
|
+
npm run test-regen
|
362
|
+
|
363
|
+
# to benchmark against bash/zsh
|
364
|
+
npm run bench
|
365
|
+
|
366
|
+
# to profile javascript
|
367
|
+
npm run prof
|
368
|
+
```
|
@@ -0,0 +1,67 @@
|
|
1
|
+
## 7.0
|
2
|
+
|
3
|
+
- Raise error if `options.cwd` is specified, and not a directory
|
4
|
+
|
5
|
+
## 6.0
|
6
|
+
|
7
|
+
- Remove comment and negation pattern support
|
8
|
+
- Ignore patterns are always in `dot:true` mode
|
9
|
+
|
10
|
+
## 5.0
|
11
|
+
|
12
|
+
- Deprecate comment and negation patterns
|
13
|
+
- Fix regression in `mark` and `nodir` options from making all cache
|
14
|
+
keys absolute path.
|
15
|
+
- Abort if `fs.readdir` returns an error that's unexpected
|
16
|
+
- Don't emit `match` events for ignored items
|
17
|
+
- Treat ENOTSUP like ENOTDIR in readdir
|
18
|
+
|
19
|
+
## 4.5
|
20
|
+
|
21
|
+
- Add `options.follow` to always follow directory symlinks in globstar
|
22
|
+
- Add `options.realpath` to call `fs.realpath` on all results
|
23
|
+
- Always cache based on absolute path
|
24
|
+
|
25
|
+
## 4.4
|
26
|
+
|
27
|
+
- Add `options.ignore`
|
28
|
+
- Fix handling of broken symlinks
|
29
|
+
|
30
|
+
## 4.3
|
31
|
+
|
32
|
+
- Bump minimatch to 2.x
|
33
|
+
- Pass all tests on Windows
|
34
|
+
|
35
|
+
## 4.2
|
36
|
+
|
37
|
+
- Add `glob.hasMagic` function
|
38
|
+
- Add `options.nodir` flag
|
39
|
+
|
40
|
+
## 4.1
|
41
|
+
|
42
|
+
- Refactor sync and async implementations for performance
|
43
|
+
- Throw if callback provided to sync glob function
|
44
|
+
- Treat symbolic links in globstar results the same as Bash 4.3
|
45
|
+
|
46
|
+
## 4.0
|
47
|
+
|
48
|
+
- Use `^` for dependency versions (bumped major because this breaks
|
49
|
+
older npm versions)
|
50
|
+
- Ensure callbacks are only ever called once
|
51
|
+
- switch to ISC license
|
52
|
+
|
53
|
+
## 3.x
|
54
|
+
|
55
|
+
- Rewrite in JavaScript
|
56
|
+
- Add support for setting root, cwd, and windows support
|
57
|
+
- Cache many fs calls
|
58
|
+
- Add globstar support
|
59
|
+
- emit match events
|
60
|
+
|
61
|
+
## 2.x
|
62
|
+
|
63
|
+
- Use `glob.h` and `fnmatch.h` from NetBSD
|
64
|
+
|
65
|
+
## 1.x
|
66
|
+
|
67
|
+
- `glob.h` static binding.
|
@@ -0,0 +1,240 @@
|
|
1
|
+
exports.alphasort = alphasort
|
2
|
+
exports.alphasorti = alphasorti
|
3
|
+
exports.setopts = setopts
|
4
|
+
exports.ownProp = ownProp
|
5
|
+
exports.makeAbs = makeAbs
|
6
|
+
exports.finish = finish
|
7
|
+
exports.mark = mark
|
8
|
+
exports.isIgnored = isIgnored
|
9
|
+
exports.childrenIgnored = childrenIgnored
|
10
|
+
|
11
|
+
function ownProp (obj, field) {
|
12
|
+
return Object.prototype.hasOwnProperty.call(obj, field)
|
13
|
+
}
|
14
|
+
|
15
|
+
var path = require("path")
|
16
|
+
var minimatch = require("minimatch")
|
17
|
+
var isAbsolute = require("path-is-absolute")
|
18
|
+
var Minimatch = minimatch.Minimatch
|
19
|
+
|
20
|
+
function alphasorti (a, b) {
|
21
|
+
return a.toLowerCase().localeCompare(b.toLowerCase())
|
22
|
+
}
|
23
|
+
|
24
|
+
function alphasort (a, b) {
|
25
|
+
return a.localeCompare(b)
|
26
|
+
}
|
27
|
+
|
28
|
+
function setupIgnores (self, options) {
|
29
|
+
self.ignore = options.ignore || []
|
30
|
+
|
31
|
+
if (!Array.isArray(self.ignore))
|
32
|
+
self.ignore = [self.ignore]
|
33
|
+
|
34
|
+
if (self.ignore.length) {
|
35
|
+
self.ignore = self.ignore.map(ignoreMap)
|
36
|
+
}
|
37
|
+
}
|
38
|
+
|
39
|
+
// ignore patterns are always in dot:true mode.
|
40
|
+
function ignoreMap (pattern) {
|
41
|
+
var gmatcher = null
|
42
|
+
if (pattern.slice(-3) === '/**') {
|
43
|
+
var gpattern = pattern.replace(/(\/\*\*)+$/, '')
|
44
|
+
gmatcher = new Minimatch(gpattern, { dot: true })
|
45
|
+
}
|
46
|
+
|
47
|
+
return {
|
48
|
+
matcher: new Minimatch(pattern, { dot: true }),
|
49
|
+
gmatcher: gmatcher
|
50
|
+
}
|
51
|
+
}
|
52
|
+
|
53
|
+
function setopts (self, pattern, options) {
|
54
|
+
if (!options)
|
55
|
+
options = {}
|
56
|
+
|
57
|
+
// base-matching: just use globstar for that.
|
58
|
+
if (options.matchBase && -1 === pattern.indexOf("/")) {
|
59
|
+
if (options.noglobstar) {
|
60
|
+
throw new Error("base matching requires globstar")
|
61
|
+
}
|
62
|
+
pattern = "**/" + pattern
|
63
|
+
}
|
64
|
+
|
65
|
+
self.silent = !!options.silent
|
66
|
+
self.pattern = pattern
|
67
|
+
self.strict = options.strict !== false
|
68
|
+
self.realpath = !!options.realpath
|
69
|
+
self.realpathCache = options.realpathCache || Object.create(null)
|
70
|
+
self.follow = !!options.follow
|
71
|
+
self.dot = !!options.dot
|
72
|
+
self.mark = !!options.mark
|
73
|
+
self.nodir = !!options.nodir
|
74
|
+
if (self.nodir)
|
75
|
+
self.mark = true
|
76
|
+
self.sync = !!options.sync
|
77
|
+
self.nounique = !!options.nounique
|
78
|
+
self.nonull = !!options.nonull
|
79
|
+
self.nosort = !!options.nosort
|
80
|
+
self.nocase = !!options.nocase
|
81
|
+
self.stat = !!options.stat
|
82
|
+
self.noprocess = !!options.noprocess
|
83
|
+
self.absolute = !!options.absolute
|
84
|
+
|
85
|
+
self.maxLength = options.maxLength || Infinity
|
86
|
+
self.cache = options.cache || Object.create(null)
|
87
|
+
self.statCache = options.statCache || Object.create(null)
|
88
|
+
self.symlinks = options.symlinks || Object.create(null)
|
89
|
+
|
90
|
+
setupIgnores(self, options)
|
91
|
+
|
92
|
+
self.changedCwd = false
|
93
|
+
var cwd = process.cwd()
|
94
|
+
if (!ownProp(options, "cwd"))
|
95
|
+
self.cwd = cwd
|
96
|
+
else {
|
97
|
+
self.cwd = path.resolve(options.cwd)
|
98
|
+
self.changedCwd = self.cwd !== cwd
|
99
|
+
}
|
100
|
+
|
101
|
+
self.root = options.root || path.resolve(self.cwd, "/")
|
102
|
+
self.root = path.resolve(self.root)
|
103
|
+
if (process.platform === "win32")
|
104
|
+
self.root = self.root.replace(/\\/g, "/")
|
105
|
+
|
106
|
+
// TODO: is an absolute `cwd` supposed to be resolved against `root`?
|
107
|
+
// e.g. { cwd: '/test', root: __dirname } === path.join(__dirname, '/test')
|
108
|
+
self.cwdAbs = isAbsolute(self.cwd) ? self.cwd : makeAbs(self, self.cwd)
|
109
|
+
if (process.platform === "win32")
|
110
|
+
self.cwdAbs = self.cwdAbs.replace(/\\/g, "/")
|
111
|
+
self.nomount = !!options.nomount
|
112
|
+
|
113
|
+
// disable comments and negation in Minimatch.
|
114
|
+
// Note that they are not supported in Glob itself anyway.
|
115
|
+
options.nonegate = true
|
116
|
+
options.nocomment = true
|
117
|
+
|
118
|
+
self.minimatch = new Minimatch(pattern, options)
|
119
|
+
self.options = self.minimatch.options
|
120
|
+
}
|
121
|
+
|
122
|
+
function finish (self) {
|
123
|
+
var nou = self.nounique
|
124
|
+
var all = nou ? [] : Object.create(null)
|
125
|
+
|
126
|
+
for (var i = 0, l = self.matches.length; i < l; i ++) {
|
127
|
+
var matches = self.matches[i]
|
128
|
+
if (!matches || Object.keys(matches).length === 0) {
|
129
|
+
if (self.nonull) {
|
130
|
+
// do like the shell, and spit out the literal glob
|
131
|
+
var literal = self.minimatch.globSet[i]
|
132
|
+
if (nou)
|
133
|
+
all.push(literal)
|
134
|
+
else
|
135
|
+
all[literal] = true
|
136
|
+
}
|
137
|
+
} else {
|
138
|
+
// had matches
|
139
|
+
var m = Object.keys(matches)
|
140
|
+
if (nou)
|
141
|
+
all.push.apply(all, m)
|
142
|
+
else
|
143
|
+
m.forEach(function (m) {
|
144
|
+
all[m] = true
|
145
|
+
})
|
146
|
+
}
|
147
|
+
}
|
148
|
+
|
149
|
+
if (!nou)
|
150
|
+
all = Object.keys(all)
|
151
|
+
|
152
|
+
if (!self.nosort)
|
153
|
+
all = all.sort(self.nocase ? alphasorti : alphasort)
|
154
|
+
|
155
|
+
// at *some* point we statted all of these
|
156
|
+
if (self.mark) {
|
157
|
+
for (var i = 0; i < all.length; i++) {
|
158
|
+
all[i] = self._mark(all[i])
|
159
|
+
}
|
160
|
+
if (self.nodir) {
|
161
|
+
all = all.filter(function (e) {
|
162
|
+
var notDir = !(/\/$/.test(e))
|
163
|
+
var c = self.cache[e] || self.cache[makeAbs(self, e)]
|
164
|
+
if (notDir && c)
|
165
|
+
notDir = c !== 'DIR' && !Array.isArray(c)
|
166
|
+
return notDir
|
167
|
+
})
|
168
|
+
}
|
169
|
+
}
|
170
|
+
|
171
|
+
if (self.ignore.length)
|
172
|
+
all = all.filter(function(m) {
|
173
|
+
return !isIgnored(self, m)
|
174
|
+
})
|
175
|
+
|
176
|
+
self.found = all
|
177
|
+
}
|
178
|
+
|
179
|
+
function mark (self, p) {
|
180
|
+
var abs = makeAbs(self, p)
|
181
|
+
var c = self.cache[abs]
|
182
|
+
var m = p
|
183
|
+
if (c) {
|
184
|
+
var isDir = c === 'DIR' || Array.isArray(c)
|
185
|
+
var slash = p.slice(-1) === '/'
|
186
|
+
|
187
|
+
if (isDir && !slash)
|
188
|
+
m += '/'
|
189
|
+
else if (!isDir && slash)
|
190
|
+
m = m.slice(0, -1)
|
191
|
+
|
192
|
+
if (m !== p) {
|
193
|
+
var mabs = makeAbs(self, m)
|
194
|
+
self.statCache[mabs] = self.statCache[abs]
|
195
|
+
self.cache[mabs] = self.cache[abs]
|
196
|
+
}
|
197
|
+
}
|
198
|
+
|
199
|
+
return m
|
200
|
+
}
|
201
|
+
|
202
|
+
// lotta situps...
|
203
|
+
function makeAbs (self, f) {
|
204
|
+
var abs = f
|
205
|
+
if (f.charAt(0) === '/') {
|
206
|
+
abs = path.join(self.root, f)
|
207
|
+
} else if (isAbsolute(f) || f === '') {
|
208
|
+
abs = f
|
209
|
+
} else if (self.changedCwd) {
|
210
|
+
abs = path.resolve(self.cwd, f)
|
211
|
+
} else {
|
212
|
+
abs = path.resolve(f)
|
213
|
+
}
|
214
|
+
|
215
|
+
if (process.platform === 'win32')
|
216
|
+
abs = abs.replace(/\\/g, '/')
|
217
|
+
|
218
|
+
return abs
|
219
|
+
}
|
220
|
+
|
221
|
+
|
222
|
+
// Return true, if pattern ends with globstar '**', for the accompanying parent directory.
|
223
|
+
// Ex:- If node_modules/** is the pattern, add 'node_modules' to ignore list along with it's contents
|
224
|
+
function isIgnored (self, path) {
|
225
|
+
if (!self.ignore.length)
|
226
|
+
return false
|
227
|
+
|
228
|
+
return self.ignore.some(function(item) {
|
229
|
+
return item.matcher.match(path) || !!(item.gmatcher && item.gmatcher.match(path))
|
230
|
+
})
|
231
|
+
}
|
232
|
+
|
233
|
+
function childrenIgnored (self, path) {
|
234
|
+
if (!self.ignore.length)
|
235
|
+
return false
|
236
|
+
|
237
|
+
return self.ignore.some(function(item) {
|
238
|
+
return !!(item.gmatcher && item.gmatcher.match(path))
|
239
|
+
})
|
240
|
+
}
|