UrgentcareCLI 0.1.1 → 0.2.3

Sign up to get free protection for your applications and to get access to all the features.
Files changed (318) hide show
  1. checksums.yaml +4 -4
  2. data/lib/UrgentCare/CLI.rb +57 -22
  3. data/lib/UrgentCare/Office.rb +1 -5
  4. data/lib/UrgentCare/Scraper.rb +71 -0
  5. data/lib/UrgentCare/version.rb +2 -2
  6. data/lib/UrgentCare.rb +2 -1
  7. metadata +27 -321
  8. data/.gitignore +0 -11
  9. data/.rspec +0 -3
  10. data/.travis.yml +0 -5
  11. data/CODE_OF_CONDUCT.md +0 -74
  12. data/Gemfile +0 -12
  13. data/Gemfile.lock +0 -84
  14. data/LICENSE.txt +0 -21
  15. data/Notes +0 -41
  16. data/README.md +0 -41
  17. data/Rakefile +0 -8
  18. data/UrgentCare.gemspec +0 -39
  19. data/background.jpg +0 -0
  20. data/data.txt +0 -4
  21. data/lib/Urgentcare/Scraper.rb +0 -78
  22. data/node_modules/.bin/rimraf +0 -1
  23. data/node_modules/.package-lock.json +0 -250
  24. data/node_modules/balanced-match/.github/FUNDING.yml +0 -2
  25. data/node_modules/balanced-match/LICENSE.md +0 -21
  26. data/node_modules/balanced-match/README.md +0 -97
  27. data/node_modules/balanced-match/index.js +0 -62
  28. data/node_modules/balanced-match/package.json +0 -48
  29. data/node_modules/brace-expansion/LICENSE +0 -21
  30. data/node_modules/brace-expansion/README.md +0 -129
  31. data/node_modules/brace-expansion/index.js +0 -201
  32. data/node_modules/brace-expansion/package.json +0 -47
  33. data/node_modules/concat-map/.travis.yml +0 -4
  34. data/node_modules/concat-map/LICENSE +0 -18
  35. data/node_modules/concat-map/README.markdown +0 -62
  36. data/node_modules/concat-map/example/map.js +0 -6
  37. data/node_modules/concat-map/index.js +0 -13
  38. data/node_modules/concat-map/package.json +0 -43
  39. data/node_modules/concat-map/test/map.js +0 -39
  40. data/node_modules/core-util-is/LICENSE +0 -19
  41. data/node_modules/core-util-is/README.md +0 -3
  42. data/node_modules/core-util-is/float.patch +0 -604
  43. data/node_modules/core-util-is/lib/util.js +0 -107
  44. data/node_modules/core-util-is/package.json +0 -32
  45. data/node_modules/core-util-is/test.js +0 -68
  46. data/node_modules/fs.realpath/LICENSE +0 -43
  47. data/node_modules/fs.realpath/README.md +0 -33
  48. data/node_modules/fs.realpath/index.js +0 -66
  49. data/node_modules/fs.realpath/old.js +0 -303
  50. data/node_modules/fs.realpath/package.json +0 -26
  51. data/node_modules/glob/LICENSE +0 -21
  52. data/node_modules/glob/README.md +0 -375
  53. data/node_modules/glob/changelog.md +0 -67
  54. data/node_modules/glob/common.js +0 -234
  55. data/node_modules/glob/glob.js +0 -788
  56. data/node_modules/glob/package.json +0 -51
  57. data/node_modules/glob/sync.js +0 -484
  58. data/node_modules/immediate/LICENSE.txt +0 -20
  59. data/node_modules/immediate/README.md +0 -93
  60. data/node_modules/immediate/dist/immediate.js +0 -75
  61. data/node_modules/immediate/dist/immediate.min.js +0 -1
  62. data/node_modules/immediate/lib/browser.js +0 -69
  63. data/node_modules/immediate/lib/index.js +0 -73
  64. data/node_modules/immediate/package.json +0 -42
  65. data/node_modules/inflight/LICENSE +0 -15
  66. data/node_modules/inflight/README.md +0 -37
  67. data/node_modules/inflight/inflight.js +0 -54
  68. data/node_modules/inflight/package.json +0 -29
  69. data/node_modules/inherits/LICENSE +0 -16
  70. data/node_modules/inherits/README.md +0 -42
  71. data/node_modules/inherits/inherits.js +0 -9
  72. data/node_modules/inherits/inherits_browser.js +0 -27
  73. data/node_modules/inherits/package.json +0 -29
  74. data/node_modules/isarray/.npmignore +0 -1
  75. data/node_modules/isarray/.travis.yml +0 -4
  76. data/node_modules/isarray/Makefile +0 -6
  77. data/node_modules/isarray/README.md +0 -60
  78. data/node_modules/isarray/component.json +0 -19
  79. data/node_modules/isarray/index.js +0 -5
  80. data/node_modules/isarray/package.json +0 -45
  81. data/node_modules/isarray/test.js +0 -20
  82. data/node_modules/jszip/.codeclimate.yml +0 -16
  83. data/node_modules/jszip/.editorconfig +0 -8
  84. data/node_modules/jszip/.jshintignore +0 -1
  85. data/node_modules/jszip/.jshintrc +0 -21
  86. data/node_modules/jszip/.travis.yml +0 -17
  87. data/node_modules/jszip/CHANGES.md +0 -163
  88. data/node_modules/jszip/LICENSE.markdown +0 -651
  89. data/node_modules/jszip/README.markdown +0 -35
  90. data/node_modules/jszip/dist/jszip.js +0 -30
  91. data/node_modules/jszip/dist/jszip.min.js +0 -13
  92. data/node_modules/jszip/index.d.ts +0 -270
  93. data/node_modules/jszip/lib/base64.js +0 -106
  94. data/node_modules/jszip/lib/compressedObject.js +0 -74
  95. data/node_modules/jszip/lib/compressions.js +0 -14
  96. data/node_modules/jszip/lib/crc32.js +0 -77
  97. data/node_modules/jszip/lib/defaults.js +0 -11
  98. data/node_modules/jszip/lib/external.js +0 -19
  99. data/node_modules/jszip/lib/flate.js +0 -85
  100. data/node_modules/jszip/lib/generate/ZipFileWorker.js +0 -540
  101. data/node_modules/jszip/lib/generate/index.js +0 -57
  102. data/node_modules/jszip/lib/index.js +0 -52
  103. data/node_modules/jszip/lib/license_header.js +0 -11
  104. data/node_modules/jszip/lib/load.js +0 -81
  105. data/node_modules/jszip/lib/nodejs/NodejsStreamInputAdapter.js +0 -74
  106. data/node_modules/jszip/lib/nodejs/NodejsStreamOutputAdapter.js +0 -42
  107. data/node_modules/jszip/lib/nodejsUtils.js +0 -57
  108. data/node_modules/jszip/lib/object.js +0 -389
  109. data/node_modules/jszip/lib/readable-stream-browser.js +0 -9
  110. data/node_modules/jszip/lib/reader/ArrayReader.js +0 -57
  111. data/node_modules/jszip/lib/reader/DataReader.js +0 -116
  112. data/node_modules/jszip/lib/reader/NodeBufferReader.js +0 -19
  113. data/node_modules/jszip/lib/reader/StringReader.js +0 -38
  114. data/node_modules/jszip/lib/reader/Uint8ArrayReader.js +0 -22
  115. data/node_modules/jszip/lib/reader/readerFor.js +0 -28
  116. data/node_modules/jszip/lib/signature.js +0 -7
  117. data/node_modules/jszip/lib/stream/ConvertWorker.js +0 -26
  118. data/node_modules/jszip/lib/stream/Crc32Probe.js +0 -24
  119. data/node_modules/jszip/lib/stream/DataLengthProbe.js +0 -29
  120. data/node_modules/jszip/lib/stream/DataWorker.js +0 -116
  121. data/node_modules/jszip/lib/stream/GenericWorker.js +0 -263
  122. data/node_modules/jszip/lib/stream/StreamHelper.js +0 -212
  123. data/node_modules/jszip/lib/support.js +0 -38
  124. data/node_modules/jszip/lib/utf8.js +0 -275
  125. data/node_modules/jszip/lib/utils.js +0 -476
  126. data/node_modules/jszip/lib/zipEntries.js +0 -262
  127. data/node_modules/jszip/lib/zipEntry.js +0 -294
  128. data/node_modules/jszip/lib/zipObject.js +0 -133
  129. data/node_modules/jszip/package.json +0 -63
  130. data/node_modules/jszip/vendor/FileSaver.js +0 -247
  131. data/node_modules/lie/README.md +0 -62
  132. data/node_modules/lie/dist/lie.js +0 -350
  133. data/node_modules/lie/dist/lie.min.js +0 -1
  134. data/node_modules/lie/dist/lie.polyfill.js +0 -358
  135. data/node_modules/lie/dist/lie.polyfill.min.js +0 -1
  136. data/node_modules/lie/lib/browser.js +0 -273
  137. data/node_modules/lie/lib/index.js +0 -298
  138. data/node_modules/lie/license.md +0 -7
  139. data/node_modules/lie/lie.d.ts +0 -244
  140. data/node_modules/lie/package.json +0 -69
  141. data/node_modules/lie/polyfill.js +0 -4
  142. data/node_modules/minimatch/LICENSE +0 -15
  143. data/node_modules/minimatch/README.md +0 -209
  144. data/node_modules/minimatch/minimatch.js +0 -923
  145. data/node_modules/minimatch/package.json +0 -30
  146. data/node_modules/once/LICENSE +0 -15
  147. data/node_modules/once/README.md +0 -79
  148. data/node_modules/once/once.js +0 -42
  149. data/node_modules/once/package.json +0 -33
  150. data/node_modules/pako/CHANGELOG.md +0 -164
  151. data/node_modules/pako/LICENSE +0 -21
  152. data/node_modules/pako/README.md +0 -191
  153. data/node_modules/pako/dist/pako.js +0 -6818
  154. data/node_modules/pako/dist/pako.min.js +0 -1
  155. data/node_modules/pako/dist/pako_deflate.js +0 -3997
  156. data/node_modules/pako/dist/pako_deflate.min.js +0 -1
  157. data/node_modules/pako/dist/pako_inflate.js +0 -3300
  158. data/node_modules/pako/dist/pako_inflate.min.js +0 -1
  159. data/node_modules/pako/index.js +0 -14
  160. data/node_modules/pako/lib/deflate.js +0 -400
  161. data/node_modules/pako/lib/inflate.js +0 -423
  162. data/node_modules/pako/lib/utils/common.js +0 -105
  163. data/node_modules/pako/lib/utils/strings.js +0 -187
  164. data/node_modules/pako/lib/zlib/README +0 -59
  165. data/node_modules/pako/lib/zlib/adler32.js +0 -51
  166. data/node_modules/pako/lib/zlib/constants.js +0 -68
  167. data/node_modules/pako/lib/zlib/crc32.js +0 -59
  168. data/node_modules/pako/lib/zlib/deflate.js +0 -1874
  169. data/node_modules/pako/lib/zlib/gzheader.js +0 -58
  170. data/node_modules/pako/lib/zlib/inffast.js +0 -345
  171. data/node_modules/pako/lib/zlib/inflate.js +0 -1556
  172. data/node_modules/pako/lib/zlib/inftrees.js +0 -343
  173. data/node_modules/pako/lib/zlib/messages.js +0 -32
  174. data/node_modules/pako/lib/zlib/trees.js +0 -1222
  175. data/node_modules/pako/lib/zlib/zstream.js +0 -47
  176. data/node_modules/pako/package.json +0 -44
  177. data/node_modules/path-is-absolute/index.js +0 -20
  178. data/node_modules/path-is-absolute/license +0 -21
  179. data/node_modules/path-is-absolute/package.json +0 -43
  180. data/node_modules/path-is-absolute/readme.md +0 -59
  181. data/node_modules/process-nextick-args/index.js +0 -45
  182. data/node_modules/process-nextick-args/license.md +0 -19
  183. data/node_modules/process-nextick-args/package.json +0 -25
  184. data/node_modules/process-nextick-args/readme.md +0 -18
  185. data/node_modules/readable-stream/.travis.yml +0 -34
  186. data/node_modules/readable-stream/CONTRIBUTING.md +0 -38
  187. data/node_modules/readable-stream/GOVERNANCE.md +0 -136
  188. data/node_modules/readable-stream/LICENSE +0 -47
  189. data/node_modules/readable-stream/README.md +0 -58
  190. data/node_modules/readable-stream/doc/wg-meetings/2015-01-30.md +0 -60
  191. data/node_modules/readable-stream/duplex-browser.js +0 -1
  192. data/node_modules/readable-stream/duplex.js +0 -1
  193. data/node_modules/readable-stream/lib/_stream_duplex.js +0 -131
  194. data/node_modules/readable-stream/lib/_stream_passthrough.js +0 -47
  195. data/node_modules/readable-stream/lib/_stream_readable.js +0 -1019
  196. data/node_modules/readable-stream/lib/_stream_transform.js +0 -214
  197. data/node_modules/readable-stream/lib/_stream_writable.js +0 -687
  198. data/node_modules/readable-stream/lib/internal/streams/BufferList.js +0 -79
  199. data/node_modules/readable-stream/lib/internal/streams/destroy.js +0 -74
  200. data/node_modules/readable-stream/lib/internal/streams/stream-browser.js +0 -1
  201. data/node_modules/readable-stream/lib/internal/streams/stream.js +0 -1
  202. data/node_modules/readable-stream/package.json +0 -52
  203. data/node_modules/readable-stream/passthrough.js +0 -1
  204. data/node_modules/readable-stream/readable-browser.js +0 -7
  205. data/node_modules/readable-stream/readable.js +0 -19
  206. data/node_modules/readable-stream/transform.js +0 -1
  207. data/node_modules/readable-stream/writable-browser.js +0 -1
  208. data/node_modules/readable-stream/writable.js +0 -8
  209. data/node_modules/rimraf/LICENSE +0 -15
  210. data/node_modules/rimraf/README.md +0 -101
  211. data/node_modules/rimraf/bin.js +0 -50
  212. data/node_modules/rimraf/package.json +0 -29
  213. data/node_modules/rimraf/rimraf.js +0 -372
  214. data/node_modules/safe-buffer/LICENSE +0 -21
  215. data/node_modules/safe-buffer/README.md +0 -584
  216. data/node_modules/safe-buffer/index.d.ts +0 -187
  217. data/node_modules/safe-buffer/index.js +0 -62
  218. data/node_modules/safe-buffer/package.json +0 -37
  219. data/node_modules/selenium-webdriver/CHANGES.md +0 -1114
  220. data/node_modules/selenium-webdriver/LICENSE +0 -202
  221. data/node_modules/selenium-webdriver/NOTICE +0 -2
  222. data/node_modules/selenium-webdriver/README.md +0 -229
  223. data/node_modules/selenium-webdriver/chrome.js +0 -295
  224. data/node_modules/selenium-webdriver/chromium.js +0 -829
  225. data/node_modules/selenium-webdriver/devtools/CDPConnection.js +0 -35
  226. data/node_modules/selenium-webdriver/edge.js +0 -224
  227. data/node_modules/selenium-webdriver/example/chrome_android.js +0 -45
  228. data/node_modules/selenium-webdriver/example/chrome_mobile_emulation.js +0 -46
  229. data/node_modules/selenium-webdriver/example/firefox_channels.js +0 -84
  230. data/node_modules/selenium-webdriver/example/google_search.js +0 -50
  231. data/node_modules/selenium-webdriver/example/google_search_test.js +0 -70
  232. data/node_modules/selenium-webdriver/example/headless.js +0 -63
  233. data/node_modules/selenium-webdriver/example/logging.js +0 -64
  234. data/node_modules/selenium-webdriver/firefox.js +0 -789
  235. data/node_modules/selenium-webdriver/http/index.js +0 -324
  236. data/node_modules/selenium-webdriver/http/util.js +0 -172
  237. data/node_modules/selenium-webdriver/ie.js +0 -503
  238. data/node_modules/selenium-webdriver/index.js +0 -825
  239. data/node_modules/selenium-webdriver/io/exec.js +0 -162
  240. data/node_modules/selenium-webdriver/io/index.js +0 -348
  241. data/node_modules/selenium-webdriver/io/zip.js +0 -223
  242. data/node_modules/selenium-webdriver/lib/atoms/find-elements.js +0 -123
  243. data/node_modules/selenium-webdriver/lib/atoms/get-attribute.js +0 -101
  244. data/node_modules/selenium-webdriver/lib/atoms/is-displayed.js +0 -101
  245. data/node_modules/selenium-webdriver/lib/atoms/mutation-listener.js +0 -55
  246. data/node_modules/selenium-webdriver/lib/by.js +0 -415
  247. data/node_modules/selenium-webdriver/lib/capabilities.js +0 -553
  248. data/node_modules/selenium-webdriver/lib/command.js +0 -206
  249. data/node_modules/selenium-webdriver/lib/error.js +0 -605
  250. data/node_modules/selenium-webdriver/lib/http.js +0 -704
  251. data/node_modules/selenium-webdriver/lib/input.js +0 -946
  252. data/node_modules/selenium-webdriver/lib/logging.js +0 -661
  253. data/node_modules/selenium-webdriver/lib/promise.js +0 -285
  254. data/node_modules/selenium-webdriver/lib/proxy.js +0 -212
  255. data/node_modules/selenium-webdriver/lib/session.js +0 -77
  256. data/node_modules/selenium-webdriver/lib/symbols.js +0 -37
  257. data/node_modules/selenium-webdriver/lib/until.js +0 -429
  258. data/node_modules/selenium-webdriver/lib/webdriver.js +0 -2919
  259. data/node_modules/selenium-webdriver/net/index.js +0 -107
  260. data/node_modules/selenium-webdriver/net/portprober.js +0 -75
  261. data/node_modules/selenium-webdriver/opera.js +0 -406
  262. data/node_modules/selenium-webdriver/package.json +0 -54
  263. data/node_modules/selenium-webdriver/proxy.js +0 -32
  264. data/node_modules/selenium-webdriver/remote/index.js +0 -624
  265. data/node_modules/selenium-webdriver/safari.js +0 -168
  266. data/node_modules/selenium-webdriver/testing/index.js +0 -504
  267. data/node_modules/set-immediate-shim/index.js +0 -7
  268. data/node_modules/set-immediate-shim/package.json +0 -34
  269. data/node_modules/set-immediate-shim/readme.md +0 -31
  270. data/node_modules/string_decoder/.travis.yml +0 -50
  271. data/node_modules/string_decoder/LICENSE +0 -48
  272. data/node_modules/string_decoder/README.md +0 -47
  273. data/node_modules/string_decoder/lib/string_decoder.js +0 -296
  274. data/node_modules/string_decoder/package.json +0 -31
  275. data/node_modules/tmp/CHANGELOG.md +0 -288
  276. data/node_modules/tmp/LICENSE +0 -21
  277. data/node_modules/tmp/README.md +0 -365
  278. data/node_modules/tmp/lib/tmp.js +0 -780
  279. data/node_modules/tmp/node_modules/.bin/rimraf +0 -1
  280. data/node_modules/tmp/node_modules/rimraf/CHANGELOG.md +0 -65
  281. data/node_modules/tmp/node_modules/rimraf/LICENSE +0 -15
  282. data/node_modules/tmp/node_modules/rimraf/README.md +0 -101
  283. data/node_modules/tmp/node_modules/rimraf/bin.js +0 -68
  284. data/node_modules/tmp/node_modules/rimraf/package.json +0 -32
  285. data/node_modules/tmp/node_modules/rimraf/rimraf.js +0 -360
  286. data/node_modules/tmp/package.json +0 -58
  287. data/node_modules/util-deprecate/History.md +0 -16
  288. data/node_modules/util-deprecate/LICENSE +0 -24
  289. data/node_modules/util-deprecate/README.md +0 -53
  290. data/node_modules/util-deprecate/browser.js +0 -67
  291. data/node_modules/util-deprecate/node.js +0 -6
  292. data/node_modules/util-deprecate/package.json +0 -27
  293. data/node_modules/wrappy/LICENSE +0 -15
  294. data/node_modules/wrappy/README.md +0 -36
  295. data/node_modules/wrappy/package.json +0 -29
  296. data/node_modules/wrappy/wrappy.js +0 -33
  297. data/node_modules/ws/LICENSE +0 -21
  298. data/node_modules/ws/README.md +0 -496
  299. data/node_modules/ws/browser.js +0 -8
  300. data/node_modules/ws/index.js +0 -10
  301. data/node_modules/ws/lib/buffer-util.js +0 -129
  302. data/node_modules/ws/lib/constants.js +0 -10
  303. data/node_modules/ws/lib/event-target.js +0 -184
  304. data/node_modules/ws/lib/extension.js +0 -223
  305. data/node_modules/ws/lib/limiter.js +0 -55
  306. data/node_modules/ws/lib/permessage-deflate.js +0 -517
  307. data/node_modules/ws/lib/receiver.js +0 -507
  308. data/node_modules/ws/lib/sender.js +0 -405
  309. data/node_modules/ws/lib/stream.js +0 -165
  310. data/node_modules/ws/lib/validation.js +0 -104
  311. data/node_modules/ws/lib/websocket-server.js +0 -418
  312. data/node_modules/ws/lib/websocket.js +0 -942
  313. data/node_modules/ws/package.json +0 -56
  314. data/package-lock.json +0 -458
  315. data/package.json +0 -5
  316. data/selenium.log +0 -1
  317. data/spec.md +0 -6
  318. data/test.data +0 -2110
@@ -1,375 +0,0 @@
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
- ![a fun cartoon logo made of glob characters](logo/glob.png)
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
- ## Glob Logo
351
- Glob's logo was created by [Tanya Brassie](http://tanyabrassie.com/). Logo files can be found [here](https://github.com/isaacs/node-glob/tree/master/logo).
352
-
353
- The logo is licensed under a [Creative Commons Attribution-ShareAlike 4.0 International License](https://creativecommons.org/licenses/by-sa/4.0/).
354
-
355
- ## Contributing
356
-
357
- Any change to behavior (including bugfixes) must come with a test.
358
-
359
- Patches that fail tests or reduce performance will be rejected.
360
-
361
- ```
362
- # to run tests
363
- npm test
364
-
365
- # to re-generate test fixtures
366
- npm run test-regen
367
-
368
- # to benchmark against bash/zsh
369
- npm run bench
370
-
371
- # to profile javascript
372
- npm run prof
373
- ```
374
-
375
- ![](oh-my-glob.gif)
@@ -1,67 +0,0 @@
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.
@@ -1,234 +0,0 @@
1
- exports.setopts = setopts
2
- exports.ownProp = ownProp
3
- exports.makeAbs = makeAbs
4
- exports.finish = finish
5
- exports.mark = mark
6
- exports.isIgnored = isIgnored
7
- exports.childrenIgnored = childrenIgnored
8
-
9
- function ownProp (obj, field) {
10
- return Object.prototype.hasOwnProperty.call(obj, field)
11
- }
12
-
13
- var path = require("path")
14
- var minimatch = require("minimatch")
15
- var isAbsolute = require("path-is-absolute")
16
- var Minimatch = minimatch.Minimatch
17
-
18
- function alphasort (a, b) {
19
- return a.localeCompare(b, 'en')
20
- }
21
-
22
- function setupIgnores (self, options) {
23
- self.ignore = options.ignore || []
24
-
25
- if (!Array.isArray(self.ignore))
26
- self.ignore = [self.ignore]
27
-
28
- if (self.ignore.length) {
29
- self.ignore = self.ignore.map(ignoreMap)
30
- }
31
- }
32
-
33
- // ignore patterns are always in dot:true mode.
34
- function ignoreMap (pattern) {
35
- var gmatcher = null
36
- if (pattern.slice(-3) === '/**') {
37
- var gpattern = pattern.replace(/(\/\*\*)+$/, '')
38
- gmatcher = new Minimatch(gpattern, { dot: true })
39
- }
40
-
41
- return {
42
- matcher: new Minimatch(pattern, { dot: true }),
43
- gmatcher: gmatcher
44
- }
45
- }
46
-
47
- function setopts (self, pattern, options) {
48
- if (!options)
49
- options = {}
50
-
51
- // base-matching: just use globstar for that.
52
- if (options.matchBase && -1 === pattern.indexOf("/")) {
53
- if (options.noglobstar) {
54
- throw new Error("base matching requires globstar")
55
- }
56
- pattern = "**/" + pattern
57
- }
58
-
59
- self.silent = !!options.silent
60
- self.pattern = pattern
61
- self.strict = options.strict !== false
62
- self.realpath = !!options.realpath
63
- self.realpathCache = options.realpathCache || Object.create(null)
64
- self.follow = !!options.follow
65
- self.dot = !!options.dot
66
- self.mark = !!options.mark
67
- self.nodir = !!options.nodir
68
- if (self.nodir)
69
- self.mark = true
70
- self.sync = !!options.sync
71
- self.nounique = !!options.nounique
72
- self.nonull = !!options.nonull
73
- self.nosort = !!options.nosort
74
- self.nocase = !!options.nocase
75
- self.stat = !!options.stat
76
- self.noprocess = !!options.noprocess
77
- self.absolute = !!options.absolute
78
-
79
- self.maxLength = options.maxLength || Infinity
80
- self.cache = options.cache || Object.create(null)
81
- self.statCache = options.statCache || Object.create(null)
82
- self.symlinks = options.symlinks || Object.create(null)
83
-
84
- setupIgnores(self, options)
85
-
86
- self.changedCwd = false
87
- var cwd = process.cwd()
88
- if (!ownProp(options, "cwd"))
89
- self.cwd = cwd
90
- else {
91
- self.cwd = path.resolve(options.cwd)
92
- self.changedCwd = self.cwd !== cwd
93
- }
94
-
95
- self.root = options.root || path.resolve(self.cwd, "/")
96
- self.root = path.resolve(self.root)
97
- if (process.platform === "win32")
98
- self.root = self.root.replace(/\\/g, "/")
99
-
100
- // TODO: is an absolute `cwd` supposed to be resolved against `root`?
101
- // e.g. { cwd: '/test', root: __dirname } === path.join(__dirname, '/test')
102
- self.cwdAbs = isAbsolute(self.cwd) ? self.cwd : makeAbs(self, self.cwd)
103
- if (process.platform === "win32")
104
- self.cwdAbs = self.cwdAbs.replace(/\\/g, "/")
105
- self.nomount = !!options.nomount
106
-
107
- // disable comments and negation in Minimatch.
108
- // Note that they are not supported in Glob itself anyway.
109
- options.nonegate = true
110
- options.nocomment = true
111
-
112
- self.minimatch = new Minimatch(pattern, options)
113
- self.options = self.minimatch.options
114
- }
115
-
116
- function finish (self) {
117
- var nou = self.nounique
118
- var all = nou ? [] : Object.create(null)
119
-
120
- for (var i = 0, l = self.matches.length; i < l; i ++) {
121
- var matches = self.matches[i]
122
- if (!matches || Object.keys(matches).length === 0) {
123
- if (self.nonull) {
124
- // do like the shell, and spit out the literal glob
125
- var literal = self.minimatch.globSet[i]
126
- if (nou)
127
- all.push(literal)
128
- else
129
- all[literal] = true
130
- }
131
- } else {
132
- // had matches
133
- var m = Object.keys(matches)
134
- if (nou)
135
- all.push.apply(all, m)
136
- else
137
- m.forEach(function (m) {
138
- all[m] = true
139
- })
140
- }
141
- }
142
-
143
- if (!nou)
144
- all = Object.keys(all)
145
-
146
- if (!self.nosort)
147
- all = all.sort(alphasort)
148
-
149
- // at *some* point we statted all of these
150
- if (self.mark) {
151
- for (var i = 0; i < all.length; i++) {
152
- all[i] = self._mark(all[i])
153
- }
154
- if (self.nodir) {
155
- all = all.filter(function (e) {
156
- var notDir = !(/\/$/.test(e))
157
- var c = self.cache[e] || self.cache[makeAbs(self, e)]
158
- if (notDir && c)
159
- notDir = c !== 'DIR' && !Array.isArray(c)
160
- return notDir
161
- })
162
- }
163
- }
164
-
165
- if (self.ignore.length)
166
- all = all.filter(function(m) {
167
- return !isIgnored(self, m)
168
- })
169
-
170
- self.found = all
171
- }
172
-
173
- function mark (self, p) {
174
- var abs = makeAbs(self, p)
175
- var c = self.cache[abs]
176
- var m = p
177
- if (c) {
178
- var isDir = c === 'DIR' || Array.isArray(c)
179
- var slash = p.slice(-1) === '/'
180
-
181
- if (isDir && !slash)
182
- m += '/'
183
- else if (!isDir && slash)
184
- m = m.slice(0, -1)
185
-
186
- if (m !== p) {
187
- var mabs = makeAbs(self, m)
188
- self.statCache[mabs] = self.statCache[abs]
189
- self.cache[mabs] = self.cache[abs]
190
- }
191
- }
192
-
193
- return m
194
- }
195
-
196
- // lotta situps...
197
- function makeAbs (self, f) {
198
- var abs = f
199
- if (f.charAt(0) === '/') {
200
- abs = path.join(self.root, f)
201
- } else if (isAbsolute(f) || f === '') {
202
- abs = f
203
- } else if (self.changedCwd) {
204
- abs = path.resolve(self.cwd, f)
205
- } else {
206
- abs = path.resolve(f)
207
- }
208
-
209
- if (process.platform === 'win32')
210
- abs = abs.replace(/\\/g, '/')
211
-
212
- return abs
213
- }
214
-
215
-
216
- // Return true, if pattern ends with globstar '**', for the accompanying parent directory.
217
- // Ex:- If node_modules/** is the pattern, add 'node_modules' to ignore list along with it's contents
218
- function isIgnored (self, path) {
219
- if (!self.ignore.length)
220
- return false
221
-
222
- return self.ignore.some(function(item) {
223
- return item.matcher.match(path) || !!(item.gmatcher && item.gmatcher.match(path))
224
- })
225
- }
226
-
227
- function childrenIgnored (self, path) {
228
- if (!self.ignore.length)
229
- return false
230
-
231
- return self.ignore.some(function(item) {
232
- return !!(item.gmatcher && item.gmatcher.match(path))
233
- })
234
- }