immosquare-cleaner 0.1.23 → 0.1.24
Sign up to get free protection for your applications and to get access to all the features.
- checksums.yaml +4 -4
- data/lib/immosquare-cleaner/version.rb +1 -1
- data/linters/rubocop-3.2.2.yml +1 -0
- data/linters/rubocop.yml +2 -0
- data/node_modules/@eslint-community/eslint-utils/node_modules/eslint/node_modules/@eslint/eslintrc/LICENSE +19 -0
- data/node_modules/@eslint-community/eslint-utils/node_modules/eslint/node_modules/@eslint/eslintrc/README.md +71 -0
- data/node_modules/@eslint-community/eslint-utils/node_modules/eslint/node_modules/@eslint/eslintrc/conf/config-schema.js +79 -0
- data/node_modules/@eslint-community/eslint-utils/node_modules/eslint/node_modules/@eslint/eslintrc/conf/environments.js +215 -0
- data/node_modules/@eslint-community/eslint-utils/node_modules/eslint/node_modules/@eslint/eslintrc/dist/eslintrc-universal.cjs +1104 -0
- data/node_modules/@eslint-community/eslint-utils/node_modules/eslint/node_modules/@eslint/eslintrc/dist/eslintrc-universal.cjs.map +1 -0
- data/node_modules/@eslint-community/eslint-utils/node_modules/eslint/node_modules/@eslint/eslintrc/dist/eslintrc.cjs +4333 -0
- data/node_modules/@eslint-community/eslint-utils/node_modules/eslint/node_modules/@eslint/eslintrc/dist/eslintrc.cjs.map +1 -0
- data/node_modules/@eslint-community/eslint-utils/node_modules/eslint/node_modules/@eslint/eslintrc/lib/cascading-config-array-factory.js +532 -0
- data/node_modules/@eslint-community/eslint-utils/node_modules/eslint/node_modules/@eslint/eslintrc/lib/config-array/config-array.js +523 -0
- data/node_modules/@eslint-community/eslint-utils/node_modules/eslint/node_modules/@eslint/eslintrc/lib/config-array/config-dependency.js +115 -0
- data/node_modules/@eslint-community/eslint-utils/node_modules/eslint/node_modules/@eslint/eslintrc/lib/config-array/extracted-config.js +145 -0
- data/node_modules/@eslint-community/eslint-utils/node_modules/eslint/node_modules/@eslint/eslintrc/lib/config-array/ignore-pattern.js +238 -0
- data/node_modules/@eslint-community/eslint-utils/node_modules/eslint/node_modules/@eslint/eslintrc/lib/config-array/index.js +19 -0
- data/node_modules/@eslint-community/eslint-utils/node_modules/eslint/node_modules/@eslint/eslintrc/lib/config-array/override-tester.js +225 -0
- data/node_modules/@eslint-community/eslint-utils/node_modules/eslint/node_modules/@eslint/eslintrc/lib/config-array-factory.js +1149 -0
- data/node_modules/@eslint-community/eslint-utils/node_modules/eslint/node_modules/@eslint/eslintrc/lib/flat-compat.js +318 -0
- data/node_modules/@eslint-community/eslint-utils/node_modules/eslint/node_modules/@eslint/eslintrc/lib/index-universal.js +29 -0
- data/node_modules/@eslint-community/eslint-utils/node_modules/eslint/node_modules/@eslint/eslintrc/lib/index.js +56 -0
- data/node_modules/@eslint-community/eslint-utils/node_modules/eslint/node_modules/@eslint/eslintrc/lib/shared/ajv.js +191 -0
- data/node_modules/@eslint-community/eslint-utils/node_modules/eslint/node_modules/@eslint/eslintrc/lib/shared/config-ops.js +135 -0
- data/node_modules/@eslint-community/eslint-utils/node_modules/eslint/node_modules/@eslint/eslintrc/lib/shared/config-validator.js +325 -0
- data/node_modules/@eslint-community/eslint-utils/node_modules/eslint/node_modules/@eslint/eslintrc/lib/shared/deprecation-warnings.js +63 -0
- data/node_modules/@eslint-community/eslint-utils/node_modules/eslint/node_modules/@eslint/eslintrc/lib/shared/naming.js +96 -0
- data/node_modules/@eslint-community/eslint-utils/node_modules/eslint/node_modules/@eslint/eslintrc/lib/shared/relative-module-resolver.js +42 -0
- data/node_modules/@eslint-community/eslint-utils/node_modules/eslint/node_modules/@eslint/eslintrc/lib/shared/types.js +149 -0
- data/node_modules/@eslint-community/eslint-utils/node_modules/eslint/node_modules/@eslint/eslintrc/node_modules/strip-json-comments/index.d.ts +36 -0
- data/node_modules/@eslint-community/eslint-utils/node_modules/eslint/node_modules/@eslint/eslintrc/node_modules/strip-json-comments/index.js +77 -0
- data/node_modules/@eslint-community/eslint-utils/node_modules/eslint/node_modules/@eslint/eslintrc/node_modules/strip-json-comments/license +9 -0
- data/node_modules/@eslint-community/eslint-utils/node_modules/eslint/node_modules/@eslint/eslintrc/node_modules/strip-json-comments/package.json +47 -0
- data/node_modules/@eslint-community/eslint-utils/node_modules/eslint/node_modules/@eslint/eslintrc/node_modules/strip-json-comments/readme.md +78 -0
- data/node_modules/@eslint-community/eslint-utils/node_modules/eslint/node_modules/@eslint/eslintrc/package.json +82 -0
- data/node_modules/@eslint-community/eslint-utils/node_modules/eslint/node_modules/@eslint/eslintrc/universal.js +9 -0
- data/node_modules/@eslint-community/eslint-utils/node_modules/eslint/node_modules/@eslint/js/LICENSE +19 -0
- data/node_modules/@eslint-community/eslint-utils/node_modules/eslint/node_modules/@eslint/js/README.md +57 -0
- data/node_modules/@eslint-community/eslint-utils/node_modules/eslint/node_modules/@eslint/js/package.json +31 -0
- data/node_modules/@eslint-community/eslint-utils/node_modules/eslint/node_modules/@eslint/js/src/configs/eslint-all.js +278 -0
- data/node_modules/@eslint-community/eslint-utils/node_modules/eslint/node_modules/@eslint/js/src/configs/eslint-recommended.js +76 -0
- data/node_modules/@eslint-community/eslint-utils/node_modules/eslint/node_modules/@eslint/js/src/index.js +17 -0
- data/node_modules/@eslint-community/eslint-utils/node_modules/eslint/node_modules/@humanwhocodes/config-array/LICENSE +201 -0
- data/node_modules/@eslint-community/eslint-utils/node_modules/eslint/node_modules/@humanwhocodes/config-array/README.md +342 -0
- data/node_modules/@eslint-community/eslint-utils/node_modules/eslint/node_modules/@humanwhocodes/config-array/api.js +1061 -0
- data/node_modules/@eslint-community/eslint-utils/node_modules/eslint/node_modules/@humanwhocodes/config-array/node_modules/@humanwhocodes/object-schema/CHANGELOG.md +8 -0
- data/node_modules/@eslint-community/eslint-utils/node_modules/eslint/node_modules/@humanwhocodes/config-array/node_modules/@humanwhocodes/object-schema/LICENSE +29 -0
- data/node_modules/@eslint-community/eslint-utils/node_modules/eslint/node_modules/@humanwhocodes/config-array/node_modules/@humanwhocodes/object-schema/README.md +234 -0
- data/node_modules/@eslint-community/eslint-utils/node_modules/eslint/node_modules/@humanwhocodes/config-array/node_modules/@humanwhocodes/object-schema/package.json +33 -0
- data/node_modules/@eslint-community/eslint-utils/node_modules/eslint/node_modules/@humanwhocodes/config-array/node_modules/@humanwhocodes/object-schema/src/index.js +7 -0
- data/node_modules/@eslint-community/eslint-utils/node_modules/eslint/node_modules/@humanwhocodes/config-array/node_modules/@humanwhocodes/object-schema/src/merge-strategy.js +53 -0
- data/node_modules/@eslint-community/eslint-utils/node_modules/eslint/node_modules/@humanwhocodes/config-array/node_modules/@humanwhocodes/object-schema/src/object-schema.js +235 -0
- data/node_modules/@eslint-community/eslint-utils/node_modules/eslint/node_modules/@humanwhocodes/config-array/node_modules/@humanwhocodes/object-schema/src/validation-strategy.js +102 -0
- data/node_modules/@eslint-community/eslint-utils/node_modules/eslint/node_modules/@humanwhocodes/config-array/node_modules/@humanwhocodes/object-schema/tests/merge-strategy.js +66 -0
- data/node_modules/@eslint-community/eslint-utils/node_modules/eslint/node_modules/@humanwhocodes/config-array/node_modules/@humanwhocodes/object-schema/tests/object-schema.js +611 -0
- data/node_modules/@eslint-community/eslint-utils/node_modules/eslint/node_modules/@humanwhocodes/config-array/node_modules/@humanwhocodes/object-schema/tests/validation-strategy.js +186 -0
- data/node_modules/@eslint-community/eslint-utils/node_modules/eslint/node_modules/@humanwhocodes/config-array/node_modules/minimatch/LICENSE +15 -0
- data/node_modules/@eslint-community/eslint-utils/node_modules/eslint/node_modules/@humanwhocodes/config-array/node_modules/minimatch/README.md +224 -0
- data/node_modules/@eslint-community/eslint-utils/node_modules/eslint/node_modules/@humanwhocodes/config-array/node_modules/minimatch/minimatch.js +947 -0
- data/node_modules/@eslint-community/eslint-utils/node_modules/eslint/node_modules/@humanwhocodes/config-array/node_modules/minimatch/node_modules/brace-expansion/LICENSE +21 -0
- data/node_modules/@eslint-community/eslint-utils/node_modules/eslint/node_modules/@humanwhocodes/config-array/node_modules/minimatch/node_modules/brace-expansion/README.md +129 -0
- data/node_modules/@eslint-community/eslint-utils/node_modules/eslint/node_modules/@humanwhocodes/config-array/node_modules/minimatch/node_modules/brace-expansion/index.js +201 -0
- data/node_modules/@eslint-community/eslint-utils/node_modules/eslint/node_modules/@humanwhocodes/config-array/node_modules/minimatch/node_modules/brace-expansion/package.json +47 -0
- data/node_modules/@eslint-community/eslint-utils/node_modules/eslint/node_modules/@humanwhocodes/config-array/node_modules/minimatch/package.json +33 -0
- data/node_modules/@eslint-community/eslint-utils/node_modules/eslint/node_modules/@humanwhocodes/config-array/package.json +61 -0
- data/node_modules/@eslint-community/eslint-utils/node_modules/eslint/node_modules/chalk/index.d.ts +415 -0
- data/node_modules/@eslint-community/eslint-utils/node_modules/eslint/node_modules/chalk/license +9 -0
- data/node_modules/@eslint-community/eslint-utils/node_modules/eslint/node_modules/chalk/package.json +68 -0
- data/node_modules/@eslint-community/eslint-utils/node_modules/eslint/node_modules/chalk/readme.md +341 -0
- data/node_modules/@eslint-community/eslint-utils/node_modules/eslint/node_modules/chalk/source/index.js +229 -0
- data/node_modules/@eslint-community/eslint-utils/node_modules/eslint/node_modules/chalk/source/templates.js +134 -0
- data/node_modules/@eslint-community/eslint-utils/node_modules/eslint/node_modules/chalk/source/util.js +39 -0
- data/node_modules/@eslint-community/eslint-utils/node_modules/eslint/node_modules/minimatch/LICENSE +15 -0
- data/node_modules/@eslint-community/eslint-utils/node_modules/eslint/node_modules/minimatch/README.md +230 -0
- data/node_modules/@eslint-community/eslint-utils/node_modules/eslint/node_modules/minimatch/minimatch.js +947 -0
- data/node_modules/@eslint-community/eslint-utils/node_modules/eslint/node_modules/minimatch/node_modules/brace-expansion/LICENSE +21 -0
- data/node_modules/@eslint-community/eslint-utils/node_modules/eslint/node_modules/minimatch/node_modules/brace-expansion/README.md +129 -0
- data/node_modules/@eslint-community/eslint-utils/node_modules/eslint/node_modules/minimatch/node_modules/brace-expansion/index.js +201 -0
- data/node_modules/@eslint-community/eslint-utils/node_modules/eslint/node_modules/minimatch/node_modules/brace-expansion/package.json +47 -0
- data/node_modules/@eslint-community/eslint-utils/node_modules/eslint/node_modules/minimatch/package.json +33 -0
- data/node_modules/@eslint-community/eslint-utils/node_modules/eslint/node_modules/strip-ansi/index.d.ts +17 -0
- data/node_modules/@eslint-community/eslint-utils/node_modules/eslint/node_modules/strip-ansi/index.js +4 -0
- data/node_modules/@eslint-community/eslint-utils/node_modules/eslint/node_modules/strip-ansi/license +9 -0
- data/node_modules/@eslint-community/eslint-utils/node_modules/eslint/node_modules/strip-ansi/node_modules/ansi-regex/index.d.ts +37 -0
- data/node_modules/@eslint-community/eslint-utils/node_modules/eslint/node_modules/strip-ansi/node_modules/ansi-regex/index.js +10 -0
- data/node_modules/@eslint-community/eslint-utils/node_modules/eslint/node_modules/strip-ansi/node_modules/ansi-regex/license +9 -0
- data/node_modules/@eslint-community/eslint-utils/node_modules/eslint/node_modules/strip-ansi/node_modules/ansi-regex/package.json +55 -0
- data/node_modules/@eslint-community/eslint-utils/node_modules/eslint/node_modules/strip-ansi/node_modules/ansi-regex/readme.md +78 -0
- data/node_modules/@eslint-community/eslint-utils/node_modules/eslint/node_modules/strip-ansi/package.json +54 -0
- data/node_modules/@eslint-community/eslint-utils/node_modules/eslint/node_modules/strip-ansi/readme.md +46 -0
- data/node_modules/eslint-plugin-import/node_modules/debug/node_modules/ms/index.js +162 -0
- data/node_modules/eslint-plugin-import/node_modules/debug/node_modules/ms/license.md +21 -0
- data/node_modules/eslint-plugin-import/node_modules/debug/node_modules/ms/package.json +38 -0
- data/node_modules/eslint-plugin-import/node_modules/debug/node_modules/ms/readme.md +59 -0
- data/node_modules/npm-check-updates/build/package.json +2 -3
- data/node_modules/npm-check-updates/build/src/lib/runGlobal.js +18 -11
- data/node_modules/npm-check-updates/build/src/lib/runGlobal.js.map +1 -1
- data/node_modules/npm-check-updates/build/src/package-managers/bun.js +2 -3
- data/node_modules/npm-check-updates/build/src/package-managers/bun.js.map +1 -1
- data/node_modules/npm-check-updates/build/src/package-managers/npm.js +12 -8
- data/node_modules/npm-check-updates/build/src/package-managers/npm.js.map +1 -1
- data/node_modules/npm-check-updates/build/src/package-managers/pnpm.js +37 -14
- data/node_modules/npm-check-updates/build/src/package-managers/pnpm.js.map +1 -1
- data/node_modules/npm-check-updates/build/src/package-managers/yarn.js +36 -11
- data/node_modules/npm-check-updates/build/src/package-managers/yarn.js.map +1 -1
- data/node_modules/npm-check-updates/package.json +2 -3
- data/node_modules/prettier/LICENSE +3 -3
- data/node_modules/prettier/index.cjs +1 -1
- data/node_modules/prettier/index.mjs +14 -22
- data/node_modules/prettier/package.json +1 -1
- data/node_modules/prettier/plugins/acorn.js +10 -10
- data/node_modules/prettier/plugins/acorn.mjs +10 -10
- data/node_modules/prettier/plugins/angular.js +1 -1
- data/node_modules/prettier/plugins/angular.mjs +1 -1
- data/node_modules/prettier/plugins/babel.js +8 -8
- data/node_modules/prettier/plugins/babel.mjs +8 -8
- data/node_modules/prettier/plugins/estree.js +24 -24
- data/node_modules/prettier/plugins/estree.mjs +24 -24
- data/node_modules/prettier/plugins/flow.js +17 -17
- data/node_modules/prettier/plugins/flow.mjs +17 -17
- data/node_modules/prettier/plugins/graphql.js +6 -6
- data/node_modules/prettier/plugins/graphql.mjs +6 -6
- data/node_modules/prettier/plugins/html.js +1 -1
- data/node_modules/prettier/plugins/html.mjs +1 -1
- data/node_modules/prettier/plugins/markdown.js +1 -1
- data/node_modules/prettier/plugins/markdown.mjs +1 -1
- data/node_modules/prettier/plugins/meriyah.js +4 -4
- data/node_modules/prettier/plugins/meriyah.mjs +4 -4
- data/node_modules/prettier/plugins/typescript.js +19 -19
- data/node_modules/prettier/plugins/typescript.mjs +19 -19
- data/node_modules/prettier/standalone.js +10 -10
- data/node_modules/prettier/standalone.mjs +9 -9
- data/package.json +2 -2
- metadata +95 -4
@@ -0,0 +1,21 @@
|
|
1
|
+
MIT License
|
2
|
+
|
3
|
+
Copyright (c) 2013 Julian Gruber <julian@juliangruber.com>
|
4
|
+
|
5
|
+
Permission is hereby granted, free of charge, to any person obtaining a copy
|
6
|
+
of this software and associated documentation files (the "Software"), to deal
|
7
|
+
in the Software without restriction, including without limitation the rights
|
8
|
+
to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
|
9
|
+
copies of the Software, and to permit persons to whom the Software is
|
10
|
+
furnished to do so, subject to the following conditions:
|
11
|
+
|
12
|
+
The above copyright notice and this permission notice shall be included in all
|
13
|
+
copies or substantial portions of the Software.
|
14
|
+
|
15
|
+
THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
|
16
|
+
IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
|
17
|
+
FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
|
18
|
+
AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
|
19
|
+
LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
|
20
|
+
OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
|
21
|
+
SOFTWARE.
|
@@ -0,0 +1,129 @@
|
|
1
|
+
# brace-expansion
|
2
|
+
|
3
|
+
[Brace expansion](https://www.gnu.org/software/bash/manual/html_node/Brace-Expansion.html),
|
4
|
+
as known from sh/bash, in JavaScript.
|
5
|
+
|
6
|
+
[![build status](https://secure.travis-ci.org/juliangruber/brace-expansion.svg)](http://travis-ci.org/juliangruber/brace-expansion)
|
7
|
+
[![downloads](https://img.shields.io/npm/dm/brace-expansion.svg)](https://www.npmjs.org/package/brace-expansion)
|
8
|
+
[![Greenkeeper badge](https://badges.greenkeeper.io/juliangruber/brace-expansion.svg)](https://greenkeeper.io/)
|
9
|
+
|
10
|
+
[![testling badge](https://ci.testling.com/juliangruber/brace-expansion.png)](https://ci.testling.com/juliangruber/brace-expansion)
|
11
|
+
|
12
|
+
## Example
|
13
|
+
|
14
|
+
```js
|
15
|
+
var expand = require('brace-expansion');
|
16
|
+
|
17
|
+
expand('file-{a,b,c}.jpg')
|
18
|
+
// => ['file-a.jpg', 'file-b.jpg', 'file-c.jpg']
|
19
|
+
|
20
|
+
expand('-v{,,}')
|
21
|
+
// => ['-v', '-v', '-v']
|
22
|
+
|
23
|
+
expand('file{0..2}.jpg')
|
24
|
+
// => ['file0.jpg', 'file1.jpg', 'file2.jpg']
|
25
|
+
|
26
|
+
expand('file-{a..c}.jpg')
|
27
|
+
// => ['file-a.jpg', 'file-b.jpg', 'file-c.jpg']
|
28
|
+
|
29
|
+
expand('file{2..0}.jpg')
|
30
|
+
// => ['file2.jpg', 'file1.jpg', 'file0.jpg']
|
31
|
+
|
32
|
+
expand('file{0..4..2}.jpg')
|
33
|
+
// => ['file0.jpg', 'file2.jpg', 'file4.jpg']
|
34
|
+
|
35
|
+
expand('file-{a..e..2}.jpg')
|
36
|
+
// => ['file-a.jpg', 'file-c.jpg', 'file-e.jpg']
|
37
|
+
|
38
|
+
expand('file{00..10..5}.jpg')
|
39
|
+
// => ['file00.jpg', 'file05.jpg', 'file10.jpg']
|
40
|
+
|
41
|
+
expand('{{A..C},{a..c}}')
|
42
|
+
// => ['A', 'B', 'C', 'a', 'b', 'c']
|
43
|
+
|
44
|
+
expand('ppp{,config,oe{,conf}}')
|
45
|
+
// => ['ppp', 'pppconfig', 'pppoe', 'pppoeconf']
|
46
|
+
```
|
47
|
+
|
48
|
+
## API
|
49
|
+
|
50
|
+
```js
|
51
|
+
var expand = require('brace-expansion');
|
52
|
+
```
|
53
|
+
|
54
|
+
### var expanded = expand(str)
|
55
|
+
|
56
|
+
Return an array of all possible and valid expansions of `str`. If none are
|
57
|
+
found, `[str]` is returned.
|
58
|
+
|
59
|
+
Valid expansions are:
|
60
|
+
|
61
|
+
```js
|
62
|
+
/^(.*,)+(.+)?$/
|
63
|
+
// {a,b,...}
|
64
|
+
```
|
65
|
+
|
66
|
+
A comma separated list of options, like `{a,b}` or `{a,{b,c}}` or `{,a,}`.
|
67
|
+
|
68
|
+
```js
|
69
|
+
/^-?\d+\.\.-?\d+(\.\.-?\d+)?$/
|
70
|
+
// {x..y[..incr]}
|
71
|
+
```
|
72
|
+
|
73
|
+
A numeric sequence from `x` to `y` inclusive, with optional increment.
|
74
|
+
If `x` or `y` start with a leading `0`, all the numbers will be padded
|
75
|
+
to have equal length. Negative numbers and backwards iteration work too.
|
76
|
+
|
77
|
+
```js
|
78
|
+
/^-?\d+\.\.-?\d+(\.\.-?\d+)?$/
|
79
|
+
// {x..y[..incr]}
|
80
|
+
```
|
81
|
+
|
82
|
+
An alphabetic sequence from `x` to `y` inclusive, with optional increment.
|
83
|
+
`x` and `y` must be exactly one character, and if given, `incr` must be a
|
84
|
+
number.
|
85
|
+
|
86
|
+
For compatibility reasons, the string `${` is not eligible for brace expansion.
|
87
|
+
|
88
|
+
## Installation
|
89
|
+
|
90
|
+
With [npm](https://npmjs.org) do:
|
91
|
+
|
92
|
+
```bash
|
93
|
+
npm install brace-expansion
|
94
|
+
```
|
95
|
+
|
96
|
+
## Contributors
|
97
|
+
|
98
|
+
- [Julian Gruber](https://github.com/juliangruber)
|
99
|
+
- [Isaac Z. Schlueter](https://github.com/isaacs)
|
100
|
+
|
101
|
+
## Sponsors
|
102
|
+
|
103
|
+
This module is proudly supported by my [Sponsors](https://github.com/juliangruber/sponsors)!
|
104
|
+
|
105
|
+
Do you want to support modules like this to improve their quality, stability and weigh in on new features? Then please consider donating to my [Patreon](https://www.patreon.com/juliangruber). Not sure how much of my modules you're using? Try [feross/thanks](https://github.com/feross/thanks)!
|
106
|
+
|
107
|
+
## License
|
108
|
+
|
109
|
+
(MIT)
|
110
|
+
|
111
|
+
Copyright (c) 2013 Julian Gruber <julian@juliangruber.com>
|
112
|
+
|
113
|
+
Permission is hereby granted, free of charge, to any person obtaining a copy of
|
114
|
+
this software and associated documentation files (the "Software"), to deal in
|
115
|
+
the Software without restriction, including without limitation the rights to
|
116
|
+
use, copy, modify, merge, publish, distribute, sublicense, and/or sell copies
|
117
|
+
of the Software, and to permit persons to whom the Software is furnished to do
|
118
|
+
so, subject to the following conditions:
|
119
|
+
|
120
|
+
The above copyright notice and this permission notice shall be included in all
|
121
|
+
copies or substantial portions of the Software.
|
122
|
+
|
123
|
+
THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
|
124
|
+
IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
|
125
|
+
FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
|
126
|
+
AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
|
127
|
+
LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
|
128
|
+
OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
|
129
|
+
SOFTWARE.
|
@@ -0,0 +1,201 @@
|
|
1
|
+
var concatMap = require('concat-map');
|
2
|
+
var balanced = require('balanced-match');
|
3
|
+
|
4
|
+
module.exports = expandTop;
|
5
|
+
|
6
|
+
var escSlash = '\0SLASH'+Math.random()+'\0';
|
7
|
+
var escOpen = '\0OPEN'+Math.random()+'\0';
|
8
|
+
var escClose = '\0CLOSE'+Math.random()+'\0';
|
9
|
+
var escComma = '\0COMMA'+Math.random()+'\0';
|
10
|
+
var escPeriod = '\0PERIOD'+Math.random()+'\0';
|
11
|
+
|
12
|
+
function numeric(str) {
|
13
|
+
return parseInt(str, 10) == str
|
14
|
+
? parseInt(str, 10)
|
15
|
+
: str.charCodeAt(0);
|
16
|
+
}
|
17
|
+
|
18
|
+
function escapeBraces(str) {
|
19
|
+
return str.split('\\\\').join(escSlash)
|
20
|
+
.split('\\{').join(escOpen)
|
21
|
+
.split('\\}').join(escClose)
|
22
|
+
.split('\\,').join(escComma)
|
23
|
+
.split('\\.').join(escPeriod);
|
24
|
+
}
|
25
|
+
|
26
|
+
function unescapeBraces(str) {
|
27
|
+
return str.split(escSlash).join('\\')
|
28
|
+
.split(escOpen).join('{')
|
29
|
+
.split(escClose).join('}')
|
30
|
+
.split(escComma).join(',')
|
31
|
+
.split(escPeriod).join('.');
|
32
|
+
}
|
33
|
+
|
34
|
+
|
35
|
+
// Basically just str.split(","), but handling cases
|
36
|
+
// where we have nested braced sections, which should be
|
37
|
+
// treated as individual members, like {a,{b,c},d}
|
38
|
+
function parseCommaParts(str) {
|
39
|
+
if (!str)
|
40
|
+
return [''];
|
41
|
+
|
42
|
+
var parts = [];
|
43
|
+
var m = balanced('{', '}', str);
|
44
|
+
|
45
|
+
if (!m)
|
46
|
+
return str.split(',');
|
47
|
+
|
48
|
+
var pre = m.pre;
|
49
|
+
var body = m.body;
|
50
|
+
var post = m.post;
|
51
|
+
var p = pre.split(',');
|
52
|
+
|
53
|
+
p[p.length-1] += '{' + body + '}';
|
54
|
+
var postParts = parseCommaParts(post);
|
55
|
+
if (post.length) {
|
56
|
+
p[p.length-1] += postParts.shift();
|
57
|
+
p.push.apply(p, postParts);
|
58
|
+
}
|
59
|
+
|
60
|
+
parts.push.apply(parts, p);
|
61
|
+
|
62
|
+
return parts;
|
63
|
+
}
|
64
|
+
|
65
|
+
function expandTop(str) {
|
66
|
+
if (!str)
|
67
|
+
return [];
|
68
|
+
|
69
|
+
// I don't know why Bash 4.3 does this, but it does.
|
70
|
+
// Anything starting with {} will have the first two bytes preserved
|
71
|
+
// but *only* at the top level, so {},a}b will not expand to anything,
|
72
|
+
// but a{},b}c will be expanded to [a}c,abc].
|
73
|
+
// One could argue that this is a bug in Bash, but since the goal of
|
74
|
+
// this module is to match Bash's rules, we escape a leading {}
|
75
|
+
if (str.substr(0, 2) === '{}') {
|
76
|
+
str = '\\{\\}' + str.substr(2);
|
77
|
+
}
|
78
|
+
|
79
|
+
return expand(escapeBraces(str), true).map(unescapeBraces);
|
80
|
+
}
|
81
|
+
|
82
|
+
function identity(e) {
|
83
|
+
return e;
|
84
|
+
}
|
85
|
+
|
86
|
+
function embrace(str) {
|
87
|
+
return '{' + str + '}';
|
88
|
+
}
|
89
|
+
function isPadded(el) {
|
90
|
+
return /^-?0\d/.test(el);
|
91
|
+
}
|
92
|
+
|
93
|
+
function lte(i, y) {
|
94
|
+
return i <= y;
|
95
|
+
}
|
96
|
+
function gte(i, y) {
|
97
|
+
return i >= y;
|
98
|
+
}
|
99
|
+
|
100
|
+
function expand(str, isTop) {
|
101
|
+
var expansions = [];
|
102
|
+
|
103
|
+
var m = balanced('{', '}', str);
|
104
|
+
if (!m || /\$$/.test(m.pre)) return [str];
|
105
|
+
|
106
|
+
var isNumericSequence = /^-?\d+\.\.-?\d+(?:\.\.-?\d+)?$/.test(m.body);
|
107
|
+
var isAlphaSequence = /^[a-zA-Z]\.\.[a-zA-Z](?:\.\.-?\d+)?$/.test(m.body);
|
108
|
+
var isSequence = isNumericSequence || isAlphaSequence;
|
109
|
+
var isOptions = m.body.indexOf(',') >= 0;
|
110
|
+
if (!isSequence && !isOptions) {
|
111
|
+
// {a},b}
|
112
|
+
if (m.post.match(/,.*\}/)) {
|
113
|
+
str = m.pre + '{' + m.body + escClose + m.post;
|
114
|
+
return expand(str);
|
115
|
+
}
|
116
|
+
return [str];
|
117
|
+
}
|
118
|
+
|
119
|
+
var n;
|
120
|
+
if (isSequence) {
|
121
|
+
n = m.body.split(/\.\./);
|
122
|
+
} else {
|
123
|
+
n = parseCommaParts(m.body);
|
124
|
+
if (n.length === 1) {
|
125
|
+
// x{{a,b}}y ==> x{a}y x{b}y
|
126
|
+
n = expand(n[0], false).map(embrace);
|
127
|
+
if (n.length === 1) {
|
128
|
+
var post = m.post.length
|
129
|
+
? expand(m.post, false)
|
130
|
+
: [''];
|
131
|
+
return post.map(function(p) {
|
132
|
+
return m.pre + n[0] + p;
|
133
|
+
});
|
134
|
+
}
|
135
|
+
}
|
136
|
+
}
|
137
|
+
|
138
|
+
// at this point, n is the parts, and we know it's not a comma set
|
139
|
+
// with a single entry.
|
140
|
+
|
141
|
+
// no need to expand pre, since it is guaranteed to be free of brace-sets
|
142
|
+
var pre = m.pre;
|
143
|
+
var post = m.post.length
|
144
|
+
? expand(m.post, false)
|
145
|
+
: [''];
|
146
|
+
|
147
|
+
var N;
|
148
|
+
|
149
|
+
if (isSequence) {
|
150
|
+
var x = numeric(n[0]);
|
151
|
+
var y = numeric(n[1]);
|
152
|
+
var width = Math.max(n[0].length, n[1].length)
|
153
|
+
var incr = n.length == 3
|
154
|
+
? Math.abs(numeric(n[2]))
|
155
|
+
: 1;
|
156
|
+
var test = lte;
|
157
|
+
var reverse = y < x;
|
158
|
+
if (reverse) {
|
159
|
+
incr *= -1;
|
160
|
+
test = gte;
|
161
|
+
}
|
162
|
+
var pad = n.some(isPadded);
|
163
|
+
|
164
|
+
N = [];
|
165
|
+
|
166
|
+
for (var i = x; test(i, y); i += incr) {
|
167
|
+
var c;
|
168
|
+
if (isAlphaSequence) {
|
169
|
+
c = String.fromCharCode(i);
|
170
|
+
if (c === '\\')
|
171
|
+
c = '';
|
172
|
+
} else {
|
173
|
+
c = String(i);
|
174
|
+
if (pad) {
|
175
|
+
var need = width - c.length;
|
176
|
+
if (need > 0) {
|
177
|
+
var z = new Array(need + 1).join('0');
|
178
|
+
if (i < 0)
|
179
|
+
c = '-' + z + c.slice(1);
|
180
|
+
else
|
181
|
+
c = z + c;
|
182
|
+
}
|
183
|
+
}
|
184
|
+
}
|
185
|
+
N.push(c);
|
186
|
+
}
|
187
|
+
} else {
|
188
|
+
N = concatMap(n, function(el) { return expand(el, false) });
|
189
|
+
}
|
190
|
+
|
191
|
+
for (var j = 0; j < N.length; j++) {
|
192
|
+
for (var k = 0; k < post.length; k++) {
|
193
|
+
var expansion = pre + N[j] + post[k];
|
194
|
+
if (!isTop || isSequence || expansion)
|
195
|
+
expansions.push(expansion);
|
196
|
+
}
|
197
|
+
}
|
198
|
+
|
199
|
+
return expansions;
|
200
|
+
}
|
201
|
+
|
@@ -0,0 +1,47 @@
|
|
1
|
+
{
|
2
|
+
"name": "brace-expansion",
|
3
|
+
"description": "Brace expansion as known from sh/bash",
|
4
|
+
"version": "1.1.11",
|
5
|
+
"repository": {
|
6
|
+
"type": "git",
|
7
|
+
"url": "git://github.com/juliangruber/brace-expansion.git"
|
8
|
+
},
|
9
|
+
"homepage": "https://github.com/juliangruber/brace-expansion",
|
10
|
+
"main": "index.js",
|
11
|
+
"scripts": {
|
12
|
+
"test": "tape test/*.js",
|
13
|
+
"gentest": "bash test/generate.sh",
|
14
|
+
"bench": "matcha test/perf/bench.js"
|
15
|
+
},
|
16
|
+
"dependencies": {
|
17
|
+
"balanced-match": "^1.0.0",
|
18
|
+
"concat-map": "0.0.1"
|
19
|
+
},
|
20
|
+
"devDependencies": {
|
21
|
+
"matcha": "^0.7.0",
|
22
|
+
"tape": "^4.6.0"
|
23
|
+
},
|
24
|
+
"keywords": [],
|
25
|
+
"author": {
|
26
|
+
"name": "Julian Gruber",
|
27
|
+
"email": "mail@juliangruber.com",
|
28
|
+
"url": "http://juliangruber.com"
|
29
|
+
},
|
30
|
+
"license": "MIT",
|
31
|
+
"testling": {
|
32
|
+
"files": "test/*.js",
|
33
|
+
"browsers": [
|
34
|
+
"ie/8..latest",
|
35
|
+
"firefox/20..latest",
|
36
|
+
"firefox/nightly",
|
37
|
+
"chrome/25..latest",
|
38
|
+
"chrome/canary",
|
39
|
+
"opera/12..latest",
|
40
|
+
"opera/next",
|
41
|
+
"safari/5.1..latest",
|
42
|
+
"ipad/6.0..latest",
|
43
|
+
"iphone/6.0..latest",
|
44
|
+
"android-browser/4.2..latest"
|
45
|
+
]
|
46
|
+
}
|
47
|
+
}
|
@@ -0,0 +1,33 @@
|
|
1
|
+
{
|
2
|
+
"author": "Isaac Z. Schlueter <i@izs.me> (http://blog.izs.me)",
|
3
|
+
"name": "minimatch",
|
4
|
+
"description": "a glob matcher in javascript",
|
5
|
+
"version": "3.0.8",
|
6
|
+
"publishConfig": {
|
7
|
+
"tag": "v3.0-legacy"
|
8
|
+
},
|
9
|
+
"repository": {
|
10
|
+
"type": "git",
|
11
|
+
"url": "git://github.com/isaacs/minimatch.git"
|
12
|
+
},
|
13
|
+
"main": "minimatch.js",
|
14
|
+
"scripts": {
|
15
|
+
"test": "tap",
|
16
|
+
"preversion": "npm test",
|
17
|
+
"postversion": "npm publish",
|
18
|
+
"postpublish": "git push origin --all; git push origin --tags"
|
19
|
+
},
|
20
|
+
"engines": {
|
21
|
+
"node": "*"
|
22
|
+
},
|
23
|
+
"dependencies": {
|
24
|
+
"brace-expansion": "^1.1.7"
|
25
|
+
},
|
26
|
+
"devDependencies": {
|
27
|
+
"tap": "^15.1.6"
|
28
|
+
},
|
29
|
+
"license": "ISC",
|
30
|
+
"files": [
|
31
|
+
"minimatch.js"
|
32
|
+
]
|
33
|
+
}
|
@@ -0,0 +1,61 @@
|
|
1
|
+
{
|
2
|
+
"name": "@humanwhocodes/config-array",
|
3
|
+
"version": "0.11.11",
|
4
|
+
"description": "Glob-based configuration matching.",
|
5
|
+
"author": "Nicholas C. Zakas",
|
6
|
+
"main": "api.js",
|
7
|
+
"files": [
|
8
|
+
"api.js"
|
9
|
+
],
|
10
|
+
"repository": {
|
11
|
+
"type": "git",
|
12
|
+
"url": "git+https://github.com/humanwhocodes/config-array.git"
|
13
|
+
},
|
14
|
+
"bugs": {
|
15
|
+
"url": "https://github.com/humanwhocodes/config-array/issues"
|
16
|
+
},
|
17
|
+
"homepage": "https://github.com/humanwhocodes/config-array#readme",
|
18
|
+
"scripts": {
|
19
|
+
"build": "rollup -c",
|
20
|
+
"format": "nitpik",
|
21
|
+
"lint": "eslint *.config.js src/*.js tests/*.js",
|
22
|
+
"lint:fix": "eslint --fix *.config.js src/*.js tests/*.js",
|
23
|
+
"prepublish": "npm run build",
|
24
|
+
"test:coverage": "nyc --include src/*.js npm run test",
|
25
|
+
"test": "mocha -r esm tests/ --recursive"
|
26
|
+
},
|
27
|
+
"gitHooks": {
|
28
|
+
"pre-commit": "lint-staged"
|
29
|
+
},
|
30
|
+
"lint-staged": {
|
31
|
+
"*.js": [
|
32
|
+
"eslint --fix --ignore-pattern '!.eslintrc.js'"
|
33
|
+
]
|
34
|
+
},
|
35
|
+
"keywords": [
|
36
|
+
"configuration",
|
37
|
+
"configarray",
|
38
|
+
"config file"
|
39
|
+
],
|
40
|
+
"license": "Apache-2.0",
|
41
|
+
"engines": {
|
42
|
+
"node": ">=10.10.0"
|
43
|
+
},
|
44
|
+
"dependencies": {
|
45
|
+
"@humanwhocodes/object-schema": "^1.2.1",
|
46
|
+
"debug": "^4.1.1",
|
47
|
+
"minimatch": "^3.0.5"
|
48
|
+
},
|
49
|
+
"devDependencies": {
|
50
|
+
"@nitpik/javascript": "0.4.0",
|
51
|
+
"@nitpik/node": "0.0.5",
|
52
|
+
"chai": "4.3.8",
|
53
|
+
"eslint": "8.41.0",
|
54
|
+
"esm": "3.2.25",
|
55
|
+
"lint-staged": "14.0.1",
|
56
|
+
"mocha": "6.2.3",
|
57
|
+
"nyc": "14.1.1",
|
58
|
+
"rollup": "3.28.1",
|
59
|
+
"yorkie": "2.0.0"
|
60
|
+
}
|
61
|
+
}
|