mirror of
https://github.com/sstent/aicyclingcoach-go.git
synced 2026-03-10 06:55:28 +00:00
sync
This commit is contained in:
1
node_modules/.bin/acorn
generated
vendored
1
node_modules/.bin/acorn
generated
vendored
@@ -1 +0,0 @@
|
|||||||
../acorn/bin/acorn
|
|
||||||
1
node_modules/.bin/escodegen
generated
vendored
1
node_modules/.bin/escodegen
generated
vendored
@@ -1 +0,0 @@
|
|||||||
../escodegen/bin/escodegen.js
|
|
||||||
1
node_modules/.bin/esgenerate
generated
vendored
1
node_modules/.bin/esgenerate
generated
vendored
@@ -1 +0,0 @@
|
|||||||
../escodegen/bin/esgenerate.js
|
|
||||||
1
node_modules/.bin/esparse
generated
vendored
1
node_modules/.bin/esparse
generated
vendored
@@ -1 +0,0 @@
|
|||||||
../esprima/bin/esparse.js
|
|
||||||
1
node_modules/.bin/esvalidate
generated
vendored
1
node_modules/.bin/esvalidate
generated
vendored
@@ -1 +0,0 @@
|
|||||||
../esprima/bin/esvalidate.js
|
|
||||||
1
node_modules/.bin/sshpk-conv
generated
vendored
1
node_modules/.bin/sshpk-conv
generated
vendored
@@ -1 +0,0 @@
|
|||||||
../sshpk/bin/sshpk-conv
|
|
||||||
1
node_modules/.bin/sshpk-sign
generated
vendored
1
node_modules/.bin/sshpk-sign
generated
vendored
@@ -1 +0,0 @@
|
|||||||
../sshpk/bin/sshpk-sign
|
|
||||||
1
node_modules/.bin/sshpk-verify
generated
vendored
1
node_modules/.bin/sshpk-verify
generated
vendored
@@ -1 +0,0 @@
|
|||||||
../sshpk/bin/sshpk-verify
|
|
||||||
1
node_modules/.bin/uuid
generated
vendored
1
node_modules/.bin/uuid
generated
vendored
@@ -1 +0,0 @@
|
|||||||
../uuid/bin/uuid
|
|
||||||
987
node_modules/.package-lock.json
generated
vendored
987
node_modules/.package-lock.json
generated
vendored
@@ -1,987 +0,0 @@
|
|||||||
{
|
|
||||||
"name": "AICyclingCoach",
|
|
||||||
"lockfileVersion": 3,
|
|
||||||
"requires": true,
|
|
||||||
"packages": {
|
|
||||||
"node_modules/@react-leaflet/core": {
|
|
||||||
"version": "2.1.0",
|
|
||||||
"resolved": "https://registry.npmjs.org/@react-leaflet/core/-/core-2.1.0.tgz",
|
|
||||||
"integrity": "sha512-Qk7Pfu8BSarKGqILj4x7bCSZ1pjuAPZ+qmRwH5S7mDS91VSbVVsJSrW4qA+GPrro8t69gFYVMWb1Zc4yFmPiVg==",
|
|
||||||
"peerDependencies": {
|
|
||||||
"leaflet": "^1.9.0",
|
|
||||||
"react": "^18.0.0",
|
|
||||||
"react-dom": "^18.0.0"
|
|
||||||
}
|
|
||||||
},
|
|
||||||
"node_modules/abab": {
|
|
||||||
"version": "2.0.6",
|
|
||||||
"resolved": "https://registry.npmjs.org/abab/-/abab-2.0.6.tgz",
|
|
||||||
"integrity": "sha512-j2afSsaIENvHZN2B8GOpF566vZ5WVk5opAiMTvWgaQT8DkbOqsTfvNAvHoRGU2zzP8cPoqys+xHTRDWW8L+/BA==",
|
|
||||||
"deprecated": "Use your platform's native atob() and btoa() methods instead"
|
|
||||||
},
|
|
||||||
"node_modules/acorn": {
|
|
||||||
"version": "7.4.1",
|
|
||||||
"resolved": "https://registry.npmjs.org/acorn/-/acorn-7.4.1.tgz",
|
|
||||||
"integrity": "sha512-nQyp0o1/mNdbTO1PO6kHkwSrmgZ0MT/jCCpNiwbUjGoRN4dlBhqJtoQuCnEOKzgTVwg0ZWiCoQy6SxMebQVh8A==",
|
|
||||||
"bin": {
|
|
||||||
"acorn": "bin/acorn"
|
|
||||||
},
|
|
||||||
"engines": {
|
|
||||||
"node": ">=0.4.0"
|
|
||||||
}
|
|
||||||
},
|
|
||||||
"node_modules/acorn-globals": {
|
|
||||||
"version": "4.3.4",
|
|
||||||
"resolved": "https://registry.npmjs.org/acorn-globals/-/acorn-globals-4.3.4.tgz",
|
|
||||||
"integrity": "sha512-clfQEh21R+D0leSbUdWf3OcfqyaCSAQ8Ryq00bofSekfr9W8u1jyYZo6ir0xu9Gtcf7BjcHJpnbZH7JOCpP60A==",
|
|
||||||
"dependencies": {
|
|
||||||
"acorn": "^6.0.1",
|
|
||||||
"acorn-walk": "^6.0.1"
|
|
||||||
}
|
|
||||||
},
|
|
||||||
"node_modules/acorn-globals/node_modules/acorn": {
|
|
||||||
"version": "6.4.2",
|
|
||||||
"resolved": "https://registry.npmjs.org/acorn/-/acorn-6.4.2.tgz",
|
|
||||||
"integrity": "sha512-XtGIhXwF8YM8bJhGxG5kXgjkEuNGLTkoYqVE+KMR+aspr4KGYmKYg7yUe3KghyQ9yheNwLnjmzh/7+gfDBmHCQ==",
|
|
||||||
"bin": {
|
|
||||||
"acorn": "bin/acorn"
|
|
||||||
},
|
|
||||||
"engines": {
|
|
||||||
"node": ">=0.4.0"
|
|
||||||
}
|
|
||||||
},
|
|
||||||
"node_modules/acorn-walk": {
|
|
||||||
"version": "6.2.0",
|
|
||||||
"resolved": "https://registry.npmjs.org/acorn-walk/-/acorn-walk-6.2.0.tgz",
|
|
||||||
"integrity": "sha512-7evsyfH1cLOCdAzZAd43Cic04yKydNx0cF+7tiA19p1XnLLPU4dpCQOqpjqwokFe//vS0QqfqqjCS2JkiIs0cA==",
|
|
||||||
"engines": {
|
|
||||||
"node": ">=0.4.0"
|
|
||||||
}
|
|
||||||
},
|
|
||||||
"node_modules/ajv": {
|
|
||||||
"version": "6.12.6",
|
|
||||||
"resolved": "https://registry.npmjs.org/ajv/-/ajv-6.12.6.tgz",
|
|
||||||
"integrity": "sha512-j3fVLgvTo527anyYyJOGTYJbG+vnnQYvE0m5mmkc1TK+nxAppkCLMIL0aZ4dblVCNoGShhm+kzE4ZUykBoMg4g==",
|
|
||||||
"dependencies": {
|
|
||||||
"fast-deep-equal": "^3.1.1",
|
|
||||||
"fast-json-stable-stringify": "^2.0.0",
|
|
||||||
"json-schema-traverse": "^0.4.1",
|
|
||||||
"uri-js": "^4.2.2"
|
|
||||||
},
|
|
||||||
"funding": {
|
|
||||||
"type": "github",
|
|
||||||
"url": "https://github.com/sponsors/epoberezkin"
|
|
||||||
}
|
|
||||||
},
|
|
||||||
"node_modules/array-equal": {
|
|
||||||
"version": "1.0.2",
|
|
||||||
"resolved": "https://registry.npmjs.org/array-equal/-/array-equal-1.0.2.tgz",
|
|
||||||
"integrity": "sha512-gUHx76KtnhEgB3HOuFYiCm3FIdEs6ocM2asHvNTkfu/Y09qQVrrVVaOKENmS2KkSaGoxgXNqC+ZVtR/n0MOkSA==",
|
|
||||||
"funding": {
|
|
||||||
"url": "https://github.com/sponsors/sindresorhus"
|
|
||||||
}
|
|
||||||
},
|
|
||||||
"node_modules/asn1": {
|
|
||||||
"version": "0.2.6",
|
|
||||||
"resolved": "https://registry.npmjs.org/asn1/-/asn1-0.2.6.tgz",
|
|
||||||
"integrity": "sha512-ix/FxPn0MDjeyJ7i/yoHGFt/EX6LyNbxSEhPPXODPL+KB0VPk86UYfL0lMdy+KCnv+fmvIzySwaK5COwqVbWTQ==",
|
|
||||||
"dependencies": {
|
|
||||||
"safer-buffer": "~2.1.0"
|
|
||||||
}
|
|
||||||
},
|
|
||||||
"node_modules/assert-plus": {
|
|
||||||
"version": "1.0.0",
|
|
||||||
"resolved": "https://registry.npmjs.org/assert-plus/-/assert-plus-1.0.0.tgz",
|
|
||||||
"integrity": "sha512-NfJ4UzBCcQGLDlQq7nHxH+tv3kyZ0hHQqF5BO6J7tNJeP5do1llPr8dZ8zHonfhAu0PHAdMkSo+8o0wxg9lZWw==",
|
|
||||||
"engines": {
|
|
||||||
"node": ">=0.8"
|
|
||||||
}
|
|
||||||
},
|
|
||||||
"node_modules/asynckit": {
|
|
||||||
"version": "0.4.0",
|
|
||||||
"resolved": "https://registry.npmjs.org/asynckit/-/asynckit-0.4.0.tgz",
|
|
||||||
"integrity": "sha512-Oei9OH4tRh0YqU3GxhX79dM/mwVgvbZJaSNaRk+bshkj0S5cfHcgYakreBjrHwatXKbz+IoIdYLxrKim2MjW0Q=="
|
|
||||||
},
|
|
||||||
"node_modules/aws-sign2": {
|
|
||||||
"version": "0.7.0",
|
|
||||||
"resolved": "https://registry.npmjs.org/aws-sign2/-/aws-sign2-0.7.0.tgz",
|
|
||||||
"integrity": "sha512-08kcGqnYf/YmjoRhfxyu+CLxBjUtHLXLXX/vUfx9l2LYzG3c1m61nrpyFUZI6zeS+Li/wWMMidD9KgrqtGq3mA==",
|
|
||||||
"engines": {
|
|
||||||
"node": "*"
|
|
||||||
}
|
|
||||||
},
|
|
||||||
"node_modules/aws4": {
|
|
||||||
"version": "1.13.2",
|
|
||||||
"resolved": "https://registry.npmjs.org/aws4/-/aws4-1.13.2.tgz",
|
|
||||||
"integrity": "sha512-lHe62zvbTB5eEABUVi/AwVh0ZKY9rMMDhmm+eeyuuUQbQ3+J+fONVQOZyj+DdrvD4BY33uYniyRJ4UJIaSKAfw=="
|
|
||||||
},
|
|
||||||
"node_modules/bcrypt-pbkdf": {
|
|
||||||
"version": "1.0.2",
|
|
||||||
"resolved": "https://registry.npmjs.org/bcrypt-pbkdf/-/bcrypt-pbkdf-1.0.2.tgz",
|
|
||||||
"integrity": "sha512-qeFIXtP4MSoi6NLqO12WfqARWWuCKi2Rn/9hJLEmtB5yTNr9DqFWkJRCf2qShWzPeAMRnOgCrq0sg/KLv5ES9w==",
|
|
||||||
"dependencies": {
|
|
||||||
"tweetnacl": "^0.14.3"
|
|
||||||
}
|
|
||||||
},
|
|
||||||
"node_modules/browser-process-hrtime": {
|
|
||||||
"version": "1.0.0",
|
|
||||||
"resolved": "https://registry.npmjs.org/browser-process-hrtime/-/browser-process-hrtime-1.0.0.tgz",
|
|
||||||
"integrity": "sha512-9o5UecI3GhkpM6DrXr69PblIuWxPKk9Y0jHBRhdocZ2y7YECBFCsHm79Pr3OyR2AvjhDkabFJaDJMYRazHgsow=="
|
|
||||||
},
|
|
||||||
"node_modules/caseless": {
|
|
||||||
"version": "0.12.0",
|
|
||||||
"resolved": "https://registry.npmjs.org/caseless/-/caseless-0.12.0.tgz",
|
|
||||||
"integrity": "sha512-4tYFyifaFfGacoiObjJegolkwSU4xQNGbVgUiNYVUxbQ2x2lUsFvY4hVgVzGiIe6WLOPqycWXA40l+PWsxthUw=="
|
|
||||||
},
|
|
||||||
"node_modules/clsx": {
|
|
||||||
"version": "2.1.1",
|
|
||||||
"resolved": "https://registry.npmjs.org/clsx/-/clsx-2.1.1.tgz",
|
|
||||||
"integrity": "sha512-eYm0QWBtUrBWZWG0d386OGAw16Z995PiOVo2B7bjWSbHedGl5e0ZWaq65kOGgUSNesEIDkB9ISbTg/JK9dhCZA==",
|
|
||||||
"engines": {
|
|
||||||
"node": ">=6"
|
|
||||||
}
|
|
||||||
},
|
|
||||||
"node_modules/combined-stream": {
|
|
||||||
"version": "1.0.8",
|
|
||||||
"resolved": "https://registry.npmjs.org/combined-stream/-/combined-stream-1.0.8.tgz",
|
|
||||||
"integrity": "sha512-FQN4MRfuJeHf7cBbBMJFXhKSDq+2kAArBlmRBvcvFE5BB1HZKXtSFASDhdlz9zOYwxh8lDdnvmMOe/+5cdoEdg==",
|
|
||||||
"dependencies": {
|
|
||||||
"delayed-stream": "~1.0.0"
|
|
||||||
},
|
|
||||||
"engines": {
|
|
||||||
"node": ">= 0.8"
|
|
||||||
}
|
|
||||||
},
|
|
||||||
"node_modules/core-util-is": {
|
|
||||||
"version": "1.0.2",
|
|
||||||
"resolved": "https://registry.npmjs.org/core-util-is/-/core-util-is-1.0.2.tgz",
|
|
||||||
"integrity": "sha512-3lqz5YjWTYnW6dlDa5TLaTCcShfar1e40rmcJVwCBJC6mWlFuj0eCHIElmG1g5kyuJ/GD+8Wn4FFCcz4gJPfaQ=="
|
|
||||||
},
|
|
||||||
"node_modules/cssom": {
|
|
||||||
"version": "0.4.4",
|
|
||||||
"resolved": "https://registry.npmjs.org/cssom/-/cssom-0.4.4.tgz",
|
|
||||||
"integrity": "sha512-p3pvU7r1MyyqbTk+WbNJIgJjG2VmTIaB10rI93LzVPrmDJKkzKYMtxxyAvQXR/NS6otuzveI7+7BBq3SjBS2mw=="
|
|
||||||
},
|
|
||||||
"node_modules/cssstyle": {
|
|
||||||
"version": "2.3.0",
|
|
||||||
"resolved": "https://registry.npmjs.org/cssstyle/-/cssstyle-2.3.0.tgz",
|
|
||||||
"integrity": "sha512-AZL67abkUzIuvcHqk7c09cezpGNcxUxU4Ioi/05xHk4DQeTkWmGYftIE6ctU6AEt+Gn4n1lDStOtj7FKycP71A==",
|
|
||||||
"dependencies": {
|
|
||||||
"cssom": "~0.3.6"
|
|
||||||
},
|
|
||||||
"engines": {
|
|
||||||
"node": ">=8"
|
|
||||||
}
|
|
||||||
},
|
|
||||||
"node_modules/cssstyle/node_modules/cssom": {
|
|
||||||
"version": "0.3.8",
|
|
||||||
"resolved": "https://registry.npmjs.org/cssom/-/cssom-0.3.8.tgz",
|
|
||||||
"integrity": "sha512-b0tGHbfegbhPJpxpiBPU2sCkigAqtM9O121le6bbOlgyV+NyGyCmVfJ6QW9eRjz8CpNfWEOYBIMIGRYkLwsIYg=="
|
|
||||||
},
|
|
||||||
"node_modules/dashdash": {
|
|
||||||
"version": "1.14.1",
|
|
||||||
"resolved": "https://registry.npmjs.org/dashdash/-/dashdash-1.14.1.tgz",
|
|
||||||
"integrity": "sha512-jRFi8UDGo6j+odZiEpjazZaWqEal3w/basFjQHQEwVtZJGDpxbH1MeYluwCS8Xq5wmLJooDlMgvVarmWfGM44g==",
|
|
||||||
"dependencies": {
|
|
||||||
"assert-plus": "^1.0.0"
|
|
||||||
},
|
|
||||||
"engines": {
|
|
||||||
"node": ">=0.10"
|
|
||||||
}
|
|
||||||
},
|
|
||||||
"node_modules/data-urls": {
|
|
||||||
"version": "1.1.0",
|
|
||||||
"resolved": "https://registry.npmjs.org/data-urls/-/data-urls-1.1.0.tgz",
|
|
||||||
"integrity": "sha512-YTWYI9se1P55u58gL5GkQHW4P6VJBJ5iBT+B5a7i2Tjadhv52paJG0qHX4A0OR6/t52odI64KP2YvFpkDOi3eQ==",
|
|
||||||
"dependencies": {
|
|
||||||
"abab": "^2.0.0",
|
|
||||||
"whatwg-mimetype": "^2.2.0",
|
|
||||||
"whatwg-url": "^7.0.0"
|
|
||||||
}
|
|
||||||
},
|
|
||||||
"node_modules/deep-is": {
|
|
||||||
"version": "0.1.4",
|
|
||||||
"resolved": "https://registry.npmjs.org/deep-is/-/deep-is-0.1.4.tgz",
|
|
||||||
"integrity": "sha512-oIPzksmTg4/MriiaYGO+okXDT7ztn/w3Eptv/+gSIdMdKsJo0u4CfYNFJPy+4SKMuCqGw2wxnA+URMg3t8a/bQ=="
|
|
||||||
},
|
|
||||||
"node_modules/delayed-stream": {
|
|
||||||
"version": "1.0.0",
|
|
||||||
"resolved": "https://registry.npmjs.org/delayed-stream/-/delayed-stream-1.0.0.tgz",
|
|
||||||
"integrity": "sha512-ZySD7Nf91aLB0RxL4KGrKHBXl7Eds1DAmEdcoVawXnLD7SDhpNgtuII2aAkg7a7QS41jxPSZ17p4VdGnMHk3MQ==",
|
|
||||||
"engines": {
|
|
||||||
"node": ">=0.4.0"
|
|
||||||
}
|
|
||||||
},
|
|
||||||
"node_modules/domexception": {
|
|
||||||
"version": "1.0.1",
|
|
||||||
"resolved": "https://registry.npmjs.org/domexception/-/domexception-1.0.1.tgz",
|
|
||||||
"integrity": "sha512-raigMkn7CJNNo6Ihro1fzG7wr3fHuYVytzquZKX5n0yizGsTcYgzdIUwj1X9pK0VvjeihV+XiclP+DjwbsSKug==",
|
|
||||||
"deprecated": "Use your platform's native DOMException instead",
|
|
||||||
"dependencies": {
|
|
||||||
"webidl-conversions": "^4.0.2"
|
|
||||||
}
|
|
||||||
},
|
|
||||||
"node_modules/ecc-jsbn": {
|
|
||||||
"version": "0.1.2",
|
|
||||||
"resolved": "https://registry.npmjs.org/ecc-jsbn/-/ecc-jsbn-0.1.2.tgz",
|
|
||||||
"integrity": "sha512-eh9O+hwRHNbG4BLTjEl3nw044CkGm5X6LoaCf7LPp7UU8Qrt47JYNi6nPX8xjW97TKGKm1ouctg0QSpZe9qrnw==",
|
|
||||||
"dependencies": {
|
|
||||||
"jsbn": "~0.1.0",
|
|
||||||
"safer-buffer": "^2.1.0"
|
|
||||||
}
|
|
||||||
},
|
|
||||||
"node_modules/escodegen": {
|
|
||||||
"version": "1.14.3",
|
|
||||||
"resolved": "https://registry.npmjs.org/escodegen/-/escodegen-1.14.3.tgz",
|
|
||||||
"integrity": "sha512-qFcX0XJkdg+PB3xjZZG/wKSuT1PnQWx57+TVSjIMmILd2yC/6ByYElPwJnslDsuWuSAp4AwJGumarAAmJch5Kw==",
|
|
||||||
"dependencies": {
|
|
||||||
"esprima": "^4.0.1",
|
|
||||||
"estraverse": "^4.2.0",
|
|
||||||
"esutils": "^2.0.2",
|
|
||||||
"optionator": "^0.8.1"
|
|
||||||
},
|
|
||||||
"bin": {
|
|
||||||
"escodegen": "bin/escodegen.js",
|
|
||||||
"esgenerate": "bin/esgenerate.js"
|
|
||||||
},
|
|
||||||
"engines": {
|
|
||||||
"node": ">=4.0"
|
|
||||||
},
|
|
||||||
"optionalDependencies": {
|
|
||||||
"source-map": "~0.6.1"
|
|
||||||
}
|
|
||||||
},
|
|
||||||
"node_modules/esprima": {
|
|
||||||
"version": "4.0.1",
|
|
||||||
"resolved": "https://registry.npmjs.org/esprima/-/esprima-4.0.1.tgz",
|
|
||||||
"integrity": "sha512-eGuFFw7Upda+g4p+QHvnW0RyTX/SVeJBDM/gCtMARO0cLuT2HcEKnTPvhjV6aGeqrCB/sbNop0Kszm0jsaWU4A==",
|
|
||||||
"bin": {
|
|
||||||
"esparse": "bin/esparse.js",
|
|
||||||
"esvalidate": "bin/esvalidate.js"
|
|
||||||
},
|
|
||||||
"engines": {
|
|
||||||
"node": ">=4"
|
|
||||||
}
|
|
||||||
},
|
|
||||||
"node_modules/estraverse": {
|
|
||||||
"version": "4.3.0",
|
|
||||||
"resolved": "https://registry.npmjs.org/estraverse/-/estraverse-4.3.0.tgz",
|
|
||||||
"integrity": "sha512-39nnKffWz8xN1BU/2c79n9nB9HDzo0niYUqx6xyqUnyoAnQyyWpOTdZEeiCch8BBu515t4wp9ZmgVfVhn9EBpw==",
|
|
||||||
"engines": {
|
|
||||||
"node": ">=4.0"
|
|
||||||
}
|
|
||||||
},
|
|
||||||
"node_modules/esutils": {
|
|
||||||
"version": "2.0.3",
|
|
||||||
"resolved": "https://registry.npmjs.org/esutils/-/esutils-2.0.3.tgz",
|
|
||||||
"integrity": "sha512-kVscqXk4OCp68SZ0dkgEKVi6/8ij300KBWTJq32P/dYeWTSwK41WyTxalN1eRmA5Z9UU/LX9D7FWSmV9SAYx6g==",
|
|
||||||
"engines": {
|
|
||||||
"node": ">=0.10.0"
|
|
||||||
}
|
|
||||||
},
|
|
||||||
"node_modules/extend": {
|
|
||||||
"version": "3.0.2",
|
|
||||||
"resolved": "https://registry.npmjs.org/extend/-/extend-3.0.2.tgz",
|
|
||||||
"integrity": "sha512-fjquC59cD7CyW6urNXK0FBufkZcoiGG80wTuPujX590cB5Ttln20E2UB4S/WARVqhXffZl2LNgS+gQdPIIim/g=="
|
|
||||||
},
|
|
||||||
"node_modules/extsprintf": {
|
|
||||||
"version": "1.3.0",
|
|
||||||
"resolved": "https://registry.npmjs.org/extsprintf/-/extsprintf-1.3.0.tgz",
|
|
||||||
"integrity": "sha512-11Ndz7Nv+mvAC1j0ktTa7fAb0vLyGGX+rMHNBYQviQDGU0Hw7lhctJANqbPhu9nV9/izT/IntTgZ7Im/9LJs9g==",
|
|
||||||
"engines": [
|
|
||||||
"node >=0.6.0"
|
|
||||||
]
|
|
||||||
},
|
|
||||||
"node_modules/fast-deep-equal": {
|
|
||||||
"version": "3.1.3",
|
|
||||||
"resolved": "https://registry.npmjs.org/fast-deep-equal/-/fast-deep-equal-3.1.3.tgz",
|
|
||||||
"integrity": "sha512-f3qQ9oQy9j2AhBe/H9VC91wLmKBCCU/gDOnKNAYG5hswO7BLKj09Hc5HYNz9cGI++xlpDCIgDaitVs03ATR84Q=="
|
|
||||||
},
|
|
||||||
"node_modules/fast-json-stable-stringify": {
|
|
||||||
"version": "2.1.0",
|
|
||||||
"resolved": "https://registry.npmjs.org/fast-json-stable-stringify/-/fast-json-stable-stringify-2.1.0.tgz",
|
|
||||||
"integrity": "sha512-lhd/wF+Lk98HZoTCtlVraHtfh5XYijIjalXck7saUtuanSDyLMxnHhSXEDJqHxD7msR8D0uCmqlkwjCV8xvwHw=="
|
|
||||||
},
|
|
||||||
"node_modules/fast-levenshtein": {
|
|
||||||
"version": "2.0.6",
|
|
||||||
"resolved": "https://registry.npmjs.org/fast-levenshtein/-/fast-levenshtein-2.0.6.tgz",
|
|
||||||
"integrity": "sha512-DCXu6Ifhqcks7TZKY3Hxp3y6qphY5SJZmrWMDrKcERSOXWQdMhU9Ig/PYrzyw/ul9jOIyh0N4M0tbC5hodg8dw=="
|
|
||||||
},
|
|
||||||
"node_modules/forever-agent": {
|
|
||||||
"version": "0.6.1",
|
|
||||||
"resolved": "https://registry.npmjs.org/forever-agent/-/forever-agent-0.6.1.tgz",
|
|
||||||
"integrity": "sha512-j0KLYPhm6zeac4lz3oJ3o65qvgQCcPubiyotZrXqEaG4hNagNYO8qdlUrX5vwqv9ohqeT/Z3j6+yW067yWWdUw==",
|
|
||||||
"engines": {
|
|
||||||
"node": "*"
|
|
||||||
}
|
|
||||||
},
|
|
||||||
"node_modules/form-data": {
|
|
||||||
"version": "2.3.3",
|
|
||||||
"resolved": "https://registry.npmjs.org/form-data/-/form-data-2.3.3.tgz",
|
|
||||||
"integrity": "sha512-1lLKB2Mu3aGP1Q/2eCOx0fNbRMe7XdwktwOruhfqqd0rIJWwN4Dh+E3hrPSlDCXnSR7UtZ1N38rVXm+6+MEhJQ==",
|
|
||||||
"dependencies": {
|
|
||||||
"asynckit": "^0.4.0",
|
|
||||||
"combined-stream": "^1.0.6",
|
|
||||||
"mime-types": "^2.1.12"
|
|
||||||
},
|
|
||||||
"engines": {
|
|
||||||
"node": ">= 0.12"
|
|
||||||
}
|
|
||||||
},
|
|
||||||
"node_modules/getpass": {
|
|
||||||
"version": "0.1.7",
|
|
||||||
"resolved": "https://registry.npmjs.org/getpass/-/getpass-0.1.7.tgz",
|
|
||||||
"integrity": "sha512-0fzj9JxOLfJ+XGLhR8ze3unN0KZCgZwiSSDz168VERjK8Wl8kVSdcu2kspd4s4wtAa1y/qrVRiAA0WclVsu0ng==",
|
|
||||||
"dependencies": {
|
|
||||||
"assert-plus": "^1.0.0"
|
|
||||||
}
|
|
||||||
},
|
|
||||||
"node_modules/gpxparser": {
|
|
||||||
"version": "3.0.8",
|
|
||||||
"resolved": "https://registry.npmjs.org/gpxparser/-/gpxparser-3.0.8.tgz",
|
|
||||||
"integrity": "sha512-rXKrDQoXUHz7wZ+Q/C9EbzGNaRLGeEC3uT/KGMPOj3pCHXEJfKWYxVsd+WjVEyivuVsjJib7eR1H/BBO8USUgA==",
|
|
||||||
"dependencies": {
|
|
||||||
"jsdom": "^15.2.1",
|
|
||||||
"jsdom-global": "^3.0.2"
|
|
||||||
}
|
|
||||||
},
|
|
||||||
"node_modules/har-schema": {
|
|
||||||
"version": "2.0.0",
|
|
||||||
"resolved": "https://registry.npmjs.org/har-schema/-/har-schema-2.0.0.tgz",
|
|
||||||
"integrity": "sha512-Oqluz6zhGX8cyRaTQlFMPw80bSJVG2x/cFb8ZPhUILGgHka9SsokCCOQgpveePerqidZOrT14ipqfJb7ILcW5Q==",
|
|
||||||
"engines": {
|
|
||||||
"node": ">=4"
|
|
||||||
}
|
|
||||||
},
|
|
||||||
"node_modules/har-validator": {
|
|
||||||
"version": "5.1.5",
|
|
||||||
"resolved": "https://registry.npmjs.org/har-validator/-/har-validator-5.1.5.tgz",
|
|
||||||
"integrity": "sha512-nmT2T0lljbxdQZfspsno9hgrG3Uir6Ks5afism62poxqBM6sDnMEuPmzTq8XN0OEwqKLLdh1jQI3qyE66Nzb3w==",
|
|
||||||
"deprecated": "this library is no longer supported",
|
|
||||||
"dependencies": {
|
|
||||||
"ajv": "^6.12.3",
|
|
||||||
"har-schema": "^2.0.0"
|
|
||||||
},
|
|
||||||
"engines": {
|
|
||||||
"node": ">=6"
|
|
||||||
}
|
|
||||||
},
|
|
||||||
"node_modules/html-encoding-sniffer": {
|
|
||||||
"version": "1.0.2",
|
|
||||||
"resolved": "https://registry.npmjs.org/html-encoding-sniffer/-/html-encoding-sniffer-1.0.2.tgz",
|
|
||||||
"integrity": "sha512-71lZziiDnsuabfdYiUeWdCVyKuqwWi23L8YeIgV9jSSZHCtb6wB1BKWooH7L3tn4/FuZJMVWyNaIDr4RGmaSYw==",
|
|
||||||
"dependencies": {
|
|
||||||
"whatwg-encoding": "^1.0.1"
|
|
||||||
}
|
|
||||||
},
|
|
||||||
"node_modules/http-signature": {
|
|
||||||
"version": "1.2.0",
|
|
||||||
"resolved": "https://registry.npmjs.org/http-signature/-/http-signature-1.2.0.tgz",
|
|
||||||
"integrity": "sha512-CAbnr6Rz4CYQkLYUtSNXxQPUH2gK8f3iWexVlsnMeD+GjlsQ0Xsy1cOX+mN3dtxYomRy21CiOzU8Uhw6OwncEQ==",
|
|
||||||
"dependencies": {
|
|
||||||
"assert-plus": "^1.0.0",
|
|
||||||
"jsprim": "^1.2.2",
|
|
||||||
"sshpk": "^1.7.0"
|
|
||||||
},
|
|
||||||
"engines": {
|
|
||||||
"node": ">=0.8",
|
|
||||||
"npm": ">=1.3.7"
|
|
||||||
}
|
|
||||||
},
|
|
||||||
"node_modules/iconv-lite": {
|
|
||||||
"version": "0.4.24",
|
|
||||||
"resolved": "https://registry.npmjs.org/iconv-lite/-/iconv-lite-0.4.24.tgz",
|
|
||||||
"integrity": "sha512-v3MXnZAcvnywkTUEZomIActle7RXXeedOR31wwl7VlyoXO4Qi9arvSenNQWne1TcRwhCL1HwLI21bEqdpj8/rA==",
|
|
||||||
"dependencies": {
|
|
||||||
"safer-buffer": ">= 2.1.2 < 3"
|
|
||||||
},
|
|
||||||
"engines": {
|
|
||||||
"node": ">=0.10.0"
|
|
||||||
}
|
|
||||||
},
|
|
||||||
"node_modules/ip-regex": {
|
|
||||||
"version": "2.1.0",
|
|
||||||
"resolved": "https://registry.npmjs.org/ip-regex/-/ip-regex-2.1.0.tgz",
|
|
||||||
"integrity": "sha512-58yWmlHpp7VYfcdTwMTvwMmqx/Elfxjd9RXTDyMsbL7lLWmhMylLEqiYVLKuLzOZqVgiWXD9MfR62Vv89VRxkw==",
|
|
||||||
"engines": {
|
|
||||||
"node": ">=4"
|
|
||||||
}
|
|
||||||
},
|
|
||||||
"node_modules/is-typedarray": {
|
|
||||||
"version": "1.0.0",
|
|
||||||
"resolved": "https://registry.npmjs.org/is-typedarray/-/is-typedarray-1.0.0.tgz",
|
|
||||||
"integrity": "sha512-cyA56iCMHAh5CdzjJIa4aohJyeO1YbwLi3Jc35MmRU6poroFjIGZzUzupGiRPOjgHg9TLu43xbpwXk523fMxKA=="
|
|
||||||
},
|
|
||||||
"node_modules/isstream": {
|
|
||||||
"version": "0.1.2",
|
|
||||||
"resolved": "https://registry.npmjs.org/isstream/-/isstream-0.1.2.tgz",
|
|
||||||
"integrity": "sha512-Yljz7ffyPbrLpLngrMtZ7NduUgVvi6wG9RJ9IUcyCd59YQ911PBJphODUcbOVbqYfxe1wuYf/LJ8PauMRwsM/g=="
|
|
||||||
},
|
|
||||||
"node_modules/jsbn": {
|
|
||||||
"version": "0.1.1",
|
|
||||||
"resolved": "https://registry.npmjs.org/jsbn/-/jsbn-0.1.1.tgz",
|
|
||||||
"integrity": "sha512-UVU9dibq2JcFWxQPA6KCqj5O42VOmAY3zQUfEKxU0KpTGXwNoCjkX1e13eHNvw/xPynt6pU0rZ1htjWTNTSXsg=="
|
|
||||||
},
|
|
||||||
"node_modules/jsdom": {
|
|
||||||
"version": "15.2.1",
|
|
||||||
"resolved": "https://registry.npmjs.org/jsdom/-/jsdom-15.2.1.tgz",
|
|
||||||
"integrity": "sha512-fAl1W0/7T2G5vURSyxBzrJ1LSdQn6Tr5UX/xD4PXDx/PDgwygedfW6El/KIj3xJ7FU61TTYnc/l/B7P49Eqt6g==",
|
|
||||||
"dependencies": {
|
|
||||||
"abab": "^2.0.0",
|
|
||||||
"acorn": "^7.1.0",
|
|
||||||
"acorn-globals": "^4.3.2",
|
|
||||||
"array-equal": "^1.0.0",
|
|
||||||
"cssom": "^0.4.1",
|
|
||||||
"cssstyle": "^2.0.0",
|
|
||||||
"data-urls": "^1.1.0",
|
|
||||||
"domexception": "^1.0.1",
|
|
||||||
"escodegen": "^1.11.1",
|
|
||||||
"html-encoding-sniffer": "^1.0.2",
|
|
||||||
"nwsapi": "^2.2.0",
|
|
||||||
"parse5": "5.1.0",
|
|
||||||
"pn": "^1.1.0",
|
|
||||||
"request": "^2.88.0",
|
|
||||||
"request-promise-native": "^1.0.7",
|
|
||||||
"saxes": "^3.1.9",
|
|
||||||
"symbol-tree": "^3.2.2",
|
|
||||||
"tough-cookie": "^3.0.1",
|
|
||||||
"w3c-hr-time": "^1.0.1",
|
|
||||||
"w3c-xmlserializer": "^1.1.2",
|
|
||||||
"webidl-conversions": "^4.0.2",
|
|
||||||
"whatwg-encoding": "^1.0.5",
|
|
||||||
"whatwg-mimetype": "^2.3.0",
|
|
||||||
"whatwg-url": "^7.0.0",
|
|
||||||
"ws": "^7.0.0",
|
|
||||||
"xml-name-validator": "^3.0.0"
|
|
||||||
},
|
|
||||||
"engines": {
|
|
||||||
"node": ">=8"
|
|
||||||
},
|
|
||||||
"peerDependencies": {
|
|
||||||
"canvas": "^2.5.0"
|
|
||||||
},
|
|
||||||
"peerDependenciesMeta": {
|
|
||||||
"canvas": {
|
|
||||||
"optional": true
|
|
||||||
}
|
|
||||||
}
|
|
||||||
},
|
|
||||||
"node_modules/jsdom-global": {
|
|
||||||
"version": "3.0.2",
|
|
||||||
"resolved": "https://registry.npmjs.org/jsdom-global/-/jsdom-global-3.0.2.tgz",
|
|
||||||
"integrity": "sha512-t1KMcBkz/pT5JrvcJbpUR2u/w1kO9jXctaaGJ0vZDzwFnIvGWw9IDSRciT83kIs8Bnw4qpOl8bQK08V01YgMPg==",
|
|
||||||
"peerDependencies": {
|
|
||||||
"jsdom": ">=10.0.0"
|
|
||||||
}
|
|
||||||
},
|
|
||||||
"node_modules/json-schema": {
|
|
||||||
"version": "0.4.0",
|
|
||||||
"resolved": "https://registry.npmjs.org/json-schema/-/json-schema-0.4.0.tgz",
|
|
||||||
"integrity": "sha512-es94M3nTIfsEPisRafak+HDLfHXnKBhV3vU5eqPcS3flIWqcxJWgXHXiey3YrpaNsanY5ei1VoYEbOzijuq9BA=="
|
|
||||||
},
|
|
||||||
"node_modules/json-schema-traverse": {
|
|
||||||
"version": "0.4.1",
|
|
||||||
"resolved": "https://registry.npmjs.org/json-schema-traverse/-/json-schema-traverse-0.4.1.tgz",
|
|
||||||
"integrity": "sha512-xbbCH5dCYU5T8LcEhhuh7HJ88HXuW3qsI3Y0zOZFKfZEHcpWiHU/Jxzk629Brsab/mMiHQti9wMP+845RPe3Vg=="
|
|
||||||
},
|
|
||||||
"node_modules/json-stringify-safe": {
|
|
||||||
"version": "5.0.1",
|
|
||||||
"resolved": "https://registry.npmjs.org/json-stringify-safe/-/json-stringify-safe-5.0.1.tgz",
|
|
||||||
"integrity": "sha512-ZClg6AaYvamvYEE82d3Iyd3vSSIjQ+odgjaTzRuO3s7toCdFKczob2i0zCh7JE8kWn17yvAWhUVxvqGwUalsRA=="
|
|
||||||
},
|
|
||||||
"node_modules/jsprim": {
|
|
||||||
"version": "1.4.2",
|
|
||||||
"resolved": "https://registry.npmjs.org/jsprim/-/jsprim-1.4.2.tgz",
|
|
||||||
"integrity": "sha512-P2bSOMAc/ciLz6DzgjVlGJP9+BrJWu5UDGK70C2iweC5QBIeFf0ZXRvGjEj2uYgrY2MkAAhsSWHDWlFtEroZWw==",
|
|
||||||
"dependencies": {
|
|
||||||
"assert-plus": "1.0.0",
|
|
||||||
"extsprintf": "1.3.0",
|
|
||||||
"json-schema": "0.4.0",
|
|
||||||
"verror": "1.10.0"
|
|
||||||
},
|
|
||||||
"engines": {
|
|
||||||
"node": ">=0.6.0"
|
|
||||||
}
|
|
||||||
},
|
|
||||||
"node_modules/leaflet": {
|
|
||||||
"version": "1.9.4",
|
|
||||||
"resolved": "https://registry.npmjs.org/leaflet/-/leaflet-1.9.4.tgz",
|
|
||||||
"integrity": "sha512-nxS1ynzJOmOlHp+iL3FyWqK89GtNL8U8rvlMOsQdTTssxZwCXh8N2NB3GDQOL+YR3XnWyZAxwQixURb+FA74PA=="
|
|
||||||
},
|
|
||||||
"node_modules/levn": {
|
|
||||||
"version": "0.3.0",
|
|
||||||
"resolved": "https://registry.npmjs.org/levn/-/levn-0.3.0.tgz",
|
|
||||||
"integrity": "sha512-0OO4y2iOHix2W6ujICbKIaEQXvFQHue65vUG3pb5EUomzPI90z9hsA1VsO/dbIIpC53J8gxM9Q4Oho0jrCM/yA==",
|
|
||||||
"dependencies": {
|
|
||||||
"prelude-ls": "~1.1.2",
|
|
||||||
"type-check": "~0.3.2"
|
|
||||||
},
|
|
||||||
"engines": {
|
|
||||||
"node": ">= 0.8.0"
|
|
||||||
}
|
|
||||||
},
|
|
||||||
"node_modules/lodash": {
|
|
||||||
"version": "4.17.21",
|
|
||||||
"resolved": "https://registry.npmjs.org/lodash/-/lodash-4.17.21.tgz",
|
|
||||||
"integrity": "sha512-v2kDEe57lecTulaDIuNTPy3Ry4gLGJ6Z1O3vE1krgXZNrsQ+LFTGHVxVjcXPs17LhbZVGedAJv8XZ1tvj5FvSg=="
|
|
||||||
},
|
|
||||||
"node_modules/lodash.sortby": {
|
|
||||||
"version": "4.7.0",
|
|
||||||
"resolved": "https://registry.npmjs.org/lodash.sortby/-/lodash.sortby-4.7.0.tgz",
|
|
||||||
"integrity": "sha512-HDWXG8isMntAyRF5vZ7xKuEvOhT4AhlRt/3czTSjvGUxjYCBVRQY48ViDHyfYz9VIoBkW4TMGQNapx+l3RUwdA=="
|
|
||||||
},
|
|
||||||
"node_modules/mime-db": {
|
|
||||||
"version": "1.52.0",
|
|
||||||
"resolved": "https://registry.npmjs.org/mime-db/-/mime-db-1.52.0.tgz",
|
|
||||||
"integrity": "sha512-sPU4uV7dYlvtWJxwwxHD0PuihVNiE7TyAbQ5SWxDCB9mUYvOgroQOwYQQOKPJ8CIbE+1ETVlOoK1UC2nU3gYvg==",
|
|
||||||
"engines": {
|
|
||||||
"node": ">= 0.6"
|
|
||||||
}
|
|
||||||
},
|
|
||||||
"node_modules/mime-types": {
|
|
||||||
"version": "2.1.35",
|
|
||||||
"resolved": "https://registry.npmjs.org/mime-types/-/mime-types-2.1.35.tgz",
|
|
||||||
"integrity": "sha512-ZDY+bPm5zTTF+YpCrAU9nK0UgICYPT0QtT1NZWFv4s++TNkcgVaT0g6+4R2uI4MjQjzysHB1zxuWL50hzaeXiw==",
|
|
||||||
"dependencies": {
|
|
||||||
"mime-db": "1.52.0"
|
|
||||||
},
|
|
||||||
"engines": {
|
|
||||||
"node": ">= 0.6"
|
|
||||||
}
|
|
||||||
},
|
|
||||||
"node_modules/nwsapi": {
|
|
||||||
"version": "2.2.22",
|
|
||||||
"resolved": "https://registry.npmjs.org/nwsapi/-/nwsapi-2.2.22.tgz",
|
|
||||||
"integrity": "sha512-ujSMe1OWVn55euT1ihwCI1ZcAaAU3nxUiDwfDQldc51ZXaB9m2AyOn6/jh1BLe2t/G8xd6uKG1UBF2aZJeg2SQ=="
|
|
||||||
},
|
|
||||||
"node_modules/oauth-sign": {
|
|
||||||
"version": "0.9.0",
|
|
||||||
"resolved": "https://registry.npmjs.org/oauth-sign/-/oauth-sign-0.9.0.tgz",
|
|
||||||
"integrity": "sha512-fexhUFFPTGV8ybAtSIGbV6gOkSv8UtRbDBnAyLQw4QPKkgNlsH2ByPGtMUqdWkos6YCRmAqViwgZrJc/mRDzZQ==",
|
|
||||||
"engines": {
|
|
||||||
"node": "*"
|
|
||||||
}
|
|
||||||
},
|
|
||||||
"node_modules/optionator": {
|
|
||||||
"version": "0.8.3",
|
|
||||||
"resolved": "https://registry.npmjs.org/optionator/-/optionator-0.8.3.tgz",
|
|
||||||
"integrity": "sha512-+IW9pACdk3XWmmTXG8m3upGUJst5XRGzxMRjXzAuJ1XnIFNvfhjjIuYkDvysnPQ7qzqVzLt78BCruntqRhWQbA==",
|
|
||||||
"dependencies": {
|
|
||||||
"deep-is": "~0.1.3",
|
|
||||||
"fast-levenshtein": "~2.0.6",
|
|
||||||
"levn": "~0.3.0",
|
|
||||||
"prelude-ls": "~1.1.2",
|
|
||||||
"type-check": "~0.3.2",
|
|
||||||
"word-wrap": "~1.2.3"
|
|
||||||
},
|
|
||||||
"engines": {
|
|
||||||
"node": ">= 0.8.0"
|
|
||||||
}
|
|
||||||
},
|
|
||||||
"node_modules/parse5": {
|
|
||||||
"version": "5.1.0",
|
|
||||||
"resolved": "https://registry.npmjs.org/parse5/-/parse5-5.1.0.tgz",
|
|
||||||
"integrity": "sha512-fxNG2sQjHvlVAYmzBZS9YlDp6PTSSDwa98vkD4QgVDDCAo84z5X1t5XyJQ62ImdLXx5NdIIfihey6xpum9/gRQ=="
|
|
||||||
},
|
|
||||||
"node_modules/performance-now": {
|
|
||||||
"version": "2.1.0",
|
|
||||||
"resolved": "https://registry.npmjs.org/performance-now/-/performance-now-2.1.0.tgz",
|
|
||||||
"integrity": "sha512-7EAHlyLHI56VEIdK57uwHdHKIaAGbnXPiw0yWbarQZOKaKpvUIgW0jWRVLiatnM+XXlSwsanIBH/hzGMJulMow=="
|
|
||||||
},
|
|
||||||
"node_modules/pn": {
|
|
||||||
"version": "1.1.0",
|
|
||||||
"resolved": "https://registry.npmjs.org/pn/-/pn-1.1.0.tgz",
|
|
||||||
"integrity": "sha512-2qHaIQr2VLRFoxe2nASzsV6ef4yOOH+Fi9FBOVH6cqeSgUnoyySPZkxzLuzd+RYOQTRpROA0ztTMqxROKSb/nA=="
|
|
||||||
},
|
|
||||||
"node_modules/prelude-ls": {
|
|
||||||
"version": "1.1.2",
|
|
||||||
"resolved": "https://registry.npmjs.org/prelude-ls/-/prelude-ls-1.1.2.tgz",
|
|
||||||
"integrity": "sha512-ESF23V4SKG6lVSGZgYNpbsiaAkdab6ZgOxe52p7+Kid3W3u3bxR4Vfd/o21dmN7jSt0IwgZ4v5MUd26FEtXE9w==",
|
|
||||||
"engines": {
|
|
||||||
"node": ">= 0.8.0"
|
|
||||||
}
|
|
||||||
},
|
|
||||||
"node_modules/psl": {
|
|
||||||
"version": "1.15.0",
|
|
||||||
"resolved": "https://registry.npmjs.org/psl/-/psl-1.15.0.tgz",
|
|
||||||
"integrity": "sha512-JZd3gMVBAVQkSs6HdNZo9Sdo0LNcQeMNP3CozBJb3JYC/QUYZTnKxP+f8oWRX4rHP5EurWxqAHTSwUCjlNKa1w==",
|
|
||||||
"dependencies": {
|
|
||||||
"punycode": "^2.3.1"
|
|
||||||
},
|
|
||||||
"funding": {
|
|
||||||
"url": "https://github.com/sponsors/lupomontero"
|
|
||||||
}
|
|
||||||
},
|
|
||||||
"node_modules/punycode": {
|
|
||||||
"version": "2.3.1",
|
|
||||||
"resolved": "https://registry.npmjs.org/punycode/-/punycode-2.3.1.tgz",
|
|
||||||
"integrity": "sha512-vYt7UD1U9Wg6138shLtLOvdAu+8DsC/ilFtEVHcH+wydcSpNE20AfSOduf6MkRFahL5FY7X1oU7nKVZFtfq8Fg==",
|
|
||||||
"engines": {
|
|
||||||
"node": ">=6"
|
|
||||||
}
|
|
||||||
},
|
|
||||||
"node_modules/qs": {
|
|
||||||
"version": "6.5.3",
|
|
||||||
"resolved": "https://registry.npmjs.org/qs/-/qs-6.5.3.tgz",
|
|
||||||
"integrity": "sha512-qxXIEh4pCGfHICj1mAJQ2/2XVZkjCDTcEgfoSQxc/fYivUZxTkk7L3bDBJSoNrEzXI17oUO5Dp07ktqE5KzczA==",
|
|
||||||
"engines": {
|
|
||||||
"node": ">=0.6"
|
|
||||||
}
|
|
||||||
},
|
|
||||||
"node_modules/react-leaflet": {
|
|
||||||
"version": "4.2.1",
|
|
||||||
"resolved": "https://registry.npmjs.org/react-leaflet/-/react-leaflet-4.2.1.tgz",
|
|
||||||
"integrity": "sha512-p9chkvhcKrWn/H/1FFeVSqLdReGwn2qmiobOQGO3BifX+/vV/39qhY8dGqbdcPh1e6jxh/QHriLXr7a4eLFK4Q==",
|
|
||||||
"dependencies": {
|
|
||||||
"@react-leaflet/core": "^2.1.0"
|
|
||||||
},
|
|
||||||
"peerDependencies": {
|
|
||||||
"leaflet": "^1.9.0",
|
|
||||||
"react": "^18.0.0",
|
|
||||||
"react-dom": "^18.0.0"
|
|
||||||
}
|
|
||||||
},
|
|
||||||
"node_modules/react-toastify": {
|
|
||||||
"version": "11.0.5",
|
|
||||||
"resolved": "https://registry.npmjs.org/react-toastify/-/react-toastify-11.0.5.tgz",
|
|
||||||
"integrity": "sha512-EpqHBGvnSTtHYhCPLxML05NLY2ZX0JURbAdNYa6BUkk+amz4wbKBQvoKQAB0ardvSarUBuY4Q4s1sluAzZwkmA==",
|
|
||||||
"dependencies": {
|
|
||||||
"clsx": "^2.1.1"
|
|
||||||
},
|
|
||||||
"peerDependencies": {
|
|
||||||
"react": "^18 || ^19",
|
|
||||||
"react-dom": "^18 || ^19"
|
|
||||||
}
|
|
||||||
},
|
|
||||||
"node_modules/request": {
|
|
||||||
"version": "2.88.2",
|
|
||||||
"resolved": "https://registry.npmjs.org/request/-/request-2.88.2.tgz",
|
|
||||||
"integrity": "sha512-MsvtOrfG9ZcrOwAW+Qi+F6HbD0CWXEh9ou77uOb7FM2WPhwT7smM833PzanhJLsgXjN89Ir6V2PczXNnMpwKhw==",
|
|
||||||
"deprecated": "request has been deprecated, see https://github.com/request/request/issues/3142",
|
|
||||||
"dependencies": {
|
|
||||||
"aws-sign2": "~0.7.0",
|
|
||||||
"aws4": "^1.8.0",
|
|
||||||
"caseless": "~0.12.0",
|
|
||||||
"combined-stream": "~1.0.6",
|
|
||||||
"extend": "~3.0.2",
|
|
||||||
"forever-agent": "~0.6.1",
|
|
||||||
"form-data": "~2.3.2",
|
|
||||||
"har-validator": "~5.1.3",
|
|
||||||
"http-signature": "~1.2.0",
|
|
||||||
"is-typedarray": "~1.0.0",
|
|
||||||
"isstream": "~0.1.2",
|
|
||||||
"json-stringify-safe": "~5.0.1",
|
|
||||||
"mime-types": "~2.1.19",
|
|
||||||
"oauth-sign": "~0.9.0",
|
|
||||||
"performance-now": "^2.1.0",
|
|
||||||
"qs": "~6.5.2",
|
|
||||||
"safe-buffer": "^5.1.2",
|
|
||||||
"tough-cookie": "~2.5.0",
|
|
||||||
"tunnel-agent": "^0.6.0",
|
|
||||||
"uuid": "^3.3.2"
|
|
||||||
},
|
|
||||||
"engines": {
|
|
||||||
"node": ">= 6"
|
|
||||||
}
|
|
||||||
},
|
|
||||||
"node_modules/request-promise-core": {
|
|
||||||
"version": "1.1.4",
|
|
||||||
"resolved": "https://registry.npmjs.org/request-promise-core/-/request-promise-core-1.1.4.tgz",
|
|
||||||
"integrity": "sha512-TTbAfBBRdWD7aNNOoVOBH4pN/KigV6LyapYNNlAPA8JwbovRti1E88m3sYAwsLi5ryhPKsE9APwnjFTgdUjTpw==",
|
|
||||||
"dependencies": {
|
|
||||||
"lodash": "^4.17.19"
|
|
||||||
},
|
|
||||||
"engines": {
|
|
||||||
"node": ">=0.10.0"
|
|
||||||
},
|
|
||||||
"peerDependencies": {
|
|
||||||
"request": "^2.34"
|
|
||||||
}
|
|
||||||
},
|
|
||||||
"node_modules/request-promise-native": {
|
|
||||||
"version": "1.0.9",
|
|
||||||
"resolved": "https://registry.npmjs.org/request-promise-native/-/request-promise-native-1.0.9.tgz",
|
|
||||||
"integrity": "sha512-wcW+sIUiWnKgNY0dqCpOZkUbF/I+YPi+f09JZIDa39Ec+q82CpSYniDp+ISgTTbKmnpJWASeJBPZmoxH84wt3g==",
|
|
||||||
"deprecated": "request-promise-native has been deprecated because it extends the now deprecated request package, see https://github.com/request/request/issues/3142",
|
|
||||||
"dependencies": {
|
|
||||||
"request-promise-core": "1.1.4",
|
|
||||||
"stealthy-require": "^1.1.1",
|
|
||||||
"tough-cookie": "^2.3.3"
|
|
||||||
},
|
|
||||||
"engines": {
|
|
||||||
"node": ">=0.12.0"
|
|
||||||
},
|
|
||||||
"peerDependencies": {
|
|
||||||
"request": "^2.34"
|
|
||||||
}
|
|
||||||
},
|
|
||||||
"node_modules/request-promise-native/node_modules/tough-cookie": {
|
|
||||||
"version": "2.5.0",
|
|
||||||
"resolved": "https://registry.npmjs.org/tough-cookie/-/tough-cookie-2.5.0.tgz",
|
|
||||||
"integrity": "sha512-nlLsUzgm1kfLXSXfRZMc1KLAugd4hqJHDTvc2hDIwS3mZAfMEuMbc03SujMF+GEcpaX/qboeycw6iO8JwVv2+g==",
|
|
||||||
"dependencies": {
|
|
||||||
"psl": "^1.1.28",
|
|
||||||
"punycode": "^2.1.1"
|
|
||||||
},
|
|
||||||
"engines": {
|
|
||||||
"node": ">=0.8"
|
|
||||||
}
|
|
||||||
},
|
|
||||||
"node_modules/request/node_modules/tough-cookie": {
|
|
||||||
"version": "2.5.0",
|
|
||||||
"resolved": "https://registry.npmjs.org/tough-cookie/-/tough-cookie-2.5.0.tgz",
|
|
||||||
"integrity": "sha512-nlLsUzgm1kfLXSXfRZMc1KLAugd4hqJHDTvc2hDIwS3mZAfMEuMbc03SujMF+GEcpaX/qboeycw6iO8JwVv2+g==",
|
|
||||||
"dependencies": {
|
|
||||||
"psl": "^1.1.28",
|
|
||||||
"punycode": "^2.1.1"
|
|
||||||
},
|
|
||||||
"engines": {
|
|
||||||
"node": ">=0.8"
|
|
||||||
}
|
|
||||||
},
|
|
||||||
"node_modules/safe-buffer": {
|
|
||||||
"version": "5.2.1",
|
|
||||||
"resolved": "https://registry.npmjs.org/safe-buffer/-/safe-buffer-5.2.1.tgz",
|
|
||||||
"integrity": "sha512-rp3So07KcdmmKbGvgaNxQSJr7bGVSVk5S9Eq1F+ppbRo70+YeaDxkw5Dd8NPN+GD6bjnYm2VuPuCXmpuYvmCXQ==",
|
|
||||||
"funding": [
|
|
||||||
{
|
|
||||||
"type": "github",
|
|
||||||
"url": "https://github.com/sponsors/feross"
|
|
||||||
},
|
|
||||||
{
|
|
||||||
"type": "patreon",
|
|
||||||
"url": "https://www.patreon.com/feross"
|
|
||||||
},
|
|
||||||
{
|
|
||||||
"type": "consulting",
|
|
||||||
"url": "https://feross.org/support"
|
|
||||||
}
|
|
||||||
]
|
|
||||||
},
|
|
||||||
"node_modules/safer-buffer": {
|
|
||||||
"version": "2.1.2",
|
|
||||||
"resolved": "https://registry.npmjs.org/safer-buffer/-/safer-buffer-2.1.2.tgz",
|
|
||||||
"integrity": "sha512-YZo3K82SD7Riyi0E1EQPojLz7kpepnSQI9IyPbHHg1XXXevb5dJI7tpyN2ADxGcQbHG7vcyRHk0cbwqcQriUtg=="
|
|
||||||
},
|
|
||||||
"node_modules/saxes": {
|
|
||||||
"version": "3.1.11",
|
|
||||||
"resolved": "https://registry.npmjs.org/saxes/-/saxes-3.1.11.tgz",
|
|
||||||
"integrity": "sha512-Ydydq3zC+WYDJK1+gRxRapLIED9PWeSuuS41wqyoRmzvhhh9nc+QQrVMKJYzJFULazeGhzSV0QleN2wD3boh2g==",
|
|
||||||
"dependencies": {
|
|
||||||
"xmlchars": "^2.1.1"
|
|
||||||
},
|
|
||||||
"engines": {
|
|
||||||
"node": ">=8"
|
|
||||||
}
|
|
||||||
},
|
|
||||||
"node_modules/source-map": {
|
|
||||||
"version": "0.6.1",
|
|
||||||
"resolved": "https://registry.npmjs.org/source-map/-/source-map-0.6.1.tgz",
|
|
||||||
"integrity": "sha512-UjgapumWlbMhkBgzT7Ykc5YXUT46F0iKu8SGXq0bcwP5dz/h0Plj6enJqjz1Zbq2l5WaqYnrVbwWOWMyF3F47g==",
|
|
||||||
"optional": true,
|
|
||||||
"engines": {
|
|
||||||
"node": ">=0.10.0"
|
|
||||||
}
|
|
||||||
},
|
|
||||||
"node_modules/sshpk": {
|
|
||||||
"version": "1.18.0",
|
|
||||||
"resolved": "https://registry.npmjs.org/sshpk/-/sshpk-1.18.0.tgz",
|
|
||||||
"integrity": "sha512-2p2KJZTSqQ/I3+HX42EpYOa2l3f8Erv8MWKsy2I9uf4wA7yFIkXRffYdsx86y6z4vHtV8u7g+pPlr8/4ouAxsQ==",
|
|
||||||
"dependencies": {
|
|
||||||
"asn1": "~0.2.3",
|
|
||||||
"assert-plus": "^1.0.0",
|
|
||||||
"bcrypt-pbkdf": "^1.0.0",
|
|
||||||
"dashdash": "^1.12.0",
|
|
||||||
"ecc-jsbn": "~0.1.1",
|
|
||||||
"getpass": "^0.1.1",
|
|
||||||
"jsbn": "~0.1.0",
|
|
||||||
"safer-buffer": "^2.0.2",
|
|
||||||
"tweetnacl": "~0.14.0"
|
|
||||||
},
|
|
||||||
"bin": {
|
|
||||||
"sshpk-conv": "bin/sshpk-conv",
|
|
||||||
"sshpk-sign": "bin/sshpk-sign",
|
|
||||||
"sshpk-verify": "bin/sshpk-verify"
|
|
||||||
},
|
|
||||||
"engines": {
|
|
||||||
"node": ">=0.10.0"
|
|
||||||
}
|
|
||||||
},
|
|
||||||
"node_modules/stealthy-require": {
|
|
||||||
"version": "1.1.1",
|
|
||||||
"resolved": "https://registry.npmjs.org/stealthy-require/-/stealthy-require-1.1.1.tgz",
|
|
||||||
"integrity": "sha512-ZnWpYnYugiOVEY5GkcuJK1io5V8QmNYChG62gSit9pQVGErXtrKuPC55ITaVSukmMta5qpMU7vqLt2Lnni4f/g==",
|
|
||||||
"engines": {
|
|
||||||
"node": ">=0.10.0"
|
|
||||||
}
|
|
||||||
},
|
|
||||||
"node_modules/symbol-tree": {
|
|
||||||
"version": "3.2.4",
|
|
||||||
"resolved": "https://registry.npmjs.org/symbol-tree/-/symbol-tree-3.2.4.tgz",
|
|
||||||
"integrity": "sha512-9QNk5KwDF+Bvz+PyObkmSYjI5ksVUYtjW7AU22r2NKcfLJcXp96hkDWU3+XndOsUb+AQ9QhfzfCT2O+CNWT5Tw=="
|
|
||||||
},
|
|
||||||
"node_modules/tough-cookie": {
|
|
||||||
"version": "3.0.1",
|
|
||||||
"resolved": "https://registry.npmjs.org/tough-cookie/-/tough-cookie-3.0.1.tgz",
|
|
||||||
"integrity": "sha512-yQyJ0u4pZsv9D4clxO69OEjLWYw+jbgspjTue4lTQZLfV0c5l1VmK2y1JK8E9ahdpltPOaAThPcp5nKPUgSnsg==",
|
|
||||||
"dependencies": {
|
|
||||||
"ip-regex": "^2.1.0",
|
|
||||||
"psl": "^1.1.28",
|
|
||||||
"punycode": "^2.1.1"
|
|
||||||
},
|
|
||||||
"engines": {
|
|
||||||
"node": ">=6"
|
|
||||||
}
|
|
||||||
},
|
|
||||||
"node_modules/tr46": {
|
|
||||||
"version": "1.0.1",
|
|
||||||
"resolved": "https://registry.npmjs.org/tr46/-/tr46-1.0.1.tgz",
|
|
||||||
"integrity": "sha512-dTpowEjclQ7Kgx5SdBkqRzVhERQXov8/l9Ft9dVM9fmg0W0KQSVaXX9T4i6twCPNtYiZM53lpSSUAwJbFPOHxA==",
|
|
||||||
"dependencies": {
|
|
||||||
"punycode": "^2.1.0"
|
|
||||||
}
|
|
||||||
},
|
|
||||||
"node_modules/tunnel-agent": {
|
|
||||||
"version": "0.6.0",
|
|
||||||
"resolved": "https://registry.npmjs.org/tunnel-agent/-/tunnel-agent-0.6.0.tgz",
|
|
||||||
"integrity": "sha512-McnNiV1l8RYeY8tBgEpuodCC1mLUdbSN+CYBL7kJsJNInOP8UjDDEwdk6Mw60vdLLrr5NHKZhMAOSrR2NZuQ+w==",
|
|
||||||
"dependencies": {
|
|
||||||
"safe-buffer": "^5.0.1"
|
|
||||||
},
|
|
||||||
"engines": {
|
|
||||||
"node": "*"
|
|
||||||
}
|
|
||||||
},
|
|
||||||
"node_modules/tweetnacl": {
|
|
||||||
"version": "0.14.5",
|
|
||||||
"resolved": "https://registry.npmjs.org/tweetnacl/-/tweetnacl-0.14.5.tgz",
|
|
||||||
"integrity": "sha512-KXXFFdAbFXY4geFIwoyNK+f5Z1b7swfXABfL7HXCmoIWMKU3dmS26672A4EeQtDzLKy7SXmfBu51JolvEKwtGA=="
|
|
||||||
},
|
|
||||||
"node_modules/type-check": {
|
|
||||||
"version": "0.3.2",
|
|
||||||
"resolved": "https://registry.npmjs.org/type-check/-/type-check-0.3.2.tgz",
|
|
||||||
"integrity": "sha512-ZCmOJdvOWDBYJlzAoFkC+Q0+bUyEOS1ltgp1MGU03fqHG+dbi9tBFU2Rd9QKiDZFAYrhPh2JUf7rZRIuHRKtOg==",
|
|
||||||
"dependencies": {
|
|
||||||
"prelude-ls": "~1.1.2"
|
|
||||||
},
|
|
||||||
"engines": {
|
|
||||||
"node": ">= 0.8.0"
|
|
||||||
}
|
|
||||||
},
|
|
||||||
"node_modules/uri-js": {
|
|
||||||
"version": "4.4.1",
|
|
||||||
"resolved": "https://registry.npmjs.org/uri-js/-/uri-js-4.4.1.tgz",
|
|
||||||
"integrity": "sha512-7rKUyy33Q1yc98pQ1DAmLtwX109F7TIfWlW1Ydo8Wl1ii1SeHieeh0HHfPeL2fMXK6z0s8ecKs9frCuLJvndBg==",
|
|
||||||
"dependencies": {
|
|
||||||
"punycode": "^2.1.0"
|
|
||||||
}
|
|
||||||
},
|
|
||||||
"node_modules/uuid": {
|
|
||||||
"version": "3.4.0",
|
|
||||||
"resolved": "https://registry.npmjs.org/uuid/-/uuid-3.4.0.tgz",
|
|
||||||
"integrity": "sha512-HjSDRw6gZE5JMggctHBcjVak08+KEVhSIiDzFnT9S9aegmp85S/bReBVTb4QTFaRNptJ9kuYaNhnbNEOkbKb/A==",
|
|
||||||
"deprecated": "Please upgrade to version 7 or higher. Older versions may use Math.random() in certain circumstances, which is known to be problematic. See https://v8.dev/blog/math-random for details.",
|
|
||||||
"bin": {
|
|
||||||
"uuid": "bin/uuid"
|
|
||||||
}
|
|
||||||
},
|
|
||||||
"node_modules/verror": {
|
|
||||||
"version": "1.10.0",
|
|
||||||
"resolved": "https://registry.npmjs.org/verror/-/verror-1.10.0.tgz",
|
|
||||||
"integrity": "sha512-ZZKSmDAEFOijERBLkmYfJ+vmk3w+7hOLYDNkRCuRuMJGEmqYNCNLyBBFwWKVMhfwaEF3WOd0Zlw86U/WC/+nYw==",
|
|
||||||
"engines": [
|
|
||||||
"node >=0.6.0"
|
|
||||||
],
|
|
||||||
"dependencies": {
|
|
||||||
"assert-plus": "^1.0.0",
|
|
||||||
"core-util-is": "1.0.2",
|
|
||||||
"extsprintf": "^1.2.0"
|
|
||||||
}
|
|
||||||
},
|
|
||||||
"node_modules/w3c-hr-time": {
|
|
||||||
"version": "1.0.2",
|
|
||||||
"resolved": "https://registry.npmjs.org/w3c-hr-time/-/w3c-hr-time-1.0.2.tgz",
|
|
||||||
"integrity": "sha512-z8P5DvDNjKDoFIHK7q8r8lackT6l+jo/Ye3HOle7l9nICP9lf1Ci25fy9vHd0JOWewkIFzXIEig3TdKT7JQ5fQ==",
|
|
||||||
"deprecated": "Use your platform's native performance.now() and performance.timeOrigin.",
|
|
||||||
"dependencies": {
|
|
||||||
"browser-process-hrtime": "^1.0.0"
|
|
||||||
}
|
|
||||||
},
|
|
||||||
"node_modules/w3c-xmlserializer": {
|
|
||||||
"version": "1.1.2",
|
|
||||||
"resolved": "https://registry.npmjs.org/w3c-xmlserializer/-/w3c-xmlserializer-1.1.2.tgz",
|
|
||||||
"integrity": "sha512-p10l/ayESzrBMYWRID6xbuCKh2Fp77+sA0doRuGn4tTIMrrZVeqfpKjXHY+oDh3K4nLdPgNwMTVP6Vp4pvqbNg==",
|
|
||||||
"dependencies": {
|
|
||||||
"domexception": "^1.0.1",
|
|
||||||
"webidl-conversions": "^4.0.2",
|
|
||||||
"xml-name-validator": "^3.0.0"
|
|
||||||
}
|
|
||||||
},
|
|
||||||
"node_modules/webidl-conversions": {
|
|
||||||
"version": "4.0.2",
|
|
||||||
"resolved": "https://registry.npmjs.org/webidl-conversions/-/webidl-conversions-4.0.2.tgz",
|
|
||||||
"integrity": "sha512-YQ+BmxuTgd6UXZW3+ICGfyqRyHXVlD5GtQr5+qjiNW7bF0cqrzX500HVXPBOvgXb5YnzDd+h0zqyv61KUD7+Sg=="
|
|
||||||
},
|
|
||||||
"node_modules/whatwg-encoding": {
|
|
||||||
"version": "1.0.5",
|
|
||||||
"resolved": "https://registry.npmjs.org/whatwg-encoding/-/whatwg-encoding-1.0.5.tgz",
|
|
||||||
"integrity": "sha512-b5lim54JOPN9HtzvK9HFXvBma/rnfFeqsic0hSpjtDbVxR3dJKLc+KB4V6GgiGOvl7CY/KNh8rxSo9DKQrnUEw==",
|
|
||||||
"dependencies": {
|
|
||||||
"iconv-lite": "0.4.24"
|
|
||||||
}
|
|
||||||
},
|
|
||||||
"node_modules/whatwg-mimetype": {
|
|
||||||
"version": "2.3.0",
|
|
||||||
"resolved": "https://registry.npmjs.org/whatwg-mimetype/-/whatwg-mimetype-2.3.0.tgz",
|
|
||||||
"integrity": "sha512-M4yMwr6mAnQz76TbJm914+gPpB/nCwvZbJU28cUD6dR004SAxDLOOSUaB1JDRqLtaOV/vi0IC5lEAGFgrjGv/g=="
|
|
||||||
},
|
|
||||||
"node_modules/whatwg-url": {
|
|
||||||
"version": "7.1.0",
|
|
||||||
"resolved": "https://registry.npmjs.org/whatwg-url/-/whatwg-url-7.1.0.tgz",
|
|
||||||
"integrity": "sha512-WUu7Rg1DroM7oQvGWfOiAK21n74Gg+T4elXEQYkOhtyLeWiJFoOGLXPKI/9gzIie9CtwVLm8wtw6YJdKyxSjeg==",
|
|
||||||
"dependencies": {
|
|
||||||
"lodash.sortby": "^4.7.0",
|
|
||||||
"tr46": "^1.0.1",
|
|
||||||
"webidl-conversions": "^4.0.2"
|
|
||||||
}
|
|
||||||
},
|
|
||||||
"node_modules/word-wrap": {
|
|
||||||
"version": "1.2.5",
|
|
||||||
"resolved": "https://registry.npmjs.org/word-wrap/-/word-wrap-1.2.5.tgz",
|
|
||||||
"integrity": "sha512-BN22B5eaMMI9UMtjrGd5g5eCYPpCPDUy0FJXbYsaT5zYxjFOckS53SQDE3pWkVoWpHXVb3BrYcEN4Twa55B5cA==",
|
|
||||||
"engines": {
|
|
||||||
"node": ">=0.10.0"
|
|
||||||
}
|
|
||||||
},
|
|
||||||
"node_modules/ws": {
|
|
||||||
"version": "7.5.10",
|
|
||||||
"resolved": "https://registry.npmjs.org/ws/-/ws-7.5.10.tgz",
|
|
||||||
"integrity": "sha512-+dbF1tHwZpXcbOJdVOkzLDxZP1ailvSxM6ZweXTegylPny803bFhA+vqBYw4s31NSAk4S2Qz+AKXK9a4wkdjcQ==",
|
|
||||||
"engines": {
|
|
||||||
"node": ">=8.3.0"
|
|
||||||
},
|
|
||||||
"peerDependencies": {
|
|
||||||
"bufferutil": "^4.0.1",
|
|
||||||
"utf-8-validate": "^5.0.2"
|
|
||||||
},
|
|
||||||
"peerDependenciesMeta": {
|
|
||||||
"bufferutil": {
|
|
||||||
"optional": true
|
|
||||||
},
|
|
||||||
"utf-8-validate": {
|
|
||||||
"optional": true
|
|
||||||
}
|
|
||||||
}
|
|
||||||
},
|
|
||||||
"node_modules/xml-name-validator": {
|
|
||||||
"version": "3.0.0",
|
|
||||||
"resolved": "https://registry.npmjs.org/xml-name-validator/-/xml-name-validator-3.0.0.tgz",
|
|
||||||
"integrity": "sha512-A5CUptxDsvxKJEU3yO6DuWBSJz/qizqzJKOMIfUJHETbBw/sFaDxgd6fxm1ewUaM0jZ444Fc5vC5ROYurg/4Pw=="
|
|
||||||
},
|
|
||||||
"node_modules/xmlchars": {
|
|
||||||
"version": "2.2.0",
|
|
||||||
"resolved": "https://registry.npmjs.org/xmlchars/-/xmlchars-2.2.0.tgz",
|
|
||||||
"integrity": "sha512-JZnDKK8B0RCDw84FNdDAIpZK+JuJw+s7Lz8nksI7SIuU3UXJJslUthsi+uWBUYOwPFwW7W7PRLRfUKpxjtjFCw=="
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
33
node_modules/@react-leaflet/core/LICENSE.md
generated
vendored
33
node_modules/@react-leaflet/core/LICENSE.md
generated
vendored
@@ -1,33 +0,0 @@
|
|||||||
@react-leaflet/core Copyright 2020 Paul Le Cam and contributors (“Licensor”)
|
|
||||||
|
|
||||||
Hippocratic License Version Number: 2.1.
|
|
||||||
|
|
||||||
Purpose. The purpose of this License is for the Licensor named above to permit the Licensee (as defined below) broad permission, if consistent with Human Rights Laws and Human Rights Principles (as each is defined below), to use and work with the Software (as defined below) within the full scope of Licensor’s copyright and patent rights, if any, in the Software, while ensuring attribution and protecting the Licensor from liability.
|
|
||||||
|
|
||||||
Permission and Conditions. The Licensor grants permission by this license (“License”), free of charge, to the extent of Licensor’s rights under applicable copyright and patent law, to any person or entity (the “Licensee”) obtaining a copy of this software and associated documentation files (the “Software”), to do everything with the Software that would otherwise infringe (i) the Licensor’s copyright in the Software or (ii) any patent claims to the Software that the Licensor can license or becomes able to license, subject to all of the following terms and conditions:
|
|
||||||
|
|
||||||
- Acceptance. This License is automatically offered to every person and entity subject to its terms and conditions. Licensee accepts this License and agrees to its terms and conditions by taking any action with the Software that, absent this License, would infringe any intellectual property right held by Licensor.
|
|
||||||
|
|
||||||
- Notice. Licensee must ensure that everyone who gets a copy of any part of this Software from Licensee, with or without changes, also receives the License and the above copyright notice (and if included by the Licensor, patent, trademark and attribution notice). Licensee must cause any modified versions of the Software to carry prominent notices stating that Licensee changed the Software. For clarity, although Licensee is free to create modifications of the Software and distribute only the modified portion created by Licensee with additional or different terms, the portion of the Software not modified must be distributed pursuant to this License. If anyone notifies Licensee in writing that Licensee has not complied with this Notice section, Licensee can keep this License by taking all practical steps to comply within 30 days after the notice. If Licensee does not do so, Licensee’s License (and all rights licensed hereunder) shall end immediately.
|
|
||||||
|
|
||||||
- Compliance with Human Rights Principles and Human Rights Laws.
|
|
||||||
|
|
||||||
1. Human Rights Principles.
|
|
||||||
|
|
||||||
(a) Licensee is advised to consult the articles of the United Nations Universal Declaration of Human Rights and the United Nations Global Compact that define recognized principles of international human rights (the “Human Rights Principles”). Licensee shall use the Software in a manner consistent with Human Rights Principles.
|
|
||||||
|
|
||||||
(b) Unless the Licensor and Licensee agree otherwise, any dispute, controversy, or claim arising out of or relating to (i) Section 1(a) regarding Human Rights Principles, including the breach of Section 1(a), termination of this License for breach of the Human Rights Principles, or invalidity of Section 1(a) or (ii) a determination of whether any Law is consistent or in conflict with Human Rights Principles pursuant to Section 2, below, shall be settled by arbitration in accordance with the Hague Rules on Business and Human Rights Arbitration (the “Rules”); provided, however, that Licensee may elect not to participate in such arbitration, in which event this License (and all rights licensed hereunder) shall end immediately. The number of arbitrators shall be one unless the Rules require otherwise.
|
|
||||||
|
|
||||||
Unless both the Licensor and Licensee agree to the contrary: (1) All documents and information concerning the arbitration shall be public and may be disclosed by any party; (2) The repository referred to under Article 43 of the Rules shall make available to the public in a timely manner all documents concerning the arbitration which are communicated to it, including all submissions of the parties, all evidence admitted into the record of the proceedings, all transcripts or other recordings of hearings and all orders, decisions and awards of the arbitral tribunal, subject only to the arbitral tribunal's powers to take such measures as may be necessary to safeguard the integrity of the arbitral process pursuant to Articles 18, 33, 41 and 42 of the Rules; and (3) Article 26(6) of the Rules shall not apply.
|
|
||||||
|
|
||||||
2. Human Rights Laws. The Software shall not be used by any person or entity for any systems, activities, or other uses that violate any Human Rights Laws. “Human Rights Laws” means any applicable laws, regulations, or rules (collectively, “Laws”) that protect human, civil, labor, privacy, political, environmental, security, economic, due process, or similar rights; provided, however, that such Laws are consistent and not in conflict with Human Rights Principles (a dispute over the consistency or a conflict between Laws and Human Rights Principles shall be determined by arbitration as stated above). Where the Human Rights Laws of more than one jurisdiction are applicable or in conflict with respect to the use of the Software, the Human Rights Laws that are most protective of the individuals or groups harmed shall apply.
|
|
||||||
|
|
||||||
3. Indemnity. Licensee shall hold harmless and indemnify Licensor (and any other contributor) against all losses, damages, liabilities, deficiencies, claims, actions, judgments, settlements, interest, awards, penalties, fines, costs, or expenses of whatever kind, including Licensor’s reasonable attorneys’ fees, arising out of or relating to Licensee’s use of the Software in violation of Human Rights Laws or Human Rights Principles.
|
|
||||||
|
|
||||||
- Failure to Comply. Any failure of Licensee to act according to the terms and conditions of this License is both a breach of the License and an infringement of the intellectual property rights of the Licensor (subject to exceptions under Laws, e.g., fair use). In the event of a breach or infringement, the terms and conditions of this License may be enforced by Licensor under the Laws of any jurisdiction to which Licensee is subject. Licensee also agrees that the Licensor may enforce the terms and conditions of this License against Licensee through specific performance (or similar remedy under Laws) to the extent permitted by Laws. For clarity, except in the event of a breach of this License, infringement, or as otherwise stated in this License, Licensor may not terminate this License with Licensee.
|
|
||||||
|
|
||||||
- Enforceability and Interpretation. If any term or provision of this License is determined to be invalid, illegal, or unenforceable by a court of competent jurisdiction, then such invalidity, illegality, or unenforceability shall not affect any other term or provision of this License or invalidate or render unenforceable such term or provision in any other jurisdiction; provided, however, subject to a court modification pursuant to the immediately following sentence, if any term or provision of this License pertaining to Human Rights Laws or Human Rights Principles is deemed invalid, illegal, or unenforceable against Licensee by a court of competent jurisdiction, all rights in the Software granted to Licensee shall be deemed null and void as between Licensor and Licensee. Upon a determination that any term or provision is invalid, illegal, or unenforceable, to the extent permitted by Laws, the court may modify this License to affect the original purpose that the Software be used in compliance with Human Rights Principles and Human Rights Laws as closely as possible. The language in this License shall be interpreted as to its fair meaning and not strictly for or against any party.
|
|
||||||
|
|
||||||
- Disclaimer. TO THE FULL EXTENT ALLOWED BY LAW, THIS SOFTWARE COMES “AS IS,” WITHOUT ANY WARRANTY, EXPRESS OR IMPLIED, AND LICENSOR AND ANY OTHER CONTRIBUTOR SHALL NOT BE LIABLE TO ANYONE FOR ANY DAMAGES OR OTHER LIABILITY ARISING FROM, OUT OF, OR IN CONNECTION WITH THE SOFTWARE OR THIS LICENSE, UNDER ANY KIND OF LEGAL CLAIM.
|
|
||||||
|
|
||||||
This Hippocratic License is an Ethical Source license (https://ethicalsource.dev) and is offered for use by licensors and licensees at their own risk, on an “AS IS” basis, and with no warranties express or implied, to the maximum extent permitted by Laws.
|
|
||||||
3
node_modules/@react-leaflet/core/README.md
generated
vendored
3
node_modules/@react-leaflet/core/README.md
generated
vendored
@@ -1,3 +0,0 @@
|
|||||||
# React Leaflet core
|
|
||||||
|
|
||||||
[Documentation](https://react-leaflet.js.org/docs/core-introduction)
|
|
||||||
2
node_modules/@react-leaflet/core/lib/attribution.d.ts
generated
vendored
2
node_modules/@react-leaflet/core/lib/attribution.d.ts
generated
vendored
@@ -1,2 +0,0 @@
|
|||||||
import type { Map } from 'leaflet';
|
|
||||||
export declare function useAttribution(map: Map, attribution: string | null | undefined): void;
|
|
||||||
18
node_modules/@react-leaflet/core/lib/attribution.js
generated
vendored
18
node_modules/@react-leaflet/core/lib/attribution.js
generated
vendored
@@ -1,18 +0,0 @@
|
|||||||
import { useEffect, useRef } from 'react';
|
|
||||||
export function useAttribution(map, attribution) {
|
|
||||||
const attributionRef = useRef(attribution);
|
|
||||||
useEffect(function updateAttribution() {
|
|
||||||
if (attribution !== attributionRef.current && map.attributionControl != null) {
|
|
||||||
if (attributionRef.current != null) {
|
|
||||||
map.attributionControl.removeAttribution(attributionRef.current);
|
|
||||||
}
|
|
||||||
if (attribution != null) {
|
|
||||||
map.attributionControl.addAttribution(attribution);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
attributionRef.current = attribution;
|
|
||||||
}, [
|
|
||||||
map,
|
|
||||||
attribution
|
|
||||||
]);
|
|
||||||
}
|
|
||||||
12
node_modules/@react-leaflet/core/lib/circle.d.ts
generated
vendored
12
node_modules/@react-leaflet/core/lib/circle.d.ts
generated
vendored
@@ -1,12 +0,0 @@
|
|||||||
import type { Circle as LeafletCircle, CircleMarker as LeafletCircleMarker, CircleMarkerOptions, CircleOptions, LatLngExpression } from 'leaflet';
|
|
||||||
import type { ReactNode } from 'react';
|
|
||||||
import type { PathProps } from './path.js';
|
|
||||||
export interface CircleMarkerProps extends CircleMarkerOptions, PathProps {
|
|
||||||
center: LatLngExpression;
|
|
||||||
children?: ReactNode;
|
|
||||||
}
|
|
||||||
export interface CircleProps extends CircleOptions, PathProps {
|
|
||||||
center: LatLngExpression;
|
|
||||||
children?: ReactNode;
|
|
||||||
}
|
|
||||||
export declare function updateCircle<P extends CircleMarkerProps | CircleProps>(layer: LeafletCircle<P> | LeafletCircleMarker<P>, props: P, prevProps: P): void;
|
|
||||||
8
node_modules/@react-leaflet/core/lib/circle.js
generated
vendored
8
node_modules/@react-leaflet/core/lib/circle.js
generated
vendored
@@ -1,8 +0,0 @@
|
|||||||
export function updateCircle(layer, props, prevProps) {
|
|
||||||
if (props.center !== prevProps.center) {
|
|
||||||
layer.setLatLng(props.center);
|
|
||||||
}
|
|
||||||
if (props.radius != null && props.radius !== prevProps.radius) {
|
|
||||||
layer.setRadius(props.radius);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
11
node_modules/@react-leaflet/core/lib/component.d.ts
generated
vendored
11
node_modules/@react-leaflet/core/lib/component.d.ts
generated
vendored
@@ -1,11 +0,0 @@
|
|||||||
import React, { type MutableRefObject, type ReactNode } from 'react';
|
|
||||||
import type { DivOverlay, DivOverlayHook } from './div-overlay.js';
|
|
||||||
import type { LeafletElement } from './element.js';
|
|
||||||
declare type ElementHook<E, P> = (props: P) => MutableRefObject<LeafletElement<E>>;
|
|
||||||
export declare type PropsWithChildren = {
|
|
||||||
children?: ReactNode;
|
|
||||||
};
|
|
||||||
export declare function createContainerComponent<E, P extends PropsWithChildren>(useElement: ElementHook<E, P>): React.ForwardRefExoticComponent<React.PropsWithoutRef<P> & React.RefAttributes<E>>;
|
|
||||||
export declare function createDivOverlayComponent<E extends DivOverlay, P extends PropsWithChildren>(useElement: ReturnType<DivOverlayHook<E, P>>): React.ForwardRefExoticComponent<React.PropsWithoutRef<P> & React.RefAttributes<E>>;
|
|
||||||
export declare function createLeafComponent<E, P>(useElement: ElementHook<E, P>): React.ForwardRefExoticComponent<React.PropsWithoutRef<P> & React.RefAttributes<E>>;
|
|
||||||
export {};
|
|
||||||
41
node_modules/@react-leaflet/core/lib/component.js
generated
vendored
41
node_modules/@react-leaflet/core/lib/component.js
generated
vendored
@@ -1,41 +0,0 @@
|
|||||||
import React, { forwardRef, useEffect, useImperativeHandle, useState } from 'react';
|
|
||||||
import { createPortal } from 'react-dom';
|
|
||||||
import { LeafletProvider } from './context.js';
|
|
||||||
export function createContainerComponent(useElement) {
|
|
||||||
function ContainerComponent(props, forwardedRef) {
|
|
||||||
const { instance , context } = useElement(props).current;
|
|
||||||
useImperativeHandle(forwardedRef, ()=>instance);
|
|
||||||
return props.children == null ? null : /*#__PURE__*/ React.createElement(LeafletProvider, {
|
|
||||||
value: context
|
|
||||||
}, props.children);
|
|
||||||
}
|
|
||||||
return /*#__PURE__*/ forwardRef(ContainerComponent);
|
|
||||||
}
|
|
||||||
export function createDivOverlayComponent(useElement) {
|
|
||||||
function OverlayComponent(props, forwardedRef) {
|
|
||||||
const [isOpen, setOpen] = useState(false);
|
|
||||||
const { instance } = useElement(props, setOpen).current;
|
|
||||||
useImperativeHandle(forwardedRef, ()=>instance);
|
|
||||||
useEffect(function updateOverlay() {
|
|
||||||
if (isOpen) {
|
|
||||||
instance.update();
|
|
||||||
}
|
|
||||||
}, [
|
|
||||||
instance,
|
|
||||||
isOpen,
|
|
||||||
props.children
|
|
||||||
]);
|
|
||||||
// @ts-ignore _contentNode missing in type definition
|
|
||||||
const contentNode = instance._contentNode;
|
|
||||||
return contentNode ? /*#__PURE__*/ createPortal(props.children, contentNode) : null;
|
|
||||||
}
|
|
||||||
return /*#__PURE__*/ forwardRef(OverlayComponent);
|
|
||||||
}
|
|
||||||
export function createLeafComponent(useElement) {
|
|
||||||
function LeafComponent(props, forwardedRef) {
|
|
||||||
const { instance } = useElement(props).current;
|
|
||||||
useImperativeHandle(forwardedRef, ()=>instance);
|
|
||||||
return null;
|
|
||||||
}
|
|
||||||
return /*#__PURE__*/ forwardRef(LeafComponent);
|
|
||||||
}
|
|
||||||
34
node_modules/@react-leaflet/core/lib/context.d.ts
generated
vendored
34
node_modules/@react-leaflet/core/lib/context.d.ts
generated
vendored
@@ -1,34 +0,0 @@
|
|||||||
/// <reference types="react" />
|
|
||||||
import type { Control, Layer, LayerGroup, Map } from 'leaflet';
|
|
||||||
export declare const CONTEXT_VERSION = 1;
|
|
||||||
export declare type ControlledLayer = {
|
|
||||||
addLayer(layer: Layer): void;
|
|
||||||
removeLayer(layer: Layer): void;
|
|
||||||
};
|
|
||||||
export declare type LeafletContextInterface = Readonly<{
|
|
||||||
__version: number;
|
|
||||||
map: Map;
|
|
||||||
layerContainer?: ControlledLayer | LayerGroup;
|
|
||||||
layersControl?: Control.Layers;
|
|
||||||
overlayContainer?: Layer;
|
|
||||||
pane?: string;
|
|
||||||
}>;
|
|
||||||
export declare function createLeafletContext(map: Map): LeafletContextInterface;
|
|
||||||
export declare function extendContext(source: LeafletContextInterface, extra: Partial<LeafletContextInterface>): LeafletContextInterface;
|
|
||||||
export declare const LeafletContext: import("react").Context<Readonly<{
|
|
||||||
__version: number;
|
|
||||||
map: Map;
|
|
||||||
layerContainer?: LayerGroup<any> | ControlledLayer | undefined;
|
|
||||||
layersControl?: Control.Layers | undefined;
|
|
||||||
overlayContainer?: Layer | undefined;
|
|
||||||
pane?: string | undefined;
|
|
||||||
}> | null>;
|
|
||||||
export declare const LeafletProvider: import("react").Provider<Readonly<{
|
|
||||||
__version: number;
|
|
||||||
map: Map;
|
|
||||||
layerContainer?: LayerGroup<any> | ControlledLayer | undefined;
|
|
||||||
layersControl?: Control.Layers | undefined;
|
|
||||||
overlayContainer?: Layer | undefined;
|
|
||||||
pane?: string | undefined;
|
|
||||||
}> | null>;
|
|
||||||
export declare function useLeafletContext(): LeafletContextInterface;
|
|
||||||
23
node_modules/@react-leaflet/core/lib/context.js
generated
vendored
23
node_modules/@react-leaflet/core/lib/context.js
generated
vendored
@@ -1,23 +0,0 @@
|
|||||||
import { createContext, useContext } from 'react';
|
|
||||||
export const CONTEXT_VERSION = 1;
|
|
||||||
export function createLeafletContext(map) {
|
|
||||||
return Object.freeze({
|
|
||||||
__version: CONTEXT_VERSION,
|
|
||||||
map
|
|
||||||
});
|
|
||||||
}
|
|
||||||
export function extendContext(source, extra) {
|
|
||||||
return Object.freeze({
|
|
||||||
...source,
|
|
||||||
...extra
|
|
||||||
});
|
|
||||||
}
|
|
||||||
export const LeafletContext = createContext(null);
|
|
||||||
export const LeafletProvider = LeafletContext.Provider;
|
|
||||||
export function useLeafletContext() {
|
|
||||||
const context = useContext(LeafletContext);
|
|
||||||
if (context == null) {
|
|
||||||
throw new Error('No context provided: useLeafletContext() can only be used in a descendant of <MapContainer>');
|
|
||||||
}
|
|
||||||
return context;
|
|
||||||
}
|
|
||||||
3
node_modules/@react-leaflet/core/lib/control.d.ts
generated
vendored
3
node_modules/@react-leaflet/core/lib/control.d.ts
generated
vendored
@@ -1,3 +0,0 @@
|
|||||||
import { Control, type ControlOptions } from 'leaflet';
|
|
||||||
import type { ElementHook } from './element.js';
|
|
||||||
export declare function createControlHook<E extends Control, P extends ControlOptions>(useElement: ElementHook<E, P>): (props: P) => ReturnType<ElementHook<E, P>>;
|
|
||||||
30
node_modules/@react-leaflet/core/lib/control.js
generated
vendored
30
node_modules/@react-leaflet/core/lib/control.js
generated
vendored
@@ -1,30 +0,0 @@
|
|||||||
import { useEffect, useRef } from 'react';
|
|
||||||
import { useLeafletContext } from './context.js';
|
|
||||||
export function createControlHook(useElement) {
|
|
||||||
return function useLeafletControl(props) {
|
|
||||||
const context = useLeafletContext();
|
|
||||||
const elementRef = useElement(props, context);
|
|
||||||
const { instance } = elementRef.current;
|
|
||||||
const positionRef = useRef(props.position);
|
|
||||||
const { position } = props;
|
|
||||||
useEffect(function addControl() {
|
|
||||||
instance.addTo(context.map);
|
|
||||||
return function removeControl() {
|
|
||||||
instance.remove();
|
|
||||||
};
|
|
||||||
}, [
|
|
||||||
context.map,
|
|
||||||
instance
|
|
||||||
]);
|
|
||||||
useEffect(function updateControl() {
|
|
||||||
if (position != null && position !== positionRef.current) {
|
|
||||||
instance.setPosition(position);
|
|
||||||
positionRef.current = position;
|
|
||||||
}
|
|
||||||
}, [
|
|
||||||
instance,
|
|
||||||
position
|
|
||||||
]);
|
|
||||||
return elementRef;
|
|
||||||
};
|
|
||||||
}
|
|
||||||
9
node_modules/@react-leaflet/core/lib/div-overlay.d.ts
generated
vendored
9
node_modules/@react-leaflet/core/lib/div-overlay.d.ts
generated
vendored
@@ -1,9 +0,0 @@
|
|||||||
import type { Popup, Tooltip } from 'leaflet';
|
|
||||||
import { type LeafletContextInterface } from './context.js';
|
|
||||||
import type { LeafletElement, ElementHook } from './element.js';
|
|
||||||
import type { LayerProps } from './layer.js';
|
|
||||||
export declare type DivOverlay = Popup | Tooltip;
|
|
||||||
export declare type SetOpenFunc = (open: boolean) => void;
|
|
||||||
export declare type DivOverlayLifecycleHook<E, P> = (element: LeafletElement<E>, context: LeafletContextInterface, props: P, setOpen: SetOpenFunc) => void;
|
|
||||||
export declare type DivOverlayHook<E extends DivOverlay, P> = (useElement: ElementHook<E, P>, useLifecycle: DivOverlayLifecycleHook<E, P>) => (props: P, setOpen: SetOpenFunc) => ReturnType<ElementHook<E, P>>;
|
|
||||||
export declare function createDivOverlayHook<E extends DivOverlay, P extends LayerProps>(useElement: ElementHook<E, P>, useLifecycle: DivOverlayLifecycleHook<E, P>): (props: P, setOpen: SetOpenFunc) => ReturnType<ElementHook<E, P>>;
|
|
||||||
14
node_modules/@react-leaflet/core/lib/div-overlay.js
generated
vendored
14
node_modules/@react-leaflet/core/lib/div-overlay.js
generated
vendored
@@ -1,14 +0,0 @@
|
|||||||
import { useAttribution } from './attribution.js';
|
|
||||||
import { useLeafletContext } from './context.js';
|
|
||||||
import { useEventHandlers } from './events.js';
|
|
||||||
import { withPane } from './pane.js';
|
|
||||||
export function createDivOverlayHook(useElement, useLifecycle) {
|
|
||||||
return function useDivOverlay(props, setOpen) {
|
|
||||||
const context = useLeafletContext();
|
|
||||||
const elementRef = useElement(withPane(props, context), context);
|
|
||||||
useAttribution(context.map, props.attribution);
|
|
||||||
useEventHandlers(elementRef.current, props.eventHandlers);
|
|
||||||
useLifecycle(elementRef.current, context, props, setOpen);
|
|
||||||
return elementRef;
|
|
||||||
};
|
|
||||||
}
|
|
||||||
3
node_modules/@react-leaflet/core/lib/dom.d.ts
generated
vendored
3
node_modules/@react-leaflet/core/lib/dom.d.ts
generated
vendored
@@ -1,3 +0,0 @@
|
|||||||
export declare function addClassName(element: HTMLElement, className: string): void;
|
|
||||||
export declare function removeClassName(element: HTMLElement, className: string): void;
|
|
||||||
export declare function updateClassName(element?: HTMLElement, prevClassName?: string, nextClassName?: string): void;
|
|
||||||
24
node_modules/@react-leaflet/core/lib/dom.js
generated
vendored
24
node_modules/@react-leaflet/core/lib/dom.js
generated
vendored
@@ -1,24 +0,0 @@
|
|||||||
import { DomUtil } from 'leaflet';
|
|
||||||
function splitClassName(className) {
|
|
||||||
return className.split(' ').filter(Boolean);
|
|
||||||
}
|
|
||||||
export function addClassName(element, className) {
|
|
||||||
splitClassName(className).forEach((cls)=>{
|
|
||||||
DomUtil.addClass(element, cls);
|
|
||||||
});
|
|
||||||
}
|
|
||||||
export function removeClassName(element, className) {
|
|
||||||
splitClassName(className).forEach((cls)=>{
|
|
||||||
DomUtil.removeClass(element, cls);
|
|
||||||
});
|
|
||||||
}
|
|
||||||
export function updateClassName(element, prevClassName, nextClassName) {
|
|
||||||
if (element != null && nextClassName !== prevClassName) {
|
|
||||||
if (prevClassName != null && prevClassName.length > 0) {
|
|
||||||
removeClassName(element, prevClassName);
|
|
||||||
}
|
|
||||||
if (nextClassName != null && nextClassName.length > 0) {
|
|
||||||
addClassName(element, nextClassName);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
10
node_modules/@react-leaflet/core/lib/element.d.ts
generated
vendored
10
node_modules/@react-leaflet/core/lib/element.d.ts
generated
vendored
@@ -1,10 +0,0 @@
|
|||||||
import { type MutableRefObject } from 'react';
|
|
||||||
import type { LeafletContextInterface } from './context.js';
|
|
||||||
export declare type LeafletElement<T, C = any> = Readonly<{
|
|
||||||
instance: T;
|
|
||||||
context: LeafletContextInterface;
|
|
||||||
container?: C | null;
|
|
||||||
}>;
|
|
||||||
export declare function createElementObject<T, C = any>(instance: T, context: LeafletContextInterface, container?: C | null): LeafletElement<T, C>;
|
|
||||||
export declare type ElementHook<E, P> = (props: P, context: LeafletContextInterface) => MutableRefObject<LeafletElement<E>>;
|
|
||||||
export declare function createElementHook<E, P, C = any>(createElement: (props: P, context: LeafletContextInterface) => LeafletElement<E>, updateElement?: (instance: E, props: P, prevProps: P) => void): (props: P, context: LeafletContextInterface) => ReturnType<ElementHook<E, P>>;
|
|
||||||
34
node_modules/@react-leaflet/core/lib/element.js
generated
vendored
34
node_modules/@react-leaflet/core/lib/element.js
generated
vendored
@@ -1,34 +0,0 @@
|
|||||||
import { useEffect, useRef } from 'react';
|
|
||||||
export function createElementObject(instance, context, container) {
|
|
||||||
return Object.freeze({
|
|
||||||
instance,
|
|
||||||
context,
|
|
||||||
container
|
|
||||||
});
|
|
||||||
}
|
|
||||||
export function createElementHook(createElement, updateElement) {
|
|
||||||
if (updateElement == null) {
|
|
||||||
return function useImmutableLeafletElement(props, context) {
|
|
||||||
const elementRef = useRef();
|
|
||||||
if (!elementRef.current) elementRef.current = createElement(props, context);
|
|
||||||
return elementRef;
|
|
||||||
};
|
|
||||||
}
|
|
||||||
return function useMutableLeafletElement(props, context) {
|
|
||||||
const elementRef = useRef();
|
|
||||||
if (!elementRef.current) elementRef.current = createElement(props, context);
|
|
||||||
const propsRef = useRef(props);
|
|
||||||
const { instance } = elementRef.current;
|
|
||||||
useEffect(function updateElementProps() {
|
|
||||||
if (propsRef.current !== props) {
|
|
||||||
updateElement(instance, props, propsRef.current);
|
|
||||||
propsRef.current = props;
|
|
||||||
}
|
|
||||||
}, [
|
|
||||||
instance,
|
|
||||||
props,
|
|
||||||
context
|
|
||||||
]);
|
|
||||||
return elementRef;
|
|
||||||
};
|
|
||||||
}
|
|
||||||
6
node_modules/@react-leaflet/core/lib/events.d.ts
generated
vendored
6
node_modules/@react-leaflet/core/lib/events.d.ts
generated
vendored
@@ -1,6 +0,0 @@
|
|||||||
import type { Evented, LeafletEventHandlerFnMap } from 'leaflet';
|
|
||||||
import type { LeafletElement } from './element.js';
|
|
||||||
export declare type EventedProps = {
|
|
||||||
eventHandlers?: LeafletEventHandlerFnMap;
|
|
||||||
};
|
|
||||||
export declare function useEventHandlers(element: LeafletElement<Evented>, eventHandlers: LeafletEventHandlerFnMap | null | undefined): void;
|
|
||||||
19
node_modules/@react-leaflet/core/lib/events.js
generated
vendored
19
node_modules/@react-leaflet/core/lib/events.js
generated
vendored
@@ -1,19 +0,0 @@
|
|||||||
import { useEffect, useRef } from 'react';
|
|
||||||
export function useEventHandlers(element, eventHandlers) {
|
|
||||||
const eventHandlersRef = useRef();
|
|
||||||
useEffect(function addEventHandlers() {
|
|
||||||
if (eventHandlers != null) {
|
|
||||||
element.instance.on(eventHandlers);
|
|
||||||
}
|
|
||||||
eventHandlersRef.current = eventHandlers;
|
|
||||||
return function removeEventHandlers() {
|
|
||||||
if (eventHandlersRef.current != null) {
|
|
||||||
element.instance.off(eventHandlersRef.current);
|
|
||||||
}
|
|
||||||
eventHandlersRef.current = null;
|
|
||||||
};
|
|
||||||
}, [
|
|
||||||
element,
|
|
||||||
eventHandlers
|
|
||||||
]);
|
|
||||||
}
|
|
||||||
18
node_modules/@react-leaflet/core/lib/generic.d.ts
generated
vendored
18
node_modules/@react-leaflet/core/lib/generic.d.ts
generated
vendored
@@ -1,18 +0,0 @@
|
|||||||
/// <reference types="react" />
|
|
||||||
import type { Control, ControlOptions, FeatureGroup, Layer, Path } from 'leaflet';
|
|
||||||
import { type PropsWithChildren } from './component.js';
|
|
||||||
import type { LeafletContextInterface } from './context.js';
|
|
||||||
import { type LeafletElement } from './element.js';
|
|
||||||
import { type LayerProps } from './layer.js';
|
|
||||||
import { type DivOverlay, type DivOverlayLifecycleHook } from './div-overlay.js';
|
|
||||||
import { type PathProps } from './path.js';
|
|
||||||
interface LayerWithChildrenProps extends LayerProps, PropsWithChildren {
|
|
||||||
}
|
|
||||||
interface PathWithChildrenProps extends PathProps, PropsWithChildren {
|
|
||||||
}
|
|
||||||
export declare function createControlComponent<E extends Control, P extends ControlOptions>(createInstance: (props: P) => E): import("react").ForwardRefExoticComponent<import("react").PropsWithoutRef<P> & import("react").RefAttributes<E>>;
|
|
||||||
export declare function createLayerComponent<E extends Layer, P extends LayerWithChildrenProps>(createElement: (props: P, context: LeafletContextInterface) => LeafletElement<E>, updateElement?: (instance: E, props: P, prevProps: P) => void): import("react").ForwardRefExoticComponent<import("react").PropsWithoutRef<P> & import("react").RefAttributes<E>>;
|
|
||||||
export declare function createOverlayComponent<E extends DivOverlay, P extends LayerWithChildrenProps>(createElement: (props: P, context: LeafletContextInterface) => LeafletElement<E>, useLifecycle: DivOverlayLifecycleHook<E, P>): import("react").ForwardRefExoticComponent<import("react").PropsWithoutRef<P> & import("react").RefAttributes<E>>;
|
|
||||||
export declare function createPathComponent<E extends FeatureGroup | Path, P extends PathWithChildrenProps>(createElement: (props: P, context: LeafletContextInterface) => LeafletElement<E>, updateElement?: (instance: E, props: P, prevProps: P) => void): import("react").ForwardRefExoticComponent<import("react").PropsWithoutRef<P> & import("react").RefAttributes<E>>;
|
|
||||||
export declare function createTileLayerComponent<E extends Layer, P extends LayerProps>(createElement: (props: P, context: LeafletContextInterface) => LeafletElement<E>, updateElement?: (instance: E, props: P, prevProps: P) => void): import("react").ForwardRefExoticComponent<import("react").PropsWithoutRef<P> & import("react").RefAttributes<E>>;
|
|
||||||
export {};
|
|
||||||
34
node_modules/@react-leaflet/core/lib/generic.js
generated
vendored
34
node_modules/@react-leaflet/core/lib/generic.js
generated
vendored
@@ -1,34 +0,0 @@
|
|||||||
import { createContainerComponent, createDivOverlayComponent, createLeafComponent } from './component.js';
|
|
||||||
import { createControlHook } from './control.js';
|
|
||||||
import { createElementHook, createElementObject } from './element.js';
|
|
||||||
import { createLayerHook } from './layer.js';
|
|
||||||
import { createDivOverlayHook } from './div-overlay.js';
|
|
||||||
import { createPathHook } from './path.js';
|
|
||||||
export function createControlComponent(createInstance) {
|
|
||||||
function createElement(props, context) {
|
|
||||||
return createElementObject(createInstance(props), context);
|
|
||||||
}
|
|
||||||
const useElement = createElementHook(createElement);
|
|
||||||
const useControl = createControlHook(useElement);
|
|
||||||
return createLeafComponent(useControl);
|
|
||||||
}
|
|
||||||
export function createLayerComponent(createElement, updateElement) {
|
|
||||||
const useElement = createElementHook(createElement, updateElement);
|
|
||||||
const useLayer = createLayerHook(useElement);
|
|
||||||
return createContainerComponent(useLayer);
|
|
||||||
}
|
|
||||||
export function createOverlayComponent(createElement, useLifecycle) {
|
|
||||||
const useElement = createElementHook(createElement);
|
|
||||||
const useOverlay = createDivOverlayHook(useElement, useLifecycle);
|
|
||||||
return createDivOverlayComponent(useOverlay);
|
|
||||||
}
|
|
||||||
export function createPathComponent(createElement, updateElement) {
|
|
||||||
const useElement = createElementHook(createElement, updateElement);
|
|
||||||
const usePath = createPathHook(useElement);
|
|
||||||
return createContainerComponent(usePath);
|
|
||||||
}
|
|
||||||
export function createTileLayerComponent(createElement, updateElement) {
|
|
||||||
const useElement = createElementHook(createElement, updateElement);
|
|
||||||
const useLayer = createLayerHook(useElement);
|
|
||||||
return createLeafComponent(useLayer);
|
|
||||||
}
|
|
||||||
2
node_modules/@react-leaflet/core/lib/grid-layer.d.ts
generated
vendored
2
node_modules/@react-leaflet/core/lib/grid-layer.d.ts
generated
vendored
@@ -1,2 +0,0 @@
|
|||||||
import type { GridLayer, GridLayerOptions } from 'leaflet';
|
|
||||||
export declare function updateGridLayer<E extends GridLayer, P extends GridLayerOptions>(layer: E, props: P, prevProps: P): void;
|
|
||||||
9
node_modules/@react-leaflet/core/lib/grid-layer.js
generated
vendored
9
node_modules/@react-leaflet/core/lib/grid-layer.js
generated
vendored
@@ -1,9 +0,0 @@
|
|||||||
export function updateGridLayer(layer, props, prevProps) {
|
|
||||||
const { opacity , zIndex } = props;
|
|
||||||
if (opacity != null && opacity !== prevProps.opacity) {
|
|
||||||
layer.setOpacity(opacity);
|
|
||||||
}
|
|
||||||
if (zIndex != null && zIndex !== prevProps.zIndex) {
|
|
||||||
layer.setZIndex(zIndex);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
15
node_modules/@react-leaflet/core/lib/index.d.ts
generated
vendored
15
node_modules/@react-leaflet/core/lib/index.d.ts
generated
vendored
@@ -1,15 +0,0 @@
|
|||||||
export { useAttribution } from './attribution.js';
|
|
||||||
export { type CircleMarkerProps, type CircleProps, updateCircle, } from './circle.js';
|
|
||||||
export { createContainerComponent, createDivOverlayComponent, createLeafComponent, } from './component.js';
|
|
||||||
export { CONTEXT_VERSION, type LeafletContextInterface, LeafletContext, LeafletProvider, createLeafletContext, extendContext, useLeafletContext, } from './context.js';
|
|
||||||
export { createControlHook } from './control.js';
|
|
||||||
export { type DivOverlayHook, type DivOverlayLifecycleHook, type SetOpenFunc, createDivOverlayHook, } from './div-overlay.js';
|
|
||||||
export { addClassName, removeClassName, updateClassName } from './dom.js';
|
|
||||||
export { type ElementHook, type LeafletElement, createElementHook, createElementObject, } from './element.js';
|
|
||||||
export { type EventedProps, useEventHandlers } from './events.js';
|
|
||||||
export { createControlComponent, createLayerComponent, createOverlayComponent, createPathComponent, createTileLayerComponent, } from './generic.js';
|
|
||||||
export { updateGridLayer } from './grid-layer.js';
|
|
||||||
export { type InteractiveLayerProps, type LayerProps, createLayerHook, useLayerLifecycle, } from './layer.js';
|
|
||||||
export { type MediaOverlayProps, updateMediaOverlay } from './media-overlay.js';
|
|
||||||
export { withPane } from './pane.js';
|
|
||||||
export { type PathProps, createPathHook, usePathOptions } from './path.js';
|
|
||||||
15
node_modules/@react-leaflet/core/lib/index.js
generated
vendored
15
node_modules/@react-leaflet/core/lib/index.js
generated
vendored
@@ -1,15 +0,0 @@
|
|||||||
export { useAttribution } from './attribution.js';
|
|
||||||
export { updateCircle } from './circle.js';
|
|
||||||
export { createContainerComponent, createDivOverlayComponent, createLeafComponent } from './component.js';
|
|
||||||
export { CONTEXT_VERSION, LeafletContext, LeafletProvider, createLeafletContext, extendContext, useLeafletContext } from './context.js';
|
|
||||||
export { createControlHook } from './control.js';
|
|
||||||
export { createDivOverlayHook } from './div-overlay.js';
|
|
||||||
export { addClassName, removeClassName, updateClassName } from './dom.js';
|
|
||||||
export { createElementHook, createElementObject } from './element.js';
|
|
||||||
export { useEventHandlers } from './events.js';
|
|
||||||
export { createControlComponent, createLayerComponent, createOverlayComponent, createPathComponent, createTileLayerComponent } from './generic.js';
|
|
||||||
export { updateGridLayer } from './grid-layer.js';
|
|
||||||
export { createLayerHook, useLayerLifecycle } from './layer.js';
|
|
||||||
export { updateMediaOverlay } from './media-overlay.js';
|
|
||||||
export { withPane } from './pane.js';
|
|
||||||
export { createPathHook, usePathOptions } from './path.js';
|
|
||||||
10
node_modules/@react-leaflet/core/lib/layer.d.ts
generated
vendored
10
node_modules/@react-leaflet/core/lib/layer.d.ts
generated
vendored
@@ -1,10 +0,0 @@
|
|||||||
import type { InteractiveLayerOptions, Layer, LayerOptions } from 'leaflet';
|
|
||||||
import { type LeafletContextInterface } from './context.js';
|
|
||||||
import type { LeafletElement, ElementHook } from './element.js';
|
|
||||||
import { type EventedProps } from './events.js';
|
|
||||||
export interface LayerProps extends EventedProps, LayerOptions {
|
|
||||||
}
|
|
||||||
export interface InteractiveLayerProps extends LayerProps, InteractiveLayerOptions {
|
|
||||||
}
|
|
||||||
export declare function useLayerLifecycle(element: LeafletElement<Layer>, context: LeafletContextInterface): void;
|
|
||||||
export declare function createLayerHook<E extends Layer, P extends LayerProps>(useElement: ElementHook<E, P>): (props: P) => ReturnType<ElementHook<E, P>>;
|
|
||||||
28
node_modules/@react-leaflet/core/lib/layer.js
generated
vendored
28
node_modules/@react-leaflet/core/lib/layer.js
generated
vendored
@@ -1,28 +0,0 @@
|
|||||||
import { useEffect } from 'react';
|
|
||||||
import { useAttribution } from './attribution.js';
|
|
||||||
import { useLeafletContext } from './context.js';
|
|
||||||
import { useEventHandlers } from './events.js';
|
|
||||||
import { withPane } from './pane.js';
|
|
||||||
export function useLayerLifecycle(element, context) {
|
|
||||||
useEffect(function addLayer() {
|
|
||||||
const container = context.layerContainer ?? context.map;
|
|
||||||
container.addLayer(element.instance);
|
|
||||||
return function removeLayer() {
|
|
||||||
context.layerContainer?.removeLayer(element.instance);
|
|
||||||
context.map.removeLayer(element.instance);
|
|
||||||
};
|
|
||||||
}, [
|
|
||||||
context,
|
|
||||||
element
|
|
||||||
]);
|
|
||||||
}
|
|
||||||
export function createLayerHook(useElement) {
|
|
||||||
return function useLayer(props) {
|
|
||||||
const context = useLeafletContext();
|
|
||||||
const elementRef = useElement(withPane(props, context), context);
|
|
||||||
useAttribution(context.map, props.attribution);
|
|
||||||
useEventHandlers(elementRef.current, props.eventHandlers);
|
|
||||||
useLayerLifecycle(elementRef.current, context);
|
|
||||||
return elementRef;
|
|
||||||
};
|
|
||||||
}
|
|
||||||
6
node_modules/@react-leaflet/core/lib/media-overlay.d.ts
generated
vendored
6
node_modules/@react-leaflet/core/lib/media-overlay.d.ts
generated
vendored
@@ -1,6 +0,0 @@
|
|||||||
import { type LatLngBoundsExpression, type ImageOverlay as LeafletImageOverlay, type ImageOverlayOptions, type SVGOverlay as LeafletSVGOverlay, type VideoOverlay as LeafletVideoOverlay } from 'leaflet';
|
|
||||||
import type { InteractiveLayerProps } from './layer.js';
|
|
||||||
export interface MediaOverlayProps extends ImageOverlayOptions, InteractiveLayerProps {
|
|
||||||
bounds: LatLngBoundsExpression;
|
|
||||||
}
|
|
||||||
export declare function updateMediaOverlay<E extends LeafletImageOverlay | LeafletSVGOverlay | LeafletVideoOverlay, P extends MediaOverlayProps>(overlay: E, props: P, prevProps: P): void;
|
|
||||||
13
node_modules/@react-leaflet/core/lib/media-overlay.js
generated
vendored
13
node_modules/@react-leaflet/core/lib/media-overlay.js
generated
vendored
@@ -1,13 +0,0 @@
|
|||||||
import { LatLngBounds } from 'leaflet';
|
|
||||||
export function updateMediaOverlay(overlay, props, prevProps) {
|
|
||||||
if (props.bounds instanceof LatLngBounds && props.bounds !== prevProps.bounds) {
|
|
||||||
overlay.setBounds(props.bounds);
|
|
||||||
}
|
|
||||||
if (props.opacity != null && props.opacity !== prevProps.opacity) {
|
|
||||||
overlay.setOpacity(props.opacity);
|
|
||||||
}
|
|
||||||
if (props.zIndex != null && props.zIndex !== prevProps.zIndex) {
|
|
||||||
// @ts-ignore missing in definition but inherited from ImageOverlay
|
|
||||||
overlay.setZIndex(props.zIndex);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
3
node_modules/@react-leaflet/core/lib/pane.d.ts
generated
vendored
3
node_modules/@react-leaflet/core/lib/pane.d.ts
generated
vendored
@@ -1,3 +0,0 @@
|
|||||||
import type { LayerOptions } from 'leaflet';
|
|
||||||
import type { LeafletContextInterface } from './context.js';
|
|
||||||
export declare function withPane<P extends LayerOptions>(props: P, context: LeafletContextInterface): P;
|
|
||||||
7
node_modules/@react-leaflet/core/lib/pane.js
generated
vendored
7
node_modules/@react-leaflet/core/lib/pane.js
generated
vendored
@@ -1,7 +0,0 @@
|
|||||||
export function withPane(props, context) {
|
|
||||||
const pane = props.pane ?? context.pane;
|
|
||||||
return pane ? {
|
|
||||||
...props,
|
|
||||||
pane
|
|
||||||
} : props;
|
|
||||||
}
|
|
||||||
8
node_modules/@react-leaflet/core/lib/path.d.ts
generated
vendored
8
node_modules/@react-leaflet/core/lib/path.d.ts
generated
vendored
@@ -1,8 +0,0 @@
|
|||||||
import type { FeatureGroup, Path, PathOptions } from 'leaflet';
|
|
||||||
import type { LeafletElement, ElementHook } from './element.js';
|
|
||||||
import { type InteractiveLayerProps } from './layer.js';
|
|
||||||
export interface PathProps extends InteractiveLayerProps {
|
|
||||||
pathOptions?: PathOptions;
|
|
||||||
}
|
|
||||||
export declare function usePathOptions(element: LeafletElement<FeatureGroup | Path>, props: PathProps): void;
|
|
||||||
export declare function createPathHook<E extends FeatureGroup | Path, P extends PathProps>(useElement: ElementHook<E, P>): (props: P) => ReturnType<ElementHook<E, P>>;
|
|
||||||
28
node_modules/@react-leaflet/core/lib/path.js
generated
vendored
28
node_modules/@react-leaflet/core/lib/path.js
generated
vendored
@@ -1,28 +0,0 @@
|
|||||||
import { useEffect, useRef } from 'react';
|
|
||||||
import { useLeafletContext } from './context.js';
|
|
||||||
import { useEventHandlers } from './events.js';
|
|
||||||
import { useLayerLifecycle } from './layer.js';
|
|
||||||
import { withPane } from './pane.js';
|
|
||||||
export function usePathOptions(element, props) {
|
|
||||||
const optionsRef = useRef();
|
|
||||||
useEffect(function updatePathOptions() {
|
|
||||||
if (props.pathOptions !== optionsRef.current) {
|
|
||||||
const options = props.pathOptions ?? {};
|
|
||||||
element.instance.setStyle(options);
|
|
||||||
optionsRef.current = options;
|
|
||||||
}
|
|
||||||
}, [
|
|
||||||
element,
|
|
||||||
props
|
|
||||||
]);
|
|
||||||
}
|
|
||||||
export function createPathHook(useElement) {
|
|
||||||
return function usePath(props) {
|
|
||||||
const context = useLeafletContext();
|
|
||||||
const elementRef = useElement(withPane(props, context), context);
|
|
||||||
useEventHandlers(elementRef.current, props.eventHandlers);
|
|
||||||
useLayerLifecycle(elementRef.current, context);
|
|
||||||
usePathOptions(elementRef.current, props);
|
|
||||||
return elementRef;
|
|
||||||
};
|
|
||||||
}
|
|
||||||
66
node_modules/@react-leaflet/core/package.json
generated
vendored
66
node_modules/@react-leaflet/core/package.json
generated
vendored
@@ -1,66 +0,0 @@
|
|||||||
{
|
|
||||||
"name": "@react-leaflet/core",
|
|
||||||
"version": "2.1.0",
|
|
||||||
"description": "React Leaflet core",
|
|
||||||
"repository": {
|
|
||||||
"type": "git",
|
|
||||||
"url": "https://github.com/PaulLeCam/react-leaflet.git"
|
|
||||||
},
|
|
||||||
"keywords": [
|
|
||||||
"react-component",
|
|
||||||
"react",
|
|
||||||
"leaflet",
|
|
||||||
"map"
|
|
||||||
],
|
|
||||||
"author": "Paul Le Cam <paul@ulem.net>",
|
|
||||||
"license": "Hippocratic-2.1",
|
|
||||||
"bugs": {
|
|
||||||
"url": "https://github.com/PaulLeCam/react-leaflet/issues"
|
|
||||||
},
|
|
||||||
"homepage": "https://react-leaflet.js.org/docs/core-introduction",
|
|
||||||
"type": "module",
|
|
||||||
"main": "lib/index.js",
|
|
||||||
"types": "lib/index.d.ts",
|
|
||||||
"exports": {
|
|
||||||
".": "./lib/index.js"
|
|
||||||
},
|
|
||||||
"files": [
|
|
||||||
"lib/*"
|
|
||||||
],
|
|
||||||
"sideEffects": false,
|
|
||||||
"peerDependencies": {
|
|
||||||
"leaflet": "^1.9.0",
|
|
||||||
"react": "^18.0.0",
|
|
||||||
"react-dom": "^18.0.0"
|
|
||||||
},
|
|
||||||
"devDependencies": {
|
|
||||||
"@types/react": "^18.0.21",
|
|
||||||
"@types/react-dom": "^18.0.6"
|
|
||||||
},
|
|
||||||
"jest": {
|
|
||||||
"extensionsToTreatAsEsm": [
|
|
||||||
".ts",
|
|
||||||
".tsx"
|
|
||||||
],
|
|
||||||
"resolver": "ts-jest-resolver",
|
|
||||||
"testEnvironment": "jsdom",
|
|
||||||
"transform": {
|
|
||||||
"^.+\\.(t|j)sx?$": [
|
|
||||||
"@swc/jest",
|
|
||||||
{
|
|
||||||
"root": "../.."
|
|
||||||
}
|
|
||||||
]
|
|
||||||
}
|
|
||||||
},
|
|
||||||
"scripts": {
|
|
||||||
"build:clean": "del lib",
|
|
||||||
"build:js": "swc src -d ./lib --config-file ../../.swcrc",
|
|
||||||
"build:types": "tsc --emitDeclarationOnly",
|
|
||||||
"build": "pnpm run build:clean && pnpm run build:types && pnpm run build:js",
|
|
||||||
"test:types": "tsc --noEmit",
|
|
||||||
"test:unit": "cross-env NODE_ENV=test jest",
|
|
||||||
"test": "pnpm run test:types && pnpm run test:unit",
|
|
||||||
"start": "pnpm run test && pnpm run build"
|
|
||||||
}
|
|
||||||
}
|
|
||||||
13
node_modules/abab/LICENSE.md
generated
vendored
13
node_modules/abab/LICENSE.md
generated
vendored
@@ -1,13 +0,0 @@
|
|||||||
Copyright © 2019 W3C and Jeff Carpenter \<jeffcarp@chromium.org\>
|
|
||||||
|
|
||||||
Both the original source code and new contributions in this repository are released under the [3-Clause BSD license](https://opensource.org/licenses/BSD-3-Clause).
|
|
||||||
|
|
||||||
# The 3-Clause BSD License
|
|
||||||
|
|
||||||
Redistribution and use in source and binary forms, with or without modification, are permitted provided that the following conditions are met:
|
|
||||||
|
|
||||||
1. Redistributions of source code must retain the above copyright notice, this list of conditions and the following disclaimer.
|
|
||||||
2. Redistributions in binary form must reproduce the above copyright notice, this list of conditions and the following disclaimer in the documentation and/or other materials provided with the distribution.
|
|
||||||
3. Neither the name of the copyright holder nor the names of its contributors may be used to endorse or promote products derived from this software without specific prior written permission.
|
|
||||||
|
|
||||||
THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
|
|
||||||
51
node_modules/abab/README.md
generated
vendored
51
node_modules/abab/README.md
generated
vendored
@@ -1,51 +0,0 @@
|
|||||||
# abab [](https://www.npmjs.com/package/abab) [](https://travis-ci.org/jsdom/abab)
|
|
||||||
|
|
||||||
A JavaScript module that implements `window.atob` and `window.btoa` according the forgiving-base64 algorithm in the [Infra Standard](https://infra.spec.whatwg.org/#forgiving-base64). The original code was forked from [w3c/web-platform-tests](https://github.com/w3c/web-platform-tests/blob/master/html/webappapis/atob/base64.html).
|
|
||||||
|
|
||||||
Compatibility: Node.js version 3+ and all major browsers.
|
|
||||||
|
|
||||||
Install with `npm`:
|
|
||||||
|
|
||||||
```sh
|
|
||||||
npm install abab
|
|
||||||
```
|
|
||||||
|
|
||||||
## API
|
|
||||||
|
|
||||||
### `btoa` (base64 encode)
|
|
||||||
|
|
||||||
```js
|
|
||||||
const { btoa } = require('abab');
|
|
||||||
btoa('Hello, world!'); // 'SGVsbG8sIHdvcmxkIQ=='
|
|
||||||
```
|
|
||||||
|
|
||||||
### `atob` (base64 decode)
|
|
||||||
|
|
||||||
```js
|
|
||||||
const { atob } = require('abab');
|
|
||||||
atob('SGVsbG8sIHdvcmxkIQ=='); // 'Hello, world!'
|
|
||||||
```
|
|
||||||
|
|
||||||
#### Valid characters
|
|
||||||
|
|
||||||
[Per the spec](https://html.spec.whatwg.org/multipage/webappapis.html#atob:dom-windowbase64-btoa-3), `btoa` will accept strings "containing only characters in the range `U+0000` to `U+00FF`." If passed a string with characters above `U+00FF`, `btoa` will return `null`. If `atob` is passed a string that is not base64-valid, it will also return `null`. In both cases when `null` is returned, the spec calls for throwing a `DOMException` of type `InvalidCharacterError`.
|
|
||||||
|
|
||||||
## Browsers
|
|
||||||
|
|
||||||
If you want to include just one of the methods to save bytes in your client-side code, you can `require` the desired module directly.
|
|
||||||
|
|
||||||
```js
|
|
||||||
const atob = require('abab/lib/atob');
|
|
||||||
const btoa = require('abab/lib/btoa');
|
|
||||||
```
|
|
||||||
|
|
||||||
## Development
|
|
||||||
|
|
||||||
If you're **submitting a PR** or **deploying to npm**, please use the [checklists in CONTRIBUTING.md](CONTRIBUTING.md#checklists).
|
|
||||||
|
|
||||||
## Remembering what `atob` and `btoa` stand for
|
|
||||||
|
|
||||||
Base64 comes from IETF [RFC 4648](https://tools.ietf.org/html/rfc4648#section-4) (2006).
|
|
||||||
|
|
||||||
- **`btoa`**, the encoder function, stands for **binary** to **ASCII**, meaning it converts any binary input into a subset of **ASCII** (Base64).
|
|
||||||
- **`atob`**, the decoder function, converts **ASCII** (or Base64) to its original **binary** format.
|
|
||||||
2
node_modules/abab/index.d.ts
generated
vendored
2
node_modules/abab/index.d.ts
generated
vendored
@@ -1,2 +0,0 @@
|
|||||||
export function atob(encodedData: string): string | null
|
|
||||||
export function btoa(stringToEncode: string): string | null
|
|
||||||
9
node_modules/abab/index.js
generated
vendored
9
node_modules/abab/index.js
generated
vendored
@@ -1,9 +0,0 @@
|
|||||||
"use strict";
|
|
||||||
|
|
||||||
const atob = require("./lib/atob");
|
|
||||||
const btoa = require("./lib/btoa");
|
|
||||||
|
|
||||||
module.exports = {
|
|
||||||
atob,
|
|
||||||
btoa
|
|
||||||
};
|
|
||||||
101
node_modules/abab/lib/atob.js
generated
vendored
101
node_modules/abab/lib/atob.js
generated
vendored
@@ -1,101 +0,0 @@
|
|||||||
"use strict";
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Implementation of atob() according to the HTML and Infra specs, except that
|
|
||||||
* instead of throwing INVALID_CHARACTER_ERR we return null.
|
|
||||||
*/
|
|
||||||
function atob(data) {
|
|
||||||
if (arguments.length === 0) {
|
|
||||||
throw new TypeError("1 argument required, but only 0 present.");
|
|
||||||
}
|
|
||||||
|
|
||||||
// Web IDL requires DOMStrings to just be converted using ECMAScript
|
|
||||||
// ToString, which in our case amounts to using a template literal.
|
|
||||||
data = `${data}`;
|
|
||||||
// "Remove all ASCII whitespace from data."
|
|
||||||
data = data.replace(/[ \t\n\f\r]/g, "");
|
|
||||||
// "If data's length divides by 4 leaving no remainder, then: if data ends
|
|
||||||
// with one or two U+003D (=) code points, then remove them from data."
|
|
||||||
if (data.length % 4 === 0) {
|
|
||||||
data = data.replace(/==?$/, "");
|
|
||||||
}
|
|
||||||
// "If data's length divides by 4 leaving a remainder of 1, then return
|
|
||||||
// failure."
|
|
||||||
//
|
|
||||||
// "If data contains a code point that is not one of
|
|
||||||
//
|
|
||||||
// U+002B (+)
|
|
||||||
// U+002F (/)
|
|
||||||
// ASCII alphanumeric
|
|
||||||
//
|
|
||||||
// then return failure."
|
|
||||||
if (data.length % 4 === 1 || /[^+/0-9A-Za-z]/.test(data)) {
|
|
||||||
return null;
|
|
||||||
}
|
|
||||||
// "Let output be an empty byte sequence."
|
|
||||||
let output = "";
|
|
||||||
// "Let buffer be an empty buffer that can have bits appended to it."
|
|
||||||
//
|
|
||||||
// We append bits via left-shift and or. accumulatedBits is used to track
|
|
||||||
// when we've gotten to 24 bits.
|
|
||||||
let buffer = 0;
|
|
||||||
let accumulatedBits = 0;
|
|
||||||
// "Let position be a position variable for data, initially pointing at the
|
|
||||||
// start of data."
|
|
||||||
//
|
|
||||||
// "While position does not point past the end of data:"
|
|
||||||
for (let i = 0; i < data.length; i++) {
|
|
||||||
// "Find the code point pointed to by position in the second column of
|
|
||||||
// Table 1: The Base 64 Alphabet of RFC 4648. Let n be the number given in
|
|
||||||
// the first cell of the same row.
|
|
||||||
//
|
|
||||||
// "Append to buffer the six bits corresponding to n, most significant bit
|
|
||||||
// first."
|
|
||||||
//
|
|
||||||
// atobLookup() implements the table from RFC 4648.
|
|
||||||
buffer <<= 6;
|
|
||||||
buffer |= atobLookup(data[i]);
|
|
||||||
accumulatedBits += 6;
|
|
||||||
// "If buffer has accumulated 24 bits, interpret them as three 8-bit
|
|
||||||
// big-endian numbers. Append three bytes with values equal to those
|
|
||||||
// numbers to output, in the same order, and then empty buffer."
|
|
||||||
if (accumulatedBits === 24) {
|
|
||||||
output += String.fromCharCode((buffer & 0xff0000) >> 16);
|
|
||||||
output += String.fromCharCode((buffer & 0xff00) >> 8);
|
|
||||||
output += String.fromCharCode(buffer & 0xff);
|
|
||||||
buffer = accumulatedBits = 0;
|
|
||||||
}
|
|
||||||
// "Advance position by 1."
|
|
||||||
}
|
|
||||||
// "If buffer is not empty, it contains either 12 or 18 bits. If it contains
|
|
||||||
// 12 bits, then discard the last four and interpret the remaining eight as
|
|
||||||
// an 8-bit big-endian number. If it contains 18 bits, then discard the last
|
|
||||||
// two and interpret the remaining 16 as two 8-bit big-endian numbers. Append
|
|
||||||
// the one or two bytes with values equal to those one or two numbers to
|
|
||||||
// output, in the same order."
|
|
||||||
if (accumulatedBits === 12) {
|
|
||||||
buffer >>= 4;
|
|
||||||
output += String.fromCharCode(buffer);
|
|
||||||
} else if (accumulatedBits === 18) {
|
|
||||||
buffer >>= 2;
|
|
||||||
output += String.fromCharCode((buffer & 0xff00) >> 8);
|
|
||||||
output += String.fromCharCode(buffer & 0xff);
|
|
||||||
}
|
|
||||||
// "Return output."
|
|
||||||
return output;
|
|
||||||
}
|
|
||||||
/**
|
|
||||||
* A lookup table for atob(), which converts an ASCII character to the
|
|
||||||
* corresponding six-bit number.
|
|
||||||
*/
|
|
||||||
|
|
||||||
const keystr =
|
|
||||||
"ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/";
|
|
||||||
|
|
||||||
function atobLookup(chr) {
|
|
||||||
const index = keystr.indexOf(chr);
|
|
||||||
// Throw exception if character is not in the lookup string; should not be hit in tests
|
|
||||||
return index < 0 ? undefined : index;
|
|
||||||
}
|
|
||||||
|
|
||||||
module.exports = atob;
|
|
||||||
62
node_modules/abab/lib/btoa.js
generated
vendored
62
node_modules/abab/lib/btoa.js
generated
vendored
@@ -1,62 +0,0 @@
|
|||||||
"use strict";
|
|
||||||
|
|
||||||
/**
|
|
||||||
* btoa() as defined by the HTML and Infra specs, which mostly just references
|
|
||||||
* RFC 4648.
|
|
||||||
*/
|
|
||||||
function btoa(s) {
|
|
||||||
if (arguments.length === 0) {
|
|
||||||
throw new TypeError("1 argument required, but only 0 present.");
|
|
||||||
}
|
|
||||||
|
|
||||||
let i;
|
|
||||||
// String conversion as required by Web IDL.
|
|
||||||
s = `${s}`;
|
|
||||||
// "The btoa() method must throw an "InvalidCharacterError" DOMException if
|
|
||||||
// data contains any character whose code point is greater than U+00FF."
|
|
||||||
for (i = 0; i < s.length; i++) {
|
|
||||||
if (s.charCodeAt(i) > 255) {
|
|
||||||
return null;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
let out = "";
|
|
||||||
for (i = 0; i < s.length; i += 3) {
|
|
||||||
const groupsOfSix = [undefined, undefined, undefined, undefined];
|
|
||||||
groupsOfSix[0] = s.charCodeAt(i) >> 2;
|
|
||||||
groupsOfSix[1] = (s.charCodeAt(i) & 0x03) << 4;
|
|
||||||
if (s.length > i + 1) {
|
|
||||||
groupsOfSix[1] |= s.charCodeAt(i + 1) >> 4;
|
|
||||||
groupsOfSix[2] = (s.charCodeAt(i + 1) & 0x0f) << 2;
|
|
||||||
}
|
|
||||||
if (s.length > i + 2) {
|
|
||||||
groupsOfSix[2] |= s.charCodeAt(i + 2) >> 6;
|
|
||||||
groupsOfSix[3] = s.charCodeAt(i + 2) & 0x3f;
|
|
||||||
}
|
|
||||||
for (let j = 0; j < groupsOfSix.length; j++) {
|
|
||||||
if (typeof groupsOfSix[j] === "undefined") {
|
|
||||||
out += "=";
|
|
||||||
} else {
|
|
||||||
out += btoaLookup(groupsOfSix[j]);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
return out;
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Lookup table for btoa(), which converts a six-bit number into the
|
|
||||||
* corresponding ASCII character.
|
|
||||||
*/
|
|
||||||
const keystr =
|
|
||||||
"ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/";
|
|
||||||
|
|
||||||
function btoaLookup(index) {
|
|
||||||
if (index >= 0 && index < 64) {
|
|
||||||
return keystr[index];
|
|
||||||
}
|
|
||||||
|
|
||||||
// Throw INVALID_CHARACTER_ERR exception here -- won't be hit in the tests.
|
|
||||||
return undefined;
|
|
||||||
}
|
|
||||||
|
|
||||||
module.exports = btoa;
|
|
||||||
42
node_modules/abab/package.json
generated
vendored
42
node_modules/abab/package.json
generated
vendored
@@ -1,42 +0,0 @@
|
|||||||
{
|
|
||||||
"name": "abab",
|
|
||||||
"version": "2.0.6",
|
|
||||||
"description": "WHATWG spec-compliant implementations of window.atob and window.btoa.",
|
|
||||||
"main": "index.js",
|
|
||||||
"files": [
|
|
||||||
"index.d.ts",
|
|
||||||
"index.js",
|
|
||||||
"lib/"
|
|
||||||
],
|
|
||||||
"scripts": {
|
|
||||||
"mocha": "mocha test/node",
|
|
||||||
"karma": "karma start",
|
|
||||||
"test": "npm run lint && npm run mocha && npm run karma",
|
|
||||||
"lint": "eslint ."
|
|
||||||
},
|
|
||||||
"repository": {
|
|
||||||
"type": "git",
|
|
||||||
"url": "git+https://github.com/jsdom/abab.git"
|
|
||||||
},
|
|
||||||
"keywords": [
|
|
||||||
"atob",
|
|
||||||
"btoa",
|
|
||||||
"browser"
|
|
||||||
],
|
|
||||||
"author": "Jeff Carpenter <gcarpenterv@gmail.com>",
|
|
||||||
"license": "BSD-3-Clause",
|
|
||||||
"bugs": {
|
|
||||||
"url": "https://github.com/jsdom/abab/issues"
|
|
||||||
},
|
|
||||||
"homepage": "https://github.com/jsdom/abab#readme",
|
|
||||||
"devDependencies": {
|
|
||||||
"eslint": "^4.19.1",
|
|
||||||
"karma": "^2.0.0",
|
|
||||||
"karma-cli": "^1.0.1",
|
|
||||||
"karma-firefox-launcher": "^1.1.0",
|
|
||||||
"karma-mocha": "^1.3.0",
|
|
||||||
"karma-webpack": "^3.0.0",
|
|
||||||
"mocha": "^5.1.0",
|
|
||||||
"webpack": "^4.5.0"
|
|
||||||
}
|
|
||||||
}
|
|
||||||
19
node_modules/acorn-globals/LICENSE
generated
vendored
19
node_modules/acorn-globals/LICENSE
generated
vendored
@@ -1,19 +0,0 @@
|
|||||||
Copyright (c) 2014 Forbes Lindesay
|
|
||||||
|
|
||||||
Permission is hereby granted, free of charge, to any person obtaining a copy
|
|
||||||
of this software and associated documentation files (the "Software"), to deal
|
|
||||||
in the Software without restriction, including without limitation the rights
|
|
||||||
to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
|
|
||||||
copies of the Software, and to permit persons to whom the Software is
|
|
||||||
furnished to do so, subject to the following conditions:
|
|
||||||
|
|
||||||
The above copyright notice and this permission notice shall be included in
|
|
||||||
all copies or substantial portions of the Software.
|
|
||||||
|
|
||||||
THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
|
|
||||||
IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
|
|
||||||
FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
|
|
||||||
AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
|
|
||||||
LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
|
|
||||||
OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN
|
|
||||||
THE SOFTWARE.
|
|
||||||
81
node_modules/acorn-globals/README.md
generated
vendored
81
node_modules/acorn-globals/README.md
generated
vendored
@@ -1,81 +0,0 @@
|
|||||||
# acorn-globals
|
|
||||||
|
|
||||||
Detect global variables in JavaScript using acorn
|
|
||||||
|
|
||||||
[Get supported acorn-globals with the Tidelift Subscription](https://tidelift.com/subscription/pkg/npm-acorn_globals?utm_source=npm-acorn-globals&utm_medium=referral&utm_campaign=readme)
|
|
||||||
|
|
||||||
[](https://travis-ci.org/ForbesLindesay/acorn-globals)
|
|
||||||
[](https://david-dm.org/ForbesLindesay/acorn-globals)
|
|
||||||
[](https://www.npmjs.org/package/acorn-globals)
|
|
||||||
|
|
||||||
## Installation
|
|
||||||
|
|
||||||
npm install acorn-globals
|
|
||||||
|
|
||||||
## Usage
|
|
||||||
|
|
||||||
detect.js
|
|
||||||
|
|
||||||
```js
|
|
||||||
var fs = require('fs');
|
|
||||||
var detect = require('acorn-globals');
|
|
||||||
|
|
||||||
var src = fs.readFileSync(__dirname + '/input.js', 'utf8');
|
|
||||||
|
|
||||||
var scope = detect(src);
|
|
||||||
console.dir(scope);
|
|
||||||
```
|
|
||||||
|
|
||||||
input.js
|
|
||||||
|
|
||||||
```js
|
|
||||||
var x = 5;
|
|
||||||
var y = 3, z = 2;
|
|
||||||
|
|
||||||
w.foo();
|
|
||||||
w = 2;
|
|
||||||
|
|
||||||
RAWR=444;
|
|
||||||
RAWR.foo();
|
|
||||||
|
|
||||||
BLARG=3;
|
|
||||||
|
|
||||||
foo(function () {
|
|
||||||
var BAR = 3;
|
|
||||||
process.nextTick(function (ZZZZZZZZZZZZ) {
|
|
||||||
console.log('beep boop');
|
|
||||||
var xyz = 4;
|
|
||||||
x += 10;
|
|
||||||
x.zzzzzz;
|
|
||||||
ZZZ=6;
|
|
||||||
});
|
|
||||||
function doom () {
|
|
||||||
}
|
|
||||||
ZZZ.foo();
|
|
||||||
|
|
||||||
});
|
|
||||||
|
|
||||||
console.log(xyz);
|
|
||||||
```
|
|
||||||
|
|
||||||
output:
|
|
||||||
|
|
||||||
```
|
|
||||||
$ node example/detect.js
|
|
||||||
[ { name: 'BLARG', nodes: [ [Object] ] },
|
|
||||||
{ name: 'RAWR', nodes: [ [Object], [Object] ] },
|
|
||||||
{ name: 'ZZZ', nodes: [ [Object], [Object] ] },
|
|
||||||
{ name: 'console', nodes: [ [Object], [Object] ] },
|
|
||||||
{ name: 'foo', nodes: [ [Object] ] },
|
|
||||||
{ name: 'process', nodes: [ [Object] ] },
|
|
||||||
{ name: 'w', nodes: [ [Object], [Object] ] },
|
|
||||||
{ name: 'xyz', nodes: [ [Object] ] } ]
|
|
||||||
```
|
|
||||||
|
|
||||||
## Security contact information
|
|
||||||
|
|
||||||
To report a security vulnerability, please use the [Tidelift security contact](https://tidelift.com/security). Tidelift will coordinate the fix and disclosure.
|
|
||||||
|
|
||||||
## License
|
|
||||||
|
|
||||||
MIT
|
|
||||||
179
node_modules/acorn-globals/index.js
generated
vendored
179
node_modules/acorn-globals/index.js
generated
vendored
@@ -1,179 +0,0 @@
|
|||||||
'use strict';
|
|
||||||
|
|
||||||
var acorn = require('acorn');
|
|
||||||
var walk = require('acorn-walk');
|
|
||||||
|
|
||||||
function isScope(node) {
|
|
||||||
return node.type === 'FunctionExpression' || node.type === 'FunctionDeclaration' || node.type === 'ArrowFunctionExpression' || node.type === 'Program';
|
|
||||||
}
|
|
||||||
function isBlockScope(node) {
|
|
||||||
return node.type === 'BlockStatement' || isScope(node);
|
|
||||||
}
|
|
||||||
|
|
||||||
function declaresArguments(node) {
|
|
||||||
return node.type === 'FunctionExpression' || node.type === 'FunctionDeclaration';
|
|
||||||
}
|
|
||||||
|
|
||||||
function declaresThis(node) {
|
|
||||||
return node.type === 'FunctionExpression' || node.type === 'FunctionDeclaration';
|
|
||||||
}
|
|
||||||
|
|
||||||
function reallyParse(source, options) {
|
|
||||||
var parseOptions = Object.assign({}, options,
|
|
||||||
{
|
|
||||||
allowReturnOutsideFunction: true,
|
|
||||||
allowImportExportEverywhere: true,
|
|
||||||
allowHashBang: true
|
|
||||||
}
|
|
||||||
);
|
|
||||||
return acorn.parse(source, parseOptions);
|
|
||||||
}
|
|
||||||
module.exports = findGlobals;
|
|
||||||
module.exports.parse = reallyParse;
|
|
||||||
function findGlobals(source, options) {
|
|
||||||
options = options || {};
|
|
||||||
var globals = [];
|
|
||||||
var ast;
|
|
||||||
// istanbul ignore else
|
|
||||||
if (typeof source === 'string') {
|
|
||||||
ast = reallyParse(source, options);
|
|
||||||
} else {
|
|
||||||
ast = source;
|
|
||||||
}
|
|
||||||
// istanbul ignore if
|
|
||||||
if (!(ast && typeof ast === 'object' && ast.type === 'Program')) {
|
|
||||||
throw new TypeError('Source must be either a string of JavaScript or an acorn AST');
|
|
||||||
}
|
|
||||||
var declareFunction = function (node) {
|
|
||||||
var fn = node;
|
|
||||||
fn.locals = fn.locals || Object.create(null);
|
|
||||||
node.params.forEach(function (node) {
|
|
||||||
declarePattern(node, fn);
|
|
||||||
});
|
|
||||||
if (node.id) {
|
|
||||||
fn.locals[node.id.name] = true;
|
|
||||||
}
|
|
||||||
};
|
|
||||||
var declareClass = function (node) {
|
|
||||||
node.locals = node.locals || Object.create(null);
|
|
||||||
if (node.id) {
|
|
||||||
node.locals[node.id.name] = true;
|
|
||||||
}
|
|
||||||
};
|
|
||||||
var declarePattern = function (node, parent) {
|
|
||||||
switch (node.type) {
|
|
||||||
case 'Identifier':
|
|
||||||
parent.locals[node.name] = true;
|
|
||||||
break;
|
|
||||||
case 'ObjectPattern':
|
|
||||||
node.properties.forEach(function (node) {
|
|
||||||
declarePattern(node.value || node.argument, parent);
|
|
||||||
});
|
|
||||||
break;
|
|
||||||
case 'ArrayPattern':
|
|
||||||
node.elements.forEach(function (node) {
|
|
||||||
if (node) declarePattern(node, parent);
|
|
||||||
});
|
|
||||||
break;
|
|
||||||
case 'RestElement':
|
|
||||||
declarePattern(node.argument, parent);
|
|
||||||
break;
|
|
||||||
case 'AssignmentPattern':
|
|
||||||
declarePattern(node.left, parent);
|
|
||||||
break;
|
|
||||||
// istanbul ignore next
|
|
||||||
default:
|
|
||||||
throw new Error('Unrecognized pattern type: ' + node.type);
|
|
||||||
}
|
|
||||||
};
|
|
||||||
var declareModuleSpecifier = function (node, parents) {
|
|
||||||
ast.locals = ast.locals || Object.create(null);
|
|
||||||
ast.locals[node.local.name] = true;
|
|
||||||
};
|
|
||||||
walk.ancestor(ast, {
|
|
||||||
'VariableDeclaration': function (node, parents) {
|
|
||||||
var parent = null;
|
|
||||||
for (var i = parents.length - 1; i >= 0 && parent === null; i--) {
|
|
||||||
if (node.kind === 'var' ? isScope(parents[i]) : isBlockScope(parents[i])) {
|
|
||||||
parent = parents[i];
|
|
||||||
}
|
|
||||||
}
|
|
||||||
parent.locals = parent.locals || Object.create(null);
|
|
||||||
node.declarations.forEach(function (declaration) {
|
|
||||||
declarePattern(declaration.id, parent);
|
|
||||||
});
|
|
||||||
},
|
|
||||||
'FunctionDeclaration': function (node, parents) {
|
|
||||||
var parent = null;
|
|
||||||
for (var i = parents.length - 2; i >= 0 && parent === null; i--) {
|
|
||||||
if (isScope(parents[i])) {
|
|
||||||
parent = parents[i];
|
|
||||||
}
|
|
||||||
}
|
|
||||||
parent.locals = parent.locals || Object.create(null);
|
|
||||||
if (node.id) {
|
|
||||||
parent.locals[node.id.name] = true;
|
|
||||||
}
|
|
||||||
declareFunction(node);
|
|
||||||
},
|
|
||||||
'Function': declareFunction,
|
|
||||||
'ClassDeclaration': function (node, parents) {
|
|
||||||
var parent = null;
|
|
||||||
for (var i = parents.length - 2; i >= 0 && parent === null; i--) {
|
|
||||||
if (isBlockScope(parents[i])) {
|
|
||||||
parent = parents[i];
|
|
||||||
}
|
|
||||||
}
|
|
||||||
parent.locals = parent.locals || Object.create(null);
|
|
||||||
if (node.id) {
|
|
||||||
parent.locals[node.id.name] = true;
|
|
||||||
}
|
|
||||||
declareClass(node);
|
|
||||||
},
|
|
||||||
'Class': declareClass,
|
|
||||||
'TryStatement': function (node) {
|
|
||||||
if (node.handler === null) return;
|
|
||||||
node.handler.locals = node.handler.locals || Object.create(null);
|
|
||||||
declarePattern(node.handler.param, node.handler);
|
|
||||||
},
|
|
||||||
'ImportDefaultSpecifier': declareModuleSpecifier,
|
|
||||||
'ImportSpecifier': declareModuleSpecifier,
|
|
||||||
'ImportNamespaceSpecifier': declareModuleSpecifier
|
|
||||||
});
|
|
||||||
function identifier(node, parents) {
|
|
||||||
var name = node.name;
|
|
||||||
if (name === 'undefined') return;
|
|
||||||
for (var i = 0; i < parents.length; i++) {
|
|
||||||
if (name === 'arguments' && declaresArguments(parents[i])) {
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
if (parents[i].locals && name in parents[i].locals) {
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
node.parents = parents.slice();
|
|
||||||
globals.push(node);
|
|
||||||
}
|
|
||||||
walk.ancestor(ast, {
|
|
||||||
'VariablePattern': identifier,
|
|
||||||
'Identifier': identifier,
|
|
||||||
'ThisExpression': function (node, parents) {
|
|
||||||
for (var i = 0; i < parents.length; i++) {
|
|
||||||
if (declaresThis(parents[i])) {
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
node.parents = parents.slice();
|
|
||||||
globals.push(node);
|
|
||||||
}
|
|
||||||
});
|
|
||||||
var groupedGlobals = Object.create(null);
|
|
||||||
globals.forEach(function (node) {
|
|
||||||
var name = node.type === 'ThisExpression' ? 'this' : node.name;
|
|
||||||
groupedGlobals[name] = (groupedGlobals[name] || []);
|
|
||||||
groupedGlobals[name].push(node);
|
|
||||||
});
|
|
||||||
return Object.keys(groupedGlobals).sort().map(function (name) {
|
|
||||||
return {name: name, nodes: groupedGlobals[name]};
|
|
||||||
});
|
|
||||||
}
|
|
||||||
1
node_modules/acorn-globals/node_modules/.bin/acorn
generated
vendored
1
node_modules/acorn-globals/node_modules/.bin/acorn
generated
vendored
@@ -1 +0,0 @@
|
|||||||
../acorn/bin/acorn
|
|
||||||
550
node_modules/acorn-globals/node_modules/acorn/CHANGELOG.md
generated
vendored
550
node_modules/acorn-globals/node_modules/acorn/CHANGELOG.md
generated
vendored
@@ -1,550 +0,0 @@
|
|||||||
## 6.4.0 (2019-11-26)
|
|
||||||
|
|
||||||
### New features
|
|
||||||
|
|
||||||
Add a static `acorn` property to the `Parser` class that contains the entire module interface, to allow plugins to access the instance of the library that they are acting on.
|
|
||||||
|
|
||||||
## 6.3.0 (2019-08-12)
|
|
||||||
|
|
||||||
### New features
|
|
||||||
|
|
||||||
`sourceType: "module"` can now be used even when `ecmaVersion` is less than 6, to parse module-style code that otherwise conforms to an older standard.
|
|
||||||
|
|
||||||
## 6.2.1 (2019-07-21)
|
|
||||||
|
|
||||||
### Bug fixes
|
|
||||||
|
|
||||||
Fix bug causing Acorn to treat some characters as identifier characters that shouldn't be treated as such.
|
|
||||||
|
|
||||||
Fix issue where setting the `allowReserved` option to `"never"` allowed reserved words in some circumstances.
|
|
||||||
|
|
||||||
## 6.2.0 (2019-07-04)
|
|
||||||
|
|
||||||
### Bug fixes
|
|
||||||
|
|
||||||
Improve valid assignment checking in `for`/`in` and `for`/`of` loops.
|
|
||||||
|
|
||||||
Disallow binding `let` in patterns.
|
|
||||||
|
|
||||||
### New features
|
|
||||||
|
|
||||||
Support bigint syntax with `ecmaVersion` >= 10.
|
|
||||||
|
|
||||||
Support dynamic `import` syntax with `ecmaVersion` >= 10.
|
|
||||||
|
|
||||||
Upgrade to Unicode version 12.
|
|
||||||
|
|
||||||
## 6.1.1 (2019-02-27)
|
|
||||||
|
|
||||||
### Bug fixes
|
|
||||||
|
|
||||||
Fix bug that caused parsing default exports of with names to fail.
|
|
||||||
|
|
||||||
## 6.1.0 (2019-02-08)
|
|
||||||
|
|
||||||
### Bug fixes
|
|
||||||
|
|
||||||
Fix scope checking when redefining a `var` as a lexical binding.
|
|
||||||
|
|
||||||
### New features
|
|
||||||
|
|
||||||
Split up `parseSubscripts` to use an internal `parseSubscript` method to make it easier to extend with plugins.
|
|
||||||
|
|
||||||
## 6.0.7 (2019-02-04)
|
|
||||||
|
|
||||||
### Bug fixes
|
|
||||||
|
|
||||||
Check that exported bindings are defined.
|
|
||||||
|
|
||||||
Don't treat `\u180e` as a whitespace character.
|
|
||||||
|
|
||||||
Check for duplicate parameter names in methods.
|
|
||||||
|
|
||||||
Don't allow shorthand properties when they are generators or async methods.
|
|
||||||
|
|
||||||
Forbid binding `await` in async arrow function's parameter list.
|
|
||||||
|
|
||||||
## 6.0.6 (2019-01-30)
|
|
||||||
|
|
||||||
### Bug fixes
|
|
||||||
|
|
||||||
The content of class declarations and expressions is now always parsed in strict mode.
|
|
||||||
|
|
||||||
Don't allow `let` or `const` to bind the variable name `let`.
|
|
||||||
|
|
||||||
Treat class declarations as lexical.
|
|
||||||
|
|
||||||
Don't allow a generator function declaration as the sole body of an `if` or `else`.
|
|
||||||
|
|
||||||
Ignore `"use strict"` when after an empty statement.
|
|
||||||
|
|
||||||
Allow string line continuations with special line terminator characters.
|
|
||||||
|
|
||||||
Treat `for` bodies as part of the `for` scope when checking for conflicting bindings.
|
|
||||||
|
|
||||||
Fix bug with parsing `yield` in a `for` loop initializer.
|
|
||||||
|
|
||||||
Implement special cases around scope checking for functions.
|
|
||||||
|
|
||||||
## 6.0.5 (2019-01-02)
|
|
||||||
|
|
||||||
### Bug fixes
|
|
||||||
|
|
||||||
Fix TypeScript type for `Parser.extend` and add `allowAwaitOutsideFunction` to options type.
|
|
||||||
|
|
||||||
Don't treat `let` as a keyword when the next token is `{` on the next line.
|
|
||||||
|
|
||||||
Fix bug that broke checking for parentheses around an object pattern in a destructuring assignment when `preserveParens` was on.
|
|
||||||
|
|
||||||
## 6.0.4 (2018-11-05)
|
|
||||||
|
|
||||||
### Bug fixes
|
|
||||||
|
|
||||||
Further improvements to tokenizing regular expressions in corner cases.
|
|
||||||
|
|
||||||
## 6.0.3 (2018-11-04)
|
|
||||||
|
|
||||||
### Bug fixes
|
|
||||||
|
|
||||||
Fix bug in tokenizing an expression-less return followed by a function followed by a regular expression.
|
|
||||||
|
|
||||||
Remove stray symlink in the package tarball.
|
|
||||||
|
|
||||||
## 6.0.2 (2018-09-26)
|
|
||||||
|
|
||||||
### Bug fixes
|
|
||||||
|
|
||||||
Fix bug where default expressions could fail to parse inside an object destructuring assignment expression.
|
|
||||||
|
|
||||||
## 6.0.1 (2018-09-14)
|
|
||||||
|
|
||||||
### Bug fixes
|
|
||||||
|
|
||||||
Fix wrong value in `version` export.
|
|
||||||
|
|
||||||
## 6.0.0 (2018-09-14)
|
|
||||||
|
|
||||||
### Bug fixes
|
|
||||||
|
|
||||||
Better handle variable-redefinition checks for catch bindings and functions directly under if statements.
|
|
||||||
|
|
||||||
Forbid `new.target` in top-level arrow functions.
|
|
||||||
|
|
||||||
Fix issue with parsing a regexp after `yield` in some contexts.
|
|
||||||
|
|
||||||
### New features
|
|
||||||
|
|
||||||
The package now comes with TypeScript definitions.
|
|
||||||
|
|
||||||
### Breaking changes
|
|
||||||
|
|
||||||
The default value of the `ecmaVersion` option is now 9 (2018).
|
|
||||||
|
|
||||||
Plugins work differently, and will have to be rewritten to work with this version.
|
|
||||||
|
|
||||||
The loose parser and walker have been moved into separate packages (`acorn-loose` and `acorn-walk`).
|
|
||||||
|
|
||||||
## 5.7.3 (2018-09-10)
|
|
||||||
|
|
||||||
### Bug fixes
|
|
||||||
|
|
||||||
Fix failure to tokenize regexps after expressions like `x.of`.
|
|
||||||
|
|
||||||
Better error message for unterminated template literals.
|
|
||||||
|
|
||||||
## 5.7.2 (2018-08-24)
|
|
||||||
|
|
||||||
### Bug fixes
|
|
||||||
|
|
||||||
Properly handle `allowAwaitOutsideFunction` in for statements.
|
|
||||||
|
|
||||||
Treat function declarations at the top level of modules like let bindings.
|
|
||||||
|
|
||||||
Don't allow async function declarations as the only statement under a label.
|
|
||||||
|
|
||||||
## 5.7.0 (2018-06-15)
|
|
||||||
|
|
||||||
### New features
|
|
||||||
|
|
||||||
Upgraded to Unicode 11.
|
|
||||||
|
|
||||||
## 5.6.0 (2018-05-31)
|
|
||||||
|
|
||||||
### New features
|
|
||||||
|
|
||||||
Allow U+2028 and U+2029 in string when ECMAVersion >= 10.
|
|
||||||
|
|
||||||
Allow binding-less catch statements when ECMAVersion >= 10.
|
|
||||||
|
|
||||||
Add `allowAwaitOutsideFunction` option for parsing top-level `await`.
|
|
||||||
|
|
||||||
## 5.5.3 (2018-03-08)
|
|
||||||
|
|
||||||
### Bug fixes
|
|
||||||
|
|
||||||
A _second_ republish of the code in 5.5.1, this time with yarn, to hopefully get valid timestamps.
|
|
||||||
|
|
||||||
## 5.5.2 (2018-03-08)
|
|
||||||
|
|
||||||
### Bug fixes
|
|
||||||
|
|
||||||
A republish of the code in 5.5.1 in an attempt to solve an issue with the file timestamps in the npm package being 0.
|
|
||||||
|
|
||||||
## 5.5.1 (2018-03-06)
|
|
||||||
|
|
||||||
### Bug fixes
|
|
||||||
|
|
||||||
Fix misleading error message for octal escapes in template strings.
|
|
||||||
|
|
||||||
## 5.5.0 (2018-02-27)
|
|
||||||
|
|
||||||
### New features
|
|
||||||
|
|
||||||
The identifier character categorization is now based on Unicode version 10.
|
|
||||||
|
|
||||||
Acorn will now validate the content of regular expressions, including new ES9 features.
|
|
||||||
|
|
||||||
## 5.4.0 (2018-02-01)
|
|
||||||
|
|
||||||
### Bug fixes
|
|
||||||
|
|
||||||
Disallow duplicate or escaped flags on regular expressions.
|
|
||||||
|
|
||||||
Disallow octal escapes in strings in strict mode.
|
|
||||||
|
|
||||||
### New features
|
|
||||||
|
|
||||||
Add support for async iteration.
|
|
||||||
|
|
||||||
Add support for object spread and rest.
|
|
||||||
|
|
||||||
## 5.3.0 (2017-12-28)
|
|
||||||
|
|
||||||
### Bug fixes
|
|
||||||
|
|
||||||
Fix parsing of floating point literals with leading zeroes in loose mode.
|
|
||||||
|
|
||||||
Allow duplicate property names in object patterns.
|
|
||||||
|
|
||||||
Don't allow static class methods named `prototype`.
|
|
||||||
|
|
||||||
Disallow async functions directly under `if` or `else`.
|
|
||||||
|
|
||||||
Parse right-hand-side of `for`/`of` as an assignment expression.
|
|
||||||
|
|
||||||
Stricter parsing of `for`/`in`.
|
|
||||||
|
|
||||||
Don't allow unicode escapes in contextual keywords.
|
|
||||||
|
|
||||||
### New features
|
|
||||||
|
|
||||||
Parsing class members was factored into smaller methods to allow plugins to hook into it.
|
|
||||||
|
|
||||||
## 5.2.1 (2017-10-30)
|
|
||||||
|
|
||||||
### Bug fixes
|
|
||||||
|
|
||||||
Fix a token context corruption bug.
|
|
||||||
|
|
||||||
## 5.2.0 (2017-10-30)
|
|
||||||
|
|
||||||
### Bug fixes
|
|
||||||
|
|
||||||
Fix token context tracking for `class` and `function` in property-name position.
|
|
||||||
|
|
||||||
Make sure `%*` isn't parsed as a valid operator.
|
|
||||||
|
|
||||||
Allow shorthand properties `get` and `set` to be followed by default values.
|
|
||||||
|
|
||||||
Disallow `super` when not in callee or object position.
|
|
||||||
|
|
||||||
### New features
|
|
||||||
|
|
||||||
Support [`directive` property](https://github.com/estree/estree/compare/b3de58c9997504d6fba04b72f76e6dd1619ee4eb...1da8e603237144f44710360f8feb7a9977e905e0) on directive expression statements.
|
|
||||||
|
|
||||||
## 5.1.2 (2017-09-04)
|
|
||||||
|
|
||||||
### Bug fixes
|
|
||||||
|
|
||||||
Disable parsing of legacy HTML-style comments in modules.
|
|
||||||
|
|
||||||
Fix parsing of async methods whose names are keywords.
|
|
||||||
|
|
||||||
## 5.1.1 (2017-07-06)
|
|
||||||
|
|
||||||
### Bug fixes
|
|
||||||
|
|
||||||
Fix problem with disambiguating regexp and division after a class.
|
|
||||||
|
|
||||||
## 5.1.0 (2017-07-05)
|
|
||||||
|
|
||||||
### Bug fixes
|
|
||||||
|
|
||||||
Fix tokenizing of regexps in an object-desctructuring `for`/`of` loop and after `yield`.
|
|
||||||
|
|
||||||
Parse zero-prefixed numbers with non-octal digits as decimal.
|
|
||||||
|
|
||||||
Allow object/array patterns in rest parameters.
|
|
||||||
|
|
||||||
Don't error when `yield` is used as a property name.
|
|
||||||
|
|
||||||
Allow `async` as a shorthand object property.
|
|
||||||
|
|
||||||
### New features
|
|
||||||
|
|
||||||
Implement the [template literal revision proposal](https://github.com/tc39/proposal-template-literal-revision) for ES9.
|
|
||||||
|
|
||||||
## 5.0.3 (2017-04-01)
|
|
||||||
|
|
||||||
### Bug fixes
|
|
||||||
|
|
||||||
Fix spurious duplicate variable definition errors for named functions.
|
|
||||||
|
|
||||||
## 5.0.2 (2017-03-30)
|
|
||||||
|
|
||||||
### Bug fixes
|
|
||||||
|
|
||||||
A binary operator after a parenthesized arrow expression is no longer incorrectly treated as an error.
|
|
||||||
|
|
||||||
## 5.0.0 (2017-03-28)
|
|
||||||
|
|
||||||
### Bug fixes
|
|
||||||
|
|
||||||
Raise an error for duplicated lexical bindings.
|
|
||||||
|
|
||||||
Fix spurious error when an assignement expression occurred after a spread expression.
|
|
||||||
|
|
||||||
Accept regular expressions after `of` (in `for`/`of`), `yield` (in a generator), and braced arrow functions.
|
|
||||||
|
|
||||||
Allow labels in front or `var` declarations, even in strict mode.
|
|
||||||
|
|
||||||
### Breaking changes
|
|
||||||
|
|
||||||
Parse declarations following `export default` as declaration nodes, not expressions. This means that class and function declarations nodes can now have `null` as their `id`.
|
|
||||||
|
|
||||||
## 4.0.11 (2017-02-07)
|
|
||||||
|
|
||||||
### Bug fixes
|
|
||||||
|
|
||||||
Allow all forms of member expressions to be parenthesized as lvalue.
|
|
||||||
|
|
||||||
## 4.0.10 (2017-02-07)
|
|
||||||
|
|
||||||
### Bug fixes
|
|
||||||
|
|
||||||
Don't expect semicolons after default-exported functions or classes, even when they are expressions.
|
|
||||||
|
|
||||||
Check for use of `'use strict'` directives in non-simple parameter functions, even when already in strict mode.
|
|
||||||
|
|
||||||
## 4.0.9 (2017-02-06)
|
|
||||||
|
|
||||||
### Bug fixes
|
|
||||||
|
|
||||||
Fix incorrect error raised for parenthesized simple assignment targets, so that `(x) = 1` parses again.
|
|
||||||
|
|
||||||
## 4.0.8 (2017-02-03)
|
|
||||||
|
|
||||||
### Bug fixes
|
|
||||||
|
|
||||||
Solve spurious parenthesized pattern errors by temporarily erring on the side of accepting programs that our delayed errors don't handle correctly yet.
|
|
||||||
|
|
||||||
## 4.0.7 (2017-02-02)
|
|
||||||
|
|
||||||
### Bug fixes
|
|
||||||
|
|
||||||
Accept invalidly rejected code like `(x).y = 2` again.
|
|
||||||
|
|
||||||
Don't raise an error when a function _inside_ strict code has a non-simple parameter list.
|
|
||||||
|
|
||||||
## 4.0.6 (2017-02-02)
|
|
||||||
|
|
||||||
### Bug fixes
|
|
||||||
|
|
||||||
Fix exponential behavior (manifesting itself as a complete hang for even relatively small source files) introduced by the new 'use strict' check.
|
|
||||||
|
|
||||||
## 4.0.5 (2017-02-02)
|
|
||||||
|
|
||||||
### Bug fixes
|
|
||||||
|
|
||||||
Disallow parenthesized pattern expressions.
|
|
||||||
|
|
||||||
Allow keywords as export names.
|
|
||||||
|
|
||||||
Don't allow the `async` keyword to be parenthesized.
|
|
||||||
|
|
||||||
Properly raise an error when a keyword contains a character escape.
|
|
||||||
|
|
||||||
Allow `"use strict"` to appear after other string literal expressions.
|
|
||||||
|
|
||||||
Disallow labeled declarations.
|
|
||||||
|
|
||||||
## 4.0.4 (2016-12-19)
|
|
||||||
|
|
||||||
### Bug fixes
|
|
||||||
|
|
||||||
Fix crash when `export` was followed by a keyword that can't be
|
|
||||||
exported.
|
|
||||||
|
|
||||||
## 4.0.3 (2016-08-16)
|
|
||||||
|
|
||||||
### Bug fixes
|
|
||||||
|
|
||||||
Allow regular function declarations inside single-statement `if` branches in loose mode. Forbid them entirely in strict mode.
|
|
||||||
|
|
||||||
Properly parse properties named `async` in ES2017 mode.
|
|
||||||
|
|
||||||
Fix bug where reserved words were broken in ES2017 mode.
|
|
||||||
|
|
||||||
## 4.0.2 (2016-08-11)
|
|
||||||
|
|
||||||
### Bug fixes
|
|
||||||
|
|
||||||
Don't ignore period or 'e' characters after octal numbers.
|
|
||||||
|
|
||||||
Fix broken parsing for call expressions in default parameter values of arrow functions.
|
|
||||||
|
|
||||||
## 4.0.1 (2016-08-08)
|
|
||||||
|
|
||||||
### Bug fixes
|
|
||||||
|
|
||||||
Fix false positives in duplicated export name errors.
|
|
||||||
|
|
||||||
## 4.0.0 (2016-08-07)
|
|
||||||
|
|
||||||
### Breaking changes
|
|
||||||
|
|
||||||
The default `ecmaVersion` option value is now 7.
|
|
||||||
|
|
||||||
A number of internal method signatures changed, so plugins might need to be updated.
|
|
||||||
|
|
||||||
### Bug fixes
|
|
||||||
|
|
||||||
The parser now raises errors on duplicated export names.
|
|
||||||
|
|
||||||
`arguments` and `eval` can now be used in shorthand properties.
|
|
||||||
|
|
||||||
Duplicate parameter names in non-simple argument lists now always produce an error.
|
|
||||||
|
|
||||||
### New features
|
|
||||||
|
|
||||||
The `ecmaVersion` option now also accepts year-style version numbers
|
|
||||||
(2015, etc).
|
|
||||||
|
|
||||||
Support for `async`/`await` syntax when `ecmaVersion` is >= 8.
|
|
||||||
|
|
||||||
Support for trailing commas in call expressions when `ecmaVersion` is >= 8.
|
|
||||||
|
|
||||||
## 3.3.0 (2016-07-25)
|
|
||||||
|
|
||||||
### Bug fixes
|
|
||||||
|
|
||||||
Fix bug in tokenizing of regexp operator after a function declaration.
|
|
||||||
|
|
||||||
Fix parser crash when parsing an array pattern with a hole.
|
|
||||||
|
|
||||||
### New features
|
|
||||||
|
|
||||||
Implement check against complex argument lists in functions that enable strict mode in ES7.
|
|
||||||
|
|
||||||
## 3.2.0 (2016-06-07)
|
|
||||||
|
|
||||||
### Bug fixes
|
|
||||||
|
|
||||||
Improve handling of lack of unicode regexp support in host
|
|
||||||
environment.
|
|
||||||
|
|
||||||
Properly reject shorthand properties whose name is a keyword.
|
|
||||||
|
|
||||||
### New features
|
|
||||||
|
|
||||||
Visitors created with `visit.make` now have their base as _prototype_, rather than copying properties into a fresh object.
|
|
||||||
|
|
||||||
## 3.1.0 (2016-04-18)
|
|
||||||
|
|
||||||
### Bug fixes
|
|
||||||
|
|
||||||
Properly tokenize the division operator directly after a function expression.
|
|
||||||
|
|
||||||
Allow trailing comma in destructuring arrays.
|
|
||||||
|
|
||||||
## 3.0.4 (2016-02-25)
|
|
||||||
|
|
||||||
### Fixes
|
|
||||||
|
|
||||||
Allow update expressions as left-hand-side of the ES7 exponential operator.
|
|
||||||
|
|
||||||
## 3.0.2 (2016-02-10)
|
|
||||||
|
|
||||||
### Fixes
|
|
||||||
|
|
||||||
Fix bug that accidentally made `undefined` a reserved word when parsing ES7.
|
|
||||||
|
|
||||||
## 3.0.0 (2016-02-10)
|
|
||||||
|
|
||||||
### Breaking changes
|
|
||||||
|
|
||||||
The default value of the `ecmaVersion` option is now 6 (used to be 5).
|
|
||||||
|
|
||||||
Support for comprehension syntax (which was dropped from the draft spec) has been removed.
|
|
||||||
|
|
||||||
### Fixes
|
|
||||||
|
|
||||||
`let` and `yield` are now “contextual keywords”, meaning you can mostly use them as identifiers in ES5 non-strict code.
|
|
||||||
|
|
||||||
A parenthesized class or function expression after `export default` is now parsed correctly.
|
|
||||||
|
|
||||||
### New features
|
|
||||||
|
|
||||||
When `ecmaVersion` is set to 7, Acorn will parse the exponentiation operator (`**`).
|
|
||||||
|
|
||||||
The identifier character ranges are now based on Unicode 8.0.0.
|
|
||||||
|
|
||||||
Plugins can now override the `raiseRecoverable` method to override the way non-critical errors are handled.
|
|
||||||
|
|
||||||
## 2.7.0 (2016-01-04)
|
|
||||||
|
|
||||||
### Fixes
|
|
||||||
|
|
||||||
Stop allowing rest parameters in setters.
|
|
||||||
|
|
||||||
Disallow `y` rexexp flag in ES5.
|
|
||||||
|
|
||||||
Disallow `\00` and `\000` escapes in strict mode.
|
|
||||||
|
|
||||||
Raise an error when an import name is a reserved word.
|
|
||||||
|
|
||||||
## 2.6.2 (2015-11-10)
|
|
||||||
|
|
||||||
### Fixes
|
|
||||||
|
|
||||||
Don't crash when no options object is passed.
|
|
||||||
|
|
||||||
## 2.6.0 (2015-11-09)
|
|
||||||
|
|
||||||
### Fixes
|
|
||||||
|
|
||||||
Add `await` as a reserved word in module sources.
|
|
||||||
|
|
||||||
Disallow `yield` in a parameter default value for a generator.
|
|
||||||
|
|
||||||
Forbid using a comma after a rest pattern in an array destructuring.
|
|
||||||
|
|
||||||
### New features
|
|
||||||
|
|
||||||
Support parsing stdin in command-line tool.
|
|
||||||
|
|
||||||
## 2.5.0 (2015-10-27)
|
|
||||||
|
|
||||||
### Fixes
|
|
||||||
|
|
||||||
Fix tokenizer support in the command-line tool.
|
|
||||||
|
|
||||||
Stop allowing `new.target` outside of functions.
|
|
||||||
|
|
||||||
Remove legacy `guard` and `guardedHandler` properties from try nodes.
|
|
||||||
|
|
||||||
Stop allowing multiple `__proto__` properties on an object literal in strict mode.
|
|
||||||
|
|
||||||
Don't allow rest parameters to be non-identifier patterns.
|
|
||||||
|
|
||||||
Check for duplicate paramter names in arrow functions.
|
|
||||||
19
node_modules/acorn-globals/node_modules/acorn/LICENSE
generated
vendored
19
node_modules/acorn-globals/node_modules/acorn/LICENSE
generated
vendored
@@ -1,19 +0,0 @@
|
|||||||
Copyright (C) 2012-2018 by various contributors (see AUTHORS)
|
|
||||||
|
|
||||||
Permission is hereby granted, free of charge, to any person obtaining a copy
|
|
||||||
of this software and associated documentation files (the "Software"), to deal
|
|
||||||
in the Software without restriction, including without limitation the rights
|
|
||||||
to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
|
|
||||||
copies of the Software, and to permit persons to whom the Software is
|
|
||||||
furnished to do so, subject to the following conditions:
|
|
||||||
|
|
||||||
The above copyright notice and this permission notice shall be included in
|
|
||||||
all copies or substantial portions of the Software.
|
|
||||||
|
|
||||||
THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
|
|
||||||
IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
|
|
||||||
FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
|
|
||||||
AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
|
|
||||||
LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
|
|
||||||
OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN
|
|
||||||
THE SOFTWARE.
|
|
||||||
269
node_modules/acorn-globals/node_modules/acorn/README.md
generated
vendored
269
node_modules/acorn-globals/node_modules/acorn/README.md
generated
vendored
@@ -1,269 +0,0 @@
|
|||||||
# Acorn
|
|
||||||
|
|
||||||
A tiny, fast JavaScript parser written in JavaScript.
|
|
||||||
|
|
||||||
## Community
|
|
||||||
|
|
||||||
Acorn is open source software released under an
|
|
||||||
[MIT license](https://github.com/acornjs/acorn/blob/master/acorn/LICENSE).
|
|
||||||
|
|
||||||
You are welcome to
|
|
||||||
[report bugs](https://github.com/acornjs/acorn/issues) or create pull
|
|
||||||
requests on [github](https://github.com/acornjs/acorn). For questions
|
|
||||||
and discussion, please use the
|
|
||||||
[Tern discussion forum](https://discuss.ternjs.net).
|
|
||||||
|
|
||||||
## Installation
|
|
||||||
|
|
||||||
The easiest way to install acorn is from [`npm`](https://www.npmjs.com/):
|
|
||||||
|
|
||||||
```sh
|
|
||||||
npm install acorn
|
|
||||||
```
|
|
||||||
|
|
||||||
Alternately, you can download the source and build acorn yourself:
|
|
||||||
|
|
||||||
```sh
|
|
||||||
git clone https://github.com/acornjs/acorn.git
|
|
||||||
cd acorn
|
|
||||||
npm install
|
|
||||||
```
|
|
||||||
|
|
||||||
## Interface
|
|
||||||
|
|
||||||
**parse**`(input, options)` is the main interface to the library. The
|
|
||||||
`input` parameter is a string, `options` can be undefined or an object
|
|
||||||
setting some of the options listed below. The return value will be an
|
|
||||||
abstract syntax tree object as specified by the [ESTree
|
|
||||||
spec](https://github.com/estree/estree).
|
|
||||||
|
|
||||||
```javascript
|
|
||||||
let acorn = require("acorn");
|
|
||||||
console.log(acorn.parse("1 + 1"));
|
|
||||||
```
|
|
||||||
|
|
||||||
When encountering a syntax error, the parser will raise a
|
|
||||||
`SyntaxError` object with a meaningful message. The error object will
|
|
||||||
have a `pos` property that indicates the string offset at which the
|
|
||||||
error occurred, and a `loc` object that contains a `{line, column}`
|
|
||||||
object referring to that same position.
|
|
||||||
|
|
||||||
Options can be provided by passing a second argument, which should be
|
|
||||||
an object containing any of these fields:
|
|
||||||
|
|
||||||
- **ecmaVersion**: Indicates the ECMAScript version to parse. Must be
|
|
||||||
either 3, 5, 6 (2015), 7 (2016), 8 (2017), 9 (2018) or 10 (2019, partial
|
|
||||||
support). This influences support for strict mode, the set of
|
|
||||||
reserved words, and support for new syntax features. Default is 9.
|
|
||||||
|
|
||||||
**NOTE**: Only 'stage 4' (finalized) ECMAScript features are being
|
|
||||||
implemented by Acorn. Other proposed new features can be implemented
|
|
||||||
through plugins.
|
|
||||||
|
|
||||||
- **sourceType**: Indicate the mode the code should be parsed in. Can be
|
|
||||||
either `"script"` or `"module"`. This influences global strict mode
|
|
||||||
and parsing of `import` and `export` declarations.
|
|
||||||
|
|
||||||
**NOTE**: If set to `"module"`, then static `import` / `export` syntax
|
|
||||||
will be valid, even if `ecmaVersion` is less than 6.
|
|
||||||
|
|
||||||
- **onInsertedSemicolon**: If given a callback, that callback will be
|
|
||||||
called whenever a missing semicolon is inserted by the parser. The
|
|
||||||
callback will be given the character offset of the point where the
|
|
||||||
semicolon is inserted as argument, and if `locations` is on, also a
|
|
||||||
`{line, column}` object representing this position.
|
|
||||||
|
|
||||||
- **onTrailingComma**: Like `onInsertedSemicolon`, but for trailing
|
|
||||||
commas.
|
|
||||||
|
|
||||||
- **allowReserved**: If `false`, using a reserved word will generate
|
|
||||||
an error. Defaults to `true` for `ecmaVersion` 3, `false` for higher
|
|
||||||
versions. When given the value `"never"`, reserved words and
|
|
||||||
keywords can also not be used as property names (as in Internet
|
|
||||||
Explorer's old parser).
|
|
||||||
|
|
||||||
- **allowReturnOutsideFunction**: By default, a return statement at
|
|
||||||
the top level raises an error. Set this to `true` to accept such
|
|
||||||
code.
|
|
||||||
|
|
||||||
- **allowImportExportEverywhere**: By default, `import` and `export`
|
|
||||||
declarations can only appear at a program's top level. Setting this
|
|
||||||
option to `true` allows them anywhere where a statement is allowed.
|
|
||||||
|
|
||||||
- **allowAwaitOutsideFunction**: By default, `await` expressions can
|
|
||||||
only appear inside `async` functions. Setting this option to
|
|
||||||
`true` allows to have top-level `await` expressions. They are
|
|
||||||
still not allowed in non-`async` functions, though.
|
|
||||||
|
|
||||||
- **allowHashBang**: When this is enabled (off by default), if the
|
|
||||||
code starts with the characters `#!` (as in a shellscript), the
|
|
||||||
first line will be treated as a comment.
|
|
||||||
|
|
||||||
- **locations**: When `true`, each node has a `loc` object attached
|
|
||||||
with `start` and `end` subobjects, each of which contains the
|
|
||||||
one-based line and zero-based column numbers in `{line, column}`
|
|
||||||
form. Default is `false`.
|
|
||||||
|
|
||||||
- **onToken**: If a function is passed for this option, each found
|
|
||||||
token will be passed in same format as tokens returned from
|
|
||||||
`tokenizer().getToken()`.
|
|
||||||
|
|
||||||
If array is passed, each found token is pushed to it.
|
|
||||||
|
|
||||||
Note that you are not allowed to call the parser from the
|
|
||||||
callback—that will corrupt its internal state.
|
|
||||||
|
|
||||||
- **onComment**: If a function is passed for this option, whenever a
|
|
||||||
comment is encountered the function will be called with the
|
|
||||||
following parameters:
|
|
||||||
|
|
||||||
- `block`: `true` if the comment is a block comment, false if it
|
|
||||||
is a line comment.
|
|
||||||
- `text`: The content of the comment.
|
|
||||||
- `start`: Character offset of the start of the comment.
|
|
||||||
- `end`: Character offset of the end of the comment.
|
|
||||||
|
|
||||||
When the `locations` options is on, the `{line, column}` locations
|
|
||||||
of the comment’s start and end are passed as two additional
|
|
||||||
parameters.
|
|
||||||
|
|
||||||
If array is passed for this option, each found comment is pushed
|
|
||||||
to it as object in Esprima format:
|
|
||||||
|
|
||||||
```javascript
|
|
||||||
{
|
|
||||||
"type": "Line" | "Block",
|
|
||||||
"value": "comment text",
|
|
||||||
"start": Number,
|
|
||||||
"end": Number,
|
|
||||||
// If `locations` option is on:
|
|
||||||
"loc": {
|
|
||||||
"start": {line: Number, column: Number}
|
|
||||||
"end": {line: Number, column: Number}
|
|
||||||
},
|
|
||||||
// If `ranges` option is on:
|
|
||||||
"range": [Number, Number]
|
|
||||||
}
|
|
||||||
```
|
|
||||||
|
|
||||||
Note that you are not allowed to call the parser from the
|
|
||||||
callback—that will corrupt its internal state.
|
|
||||||
|
|
||||||
- **ranges**: Nodes have their start and end characters offsets
|
|
||||||
recorded in `start` and `end` properties (directly on the node,
|
|
||||||
rather than the `loc` object, which holds line/column data. To also
|
|
||||||
add a
|
|
||||||
[semi-standardized](https://bugzilla.mozilla.org/show_bug.cgi?id=745678)
|
|
||||||
`range` property holding a `[start, end]` array with the same
|
|
||||||
numbers, set the `ranges` option to `true`.
|
|
||||||
|
|
||||||
- **program**: It is possible to parse multiple files into a single
|
|
||||||
AST by passing the tree produced by parsing the first file as the
|
|
||||||
`program` option in subsequent parses. This will add the toplevel
|
|
||||||
forms of the parsed file to the "Program" (top) node of an existing
|
|
||||||
parse tree.
|
|
||||||
|
|
||||||
- **sourceFile**: When the `locations` option is `true`, you can pass
|
|
||||||
this option to add a `source` attribute in every node’s `loc`
|
|
||||||
object. Note that the contents of this option are not examined or
|
|
||||||
processed in any way; you are free to use whatever format you
|
|
||||||
choose.
|
|
||||||
|
|
||||||
- **directSourceFile**: Like `sourceFile`, but a `sourceFile` property
|
|
||||||
will be added (regardless of the `location` option) directly to the
|
|
||||||
nodes, rather than the `loc` object.
|
|
||||||
|
|
||||||
- **preserveParens**: If this option is `true`, parenthesized expressions
|
|
||||||
are represented by (non-standard) `ParenthesizedExpression` nodes
|
|
||||||
that have a single `expression` property containing the expression
|
|
||||||
inside parentheses.
|
|
||||||
|
|
||||||
**parseExpressionAt**`(input, offset, options)` will parse a single
|
|
||||||
expression in a string, and return its AST. It will not complain if
|
|
||||||
there is more of the string left after the expression.
|
|
||||||
|
|
||||||
**tokenizer**`(input, options)` returns an object with a `getToken`
|
|
||||||
method that can be called repeatedly to get the next token, a `{start,
|
|
||||||
end, type, value}` object (with added `loc` property when the
|
|
||||||
`locations` option is enabled and `range` property when the `ranges`
|
|
||||||
option is enabled). When the token's type is `tokTypes.eof`, you
|
|
||||||
should stop calling the method, since it will keep returning that same
|
|
||||||
token forever.
|
|
||||||
|
|
||||||
In ES6 environment, returned result can be used as any other
|
|
||||||
protocol-compliant iterable:
|
|
||||||
|
|
||||||
```javascript
|
|
||||||
for (let token of acorn.tokenizer(str)) {
|
|
||||||
// iterate over the tokens
|
|
||||||
}
|
|
||||||
|
|
||||||
// transform code to array of tokens:
|
|
||||||
var tokens = [...acorn.tokenizer(str)];
|
|
||||||
```
|
|
||||||
|
|
||||||
**tokTypes** holds an object mapping names to the token type objects
|
|
||||||
that end up in the `type` properties of tokens.
|
|
||||||
|
|
||||||
**getLineInfo**`(input, offset)` can be used to get a `{line,
|
|
||||||
column}` object for a given program string and offset.
|
|
||||||
|
|
||||||
### The `Parser` class
|
|
||||||
|
|
||||||
Instances of the **`Parser`** class contain all the state and logic
|
|
||||||
that drives a parse. It has static methods `parse`,
|
|
||||||
`parseExpressionAt`, and `tokenizer` that match the top-level
|
|
||||||
functions by the same name.
|
|
||||||
|
|
||||||
When extending the parser with plugins, you need to call these methods
|
|
||||||
on the extended version of the class. To extend a parser with plugins,
|
|
||||||
you can use its static `extend` method.
|
|
||||||
|
|
||||||
```javascript
|
|
||||||
var acorn = require("acorn");
|
|
||||||
var jsx = require("acorn-jsx");
|
|
||||||
var JSXParser = acorn.Parser.extend(jsx());
|
|
||||||
JSXParser.parse("foo(<bar/>)");
|
|
||||||
```
|
|
||||||
|
|
||||||
The `extend` method takes any number of plugin values, and returns a
|
|
||||||
new `Parser` class that includes the extra parser logic provided by
|
|
||||||
the plugins.
|
|
||||||
|
|
||||||
## Command line interface
|
|
||||||
|
|
||||||
The `bin/acorn` utility can be used to parse a file from the command
|
|
||||||
line. It accepts as arguments its input file and the following
|
|
||||||
options:
|
|
||||||
|
|
||||||
- `--ecma3|--ecma5|--ecma6|--ecma7|--ecma8|--ecma9|--ecma10`: Sets the ECMAScript version
|
|
||||||
to parse. Default is version 9.
|
|
||||||
|
|
||||||
- `--module`: Sets the parsing mode to `"module"`. Is set to `"script"` otherwise.
|
|
||||||
|
|
||||||
- `--locations`: Attaches a "loc" object to each node with "start" and
|
|
||||||
"end" subobjects, each of which contains the one-based line and
|
|
||||||
zero-based column numbers in `{line, column}` form.
|
|
||||||
|
|
||||||
- `--allow-hash-bang`: If the code starts with the characters #! (as
|
|
||||||
in a shellscript), the first line will be treated as a comment.
|
|
||||||
|
|
||||||
- `--compact`: No whitespace is used in the AST output.
|
|
||||||
|
|
||||||
- `--silent`: Do not output the AST, just return the exit status.
|
|
||||||
|
|
||||||
- `--help`: Print the usage information and quit.
|
|
||||||
|
|
||||||
The utility spits out the syntax tree as JSON data.
|
|
||||||
|
|
||||||
## Existing plugins
|
|
||||||
|
|
||||||
- [`acorn-jsx`](https://github.com/RReverser/acorn-jsx): Parse [Facebook JSX syntax extensions](https://github.com/facebook/jsx)
|
|
||||||
|
|
||||||
Plugins for ECMAScript proposals:
|
|
||||||
|
|
||||||
- [`acorn-stage3`](https://github.com/acornjs/acorn-stage3): Parse most stage 3 proposals, bundling:
|
|
||||||
- [`acorn-class-fields`](https://github.com/acornjs/acorn-class-fields): Parse [class fields proposal](https://github.com/tc39/proposal-class-fields)
|
|
||||||
- [`acorn-import-meta`](https://github.com/acornjs/acorn-import-meta): Parse [import.meta proposal](https://github.com/tc39/proposal-import-meta)
|
|
||||||
- [`acorn-numeric-separator`](https://github.com/acornjs/acorn-numeric-separator): Parse [numeric separator proposal](https://github.com/tc39/proposal-numeric-separator)
|
|
||||||
- [`acorn-private-methods`](https://github.com/acornjs/acorn-private-methods): parse [private methods, getters and setters proposal](https://github.com/tc39/proposal-private-methods)n
|
|
||||||
34
node_modules/acorn-globals/node_modules/acorn/package.json
generated
vendored
34
node_modules/acorn-globals/node_modules/acorn/package.json
generated
vendored
@@ -1,34 +0,0 @@
|
|||||||
{
|
|
||||||
"name": "acorn",
|
|
||||||
"description": "ECMAScript parser",
|
|
||||||
"homepage": "https://github.com/acornjs/acorn",
|
|
||||||
"main": "dist/acorn.js",
|
|
||||||
"module": "dist/acorn.mjs",
|
|
||||||
"version": "6.4.2",
|
|
||||||
"engines": {"node": ">=0.4.0"},
|
|
||||||
"maintainers": [
|
|
||||||
{
|
|
||||||
"name": "Marijn Haverbeke",
|
|
||||||
"email": "marijnh@gmail.com",
|
|
||||||
"web": "https://marijnhaverbeke.nl"
|
|
||||||
},
|
|
||||||
{
|
|
||||||
"name": "Ingvar Stepanyan",
|
|
||||||
"email": "me@rreverser.com",
|
|
||||||
"web": "https://rreverser.com/"
|
|
||||||
},
|
|
||||||
{
|
|
||||||
"name": "Adrian Heine",
|
|
||||||
"web": "http://adrianheine.de"
|
|
||||||
}
|
|
||||||
],
|
|
||||||
"repository": {
|
|
||||||
"type": "git",
|
|
||||||
"url": "https://github.com/acornjs/acorn.git"
|
|
||||||
},
|
|
||||||
"license": "MIT",
|
|
||||||
"scripts": {
|
|
||||||
"prepare": "cd ..; npm run build:main && npm run build:bin"
|
|
||||||
},
|
|
||||||
"bin": {"acorn": "./bin/acorn"}
|
|
||||||
}
|
|
||||||
35
node_modules/acorn-globals/package.json
generated
vendored
35
node_modules/acorn-globals/package.json
generated
vendored
@@ -1,35 +0,0 @@
|
|||||||
{
|
|
||||||
"name": "acorn-globals",
|
|
||||||
"version": "4.3.4",
|
|
||||||
"description": "Detect global variables in JavaScript using acorn",
|
|
||||||
"keywords": [
|
|
||||||
"ast",
|
|
||||||
"variable",
|
|
||||||
"name",
|
|
||||||
"lexical",
|
|
||||||
"scope",
|
|
||||||
"local",
|
|
||||||
"global",
|
|
||||||
"implicit"
|
|
||||||
],
|
|
||||||
"files": [
|
|
||||||
"index.js",
|
|
||||||
"LICENSE"
|
|
||||||
],
|
|
||||||
"dependencies": {
|
|
||||||
"acorn": "^6.0.1",
|
|
||||||
"acorn-walk": "^6.0.1"
|
|
||||||
},
|
|
||||||
"devDependencies": {
|
|
||||||
"testit": "^3.0.0"
|
|
||||||
},
|
|
||||||
"scripts": {
|
|
||||||
"test": "node test"
|
|
||||||
},
|
|
||||||
"repository": {
|
|
||||||
"type": "git",
|
|
||||||
"url": "https://github.com/ForbesLindesay/acorn-globals.git"
|
|
||||||
},
|
|
||||||
"author": "ForbesLindesay",
|
|
||||||
"license": "MIT"
|
|
||||||
}
|
|
||||||
103
node_modules/acorn-walk/CHANGELOG.md
generated
vendored
103
node_modules/acorn-walk/CHANGELOG.md
generated
vendored
@@ -1,103 +0,0 @@
|
|||||||
## 6.2.0 (2017-07-04)
|
|
||||||
|
|
||||||
### New features
|
|
||||||
|
|
||||||
Add support for `Import` nodes.
|
|
||||||
|
|
||||||
## 6.1.0 (2018-09-28)
|
|
||||||
|
|
||||||
### New features
|
|
||||||
|
|
||||||
The walker now walks `TemplateElement` nodes.
|
|
||||||
|
|
||||||
## 6.0.1 (2018-09-14)
|
|
||||||
|
|
||||||
### Bug fixes
|
|
||||||
|
|
||||||
Fix bad "main" field in package.json.
|
|
||||||
|
|
||||||
## 6.0.0 (2018-09-14)
|
|
||||||
|
|
||||||
### Breaking changes
|
|
||||||
|
|
||||||
This is now a separate package, `acorn-walk`, rather than part of the main `acorn` package.
|
|
||||||
|
|
||||||
The `ScopeBody` and `ScopeExpression` meta-node-types are no longer supported.
|
|
||||||
|
|
||||||
## 5.7.1 (2018-06-15)
|
|
||||||
|
|
||||||
### Bug fixes
|
|
||||||
|
|
||||||
Make sure the walker and bin files are rebuilt on release (the previous release didn't get the up-to-date versions).
|
|
||||||
|
|
||||||
## 5.7.0 (2018-06-15)
|
|
||||||
|
|
||||||
### Bug fixes
|
|
||||||
|
|
||||||
Fix crash in walker when walking a binding-less catch node.
|
|
||||||
|
|
||||||
## 5.6.2 (2018-06-05)
|
|
||||||
|
|
||||||
### Bug fixes
|
|
||||||
|
|
||||||
In the walker, go back to allowing the `baseVisitor` argument to be null to default to the default base everywhere.
|
|
||||||
|
|
||||||
## 5.6.1 (2018-06-01)
|
|
||||||
|
|
||||||
### Bug fixes
|
|
||||||
|
|
||||||
Fix regression when passing `null` as fourth argument to `walk.recursive`.
|
|
||||||
|
|
||||||
## 5.6.0 (2018-05-31)
|
|
||||||
|
|
||||||
### Bug fixes
|
|
||||||
|
|
||||||
Fix a bug in the walker that caused a crash when walking an object pattern spread.
|
|
||||||
|
|
||||||
## 5.5.1 (2018-03-06)
|
|
||||||
|
|
||||||
### Bug fixes
|
|
||||||
|
|
||||||
Fix regression in walker causing property values in object patterns to be walked as expressions.
|
|
||||||
|
|
||||||
## 5.5.0 (2018-02-27)
|
|
||||||
|
|
||||||
### Bug fixes
|
|
||||||
|
|
||||||
Support object spread in the AST walker.
|
|
||||||
|
|
||||||
## 5.4.1 (2018-02-02)
|
|
||||||
|
|
||||||
### Bug fixes
|
|
||||||
|
|
||||||
5.4.0 somehow accidentally included an old version of walk.js.
|
|
||||||
|
|
||||||
## 5.2.0 (2017-10-30)
|
|
||||||
|
|
||||||
### Bug fixes
|
|
||||||
|
|
||||||
The `full` and `fullAncestor` walkers no longer visit nodes multiple times.
|
|
||||||
|
|
||||||
## 5.1.0 (2017-07-05)
|
|
||||||
|
|
||||||
### New features
|
|
||||||
|
|
||||||
New walker functions `full` and `fullAncestor`.
|
|
||||||
|
|
||||||
## 3.2.0 (2016-06-07)
|
|
||||||
|
|
||||||
### New features
|
|
||||||
|
|
||||||
Make it possible to use `visit.ancestor` with a walk state.
|
|
||||||
|
|
||||||
## 3.1.0 (2016-04-18)
|
|
||||||
|
|
||||||
### New features
|
|
||||||
|
|
||||||
The walker now allows defining handlers for `CatchClause` nodes.
|
|
||||||
|
|
||||||
## 2.5.2 (2015-10-27)
|
|
||||||
|
|
||||||
### Fixes
|
|
||||||
|
|
||||||
Fix bug where the walker walked an exported `let` statement as an expression.
|
|
||||||
19
node_modules/acorn-walk/LICENSE
generated
vendored
19
node_modules/acorn-walk/LICENSE
generated
vendored
@@ -1,19 +0,0 @@
|
|||||||
Copyright (C) 2012-2018 by various contributors (see AUTHORS)
|
|
||||||
|
|
||||||
Permission is hereby granted, free of charge, to any person obtaining a copy
|
|
||||||
of this software and associated documentation files (the "Software"), to deal
|
|
||||||
in the Software without restriction, including without limitation the rights
|
|
||||||
to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
|
|
||||||
copies of the Software, and to permit persons to whom the Software is
|
|
||||||
furnished to do so, subject to the following conditions:
|
|
||||||
|
|
||||||
The above copyright notice and this permission notice shall be included in
|
|
||||||
all copies or substantial portions of the Software.
|
|
||||||
|
|
||||||
THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
|
|
||||||
IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
|
|
||||||
FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
|
|
||||||
AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
|
|
||||||
LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
|
|
||||||
OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN
|
|
||||||
THE SOFTWARE.
|
|
||||||
126
node_modules/acorn-walk/README.md
generated
vendored
126
node_modules/acorn-walk/README.md
generated
vendored
@@ -1,126 +0,0 @@
|
|||||||
# Acorn AST walker
|
|
||||||
|
|
||||||
An abstract syntax tree walker for the
|
|
||||||
[ESTree](https://github.com/estree/estree) format.
|
|
||||||
|
|
||||||
## Community
|
|
||||||
|
|
||||||
Acorn is open source software released under an
|
|
||||||
[MIT license](https://github.com/acornjs/acorn/blob/master/acorn-walk/LICENSE).
|
|
||||||
|
|
||||||
You are welcome to
|
|
||||||
[report bugs](https://github.com/acornjs/acorn/issues) or create pull
|
|
||||||
requests on [github](https://github.com/acornjs/acorn). For questions
|
|
||||||
and discussion, please use the
|
|
||||||
[Tern discussion forum](https://discuss.ternjs.net).
|
|
||||||
|
|
||||||
## Installation
|
|
||||||
|
|
||||||
The easiest way to install acorn is from [`npm`](https://www.npmjs.com/):
|
|
||||||
|
|
||||||
```sh
|
|
||||||
npm install acorn-walk
|
|
||||||
```
|
|
||||||
|
|
||||||
Alternately, you can download the source and build acorn yourself:
|
|
||||||
|
|
||||||
```sh
|
|
||||||
git clone https://github.com/acornjs/acorn.git
|
|
||||||
cd acorn
|
|
||||||
npm install
|
|
||||||
```
|
|
||||||
|
|
||||||
## Interface
|
|
||||||
|
|
||||||
An algorithm for recursing through a syntax tree is stored as an
|
|
||||||
object, with a property for each tree node type holding a function
|
|
||||||
that will recurse through such a node. There are several ways to run
|
|
||||||
such a walker.
|
|
||||||
|
|
||||||
**simple**`(node, visitors, base, state)` does a 'simple' walk over a
|
|
||||||
tree. `node` should be the AST node to walk, and `visitors` an object
|
|
||||||
with properties whose names correspond to node types in the [ESTree
|
|
||||||
spec](https://github.com/estree/estree). The properties should contain
|
|
||||||
functions that will be called with the node object and, if applicable
|
|
||||||
the state at that point. The last two arguments are optional. `base`
|
|
||||||
is a walker algorithm, and `state` is a start state. The default
|
|
||||||
walker will simply visit all statements and expressions and not
|
|
||||||
produce a meaningful state. (An example of a use of state is to track
|
|
||||||
scope at each point in the tree.)
|
|
||||||
|
|
||||||
```js
|
|
||||||
const acorn = require("acorn")
|
|
||||||
const walk = require("acorn-walk")
|
|
||||||
|
|
||||||
walk.simple(acorn.parse("let x = 10"), {
|
|
||||||
Literal(node) {
|
|
||||||
console.log(`Found a literal: ${node.value}`)
|
|
||||||
}
|
|
||||||
})
|
|
||||||
```
|
|
||||||
|
|
||||||
**ancestor**`(node, visitors, base, state)` does a 'simple' walk over
|
|
||||||
a tree, building up an array of ancestor nodes (including the current node)
|
|
||||||
and passing the array to the callbacks as a third parameter.
|
|
||||||
|
|
||||||
```js
|
|
||||||
const acorn = require("acorn")
|
|
||||||
const walk = require("acorn-walk")
|
|
||||||
|
|
||||||
walk.ancestor(acorn.parse("foo('hi')"), {
|
|
||||||
Literal(_, ancestors) {
|
|
||||||
console.log("This literal's ancestors are:", ancestors.map(n => n.type))
|
|
||||||
}
|
|
||||||
})
|
|
||||||
```
|
|
||||||
|
|
||||||
**recursive**`(node, state, functions, base)` does a 'recursive'
|
|
||||||
walk, where the walker functions are responsible for continuing the
|
|
||||||
walk on the child nodes of their target node. `state` is the start
|
|
||||||
state, and `functions` should contain an object that maps node types
|
|
||||||
to walker functions. Such functions are called with `(node, state, c)`
|
|
||||||
arguments, and can cause the walk to continue on a sub-node by calling
|
|
||||||
the `c` argument on it with `(node, state)` arguments. The optional
|
|
||||||
`base` argument provides the fallback walker functions for node types
|
|
||||||
that aren't handled in the `functions` object. If not given, the
|
|
||||||
default walkers will be used.
|
|
||||||
|
|
||||||
**make**`(functions, base)` builds a new walker object by using the
|
|
||||||
walker functions in `functions` and filling in the missing ones by
|
|
||||||
taking defaults from `base`.
|
|
||||||
|
|
||||||
**full**`(node, callback, base, state)` does a 'full' walk over a
|
|
||||||
tree, calling the callback with the arguments (node, state, type) for
|
|
||||||
each node
|
|
||||||
|
|
||||||
**fullAncestor**`(node, callback, base, state)` does a 'full' walk
|
|
||||||
over a tree, building up an array of ancestor nodes (including the
|
|
||||||
current node) and passing the array to the callbacks as a third
|
|
||||||
parameter.
|
|
||||||
|
|
||||||
```js
|
|
||||||
const acorn = require("acorn")
|
|
||||||
const walk = require("acorn-walk")
|
|
||||||
|
|
||||||
walk.full(acorn.parse("1 + 1"), node => {
|
|
||||||
console.log(`There's a ${node.type} node at ${node.ch}`)
|
|
||||||
})
|
|
||||||
```
|
|
||||||
|
|
||||||
**findNodeAt**`(node, start, end, test, base, state)` tries to locate
|
|
||||||
a node in a tree at the given start and/or end offsets, which
|
|
||||||
satisfies the predicate `test`. `start` and `end` can be either `null`
|
|
||||||
(as wildcard) or a number. `test` may be a string (indicating a node
|
|
||||||
type) or a function that takes `(nodeType, node)` arguments and
|
|
||||||
returns a boolean indicating whether this node is interesting. `base`
|
|
||||||
and `state` are optional, and can be used to specify a custom walker.
|
|
||||||
Nodes are tested from inner to outer, so if two nodes match the
|
|
||||||
boundaries, the inner one will be preferred.
|
|
||||||
|
|
||||||
**findNodeAround**`(node, pos, test, base, state)` is a lot like
|
|
||||||
`findNodeAt`, but will match any node that exists 'around' (spanning)
|
|
||||||
the given position.
|
|
||||||
|
|
||||||
**findNodeAfter**`(node, pos, test, base, state)` is similar to
|
|
||||||
`findNodeAround`, but will match all nodes *after* the given position
|
|
||||||
(testing outer nodes before inner nodes).
|
|
||||||
33
node_modules/acorn-walk/package.json
generated
vendored
33
node_modules/acorn-walk/package.json
generated
vendored
@@ -1,33 +0,0 @@
|
|||||||
{
|
|
||||||
"name": "acorn-walk",
|
|
||||||
"description": "ECMAScript (ESTree) AST walker",
|
|
||||||
"homepage": "https://github.com/acornjs/acorn",
|
|
||||||
"main": "dist/walk.js",
|
|
||||||
"module": "dist/walk.mjs",
|
|
||||||
"version": "6.2.0",
|
|
||||||
"engines": {"node": ">=0.4.0"},
|
|
||||||
"maintainers": [
|
|
||||||
{
|
|
||||||
"name": "Marijn Haverbeke",
|
|
||||||
"email": "marijnh@gmail.com",
|
|
||||||
"web": "https://marijnhaverbeke.nl"
|
|
||||||
},
|
|
||||||
{
|
|
||||||
"name": "Ingvar Stepanyan",
|
|
||||||
"email": "me@rreverser.com",
|
|
||||||
"web": "https://rreverser.com/"
|
|
||||||
},
|
|
||||||
{
|
|
||||||
"name": "Adrian Heine",
|
|
||||||
"web": "http://adrianheine.de"
|
|
||||||
}
|
|
||||||
],
|
|
||||||
"repository": {
|
|
||||||
"type": "git",
|
|
||||||
"url": "https://github.com/acornjs/acorn.git"
|
|
||||||
},
|
|
||||||
"scripts": {
|
|
||||||
"prepare": "cd ..; npm run build:walk"
|
|
||||||
},
|
|
||||||
"license": "MIT"
|
|
||||||
}
|
|
||||||
620
node_modules/acorn/CHANGELOG.md
generated
vendored
620
node_modules/acorn/CHANGELOG.md
generated
vendored
@@ -1,620 +0,0 @@
|
|||||||
## 7.4.0 (2020-08-03)
|
|
||||||
|
|
||||||
### New features
|
|
||||||
|
|
||||||
Add support for logical assignment operators.
|
|
||||||
|
|
||||||
Add support for numeric separators.
|
|
||||||
|
|
||||||
## 7.3.1 (2020-06-11)
|
|
||||||
|
|
||||||
### Bug fixes
|
|
||||||
|
|
||||||
Make the string in the `version` export match the actual library version.
|
|
||||||
|
|
||||||
## 7.3.0 (2020-06-11)
|
|
||||||
|
|
||||||
### Bug fixes
|
|
||||||
|
|
||||||
Fix a bug that caused parsing of object patterns with a property named `set` that had a default value to fail.
|
|
||||||
|
|
||||||
### New features
|
|
||||||
|
|
||||||
Add support for optional chaining (`?.`).
|
|
||||||
|
|
||||||
## 7.2.0 (2020-05-09)
|
|
||||||
|
|
||||||
### Bug fixes
|
|
||||||
|
|
||||||
Fix precedence issue in parsing of async arrow functions.
|
|
||||||
|
|
||||||
### New features
|
|
||||||
|
|
||||||
Add support for nullish coalescing.
|
|
||||||
|
|
||||||
Add support for `import.meta`.
|
|
||||||
|
|
||||||
Support `export * as ...` syntax.
|
|
||||||
|
|
||||||
Upgrade to Unicode 13.
|
|
||||||
|
|
||||||
## 6.4.1 (2020-03-09)
|
|
||||||
|
|
||||||
### Bug fixes
|
|
||||||
|
|
||||||
More carefully check for valid UTF16 surrogate pairs in regexp validator.
|
|
||||||
|
|
||||||
## 7.1.1 (2020-03-01)
|
|
||||||
|
|
||||||
### Bug fixes
|
|
||||||
|
|
||||||
Treat `\8` and `\9` as invalid escapes in template strings.
|
|
||||||
|
|
||||||
Allow unicode escapes in property names that are keywords.
|
|
||||||
|
|
||||||
Don't error on an exponential operator expression as argument to `await`.
|
|
||||||
|
|
||||||
More carefully check for valid UTF16 surrogate pairs in regexp validator.
|
|
||||||
|
|
||||||
## 7.1.0 (2019-09-24)
|
|
||||||
|
|
||||||
### Bug fixes
|
|
||||||
|
|
||||||
Disallow trailing object literal commas when ecmaVersion is less than 5.
|
|
||||||
|
|
||||||
### New features
|
|
||||||
|
|
||||||
Add a static `acorn` property to the `Parser` class that contains the entire module interface, to allow plugins to access the instance of the library that they are acting on.
|
|
||||||
|
|
||||||
## 7.0.0 (2019-08-13)
|
|
||||||
|
|
||||||
### Breaking changes
|
|
||||||
|
|
||||||
Changes the node format for dynamic imports to use the `ImportExpression` node type, as defined in [ESTree](https://github.com/estree/estree/blob/master/es2020.md#importexpression).
|
|
||||||
|
|
||||||
Makes 10 (ES2019) the default value for the `ecmaVersion` option.
|
|
||||||
|
|
||||||
## 6.3.0 (2019-08-12)
|
|
||||||
|
|
||||||
### New features
|
|
||||||
|
|
||||||
`sourceType: "module"` can now be used even when `ecmaVersion` is less than 6, to parse module-style code that otherwise conforms to an older standard.
|
|
||||||
|
|
||||||
## 6.2.1 (2019-07-21)
|
|
||||||
|
|
||||||
### Bug fixes
|
|
||||||
|
|
||||||
Fix bug causing Acorn to treat some characters as identifier characters that shouldn't be treated as such.
|
|
||||||
|
|
||||||
Fix issue where setting the `allowReserved` option to `"never"` allowed reserved words in some circumstances.
|
|
||||||
|
|
||||||
## 6.2.0 (2019-07-04)
|
|
||||||
|
|
||||||
### Bug fixes
|
|
||||||
|
|
||||||
Improve valid assignment checking in `for`/`in` and `for`/`of` loops.
|
|
||||||
|
|
||||||
Disallow binding `let` in patterns.
|
|
||||||
|
|
||||||
### New features
|
|
||||||
|
|
||||||
Support bigint syntax with `ecmaVersion` >= 11.
|
|
||||||
|
|
||||||
Support dynamic `import` syntax with `ecmaVersion` >= 11.
|
|
||||||
|
|
||||||
Upgrade to Unicode version 12.
|
|
||||||
|
|
||||||
## 6.1.1 (2019-02-27)
|
|
||||||
|
|
||||||
### Bug fixes
|
|
||||||
|
|
||||||
Fix bug that caused parsing default exports of with names to fail.
|
|
||||||
|
|
||||||
## 6.1.0 (2019-02-08)
|
|
||||||
|
|
||||||
### Bug fixes
|
|
||||||
|
|
||||||
Fix scope checking when redefining a `var` as a lexical binding.
|
|
||||||
|
|
||||||
### New features
|
|
||||||
|
|
||||||
Split up `parseSubscripts` to use an internal `parseSubscript` method to make it easier to extend with plugins.
|
|
||||||
|
|
||||||
## 6.0.7 (2019-02-04)
|
|
||||||
|
|
||||||
### Bug fixes
|
|
||||||
|
|
||||||
Check that exported bindings are defined.
|
|
||||||
|
|
||||||
Don't treat `\u180e` as a whitespace character.
|
|
||||||
|
|
||||||
Check for duplicate parameter names in methods.
|
|
||||||
|
|
||||||
Don't allow shorthand properties when they are generators or async methods.
|
|
||||||
|
|
||||||
Forbid binding `await` in async arrow function's parameter list.
|
|
||||||
|
|
||||||
## 6.0.6 (2019-01-30)
|
|
||||||
|
|
||||||
### Bug fixes
|
|
||||||
|
|
||||||
The content of class declarations and expressions is now always parsed in strict mode.
|
|
||||||
|
|
||||||
Don't allow `let` or `const` to bind the variable name `let`.
|
|
||||||
|
|
||||||
Treat class declarations as lexical.
|
|
||||||
|
|
||||||
Don't allow a generator function declaration as the sole body of an `if` or `else`.
|
|
||||||
|
|
||||||
Ignore `"use strict"` when after an empty statement.
|
|
||||||
|
|
||||||
Allow string line continuations with special line terminator characters.
|
|
||||||
|
|
||||||
Treat `for` bodies as part of the `for` scope when checking for conflicting bindings.
|
|
||||||
|
|
||||||
Fix bug with parsing `yield` in a `for` loop initializer.
|
|
||||||
|
|
||||||
Implement special cases around scope checking for functions.
|
|
||||||
|
|
||||||
## 6.0.5 (2019-01-02)
|
|
||||||
|
|
||||||
### Bug fixes
|
|
||||||
|
|
||||||
Fix TypeScript type for `Parser.extend` and add `allowAwaitOutsideFunction` to options type.
|
|
||||||
|
|
||||||
Don't treat `let` as a keyword when the next token is `{` on the next line.
|
|
||||||
|
|
||||||
Fix bug that broke checking for parentheses around an object pattern in a destructuring assignment when `preserveParens` was on.
|
|
||||||
|
|
||||||
## 6.0.4 (2018-11-05)
|
|
||||||
|
|
||||||
### Bug fixes
|
|
||||||
|
|
||||||
Further improvements to tokenizing regular expressions in corner cases.
|
|
||||||
|
|
||||||
## 6.0.3 (2018-11-04)
|
|
||||||
|
|
||||||
### Bug fixes
|
|
||||||
|
|
||||||
Fix bug in tokenizing an expression-less return followed by a function followed by a regular expression.
|
|
||||||
|
|
||||||
Remove stray symlink in the package tarball.
|
|
||||||
|
|
||||||
## 6.0.2 (2018-09-26)
|
|
||||||
|
|
||||||
### Bug fixes
|
|
||||||
|
|
||||||
Fix bug where default expressions could fail to parse inside an object destructuring assignment expression.
|
|
||||||
|
|
||||||
## 6.0.1 (2018-09-14)
|
|
||||||
|
|
||||||
### Bug fixes
|
|
||||||
|
|
||||||
Fix wrong value in `version` export.
|
|
||||||
|
|
||||||
## 6.0.0 (2018-09-14)
|
|
||||||
|
|
||||||
### Bug fixes
|
|
||||||
|
|
||||||
Better handle variable-redefinition checks for catch bindings and functions directly under if statements.
|
|
||||||
|
|
||||||
Forbid `new.target` in top-level arrow functions.
|
|
||||||
|
|
||||||
Fix issue with parsing a regexp after `yield` in some contexts.
|
|
||||||
|
|
||||||
### New features
|
|
||||||
|
|
||||||
The package now comes with TypeScript definitions.
|
|
||||||
|
|
||||||
### Breaking changes
|
|
||||||
|
|
||||||
The default value of the `ecmaVersion` option is now 9 (2018).
|
|
||||||
|
|
||||||
Plugins work differently, and will have to be rewritten to work with this version.
|
|
||||||
|
|
||||||
The loose parser and walker have been moved into separate packages (`acorn-loose` and `acorn-walk`).
|
|
||||||
|
|
||||||
## 5.7.3 (2018-09-10)
|
|
||||||
|
|
||||||
### Bug fixes
|
|
||||||
|
|
||||||
Fix failure to tokenize regexps after expressions like `x.of`.
|
|
||||||
|
|
||||||
Better error message for unterminated template literals.
|
|
||||||
|
|
||||||
## 5.7.2 (2018-08-24)
|
|
||||||
|
|
||||||
### Bug fixes
|
|
||||||
|
|
||||||
Properly handle `allowAwaitOutsideFunction` in for statements.
|
|
||||||
|
|
||||||
Treat function declarations at the top level of modules like let bindings.
|
|
||||||
|
|
||||||
Don't allow async function declarations as the only statement under a label.
|
|
||||||
|
|
||||||
## 5.7.0 (2018-06-15)
|
|
||||||
|
|
||||||
### New features
|
|
||||||
|
|
||||||
Upgraded to Unicode 11.
|
|
||||||
|
|
||||||
## 5.6.0 (2018-05-31)
|
|
||||||
|
|
||||||
### New features
|
|
||||||
|
|
||||||
Allow U+2028 and U+2029 in string when ECMAVersion >= 10.
|
|
||||||
|
|
||||||
Allow binding-less catch statements when ECMAVersion >= 10.
|
|
||||||
|
|
||||||
Add `allowAwaitOutsideFunction` option for parsing top-level `await`.
|
|
||||||
|
|
||||||
## 5.5.3 (2018-03-08)
|
|
||||||
|
|
||||||
### Bug fixes
|
|
||||||
|
|
||||||
A _second_ republish of the code in 5.5.1, this time with yarn, to hopefully get valid timestamps.
|
|
||||||
|
|
||||||
## 5.5.2 (2018-03-08)
|
|
||||||
|
|
||||||
### Bug fixes
|
|
||||||
|
|
||||||
A republish of the code in 5.5.1 in an attempt to solve an issue with the file timestamps in the npm package being 0.
|
|
||||||
|
|
||||||
## 5.5.1 (2018-03-06)
|
|
||||||
|
|
||||||
### Bug fixes
|
|
||||||
|
|
||||||
Fix misleading error message for octal escapes in template strings.
|
|
||||||
|
|
||||||
## 5.5.0 (2018-02-27)
|
|
||||||
|
|
||||||
### New features
|
|
||||||
|
|
||||||
The identifier character categorization is now based on Unicode version 10.
|
|
||||||
|
|
||||||
Acorn will now validate the content of regular expressions, including new ES9 features.
|
|
||||||
|
|
||||||
## 5.4.0 (2018-02-01)
|
|
||||||
|
|
||||||
### Bug fixes
|
|
||||||
|
|
||||||
Disallow duplicate or escaped flags on regular expressions.
|
|
||||||
|
|
||||||
Disallow octal escapes in strings in strict mode.
|
|
||||||
|
|
||||||
### New features
|
|
||||||
|
|
||||||
Add support for async iteration.
|
|
||||||
|
|
||||||
Add support for object spread and rest.
|
|
||||||
|
|
||||||
## 5.3.0 (2017-12-28)
|
|
||||||
|
|
||||||
### Bug fixes
|
|
||||||
|
|
||||||
Fix parsing of floating point literals with leading zeroes in loose mode.
|
|
||||||
|
|
||||||
Allow duplicate property names in object patterns.
|
|
||||||
|
|
||||||
Don't allow static class methods named `prototype`.
|
|
||||||
|
|
||||||
Disallow async functions directly under `if` or `else`.
|
|
||||||
|
|
||||||
Parse right-hand-side of `for`/`of` as an assignment expression.
|
|
||||||
|
|
||||||
Stricter parsing of `for`/`in`.
|
|
||||||
|
|
||||||
Don't allow unicode escapes in contextual keywords.
|
|
||||||
|
|
||||||
### New features
|
|
||||||
|
|
||||||
Parsing class members was factored into smaller methods to allow plugins to hook into it.
|
|
||||||
|
|
||||||
## 5.2.1 (2017-10-30)
|
|
||||||
|
|
||||||
### Bug fixes
|
|
||||||
|
|
||||||
Fix a token context corruption bug.
|
|
||||||
|
|
||||||
## 5.2.0 (2017-10-30)
|
|
||||||
|
|
||||||
### Bug fixes
|
|
||||||
|
|
||||||
Fix token context tracking for `class` and `function` in property-name position.
|
|
||||||
|
|
||||||
Make sure `%*` isn't parsed as a valid operator.
|
|
||||||
|
|
||||||
Allow shorthand properties `get` and `set` to be followed by default values.
|
|
||||||
|
|
||||||
Disallow `super` when not in callee or object position.
|
|
||||||
|
|
||||||
### New features
|
|
||||||
|
|
||||||
Support [`directive` property](https://github.com/estree/estree/compare/b3de58c9997504d6fba04b72f76e6dd1619ee4eb...1da8e603237144f44710360f8feb7a9977e905e0) on directive expression statements.
|
|
||||||
|
|
||||||
## 5.1.2 (2017-09-04)
|
|
||||||
|
|
||||||
### Bug fixes
|
|
||||||
|
|
||||||
Disable parsing of legacy HTML-style comments in modules.
|
|
||||||
|
|
||||||
Fix parsing of async methods whose names are keywords.
|
|
||||||
|
|
||||||
## 5.1.1 (2017-07-06)
|
|
||||||
|
|
||||||
### Bug fixes
|
|
||||||
|
|
||||||
Fix problem with disambiguating regexp and division after a class.
|
|
||||||
|
|
||||||
## 5.1.0 (2017-07-05)
|
|
||||||
|
|
||||||
### Bug fixes
|
|
||||||
|
|
||||||
Fix tokenizing of regexps in an object-desctructuring `for`/`of` loop and after `yield`.
|
|
||||||
|
|
||||||
Parse zero-prefixed numbers with non-octal digits as decimal.
|
|
||||||
|
|
||||||
Allow object/array patterns in rest parameters.
|
|
||||||
|
|
||||||
Don't error when `yield` is used as a property name.
|
|
||||||
|
|
||||||
Allow `async` as a shorthand object property.
|
|
||||||
|
|
||||||
### New features
|
|
||||||
|
|
||||||
Implement the [template literal revision proposal](https://github.com/tc39/proposal-template-literal-revision) for ES9.
|
|
||||||
|
|
||||||
## 5.0.3 (2017-04-01)
|
|
||||||
|
|
||||||
### Bug fixes
|
|
||||||
|
|
||||||
Fix spurious duplicate variable definition errors for named functions.
|
|
||||||
|
|
||||||
## 5.0.2 (2017-03-30)
|
|
||||||
|
|
||||||
### Bug fixes
|
|
||||||
|
|
||||||
A binary operator after a parenthesized arrow expression is no longer incorrectly treated as an error.
|
|
||||||
|
|
||||||
## 5.0.0 (2017-03-28)
|
|
||||||
|
|
||||||
### Bug fixes
|
|
||||||
|
|
||||||
Raise an error for duplicated lexical bindings.
|
|
||||||
|
|
||||||
Fix spurious error when an assignement expression occurred after a spread expression.
|
|
||||||
|
|
||||||
Accept regular expressions after `of` (in `for`/`of`), `yield` (in a generator), and braced arrow functions.
|
|
||||||
|
|
||||||
Allow labels in front or `var` declarations, even in strict mode.
|
|
||||||
|
|
||||||
### Breaking changes
|
|
||||||
|
|
||||||
Parse declarations following `export default` as declaration nodes, not expressions. This means that class and function declarations nodes can now have `null` as their `id`.
|
|
||||||
|
|
||||||
## 4.0.11 (2017-02-07)
|
|
||||||
|
|
||||||
### Bug fixes
|
|
||||||
|
|
||||||
Allow all forms of member expressions to be parenthesized as lvalue.
|
|
||||||
|
|
||||||
## 4.0.10 (2017-02-07)
|
|
||||||
|
|
||||||
### Bug fixes
|
|
||||||
|
|
||||||
Don't expect semicolons after default-exported functions or classes, even when they are expressions.
|
|
||||||
|
|
||||||
Check for use of `'use strict'` directives in non-simple parameter functions, even when already in strict mode.
|
|
||||||
|
|
||||||
## 4.0.9 (2017-02-06)
|
|
||||||
|
|
||||||
### Bug fixes
|
|
||||||
|
|
||||||
Fix incorrect error raised for parenthesized simple assignment targets, so that `(x) = 1` parses again.
|
|
||||||
|
|
||||||
## 4.0.8 (2017-02-03)
|
|
||||||
|
|
||||||
### Bug fixes
|
|
||||||
|
|
||||||
Solve spurious parenthesized pattern errors by temporarily erring on the side of accepting programs that our delayed errors don't handle correctly yet.
|
|
||||||
|
|
||||||
## 4.0.7 (2017-02-02)
|
|
||||||
|
|
||||||
### Bug fixes
|
|
||||||
|
|
||||||
Accept invalidly rejected code like `(x).y = 2` again.
|
|
||||||
|
|
||||||
Don't raise an error when a function _inside_ strict code has a non-simple parameter list.
|
|
||||||
|
|
||||||
## 4.0.6 (2017-02-02)
|
|
||||||
|
|
||||||
### Bug fixes
|
|
||||||
|
|
||||||
Fix exponential behavior (manifesting itself as a complete hang for even relatively small source files) introduced by the new 'use strict' check.
|
|
||||||
|
|
||||||
## 4.0.5 (2017-02-02)
|
|
||||||
|
|
||||||
### Bug fixes
|
|
||||||
|
|
||||||
Disallow parenthesized pattern expressions.
|
|
||||||
|
|
||||||
Allow keywords as export names.
|
|
||||||
|
|
||||||
Don't allow the `async` keyword to be parenthesized.
|
|
||||||
|
|
||||||
Properly raise an error when a keyword contains a character escape.
|
|
||||||
|
|
||||||
Allow `"use strict"` to appear after other string literal expressions.
|
|
||||||
|
|
||||||
Disallow labeled declarations.
|
|
||||||
|
|
||||||
## 4.0.4 (2016-12-19)
|
|
||||||
|
|
||||||
### Bug fixes
|
|
||||||
|
|
||||||
Fix crash when `export` was followed by a keyword that can't be
|
|
||||||
exported.
|
|
||||||
|
|
||||||
## 4.0.3 (2016-08-16)
|
|
||||||
|
|
||||||
### Bug fixes
|
|
||||||
|
|
||||||
Allow regular function declarations inside single-statement `if` branches in loose mode. Forbid them entirely in strict mode.
|
|
||||||
|
|
||||||
Properly parse properties named `async` in ES2017 mode.
|
|
||||||
|
|
||||||
Fix bug where reserved words were broken in ES2017 mode.
|
|
||||||
|
|
||||||
## 4.0.2 (2016-08-11)
|
|
||||||
|
|
||||||
### Bug fixes
|
|
||||||
|
|
||||||
Don't ignore period or 'e' characters after octal numbers.
|
|
||||||
|
|
||||||
Fix broken parsing for call expressions in default parameter values of arrow functions.
|
|
||||||
|
|
||||||
## 4.0.1 (2016-08-08)
|
|
||||||
|
|
||||||
### Bug fixes
|
|
||||||
|
|
||||||
Fix false positives in duplicated export name errors.
|
|
||||||
|
|
||||||
## 4.0.0 (2016-08-07)
|
|
||||||
|
|
||||||
### Breaking changes
|
|
||||||
|
|
||||||
The default `ecmaVersion` option value is now 7.
|
|
||||||
|
|
||||||
A number of internal method signatures changed, so plugins might need to be updated.
|
|
||||||
|
|
||||||
### Bug fixes
|
|
||||||
|
|
||||||
The parser now raises errors on duplicated export names.
|
|
||||||
|
|
||||||
`arguments` and `eval` can now be used in shorthand properties.
|
|
||||||
|
|
||||||
Duplicate parameter names in non-simple argument lists now always produce an error.
|
|
||||||
|
|
||||||
### New features
|
|
||||||
|
|
||||||
The `ecmaVersion` option now also accepts year-style version numbers
|
|
||||||
(2015, etc).
|
|
||||||
|
|
||||||
Support for `async`/`await` syntax when `ecmaVersion` is >= 8.
|
|
||||||
|
|
||||||
Support for trailing commas in call expressions when `ecmaVersion` is >= 8.
|
|
||||||
|
|
||||||
## 3.3.0 (2016-07-25)
|
|
||||||
|
|
||||||
### Bug fixes
|
|
||||||
|
|
||||||
Fix bug in tokenizing of regexp operator after a function declaration.
|
|
||||||
|
|
||||||
Fix parser crash when parsing an array pattern with a hole.
|
|
||||||
|
|
||||||
### New features
|
|
||||||
|
|
||||||
Implement check against complex argument lists in functions that enable strict mode in ES7.
|
|
||||||
|
|
||||||
## 3.2.0 (2016-06-07)
|
|
||||||
|
|
||||||
### Bug fixes
|
|
||||||
|
|
||||||
Improve handling of lack of unicode regexp support in host
|
|
||||||
environment.
|
|
||||||
|
|
||||||
Properly reject shorthand properties whose name is a keyword.
|
|
||||||
|
|
||||||
### New features
|
|
||||||
|
|
||||||
Visitors created with `visit.make` now have their base as _prototype_, rather than copying properties into a fresh object.
|
|
||||||
|
|
||||||
## 3.1.0 (2016-04-18)
|
|
||||||
|
|
||||||
### Bug fixes
|
|
||||||
|
|
||||||
Properly tokenize the division operator directly after a function expression.
|
|
||||||
|
|
||||||
Allow trailing comma in destructuring arrays.
|
|
||||||
|
|
||||||
## 3.0.4 (2016-02-25)
|
|
||||||
|
|
||||||
### Fixes
|
|
||||||
|
|
||||||
Allow update expressions as left-hand-side of the ES7 exponential operator.
|
|
||||||
|
|
||||||
## 3.0.2 (2016-02-10)
|
|
||||||
|
|
||||||
### Fixes
|
|
||||||
|
|
||||||
Fix bug that accidentally made `undefined` a reserved word when parsing ES7.
|
|
||||||
|
|
||||||
## 3.0.0 (2016-02-10)
|
|
||||||
|
|
||||||
### Breaking changes
|
|
||||||
|
|
||||||
The default value of the `ecmaVersion` option is now 6 (used to be 5).
|
|
||||||
|
|
||||||
Support for comprehension syntax (which was dropped from the draft spec) has been removed.
|
|
||||||
|
|
||||||
### Fixes
|
|
||||||
|
|
||||||
`let` and `yield` are now “contextual keywords”, meaning you can mostly use them as identifiers in ES5 non-strict code.
|
|
||||||
|
|
||||||
A parenthesized class or function expression after `export default` is now parsed correctly.
|
|
||||||
|
|
||||||
### New features
|
|
||||||
|
|
||||||
When `ecmaVersion` is set to 7, Acorn will parse the exponentiation operator (`**`).
|
|
||||||
|
|
||||||
The identifier character ranges are now based on Unicode 8.0.0.
|
|
||||||
|
|
||||||
Plugins can now override the `raiseRecoverable` method to override the way non-critical errors are handled.
|
|
||||||
|
|
||||||
## 2.7.0 (2016-01-04)
|
|
||||||
|
|
||||||
### Fixes
|
|
||||||
|
|
||||||
Stop allowing rest parameters in setters.
|
|
||||||
|
|
||||||
Disallow `y` rexexp flag in ES5.
|
|
||||||
|
|
||||||
Disallow `\00` and `\000` escapes in strict mode.
|
|
||||||
|
|
||||||
Raise an error when an import name is a reserved word.
|
|
||||||
|
|
||||||
## 2.6.2 (2015-11-10)
|
|
||||||
|
|
||||||
### Fixes
|
|
||||||
|
|
||||||
Don't crash when no options object is passed.
|
|
||||||
|
|
||||||
## 2.6.0 (2015-11-09)
|
|
||||||
|
|
||||||
### Fixes
|
|
||||||
|
|
||||||
Add `await` as a reserved word in module sources.
|
|
||||||
|
|
||||||
Disallow `yield` in a parameter default value for a generator.
|
|
||||||
|
|
||||||
Forbid using a comma after a rest pattern in an array destructuring.
|
|
||||||
|
|
||||||
### New features
|
|
||||||
|
|
||||||
Support parsing stdin in command-line tool.
|
|
||||||
|
|
||||||
## 2.5.0 (2015-10-27)
|
|
||||||
|
|
||||||
### Fixes
|
|
||||||
|
|
||||||
Fix tokenizer support in the command-line tool.
|
|
||||||
|
|
||||||
Stop allowing `new.target` outside of functions.
|
|
||||||
|
|
||||||
Remove legacy `guard` and `guardedHandler` properties from try nodes.
|
|
||||||
|
|
||||||
Stop allowing multiple `__proto__` properties on an object literal in strict mode.
|
|
||||||
|
|
||||||
Don't allow rest parameters to be non-identifier patterns.
|
|
||||||
|
|
||||||
Check for duplicate paramter names in arrow functions.
|
|
||||||
21
node_modules/acorn/LICENSE
generated
vendored
21
node_modules/acorn/LICENSE
generated
vendored
@@ -1,21 +0,0 @@
|
|||||||
MIT License
|
|
||||||
|
|
||||||
Copyright (C) 2012-2018 by various contributors (see AUTHORS)
|
|
||||||
|
|
||||||
Permission is hereby granted, free of charge, to any person obtaining a copy
|
|
||||||
of this software and associated documentation files (the "Software"), to deal
|
|
||||||
in the Software without restriction, including without limitation the rights
|
|
||||||
to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
|
|
||||||
copies of the Software, and to permit persons to whom the Software is
|
|
||||||
furnished to do so, subject to the following conditions:
|
|
||||||
|
|
||||||
The above copyright notice and this permission notice shall be included in
|
|
||||||
all copies or substantial portions of the Software.
|
|
||||||
|
|
||||||
THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
|
|
||||||
IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
|
|
||||||
FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
|
|
||||||
AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
|
|
||||||
LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
|
|
||||||
OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN
|
|
||||||
THE SOFTWARE.
|
|
||||||
269
node_modules/acorn/README.md
generated
vendored
269
node_modules/acorn/README.md
generated
vendored
@@ -1,269 +0,0 @@
|
|||||||
# Acorn
|
|
||||||
|
|
||||||
A tiny, fast JavaScript parser written in JavaScript.
|
|
||||||
|
|
||||||
## Community
|
|
||||||
|
|
||||||
Acorn is open source software released under an
|
|
||||||
[MIT license](https://github.com/acornjs/acorn/blob/master/acorn/LICENSE).
|
|
||||||
|
|
||||||
You are welcome to
|
|
||||||
[report bugs](https://github.com/acornjs/acorn/issues) or create pull
|
|
||||||
requests on [github](https://github.com/acornjs/acorn). For questions
|
|
||||||
and discussion, please use the
|
|
||||||
[Tern discussion forum](https://discuss.ternjs.net).
|
|
||||||
|
|
||||||
## Installation
|
|
||||||
|
|
||||||
The easiest way to install acorn is from [`npm`](https://www.npmjs.com/):
|
|
||||||
|
|
||||||
```sh
|
|
||||||
npm install acorn
|
|
||||||
```
|
|
||||||
|
|
||||||
Alternately, you can download the source and build acorn yourself:
|
|
||||||
|
|
||||||
```sh
|
|
||||||
git clone https://github.com/acornjs/acorn.git
|
|
||||||
cd acorn
|
|
||||||
npm install
|
|
||||||
```
|
|
||||||
|
|
||||||
## Interface
|
|
||||||
|
|
||||||
**parse**`(input, options)` is the main interface to the library. The
|
|
||||||
`input` parameter is a string, `options` can be undefined or an object
|
|
||||||
setting some of the options listed below. The return value will be an
|
|
||||||
abstract syntax tree object as specified by the [ESTree
|
|
||||||
spec](https://github.com/estree/estree).
|
|
||||||
|
|
||||||
```javascript
|
|
||||||
let acorn = require("acorn");
|
|
||||||
console.log(acorn.parse("1 + 1"));
|
|
||||||
```
|
|
||||||
|
|
||||||
When encountering a syntax error, the parser will raise a
|
|
||||||
`SyntaxError` object with a meaningful message. The error object will
|
|
||||||
have a `pos` property that indicates the string offset at which the
|
|
||||||
error occurred, and a `loc` object that contains a `{line, column}`
|
|
||||||
object referring to that same position.
|
|
||||||
|
|
||||||
Options can be provided by passing a second argument, which should be
|
|
||||||
an object containing any of these fields:
|
|
||||||
|
|
||||||
- **ecmaVersion**: Indicates the ECMAScript version to parse. Must be
|
|
||||||
either 3, 5, 6 (2015), 7 (2016), 8 (2017), 9 (2018), 10 (2019) or 11
|
|
||||||
(2020, partial support). This influences support for strict mode,
|
|
||||||
the set of reserved words, and support for new syntax features.
|
|
||||||
Default is 10.
|
|
||||||
|
|
||||||
**NOTE**: Only 'stage 4' (finalized) ECMAScript features are being
|
|
||||||
implemented by Acorn. Other proposed new features can be implemented
|
|
||||||
through plugins.
|
|
||||||
|
|
||||||
- **sourceType**: Indicate the mode the code should be parsed in. Can be
|
|
||||||
either `"script"` or `"module"`. This influences global strict mode
|
|
||||||
and parsing of `import` and `export` declarations.
|
|
||||||
|
|
||||||
**NOTE**: If set to `"module"`, then static `import` / `export` syntax
|
|
||||||
will be valid, even if `ecmaVersion` is less than 6.
|
|
||||||
|
|
||||||
- **onInsertedSemicolon**: If given a callback, that callback will be
|
|
||||||
called whenever a missing semicolon is inserted by the parser. The
|
|
||||||
callback will be given the character offset of the point where the
|
|
||||||
semicolon is inserted as argument, and if `locations` is on, also a
|
|
||||||
`{line, column}` object representing this position.
|
|
||||||
|
|
||||||
- **onTrailingComma**: Like `onInsertedSemicolon`, but for trailing
|
|
||||||
commas.
|
|
||||||
|
|
||||||
- **allowReserved**: If `false`, using a reserved word will generate
|
|
||||||
an error. Defaults to `true` for `ecmaVersion` 3, `false` for higher
|
|
||||||
versions. When given the value `"never"`, reserved words and
|
|
||||||
keywords can also not be used as property names (as in Internet
|
|
||||||
Explorer's old parser).
|
|
||||||
|
|
||||||
- **allowReturnOutsideFunction**: By default, a return statement at
|
|
||||||
the top level raises an error. Set this to `true` to accept such
|
|
||||||
code.
|
|
||||||
|
|
||||||
- **allowImportExportEverywhere**: By default, `import` and `export`
|
|
||||||
declarations can only appear at a program's top level. Setting this
|
|
||||||
option to `true` allows them anywhere where a statement is allowed.
|
|
||||||
|
|
||||||
- **allowAwaitOutsideFunction**: By default, `await` expressions can
|
|
||||||
only appear inside `async` functions. Setting this option to
|
|
||||||
`true` allows to have top-level `await` expressions. They are
|
|
||||||
still not allowed in non-`async` functions, though.
|
|
||||||
|
|
||||||
- **allowHashBang**: When this is enabled (off by default), if the
|
|
||||||
code starts with the characters `#!` (as in a shellscript), the
|
|
||||||
first line will be treated as a comment.
|
|
||||||
|
|
||||||
- **locations**: When `true`, each node has a `loc` object attached
|
|
||||||
with `start` and `end` subobjects, each of which contains the
|
|
||||||
one-based line and zero-based column numbers in `{line, column}`
|
|
||||||
form. Default is `false`.
|
|
||||||
|
|
||||||
- **onToken**: If a function is passed for this option, each found
|
|
||||||
token will be passed in same format as tokens returned from
|
|
||||||
`tokenizer().getToken()`.
|
|
||||||
|
|
||||||
If array is passed, each found token is pushed to it.
|
|
||||||
|
|
||||||
Note that you are not allowed to call the parser from the
|
|
||||||
callback—that will corrupt its internal state.
|
|
||||||
|
|
||||||
- **onComment**: If a function is passed for this option, whenever a
|
|
||||||
comment is encountered the function will be called with the
|
|
||||||
following parameters:
|
|
||||||
|
|
||||||
- `block`: `true` if the comment is a block comment, false if it
|
|
||||||
is a line comment.
|
|
||||||
- `text`: The content of the comment.
|
|
||||||
- `start`: Character offset of the start of the comment.
|
|
||||||
- `end`: Character offset of the end of the comment.
|
|
||||||
|
|
||||||
When the `locations` options is on, the `{line, column}` locations
|
|
||||||
of the comment’s start and end are passed as two additional
|
|
||||||
parameters.
|
|
||||||
|
|
||||||
If array is passed for this option, each found comment is pushed
|
|
||||||
to it as object in Esprima format:
|
|
||||||
|
|
||||||
```javascript
|
|
||||||
{
|
|
||||||
"type": "Line" | "Block",
|
|
||||||
"value": "comment text",
|
|
||||||
"start": Number,
|
|
||||||
"end": Number,
|
|
||||||
// If `locations` option is on:
|
|
||||||
"loc": {
|
|
||||||
"start": {line: Number, column: Number}
|
|
||||||
"end": {line: Number, column: Number}
|
|
||||||
},
|
|
||||||
// If `ranges` option is on:
|
|
||||||
"range": [Number, Number]
|
|
||||||
}
|
|
||||||
```
|
|
||||||
|
|
||||||
Note that you are not allowed to call the parser from the
|
|
||||||
callback—that will corrupt its internal state.
|
|
||||||
|
|
||||||
- **ranges**: Nodes have their start and end characters offsets
|
|
||||||
recorded in `start` and `end` properties (directly on the node,
|
|
||||||
rather than the `loc` object, which holds line/column data. To also
|
|
||||||
add a
|
|
||||||
[semi-standardized](https://bugzilla.mozilla.org/show_bug.cgi?id=745678)
|
|
||||||
`range` property holding a `[start, end]` array with the same
|
|
||||||
numbers, set the `ranges` option to `true`.
|
|
||||||
|
|
||||||
- **program**: It is possible to parse multiple files into a single
|
|
||||||
AST by passing the tree produced by parsing the first file as the
|
|
||||||
`program` option in subsequent parses. This will add the toplevel
|
|
||||||
forms of the parsed file to the "Program" (top) node of an existing
|
|
||||||
parse tree.
|
|
||||||
|
|
||||||
- **sourceFile**: When the `locations` option is `true`, you can pass
|
|
||||||
this option to add a `source` attribute in every node’s `loc`
|
|
||||||
object. Note that the contents of this option are not examined or
|
|
||||||
processed in any way; you are free to use whatever format you
|
|
||||||
choose.
|
|
||||||
|
|
||||||
- **directSourceFile**: Like `sourceFile`, but a `sourceFile` property
|
|
||||||
will be added (regardless of the `location` option) directly to the
|
|
||||||
nodes, rather than the `loc` object.
|
|
||||||
|
|
||||||
- **preserveParens**: If this option is `true`, parenthesized expressions
|
|
||||||
are represented by (non-standard) `ParenthesizedExpression` nodes
|
|
||||||
that have a single `expression` property containing the expression
|
|
||||||
inside parentheses.
|
|
||||||
|
|
||||||
**parseExpressionAt**`(input, offset, options)` will parse a single
|
|
||||||
expression in a string, and return its AST. It will not complain if
|
|
||||||
there is more of the string left after the expression.
|
|
||||||
|
|
||||||
**tokenizer**`(input, options)` returns an object with a `getToken`
|
|
||||||
method that can be called repeatedly to get the next token, a `{start,
|
|
||||||
end, type, value}` object (with added `loc` property when the
|
|
||||||
`locations` option is enabled and `range` property when the `ranges`
|
|
||||||
option is enabled). When the token's type is `tokTypes.eof`, you
|
|
||||||
should stop calling the method, since it will keep returning that same
|
|
||||||
token forever.
|
|
||||||
|
|
||||||
In ES6 environment, returned result can be used as any other
|
|
||||||
protocol-compliant iterable:
|
|
||||||
|
|
||||||
```javascript
|
|
||||||
for (let token of acorn.tokenizer(str)) {
|
|
||||||
// iterate over the tokens
|
|
||||||
}
|
|
||||||
|
|
||||||
// transform code to array of tokens:
|
|
||||||
var tokens = [...acorn.tokenizer(str)];
|
|
||||||
```
|
|
||||||
|
|
||||||
**tokTypes** holds an object mapping names to the token type objects
|
|
||||||
that end up in the `type` properties of tokens.
|
|
||||||
|
|
||||||
**getLineInfo**`(input, offset)` can be used to get a `{line,
|
|
||||||
column}` object for a given program string and offset.
|
|
||||||
|
|
||||||
### The `Parser` class
|
|
||||||
|
|
||||||
Instances of the **`Parser`** class contain all the state and logic
|
|
||||||
that drives a parse. It has static methods `parse`,
|
|
||||||
`parseExpressionAt`, and `tokenizer` that match the top-level
|
|
||||||
functions by the same name.
|
|
||||||
|
|
||||||
When extending the parser with plugins, you need to call these methods
|
|
||||||
on the extended version of the class. To extend a parser with plugins,
|
|
||||||
you can use its static `extend` method.
|
|
||||||
|
|
||||||
```javascript
|
|
||||||
var acorn = require("acorn");
|
|
||||||
var jsx = require("acorn-jsx");
|
|
||||||
var JSXParser = acorn.Parser.extend(jsx());
|
|
||||||
JSXParser.parse("foo(<bar/>)");
|
|
||||||
```
|
|
||||||
|
|
||||||
The `extend` method takes any number of plugin values, and returns a
|
|
||||||
new `Parser` class that includes the extra parser logic provided by
|
|
||||||
the plugins.
|
|
||||||
|
|
||||||
## Command line interface
|
|
||||||
|
|
||||||
The `bin/acorn` utility can be used to parse a file from the command
|
|
||||||
line. It accepts as arguments its input file and the following
|
|
||||||
options:
|
|
||||||
|
|
||||||
- `--ecma3|--ecma5|--ecma6|--ecma7|--ecma8|--ecma9|--ecma10`: Sets the ECMAScript version
|
|
||||||
to parse. Default is version 9.
|
|
||||||
|
|
||||||
- `--module`: Sets the parsing mode to `"module"`. Is set to `"script"` otherwise.
|
|
||||||
|
|
||||||
- `--locations`: Attaches a "loc" object to each node with "start" and
|
|
||||||
"end" subobjects, each of which contains the one-based line and
|
|
||||||
zero-based column numbers in `{line, column}` form.
|
|
||||||
|
|
||||||
- `--allow-hash-bang`: If the code starts with the characters #! (as
|
|
||||||
in a shellscript), the first line will be treated as a comment.
|
|
||||||
|
|
||||||
- `--compact`: No whitespace is used in the AST output.
|
|
||||||
|
|
||||||
- `--silent`: Do not output the AST, just return the exit status.
|
|
||||||
|
|
||||||
- `--help`: Print the usage information and quit.
|
|
||||||
|
|
||||||
The utility spits out the syntax tree as JSON data.
|
|
||||||
|
|
||||||
## Existing plugins
|
|
||||||
|
|
||||||
- [`acorn-jsx`](https://github.com/RReverser/acorn-jsx): Parse [Facebook JSX syntax extensions](https://github.com/facebook/jsx)
|
|
||||||
|
|
||||||
Plugins for ECMAScript proposals:
|
|
||||||
|
|
||||||
- [`acorn-stage3`](https://github.com/acornjs/acorn-stage3): Parse most stage 3 proposals, bundling:
|
|
||||||
- [`acorn-class-fields`](https://github.com/acornjs/acorn-class-fields): Parse [class fields proposal](https://github.com/tc39/proposal-class-fields)
|
|
||||||
- [`acorn-import-meta`](https://github.com/acornjs/acorn-import-meta): Parse [import.meta proposal](https://github.com/tc39/proposal-import-meta)
|
|
||||||
- [`acorn-private-methods`](https://github.com/acornjs/acorn-private-methods): parse [private methods, getters and setters proposal](https://github.com/tc39/proposal-private-methods)n
|
|
||||||
35
node_modules/acorn/package.json
generated
vendored
35
node_modules/acorn/package.json
generated
vendored
@@ -1,35 +0,0 @@
|
|||||||
{
|
|
||||||
"name": "acorn",
|
|
||||||
"description": "ECMAScript parser",
|
|
||||||
"homepage": "https://github.com/acornjs/acorn",
|
|
||||||
"main": "dist/acorn.js",
|
|
||||||
"types": "dist/acorn.d.ts",
|
|
||||||
"module": "dist/acorn.mjs",
|
|
||||||
"version": "7.4.1",
|
|
||||||
"engines": {"node": ">=0.4.0"},
|
|
||||||
"maintainers": [
|
|
||||||
{
|
|
||||||
"name": "Marijn Haverbeke",
|
|
||||||
"email": "marijnh@gmail.com",
|
|
||||||
"web": "https://marijnhaverbeke.nl"
|
|
||||||
},
|
|
||||||
{
|
|
||||||
"name": "Ingvar Stepanyan",
|
|
||||||
"email": "me@rreverser.com",
|
|
||||||
"web": "https://rreverser.com/"
|
|
||||||
},
|
|
||||||
{
|
|
||||||
"name": "Adrian Heine",
|
|
||||||
"web": "http://adrianheine.de"
|
|
||||||
}
|
|
||||||
],
|
|
||||||
"repository": {
|
|
||||||
"type": "git",
|
|
||||||
"url": "https://github.com/acornjs/acorn.git"
|
|
||||||
},
|
|
||||||
"license": "MIT",
|
|
||||||
"scripts": {
|
|
||||||
"prepare": "cd ..; npm run build:main && npm run build:bin"
|
|
||||||
},
|
|
||||||
"bin": {"acorn": "./bin/acorn"}
|
|
||||||
}
|
|
||||||
20
node_modules/ajv/.tonic_example.js
generated
vendored
20
node_modules/ajv/.tonic_example.js
generated
vendored
@@ -1,20 +0,0 @@
|
|||||||
var Ajv = require('ajv');
|
|
||||||
var ajv = new Ajv({allErrors: true});
|
|
||||||
|
|
||||||
var schema = {
|
|
||||||
"properties": {
|
|
||||||
"foo": { "type": "string" },
|
|
||||||
"bar": { "type": "number", "maximum": 3 }
|
|
||||||
}
|
|
||||||
};
|
|
||||||
|
|
||||||
var validate = ajv.compile(schema);
|
|
||||||
|
|
||||||
test({"foo": "abc", "bar": 2});
|
|
||||||
test({"foo": 2, "bar": 4});
|
|
||||||
|
|
||||||
function test(data) {
|
|
||||||
var valid = validate(data);
|
|
||||||
if (valid) console.log('Valid!');
|
|
||||||
else console.log('Invalid: ' + ajv.errorsText(validate.errors));
|
|
||||||
}
|
|
||||||
22
node_modules/ajv/LICENSE
generated
vendored
22
node_modules/ajv/LICENSE
generated
vendored
@@ -1,22 +0,0 @@
|
|||||||
The MIT License (MIT)
|
|
||||||
|
|
||||||
Copyright (c) 2015-2017 Evgeny Poberezkin
|
|
||||||
|
|
||||||
Permission is hereby granted, free of charge, to any person obtaining a copy
|
|
||||||
of this software and associated documentation files (the "Software"), to deal
|
|
||||||
in the Software without restriction, including without limitation the rights
|
|
||||||
to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
|
|
||||||
copies of the Software, and to permit persons to whom the Software is
|
|
||||||
furnished to do so, subject to the following conditions:
|
|
||||||
|
|
||||||
The above copyright notice and this permission notice shall be included in all
|
|
||||||
copies or substantial portions of the Software.
|
|
||||||
|
|
||||||
THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
|
|
||||||
IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
|
|
||||||
FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
|
|
||||||
AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
|
|
||||||
LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
|
|
||||||
OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
|
|
||||||
SOFTWARE.
|
|
||||||
|
|
||||||
1497
node_modules/ajv/README.md
generated
vendored
1497
node_modules/ajv/README.md
generated
vendored
File diff suppressed because it is too large
Load Diff
397
node_modules/ajv/lib/ajv.d.ts
generated
vendored
397
node_modules/ajv/lib/ajv.d.ts
generated
vendored
@@ -1,397 +0,0 @@
|
|||||||
declare var ajv: {
|
|
||||||
(options?: ajv.Options): ajv.Ajv;
|
|
||||||
new(options?: ajv.Options): ajv.Ajv;
|
|
||||||
ValidationError: typeof AjvErrors.ValidationError;
|
|
||||||
MissingRefError: typeof AjvErrors.MissingRefError;
|
|
||||||
$dataMetaSchema: object;
|
|
||||||
}
|
|
||||||
|
|
||||||
declare namespace AjvErrors {
|
|
||||||
class ValidationError extends Error {
|
|
||||||
constructor(errors: Array<ajv.ErrorObject>);
|
|
||||||
|
|
||||||
message: string;
|
|
||||||
errors: Array<ajv.ErrorObject>;
|
|
||||||
ajv: true;
|
|
||||||
validation: true;
|
|
||||||
}
|
|
||||||
|
|
||||||
class MissingRefError extends Error {
|
|
||||||
constructor(baseId: string, ref: string, message?: string);
|
|
||||||
static message: (baseId: string, ref: string) => string;
|
|
||||||
|
|
||||||
message: string;
|
|
||||||
missingRef: string;
|
|
||||||
missingSchema: string;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
declare namespace ajv {
|
|
||||||
type ValidationError = AjvErrors.ValidationError;
|
|
||||||
|
|
||||||
type MissingRefError = AjvErrors.MissingRefError;
|
|
||||||
|
|
||||||
interface Ajv {
|
|
||||||
/**
|
|
||||||
* Validate data using schema
|
|
||||||
* Schema will be compiled and cached (using serialized JSON as key, [fast-json-stable-stringify](https://github.com/epoberezkin/fast-json-stable-stringify) is used to serialize by default).
|
|
||||||
* @param {string|object|Boolean} schemaKeyRef key, ref or schema object
|
|
||||||
* @param {Any} data to be validated
|
|
||||||
* @return {Boolean} validation result. Errors from the last validation will be available in `ajv.errors` (and also in compiled schema: `schema.errors`).
|
|
||||||
*/
|
|
||||||
validate(schemaKeyRef: object | string | boolean, data: any): boolean | PromiseLike<any>;
|
|
||||||
/**
|
|
||||||
* Create validating function for passed schema.
|
|
||||||
* @param {object|Boolean} schema schema object
|
|
||||||
* @return {Function} validating function
|
|
||||||
*/
|
|
||||||
compile(schema: object | boolean): ValidateFunction;
|
|
||||||
/**
|
|
||||||
* Creates validating function for passed schema with asynchronous loading of missing schemas.
|
|
||||||
* `loadSchema` option should be a function that accepts schema uri and node-style callback.
|
|
||||||
* @this Ajv
|
|
||||||
* @param {object|Boolean} schema schema object
|
|
||||||
* @param {Boolean} meta optional true to compile meta-schema; this parameter can be skipped
|
|
||||||
* @param {Function} callback optional node-style callback, it is always called with 2 parameters: error (or null) and validating function.
|
|
||||||
* @return {PromiseLike<ValidateFunction>} validating function
|
|
||||||
*/
|
|
||||||
compileAsync(schema: object | boolean, meta?: Boolean, callback?: (err: Error, validate: ValidateFunction) => any): PromiseLike<ValidateFunction>;
|
|
||||||
/**
|
|
||||||
* Adds schema to the instance.
|
|
||||||
* @param {object|Array} schema schema or array of schemas. If array is passed, `key` and other parameters will be ignored.
|
|
||||||
* @param {string} key Optional schema key. Can be passed to `validate` method instead of schema object or id/ref. One schema per instance can have empty `id` and `key`.
|
|
||||||
* @return {Ajv} this for method chaining
|
|
||||||
*/
|
|
||||||
addSchema(schema: Array<object> | object, key?: string): Ajv;
|
|
||||||
/**
|
|
||||||
* Add schema that will be used to validate other schemas
|
|
||||||
* options in META_IGNORE_OPTIONS are alway set to false
|
|
||||||
* @param {object} schema schema object
|
|
||||||
* @param {string} key optional schema key
|
|
||||||
* @return {Ajv} this for method chaining
|
|
||||||
*/
|
|
||||||
addMetaSchema(schema: object, key?: string): Ajv;
|
|
||||||
/**
|
|
||||||
* Validate schema
|
|
||||||
* @param {object|Boolean} schema schema to validate
|
|
||||||
* @return {Boolean} true if schema is valid
|
|
||||||
*/
|
|
||||||
validateSchema(schema: object | boolean): boolean;
|
|
||||||
/**
|
|
||||||
* Get compiled schema from the instance by `key` or `ref`.
|
|
||||||
* @param {string} keyRef `key` that was passed to `addSchema` or full schema reference (`schema.id` or resolved id).
|
|
||||||
* @return {Function} schema validating function (with property `schema`). Returns undefined if keyRef can't be resolved to an existing schema.
|
|
||||||
*/
|
|
||||||
getSchema(keyRef: string): ValidateFunction | undefined;
|
|
||||||
/**
|
|
||||||
* Remove cached schema(s).
|
|
||||||
* If no parameter is passed all schemas but meta-schemas are removed.
|
|
||||||
* If RegExp is passed all schemas with key/id matching pattern but meta-schemas are removed.
|
|
||||||
* Even if schema is referenced by other schemas it still can be removed as other schemas have local references.
|
|
||||||
* @param {string|object|RegExp|Boolean} schemaKeyRef key, ref, pattern to match key/ref or schema object
|
|
||||||
* @return {Ajv} this for method chaining
|
|
||||||
*/
|
|
||||||
removeSchema(schemaKeyRef?: object | string | RegExp | boolean): Ajv;
|
|
||||||
/**
|
|
||||||
* Add custom format
|
|
||||||
* @param {string} name format name
|
|
||||||
* @param {string|RegExp|Function} format string is converted to RegExp; function should return boolean (true when valid)
|
|
||||||
* @return {Ajv} this for method chaining
|
|
||||||
*/
|
|
||||||
addFormat(name: string, format: FormatValidator | FormatDefinition): Ajv;
|
|
||||||
/**
|
|
||||||
* Define custom keyword
|
|
||||||
* @this Ajv
|
|
||||||
* @param {string} keyword custom keyword, should be a valid identifier, should be different from all standard, custom and macro keywords.
|
|
||||||
* @param {object} definition keyword definition object with properties `type` (type(s) which the keyword applies to), `validate` or `compile`.
|
|
||||||
* @return {Ajv} this for method chaining
|
|
||||||
*/
|
|
||||||
addKeyword(keyword: string, definition: KeywordDefinition): Ajv;
|
|
||||||
/**
|
|
||||||
* Get keyword definition
|
|
||||||
* @this Ajv
|
|
||||||
* @param {string} keyword pre-defined or custom keyword.
|
|
||||||
* @return {object|Boolean} custom keyword definition, `true` if it is a predefined keyword, `false` otherwise.
|
|
||||||
*/
|
|
||||||
getKeyword(keyword: string): object | boolean;
|
|
||||||
/**
|
|
||||||
* Remove keyword
|
|
||||||
* @this Ajv
|
|
||||||
* @param {string} keyword pre-defined or custom keyword.
|
|
||||||
* @return {Ajv} this for method chaining
|
|
||||||
*/
|
|
||||||
removeKeyword(keyword: string): Ajv;
|
|
||||||
/**
|
|
||||||
* Validate keyword
|
|
||||||
* @this Ajv
|
|
||||||
* @param {object} definition keyword definition object
|
|
||||||
* @param {boolean} throwError true to throw exception if definition is invalid
|
|
||||||
* @return {boolean} validation result
|
|
||||||
*/
|
|
||||||
validateKeyword(definition: KeywordDefinition, throwError: boolean): boolean;
|
|
||||||
/**
|
|
||||||
* Convert array of error message objects to string
|
|
||||||
* @param {Array<object>} errors optional array of validation errors, if not passed errors from the instance are used.
|
|
||||||
* @param {object} options optional options with properties `separator` and `dataVar`.
|
|
||||||
* @return {string} human readable string with all errors descriptions
|
|
||||||
*/
|
|
||||||
errorsText(errors?: Array<ErrorObject> | null, options?: ErrorsTextOptions): string;
|
|
||||||
errors?: Array<ErrorObject> | null;
|
|
||||||
_opts: Options;
|
|
||||||
}
|
|
||||||
|
|
||||||
interface CustomLogger {
|
|
||||||
log(...args: any[]): any;
|
|
||||||
warn(...args: any[]): any;
|
|
||||||
error(...args: any[]): any;
|
|
||||||
}
|
|
||||||
|
|
||||||
interface ValidateFunction {
|
|
||||||
(
|
|
||||||
data: any,
|
|
||||||
dataPath?: string,
|
|
||||||
parentData?: object | Array<any>,
|
|
||||||
parentDataProperty?: string | number,
|
|
||||||
rootData?: object | Array<any>
|
|
||||||
): boolean | PromiseLike<any>;
|
|
||||||
schema?: object | boolean;
|
|
||||||
errors?: null | Array<ErrorObject>;
|
|
||||||
refs?: object;
|
|
||||||
refVal?: Array<any>;
|
|
||||||
root?: ValidateFunction | object;
|
|
||||||
$async?: true;
|
|
||||||
source?: object;
|
|
||||||
}
|
|
||||||
|
|
||||||
interface Options {
|
|
||||||
$data?: boolean;
|
|
||||||
allErrors?: boolean;
|
|
||||||
verbose?: boolean;
|
|
||||||
jsonPointers?: boolean;
|
|
||||||
uniqueItems?: boolean;
|
|
||||||
unicode?: boolean;
|
|
||||||
format?: false | string;
|
|
||||||
formats?: object;
|
|
||||||
keywords?: object;
|
|
||||||
unknownFormats?: true | string[] | 'ignore';
|
|
||||||
schemas?: Array<object> | object;
|
|
||||||
schemaId?: '$id' | 'id' | 'auto';
|
|
||||||
missingRefs?: true | 'ignore' | 'fail';
|
|
||||||
extendRefs?: true | 'ignore' | 'fail';
|
|
||||||
loadSchema?: (uri: string, cb?: (err: Error, schema: object) => void) => PromiseLike<object | boolean>;
|
|
||||||
removeAdditional?: boolean | 'all' | 'failing';
|
|
||||||
useDefaults?: boolean | 'empty' | 'shared';
|
|
||||||
coerceTypes?: boolean | 'array';
|
|
||||||
strictDefaults?: boolean | 'log';
|
|
||||||
strictKeywords?: boolean | 'log';
|
|
||||||
strictNumbers?: boolean;
|
|
||||||
async?: boolean | string;
|
|
||||||
transpile?: string | ((code: string) => string);
|
|
||||||
meta?: boolean | object;
|
|
||||||
validateSchema?: boolean | 'log';
|
|
||||||
addUsedSchema?: boolean;
|
|
||||||
inlineRefs?: boolean | number;
|
|
||||||
passContext?: boolean;
|
|
||||||
loopRequired?: number;
|
|
||||||
ownProperties?: boolean;
|
|
||||||
multipleOfPrecision?: boolean | number;
|
|
||||||
errorDataPath?: string,
|
|
||||||
messages?: boolean;
|
|
||||||
sourceCode?: boolean;
|
|
||||||
processCode?: (code: string, schema: object) => string;
|
|
||||||
cache?: object;
|
|
||||||
logger?: CustomLogger | false;
|
|
||||||
nullable?: boolean;
|
|
||||||
serialize?: ((schema: object | boolean) => any) | false;
|
|
||||||
}
|
|
||||||
|
|
||||||
type FormatValidator = string | RegExp | ((data: string) => boolean | PromiseLike<any>);
|
|
||||||
type NumberFormatValidator = ((data: number) => boolean | PromiseLike<any>);
|
|
||||||
|
|
||||||
interface NumberFormatDefinition {
|
|
||||||
type: "number",
|
|
||||||
validate: NumberFormatValidator;
|
|
||||||
compare?: (data1: number, data2: number) => number;
|
|
||||||
async?: boolean;
|
|
||||||
}
|
|
||||||
|
|
||||||
interface StringFormatDefinition {
|
|
||||||
type?: "string",
|
|
||||||
validate: FormatValidator;
|
|
||||||
compare?: (data1: string, data2: string) => number;
|
|
||||||
async?: boolean;
|
|
||||||
}
|
|
||||||
|
|
||||||
type FormatDefinition = NumberFormatDefinition | StringFormatDefinition;
|
|
||||||
|
|
||||||
interface KeywordDefinition {
|
|
||||||
type?: string | Array<string>;
|
|
||||||
async?: boolean;
|
|
||||||
$data?: boolean;
|
|
||||||
errors?: boolean | string;
|
|
||||||
metaSchema?: object;
|
|
||||||
// schema: false makes validate not to expect schema (ValidateFunction)
|
|
||||||
schema?: boolean;
|
|
||||||
statements?: boolean;
|
|
||||||
dependencies?: Array<string>;
|
|
||||||
modifying?: boolean;
|
|
||||||
valid?: boolean;
|
|
||||||
// one and only one of the following properties should be present
|
|
||||||
validate?: SchemaValidateFunction | ValidateFunction;
|
|
||||||
compile?: (schema: any, parentSchema: object, it: CompilationContext) => ValidateFunction;
|
|
||||||
macro?: (schema: any, parentSchema: object, it: CompilationContext) => object | boolean;
|
|
||||||
inline?: (it: CompilationContext, keyword: string, schema: any, parentSchema: object) => string;
|
|
||||||
}
|
|
||||||
|
|
||||||
interface CompilationContext {
|
|
||||||
level: number;
|
|
||||||
dataLevel: number;
|
|
||||||
dataPathArr: string[];
|
|
||||||
schema: any;
|
|
||||||
schemaPath: string;
|
|
||||||
baseId: string;
|
|
||||||
async: boolean;
|
|
||||||
opts: Options;
|
|
||||||
formats: {
|
|
||||||
[index: string]: FormatDefinition | undefined;
|
|
||||||
};
|
|
||||||
keywords: {
|
|
||||||
[index: string]: KeywordDefinition | undefined;
|
|
||||||
};
|
|
||||||
compositeRule: boolean;
|
|
||||||
validate: (schema: object) => boolean;
|
|
||||||
util: {
|
|
||||||
copy(obj: any, target?: any): any;
|
|
||||||
toHash(source: string[]): { [index: string]: true | undefined };
|
|
||||||
equal(obj: any, target: any): boolean;
|
|
||||||
getProperty(str: string): string;
|
|
||||||
schemaHasRules(schema: object, rules: any): string;
|
|
||||||
escapeQuotes(str: string): string;
|
|
||||||
toQuotedString(str: string): string;
|
|
||||||
getData(jsonPointer: string, dataLevel: number, paths: string[]): string;
|
|
||||||
escapeJsonPointer(str: string): string;
|
|
||||||
unescapeJsonPointer(str: string): string;
|
|
||||||
escapeFragment(str: string): string;
|
|
||||||
unescapeFragment(str: string): string;
|
|
||||||
};
|
|
||||||
self: Ajv;
|
|
||||||
}
|
|
||||||
|
|
||||||
interface SchemaValidateFunction {
|
|
||||||
(
|
|
||||||
schema: any,
|
|
||||||
data: any,
|
|
||||||
parentSchema?: object,
|
|
||||||
dataPath?: string,
|
|
||||||
parentData?: object | Array<any>,
|
|
||||||
parentDataProperty?: string | number,
|
|
||||||
rootData?: object | Array<any>
|
|
||||||
): boolean | PromiseLike<any>;
|
|
||||||
errors?: Array<ErrorObject>;
|
|
||||||
}
|
|
||||||
|
|
||||||
interface ErrorsTextOptions {
|
|
||||||
separator?: string;
|
|
||||||
dataVar?: string;
|
|
||||||
}
|
|
||||||
|
|
||||||
interface ErrorObject {
|
|
||||||
keyword: string;
|
|
||||||
dataPath: string;
|
|
||||||
schemaPath: string;
|
|
||||||
params: ErrorParameters;
|
|
||||||
// Added to validation errors of propertyNames keyword schema
|
|
||||||
propertyName?: string;
|
|
||||||
// Excluded if messages set to false.
|
|
||||||
message?: string;
|
|
||||||
// These are added with the `verbose` option.
|
|
||||||
schema?: any;
|
|
||||||
parentSchema?: object;
|
|
||||||
data?: any;
|
|
||||||
}
|
|
||||||
|
|
||||||
type ErrorParameters = RefParams | LimitParams | AdditionalPropertiesParams |
|
|
||||||
DependenciesParams | FormatParams | ComparisonParams |
|
|
||||||
MultipleOfParams | PatternParams | RequiredParams |
|
|
||||||
TypeParams | UniqueItemsParams | CustomParams |
|
|
||||||
PatternRequiredParams | PropertyNamesParams |
|
|
||||||
IfParams | SwitchParams | NoParams | EnumParams;
|
|
||||||
|
|
||||||
interface RefParams {
|
|
||||||
ref: string;
|
|
||||||
}
|
|
||||||
|
|
||||||
interface LimitParams {
|
|
||||||
limit: number;
|
|
||||||
}
|
|
||||||
|
|
||||||
interface AdditionalPropertiesParams {
|
|
||||||
additionalProperty: string;
|
|
||||||
}
|
|
||||||
|
|
||||||
interface DependenciesParams {
|
|
||||||
property: string;
|
|
||||||
missingProperty: string;
|
|
||||||
depsCount: number;
|
|
||||||
deps: string;
|
|
||||||
}
|
|
||||||
|
|
||||||
interface FormatParams {
|
|
||||||
format: string
|
|
||||||
}
|
|
||||||
|
|
||||||
interface ComparisonParams {
|
|
||||||
comparison: string;
|
|
||||||
limit: number | string;
|
|
||||||
exclusive: boolean;
|
|
||||||
}
|
|
||||||
|
|
||||||
interface MultipleOfParams {
|
|
||||||
multipleOf: number;
|
|
||||||
}
|
|
||||||
|
|
||||||
interface PatternParams {
|
|
||||||
pattern: string;
|
|
||||||
}
|
|
||||||
|
|
||||||
interface RequiredParams {
|
|
||||||
missingProperty: string;
|
|
||||||
}
|
|
||||||
|
|
||||||
interface TypeParams {
|
|
||||||
type: string;
|
|
||||||
}
|
|
||||||
|
|
||||||
interface UniqueItemsParams {
|
|
||||||
i: number;
|
|
||||||
j: number;
|
|
||||||
}
|
|
||||||
|
|
||||||
interface CustomParams {
|
|
||||||
keyword: string;
|
|
||||||
}
|
|
||||||
|
|
||||||
interface PatternRequiredParams {
|
|
||||||
missingPattern: string;
|
|
||||||
}
|
|
||||||
|
|
||||||
interface PropertyNamesParams {
|
|
||||||
propertyName: string;
|
|
||||||
}
|
|
||||||
|
|
||||||
interface IfParams {
|
|
||||||
failingKeyword: string;
|
|
||||||
}
|
|
||||||
|
|
||||||
interface SwitchParams {
|
|
||||||
caseIndex: number;
|
|
||||||
}
|
|
||||||
|
|
||||||
interface NoParams { }
|
|
||||||
|
|
||||||
interface EnumParams {
|
|
||||||
allowedValues: Array<any>;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
export = ajv;
|
|
||||||
506
node_modules/ajv/lib/ajv.js
generated
vendored
506
node_modules/ajv/lib/ajv.js
generated
vendored
@@ -1,506 +0,0 @@
|
|||||||
'use strict';
|
|
||||||
|
|
||||||
var compileSchema = require('./compile')
|
|
||||||
, resolve = require('./compile/resolve')
|
|
||||||
, Cache = require('./cache')
|
|
||||||
, SchemaObject = require('./compile/schema_obj')
|
|
||||||
, stableStringify = require('fast-json-stable-stringify')
|
|
||||||
, formats = require('./compile/formats')
|
|
||||||
, rules = require('./compile/rules')
|
|
||||||
, $dataMetaSchema = require('./data')
|
|
||||||
, util = require('./compile/util');
|
|
||||||
|
|
||||||
module.exports = Ajv;
|
|
||||||
|
|
||||||
Ajv.prototype.validate = validate;
|
|
||||||
Ajv.prototype.compile = compile;
|
|
||||||
Ajv.prototype.addSchema = addSchema;
|
|
||||||
Ajv.prototype.addMetaSchema = addMetaSchema;
|
|
||||||
Ajv.prototype.validateSchema = validateSchema;
|
|
||||||
Ajv.prototype.getSchema = getSchema;
|
|
||||||
Ajv.prototype.removeSchema = removeSchema;
|
|
||||||
Ajv.prototype.addFormat = addFormat;
|
|
||||||
Ajv.prototype.errorsText = errorsText;
|
|
||||||
|
|
||||||
Ajv.prototype._addSchema = _addSchema;
|
|
||||||
Ajv.prototype._compile = _compile;
|
|
||||||
|
|
||||||
Ajv.prototype.compileAsync = require('./compile/async');
|
|
||||||
var customKeyword = require('./keyword');
|
|
||||||
Ajv.prototype.addKeyword = customKeyword.add;
|
|
||||||
Ajv.prototype.getKeyword = customKeyword.get;
|
|
||||||
Ajv.prototype.removeKeyword = customKeyword.remove;
|
|
||||||
Ajv.prototype.validateKeyword = customKeyword.validate;
|
|
||||||
|
|
||||||
var errorClasses = require('./compile/error_classes');
|
|
||||||
Ajv.ValidationError = errorClasses.Validation;
|
|
||||||
Ajv.MissingRefError = errorClasses.MissingRef;
|
|
||||||
Ajv.$dataMetaSchema = $dataMetaSchema;
|
|
||||||
|
|
||||||
var META_SCHEMA_ID = 'http://json-schema.org/draft-07/schema';
|
|
||||||
|
|
||||||
var META_IGNORE_OPTIONS = [ 'removeAdditional', 'useDefaults', 'coerceTypes', 'strictDefaults' ];
|
|
||||||
var META_SUPPORT_DATA = ['/properties'];
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Creates validator instance.
|
|
||||||
* Usage: `Ajv(opts)`
|
|
||||||
* @param {Object} opts optional options
|
|
||||||
* @return {Object} ajv instance
|
|
||||||
*/
|
|
||||||
function Ajv(opts) {
|
|
||||||
if (!(this instanceof Ajv)) return new Ajv(opts);
|
|
||||||
opts = this._opts = util.copy(opts) || {};
|
|
||||||
setLogger(this);
|
|
||||||
this._schemas = {};
|
|
||||||
this._refs = {};
|
|
||||||
this._fragments = {};
|
|
||||||
this._formats = formats(opts.format);
|
|
||||||
|
|
||||||
this._cache = opts.cache || new Cache;
|
|
||||||
this._loadingSchemas = {};
|
|
||||||
this._compilations = [];
|
|
||||||
this.RULES = rules();
|
|
||||||
this._getId = chooseGetId(opts);
|
|
||||||
|
|
||||||
opts.loopRequired = opts.loopRequired || Infinity;
|
|
||||||
if (opts.errorDataPath == 'property') opts._errorDataPathProperty = true;
|
|
||||||
if (opts.serialize === undefined) opts.serialize = stableStringify;
|
|
||||||
this._metaOpts = getMetaSchemaOptions(this);
|
|
||||||
|
|
||||||
if (opts.formats) addInitialFormats(this);
|
|
||||||
if (opts.keywords) addInitialKeywords(this);
|
|
||||||
addDefaultMetaSchema(this);
|
|
||||||
if (typeof opts.meta == 'object') this.addMetaSchema(opts.meta);
|
|
||||||
if (opts.nullable) this.addKeyword('nullable', {metaSchema: {type: 'boolean'}});
|
|
||||||
addInitialSchemas(this);
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Validate data using schema
|
|
||||||
* Schema will be compiled and cached (using serialized JSON as key. [fast-json-stable-stringify](https://github.com/epoberezkin/fast-json-stable-stringify) is used to serialize.
|
|
||||||
* @this Ajv
|
|
||||||
* @param {String|Object} schemaKeyRef key, ref or schema object
|
|
||||||
* @param {Any} data to be validated
|
|
||||||
* @return {Boolean} validation result. Errors from the last validation will be available in `ajv.errors` (and also in compiled schema: `schema.errors`).
|
|
||||||
*/
|
|
||||||
function validate(schemaKeyRef, data) {
|
|
||||||
var v;
|
|
||||||
if (typeof schemaKeyRef == 'string') {
|
|
||||||
v = this.getSchema(schemaKeyRef);
|
|
||||||
if (!v) throw new Error('no schema with key or ref "' + schemaKeyRef + '"');
|
|
||||||
} else {
|
|
||||||
var schemaObj = this._addSchema(schemaKeyRef);
|
|
||||||
v = schemaObj.validate || this._compile(schemaObj);
|
|
||||||
}
|
|
||||||
|
|
||||||
var valid = v(data);
|
|
||||||
if (v.$async !== true) this.errors = v.errors;
|
|
||||||
return valid;
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Create validating function for passed schema.
|
|
||||||
* @this Ajv
|
|
||||||
* @param {Object} schema schema object
|
|
||||||
* @param {Boolean} _meta true if schema is a meta-schema. Used internally to compile meta schemas of custom keywords.
|
|
||||||
* @return {Function} validating function
|
|
||||||
*/
|
|
||||||
function compile(schema, _meta) {
|
|
||||||
var schemaObj = this._addSchema(schema, undefined, _meta);
|
|
||||||
return schemaObj.validate || this._compile(schemaObj);
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Adds schema to the instance.
|
|
||||||
* @this Ajv
|
|
||||||
* @param {Object|Array} schema schema or array of schemas. If array is passed, `key` and other parameters will be ignored.
|
|
||||||
* @param {String} key Optional schema key. Can be passed to `validate` method instead of schema object or id/ref. One schema per instance can have empty `id` and `key`.
|
|
||||||
* @param {Boolean} _skipValidation true to skip schema validation. Used internally, option validateSchema should be used instead.
|
|
||||||
* @param {Boolean} _meta true if schema is a meta-schema. Used internally, addMetaSchema should be used instead.
|
|
||||||
* @return {Ajv} this for method chaining
|
|
||||||
*/
|
|
||||||
function addSchema(schema, key, _skipValidation, _meta) {
|
|
||||||
if (Array.isArray(schema)){
|
|
||||||
for (var i=0; i<schema.length; i++) this.addSchema(schema[i], undefined, _skipValidation, _meta);
|
|
||||||
return this;
|
|
||||||
}
|
|
||||||
var id = this._getId(schema);
|
|
||||||
if (id !== undefined && typeof id != 'string')
|
|
||||||
throw new Error('schema id must be string');
|
|
||||||
key = resolve.normalizeId(key || id);
|
|
||||||
checkUnique(this, key);
|
|
||||||
this._schemas[key] = this._addSchema(schema, _skipValidation, _meta, true);
|
|
||||||
return this;
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Add schema that will be used to validate other schemas
|
|
||||||
* options in META_IGNORE_OPTIONS are alway set to false
|
|
||||||
* @this Ajv
|
|
||||||
* @param {Object} schema schema object
|
|
||||||
* @param {String} key optional schema key
|
|
||||||
* @param {Boolean} skipValidation true to skip schema validation, can be used to override validateSchema option for meta-schema
|
|
||||||
* @return {Ajv} this for method chaining
|
|
||||||
*/
|
|
||||||
function addMetaSchema(schema, key, skipValidation) {
|
|
||||||
this.addSchema(schema, key, skipValidation, true);
|
|
||||||
return this;
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Validate schema
|
|
||||||
* @this Ajv
|
|
||||||
* @param {Object} schema schema to validate
|
|
||||||
* @param {Boolean} throwOrLogError pass true to throw (or log) an error if invalid
|
|
||||||
* @return {Boolean} true if schema is valid
|
|
||||||
*/
|
|
||||||
function validateSchema(schema, throwOrLogError) {
|
|
||||||
var $schema = schema.$schema;
|
|
||||||
if ($schema !== undefined && typeof $schema != 'string')
|
|
||||||
throw new Error('$schema must be a string');
|
|
||||||
$schema = $schema || this._opts.defaultMeta || defaultMeta(this);
|
|
||||||
if (!$schema) {
|
|
||||||
this.logger.warn('meta-schema not available');
|
|
||||||
this.errors = null;
|
|
||||||
return true;
|
|
||||||
}
|
|
||||||
var valid = this.validate($schema, schema);
|
|
||||||
if (!valid && throwOrLogError) {
|
|
||||||
var message = 'schema is invalid: ' + this.errorsText();
|
|
||||||
if (this._opts.validateSchema == 'log') this.logger.error(message);
|
|
||||||
else throw new Error(message);
|
|
||||||
}
|
|
||||||
return valid;
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
function defaultMeta(self) {
|
|
||||||
var meta = self._opts.meta;
|
|
||||||
self._opts.defaultMeta = typeof meta == 'object'
|
|
||||||
? self._getId(meta) || meta
|
|
||||||
: self.getSchema(META_SCHEMA_ID)
|
|
||||||
? META_SCHEMA_ID
|
|
||||||
: undefined;
|
|
||||||
return self._opts.defaultMeta;
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Get compiled schema from the instance by `key` or `ref`.
|
|
||||||
* @this Ajv
|
|
||||||
* @param {String} keyRef `key` that was passed to `addSchema` or full schema reference (`schema.id` or resolved id).
|
|
||||||
* @return {Function} schema validating function (with property `schema`).
|
|
||||||
*/
|
|
||||||
function getSchema(keyRef) {
|
|
||||||
var schemaObj = _getSchemaObj(this, keyRef);
|
|
||||||
switch (typeof schemaObj) {
|
|
||||||
case 'object': return schemaObj.validate || this._compile(schemaObj);
|
|
||||||
case 'string': return this.getSchema(schemaObj);
|
|
||||||
case 'undefined': return _getSchemaFragment(this, keyRef);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
function _getSchemaFragment(self, ref) {
|
|
||||||
var res = resolve.schema.call(self, { schema: {} }, ref);
|
|
||||||
if (res) {
|
|
||||||
var schema = res.schema
|
|
||||||
, root = res.root
|
|
||||||
, baseId = res.baseId;
|
|
||||||
var v = compileSchema.call(self, schema, root, undefined, baseId);
|
|
||||||
self._fragments[ref] = new SchemaObject({
|
|
||||||
ref: ref,
|
|
||||||
fragment: true,
|
|
||||||
schema: schema,
|
|
||||||
root: root,
|
|
||||||
baseId: baseId,
|
|
||||||
validate: v
|
|
||||||
});
|
|
||||||
return v;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
function _getSchemaObj(self, keyRef) {
|
|
||||||
keyRef = resolve.normalizeId(keyRef);
|
|
||||||
return self._schemas[keyRef] || self._refs[keyRef] || self._fragments[keyRef];
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Remove cached schema(s).
|
|
||||||
* If no parameter is passed all schemas but meta-schemas are removed.
|
|
||||||
* If RegExp is passed all schemas with key/id matching pattern but meta-schemas are removed.
|
|
||||||
* Even if schema is referenced by other schemas it still can be removed as other schemas have local references.
|
|
||||||
* @this Ajv
|
|
||||||
* @param {String|Object|RegExp} schemaKeyRef key, ref, pattern to match key/ref or schema object
|
|
||||||
* @return {Ajv} this for method chaining
|
|
||||||
*/
|
|
||||||
function removeSchema(schemaKeyRef) {
|
|
||||||
if (schemaKeyRef instanceof RegExp) {
|
|
||||||
_removeAllSchemas(this, this._schemas, schemaKeyRef);
|
|
||||||
_removeAllSchemas(this, this._refs, schemaKeyRef);
|
|
||||||
return this;
|
|
||||||
}
|
|
||||||
switch (typeof schemaKeyRef) {
|
|
||||||
case 'undefined':
|
|
||||||
_removeAllSchemas(this, this._schemas);
|
|
||||||
_removeAllSchemas(this, this._refs);
|
|
||||||
this._cache.clear();
|
|
||||||
return this;
|
|
||||||
case 'string':
|
|
||||||
var schemaObj = _getSchemaObj(this, schemaKeyRef);
|
|
||||||
if (schemaObj) this._cache.del(schemaObj.cacheKey);
|
|
||||||
delete this._schemas[schemaKeyRef];
|
|
||||||
delete this._refs[schemaKeyRef];
|
|
||||||
return this;
|
|
||||||
case 'object':
|
|
||||||
var serialize = this._opts.serialize;
|
|
||||||
var cacheKey = serialize ? serialize(schemaKeyRef) : schemaKeyRef;
|
|
||||||
this._cache.del(cacheKey);
|
|
||||||
var id = this._getId(schemaKeyRef);
|
|
||||||
if (id) {
|
|
||||||
id = resolve.normalizeId(id);
|
|
||||||
delete this._schemas[id];
|
|
||||||
delete this._refs[id];
|
|
||||||
}
|
|
||||||
}
|
|
||||||
return this;
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
function _removeAllSchemas(self, schemas, regex) {
|
|
||||||
for (var keyRef in schemas) {
|
|
||||||
var schemaObj = schemas[keyRef];
|
|
||||||
if (!schemaObj.meta && (!regex || regex.test(keyRef))) {
|
|
||||||
self._cache.del(schemaObj.cacheKey);
|
|
||||||
delete schemas[keyRef];
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
/* @this Ajv */
|
|
||||||
function _addSchema(schema, skipValidation, meta, shouldAddSchema) {
|
|
||||||
if (typeof schema != 'object' && typeof schema != 'boolean')
|
|
||||||
throw new Error('schema should be object or boolean');
|
|
||||||
var serialize = this._opts.serialize;
|
|
||||||
var cacheKey = serialize ? serialize(schema) : schema;
|
|
||||||
var cached = this._cache.get(cacheKey);
|
|
||||||
if (cached) return cached;
|
|
||||||
|
|
||||||
shouldAddSchema = shouldAddSchema || this._opts.addUsedSchema !== false;
|
|
||||||
|
|
||||||
var id = resolve.normalizeId(this._getId(schema));
|
|
||||||
if (id && shouldAddSchema) checkUnique(this, id);
|
|
||||||
|
|
||||||
var willValidate = this._opts.validateSchema !== false && !skipValidation;
|
|
||||||
var recursiveMeta;
|
|
||||||
if (willValidate && !(recursiveMeta = id && id == resolve.normalizeId(schema.$schema)))
|
|
||||||
this.validateSchema(schema, true);
|
|
||||||
|
|
||||||
var localRefs = resolve.ids.call(this, schema);
|
|
||||||
|
|
||||||
var schemaObj = new SchemaObject({
|
|
||||||
id: id,
|
|
||||||
schema: schema,
|
|
||||||
localRefs: localRefs,
|
|
||||||
cacheKey: cacheKey,
|
|
||||||
meta: meta
|
|
||||||
});
|
|
||||||
|
|
||||||
if (id[0] != '#' && shouldAddSchema) this._refs[id] = schemaObj;
|
|
||||||
this._cache.put(cacheKey, schemaObj);
|
|
||||||
|
|
||||||
if (willValidate && recursiveMeta) this.validateSchema(schema, true);
|
|
||||||
|
|
||||||
return schemaObj;
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
/* @this Ajv */
|
|
||||||
function _compile(schemaObj, root) {
|
|
||||||
if (schemaObj.compiling) {
|
|
||||||
schemaObj.validate = callValidate;
|
|
||||||
callValidate.schema = schemaObj.schema;
|
|
||||||
callValidate.errors = null;
|
|
||||||
callValidate.root = root ? root : callValidate;
|
|
||||||
if (schemaObj.schema.$async === true)
|
|
||||||
callValidate.$async = true;
|
|
||||||
return callValidate;
|
|
||||||
}
|
|
||||||
schemaObj.compiling = true;
|
|
||||||
|
|
||||||
var currentOpts;
|
|
||||||
if (schemaObj.meta) {
|
|
||||||
currentOpts = this._opts;
|
|
||||||
this._opts = this._metaOpts;
|
|
||||||
}
|
|
||||||
|
|
||||||
var v;
|
|
||||||
try { v = compileSchema.call(this, schemaObj.schema, root, schemaObj.localRefs); }
|
|
||||||
catch(e) {
|
|
||||||
delete schemaObj.validate;
|
|
||||||
throw e;
|
|
||||||
}
|
|
||||||
finally {
|
|
||||||
schemaObj.compiling = false;
|
|
||||||
if (schemaObj.meta) this._opts = currentOpts;
|
|
||||||
}
|
|
||||||
|
|
||||||
schemaObj.validate = v;
|
|
||||||
schemaObj.refs = v.refs;
|
|
||||||
schemaObj.refVal = v.refVal;
|
|
||||||
schemaObj.root = v.root;
|
|
||||||
return v;
|
|
||||||
|
|
||||||
|
|
||||||
/* @this {*} - custom context, see passContext option */
|
|
||||||
function callValidate() {
|
|
||||||
/* jshint validthis: true */
|
|
||||||
var _validate = schemaObj.validate;
|
|
||||||
var result = _validate.apply(this, arguments);
|
|
||||||
callValidate.errors = _validate.errors;
|
|
||||||
return result;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
function chooseGetId(opts) {
|
|
||||||
switch (opts.schemaId) {
|
|
||||||
case 'auto': return _get$IdOrId;
|
|
||||||
case 'id': return _getId;
|
|
||||||
default: return _get$Id;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
/* @this Ajv */
|
|
||||||
function _getId(schema) {
|
|
||||||
if (schema.$id) this.logger.warn('schema $id ignored', schema.$id);
|
|
||||||
return schema.id;
|
|
||||||
}
|
|
||||||
|
|
||||||
/* @this Ajv */
|
|
||||||
function _get$Id(schema) {
|
|
||||||
if (schema.id) this.logger.warn('schema id ignored', schema.id);
|
|
||||||
return schema.$id;
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
function _get$IdOrId(schema) {
|
|
||||||
if (schema.$id && schema.id && schema.$id != schema.id)
|
|
||||||
throw new Error('schema $id is different from id');
|
|
||||||
return schema.$id || schema.id;
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Convert array of error message objects to string
|
|
||||||
* @this Ajv
|
|
||||||
* @param {Array<Object>} errors optional array of validation errors, if not passed errors from the instance are used.
|
|
||||||
* @param {Object} options optional options with properties `separator` and `dataVar`.
|
|
||||||
* @return {String} human readable string with all errors descriptions
|
|
||||||
*/
|
|
||||||
function errorsText(errors, options) {
|
|
||||||
errors = errors || this.errors;
|
|
||||||
if (!errors) return 'No errors';
|
|
||||||
options = options || {};
|
|
||||||
var separator = options.separator === undefined ? ', ' : options.separator;
|
|
||||||
var dataVar = options.dataVar === undefined ? 'data' : options.dataVar;
|
|
||||||
|
|
||||||
var text = '';
|
|
||||||
for (var i=0; i<errors.length; i++) {
|
|
||||||
var e = errors[i];
|
|
||||||
if (e) text += dataVar + e.dataPath + ' ' + e.message + separator;
|
|
||||||
}
|
|
||||||
return text.slice(0, -separator.length);
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Add custom format
|
|
||||||
* @this Ajv
|
|
||||||
* @param {String} name format name
|
|
||||||
* @param {String|RegExp|Function} format string is converted to RegExp; function should return boolean (true when valid)
|
|
||||||
* @return {Ajv} this for method chaining
|
|
||||||
*/
|
|
||||||
function addFormat(name, format) {
|
|
||||||
if (typeof format == 'string') format = new RegExp(format);
|
|
||||||
this._formats[name] = format;
|
|
||||||
return this;
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
function addDefaultMetaSchema(self) {
|
|
||||||
var $dataSchema;
|
|
||||||
if (self._opts.$data) {
|
|
||||||
$dataSchema = require('./refs/data.json');
|
|
||||||
self.addMetaSchema($dataSchema, $dataSchema.$id, true);
|
|
||||||
}
|
|
||||||
if (self._opts.meta === false) return;
|
|
||||||
var metaSchema = require('./refs/json-schema-draft-07.json');
|
|
||||||
if (self._opts.$data) metaSchema = $dataMetaSchema(metaSchema, META_SUPPORT_DATA);
|
|
||||||
self.addMetaSchema(metaSchema, META_SCHEMA_ID, true);
|
|
||||||
self._refs['http://json-schema.org/schema'] = META_SCHEMA_ID;
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
function addInitialSchemas(self) {
|
|
||||||
var optsSchemas = self._opts.schemas;
|
|
||||||
if (!optsSchemas) return;
|
|
||||||
if (Array.isArray(optsSchemas)) self.addSchema(optsSchemas);
|
|
||||||
else for (var key in optsSchemas) self.addSchema(optsSchemas[key], key);
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
function addInitialFormats(self) {
|
|
||||||
for (var name in self._opts.formats) {
|
|
||||||
var format = self._opts.formats[name];
|
|
||||||
self.addFormat(name, format);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
function addInitialKeywords(self) {
|
|
||||||
for (var name in self._opts.keywords) {
|
|
||||||
var keyword = self._opts.keywords[name];
|
|
||||||
self.addKeyword(name, keyword);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
function checkUnique(self, id) {
|
|
||||||
if (self._schemas[id] || self._refs[id])
|
|
||||||
throw new Error('schema with key or id "' + id + '" already exists');
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
function getMetaSchemaOptions(self) {
|
|
||||||
var metaOpts = util.copy(self._opts);
|
|
||||||
for (var i=0; i<META_IGNORE_OPTIONS.length; i++)
|
|
||||||
delete metaOpts[META_IGNORE_OPTIONS[i]];
|
|
||||||
return metaOpts;
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
function setLogger(self) {
|
|
||||||
var logger = self._opts.logger;
|
|
||||||
if (logger === false) {
|
|
||||||
self.logger = {log: noop, warn: noop, error: noop};
|
|
||||||
} else {
|
|
||||||
if (logger === undefined) logger = console;
|
|
||||||
if (!(typeof logger == 'object' && logger.log && logger.warn && logger.error))
|
|
||||||
throw new Error('logger must implement log, warn and error methods');
|
|
||||||
self.logger = logger;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
function noop() {}
|
|
||||||
26
node_modules/ajv/lib/cache.js
generated
vendored
26
node_modules/ajv/lib/cache.js
generated
vendored
@@ -1,26 +0,0 @@
|
|||||||
'use strict';
|
|
||||||
|
|
||||||
|
|
||||||
var Cache = module.exports = function Cache() {
|
|
||||||
this._cache = {};
|
|
||||||
};
|
|
||||||
|
|
||||||
|
|
||||||
Cache.prototype.put = function Cache_put(key, value) {
|
|
||||||
this._cache[key] = value;
|
|
||||||
};
|
|
||||||
|
|
||||||
|
|
||||||
Cache.prototype.get = function Cache_get(key) {
|
|
||||||
return this._cache[key];
|
|
||||||
};
|
|
||||||
|
|
||||||
|
|
||||||
Cache.prototype.del = function Cache_del(key) {
|
|
||||||
delete this._cache[key];
|
|
||||||
};
|
|
||||||
|
|
||||||
|
|
||||||
Cache.prototype.clear = function Cache_clear() {
|
|
||||||
this._cache = {};
|
|
||||||
};
|
|
||||||
90
node_modules/ajv/lib/compile/async.js
generated
vendored
90
node_modules/ajv/lib/compile/async.js
generated
vendored
@@ -1,90 +0,0 @@
|
|||||||
'use strict';
|
|
||||||
|
|
||||||
var MissingRefError = require('./error_classes').MissingRef;
|
|
||||||
|
|
||||||
module.exports = compileAsync;
|
|
||||||
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Creates validating function for passed schema with asynchronous loading of missing schemas.
|
|
||||||
* `loadSchema` option should be a function that accepts schema uri and returns promise that resolves with the schema.
|
|
||||||
* @this Ajv
|
|
||||||
* @param {Object} schema schema object
|
|
||||||
* @param {Boolean} meta optional true to compile meta-schema; this parameter can be skipped
|
|
||||||
* @param {Function} callback an optional node-style callback, it is called with 2 parameters: error (or null) and validating function.
|
|
||||||
* @return {Promise} promise that resolves with a validating function.
|
|
||||||
*/
|
|
||||||
function compileAsync(schema, meta, callback) {
|
|
||||||
/* eslint no-shadow: 0 */
|
|
||||||
/* global Promise */
|
|
||||||
/* jshint validthis: true */
|
|
||||||
var self = this;
|
|
||||||
if (typeof this._opts.loadSchema != 'function')
|
|
||||||
throw new Error('options.loadSchema should be a function');
|
|
||||||
|
|
||||||
if (typeof meta == 'function') {
|
|
||||||
callback = meta;
|
|
||||||
meta = undefined;
|
|
||||||
}
|
|
||||||
|
|
||||||
var p = loadMetaSchemaOf(schema).then(function () {
|
|
||||||
var schemaObj = self._addSchema(schema, undefined, meta);
|
|
||||||
return schemaObj.validate || _compileAsync(schemaObj);
|
|
||||||
});
|
|
||||||
|
|
||||||
if (callback) {
|
|
||||||
p.then(
|
|
||||||
function(v) { callback(null, v); },
|
|
||||||
callback
|
|
||||||
);
|
|
||||||
}
|
|
||||||
|
|
||||||
return p;
|
|
||||||
|
|
||||||
|
|
||||||
function loadMetaSchemaOf(sch) {
|
|
||||||
var $schema = sch.$schema;
|
|
||||||
return $schema && !self.getSchema($schema)
|
|
||||||
? compileAsync.call(self, { $ref: $schema }, true)
|
|
||||||
: Promise.resolve();
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
function _compileAsync(schemaObj) {
|
|
||||||
try { return self._compile(schemaObj); }
|
|
||||||
catch(e) {
|
|
||||||
if (e instanceof MissingRefError) return loadMissingSchema(e);
|
|
||||||
throw e;
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
function loadMissingSchema(e) {
|
|
||||||
var ref = e.missingSchema;
|
|
||||||
if (added(ref)) throw new Error('Schema ' + ref + ' is loaded but ' + e.missingRef + ' cannot be resolved');
|
|
||||||
|
|
||||||
var schemaPromise = self._loadingSchemas[ref];
|
|
||||||
if (!schemaPromise) {
|
|
||||||
schemaPromise = self._loadingSchemas[ref] = self._opts.loadSchema(ref);
|
|
||||||
schemaPromise.then(removePromise, removePromise);
|
|
||||||
}
|
|
||||||
|
|
||||||
return schemaPromise.then(function (sch) {
|
|
||||||
if (!added(ref)) {
|
|
||||||
return loadMetaSchemaOf(sch).then(function () {
|
|
||||||
if (!added(ref)) self.addSchema(sch, ref, undefined, meta);
|
|
||||||
});
|
|
||||||
}
|
|
||||||
}).then(function() {
|
|
||||||
return _compileAsync(schemaObj);
|
|
||||||
});
|
|
||||||
|
|
||||||
function removePromise() {
|
|
||||||
delete self._loadingSchemas[ref];
|
|
||||||
}
|
|
||||||
|
|
||||||
function added(ref) {
|
|
||||||
return self._refs[ref] || self._schemas[ref];
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
5
node_modules/ajv/lib/compile/equal.js
generated
vendored
5
node_modules/ajv/lib/compile/equal.js
generated
vendored
@@ -1,5 +0,0 @@
|
|||||||
'use strict';
|
|
||||||
|
|
||||||
// do NOT remove this file - it would break pre-compiled schemas
|
|
||||||
// https://github.com/ajv-validator/ajv/issues/889
|
|
||||||
module.exports = require('fast-deep-equal');
|
|
||||||
34
node_modules/ajv/lib/compile/error_classes.js
generated
vendored
34
node_modules/ajv/lib/compile/error_classes.js
generated
vendored
@@ -1,34 +0,0 @@
|
|||||||
'use strict';
|
|
||||||
|
|
||||||
var resolve = require('./resolve');
|
|
||||||
|
|
||||||
module.exports = {
|
|
||||||
Validation: errorSubclass(ValidationError),
|
|
||||||
MissingRef: errorSubclass(MissingRefError)
|
|
||||||
};
|
|
||||||
|
|
||||||
|
|
||||||
function ValidationError(errors) {
|
|
||||||
this.message = 'validation failed';
|
|
||||||
this.errors = errors;
|
|
||||||
this.ajv = this.validation = true;
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
MissingRefError.message = function (baseId, ref) {
|
|
||||||
return 'can\'t resolve reference ' + ref + ' from id ' + baseId;
|
|
||||||
};
|
|
||||||
|
|
||||||
|
|
||||||
function MissingRefError(baseId, ref, message) {
|
|
||||||
this.message = message || MissingRefError.message(baseId, ref);
|
|
||||||
this.missingRef = resolve.url(baseId, ref);
|
|
||||||
this.missingSchema = resolve.normalizeId(resolve.fullPath(this.missingRef));
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
function errorSubclass(Subclass) {
|
|
||||||
Subclass.prototype = Object.create(Error.prototype);
|
|
||||||
Subclass.prototype.constructor = Subclass;
|
|
||||||
return Subclass;
|
|
||||||
}
|
|
||||||
142
node_modules/ajv/lib/compile/formats.js
generated
vendored
142
node_modules/ajv/lib/compile/formats.js
generated
vendored
@@ -1,142 +0,0 @@
|
|||||||
'use strict';
|
|
||||||
|
|
||||||
var util = require('./util');
|
|
||||||
|
|
||||||
var DATE = /^(\d\d\d\d)-(\d\d)-(\d\d)$/;
|
|
||||||
var DAYS = [0,31,28,31,30,31,30,31,31,30,31,30,31];
|
|
||||||
var TIME = /^(\d\d):(\d\d):(\d\d)(\.\d+)?(z|[+-]\d\d(?::?\d\d)?)?$/i;
|
|
||||||
var HOSTNAME = /^(?=.{1,253}\.?$)[a-z0-9](?:[a-z0-9-]{0,61}[a-z0-9])?(?:\.[a-z0-9](?:[-0-9a-z]{0,61}[0-9a-z])?)*\.?$/i;
|
|
||||||
var URI = /^(?:[a-z][a-z0-9+\-.]*:)(?:\/?\/(?:(?:[a-z0-9\-._~!$&'()*+,;=:]|%[0-9a-f]{2})*@)?(?:\[(?:(?:(?:(?:[0-9a-f]{1,4}:){6}|::(?:[0-9a-f]{1,4}:){5}|(?:[0-9a-f]{1,4})?::(?:[0-9a-f]{1,4}:){4}|(?:(?:[0-9a-f]{1,4}:){0,1}[0-9a-f]{1,4})?::(?:[0-9a-f]{1,4}:){3}|(?:(?:[0-9a-f]{1,4}:){0,2}[0-9a-f]{1,4})?::(?:[0-9a-f]{1,4}:){2}|(?:(?:[0-9a-f]{1,4}:){0,3}[0-9a-f]{1,4})?::[0-9a-f]{1,4}:|(?:(?:[0-9a-f]{1,4}:){0,4}[0-9a-f]{1,4})?::)(?:[0-9a-f]{1,4}:[0-9a-f]{1,4}|(?:(?:25[0-5]|2[0-4]\d|[01]?\d\d?)\.){3}(?:25[0-5]|2[0-4]\d|[01]?\d\d?))|(?:(?:[0-9a-f]{1,4}:){0,5}[0-9a-f]{1,4})?::[0-9a-f]{1,4}|(?:(?:[0-9a-f]{1,4}:){0,6}[0-9a-f]{1,4})?::)|[Vv][0-9a-f]+\.[a-z0-9\-._~!$&'()*+,;=:]+)\]|(?:(?:25[0-5]|2[0-4]\d|[01]?\d\d?)\.){3}(?:25[0-5]|2[0-4]\d|[01]?\d\d?)|(?:[a-z0-9\-._~!$&'()*+,;=]|%[0-9a-f]{2})*)(?::\d*)?(?:\/(?:[a-z0-9\-._~!$&'()*+,;=:@]|%[0-9a-f]{2})*)*|\/(?:(?:[a-z0-9\-._~!$&'()*+,;=:@]|%[0-9a-f]{2})+(?:\/(?:[a-z0-9\-._~!$&'()*+,;=:@]|%[0-9a-f]{2})*)*)?|(?:[a-z0-9\-._~!$&'()*+,;=:@]|%[0-9a-f]{2})+(?:\/(?:[a-z0-9\-._~!$&'()*+,;=:@]|%[0-9a-f]{2})*)*)(?:\?(?:[a-z0-9\-._~!$&'()*+,;=:@/?]|%[0-9a-f]{2})*)?(?:#(?:[a-z0-9\-._~!$&'()*+,;=:@/?]|%[0-9a-f]{2})*)?$/i;
|
|
||||||
var URIREF = /^(?:[a-z][a-z0-9+\-.]*:)?(?:\/?\/(?:(?:[a-z0-9\-._~!$&'()*+,;=:]|%[0-9a-f]{2})*@)?(?:\[(?:(?:(?:(?:[0-9a-f]{1,4}:){6}|::(?:[0-9a-f]{1,4}:){5}|(?:[0-9a-f]{1,4})?::(?:[0-9a-f]{1,4}:){4}|(?:(?:[0-9a-f]{1,4}:){0,1}[0-9a-f]{1,4})?::(?:[0-9a-f]{1,4}:){3}|(?:(?:[0-9a-f]{1,4}:){0,2}[0-9a-f]{1,4})?::(?:[0-9a-f]{1,4}:){2}|(?:(?:[0-9a-f]{1,4}:){0,3}[0-9a-f]{1,4})?::[0-9a-f]{1,4}:|(?:(?:[0-9a-f]{1,4}:){0,4}[0-9a-f]{1,4})?::)(?:[0-9a-f]{1,4}:[0-9a-f]{1,4}|(?:(?:25[0-5]|2[0-4]\d|[01]?\d\d?)\.){3}(?:25[0-5]|2[0-4]\d|[01]?\d\d?))|(?:(?:[0-9a-f]{1,4}:){0,5}[0-9a-f]{1,4})?::[0-9a-f]{1,4}|(?:(?:[0-9a-f]{1,4}:){0,6}[0-9a-f]{1,4})?::)|[Vv][0-9a-f]+\.[a-z0-9\-._~!$&'()*+,;=:]+)\]|(?:(?:25[0-5]|2[0-4]\d|[01]?\d\d?)\.){3}(?:25[0-5]|2[0-4]\d|[01]?\d\d?)|(?:[a-z0-9\-._~!$&'"()*+,;=]|%[0-9a-f]{2})*)(?::\d*)?(?:\/(?:[a-z0-9\-._~!$&'"()*+,;=:@]|%[0-9a-f]{2})*)*|\/(?:(?:[a-z0-9\-._~!$&'"()*+,;=:@]|%[0-9a-f]{2})+(?:\/(?:[a-z0-9\-._~!$&'"()*+,;=:@]|%[0-9a-f]{2})*)*)?|(?:[a-z0-9\-._~!$&'"()*+,;=:@]|%[0-9a-f]{2})+(?:\/(?:[a-z0-9\-._~!$&'"()*+,;=:@]|%[0-9a-f]{2})*)*)?(?:\?(?:[a-z0-9\-._~!$&'"()*+,;=:@/?]|%[0-9a-f]{2})*)?(?:#(?:[a-z0-9\-._~!$&'"()*+,;=:@/?]|%[0-9a-f]{2})*)?$/i;
|
|
||||||
// uri-template: https://tools.ietf.org/html/rfc6570
|
|
||||||
var URITEMPLATE = /^(?:(?:[^\x00-\x20"'<>%\\^`{|}]|%[0-9a-f]{2})|\{[+#./;?&=,!@|]?(?:[a-z0-9_]|%[0-9a-f]{2})+(?::[1-9][0-9]{0,3}|\*)?(?:,(?:[a-z0-9_]|%[0-9a-f]{2})+(?::[1-9][0-9]{0,3}|\*)?)*\})*$/i;
|
|
||||||
// For the source: https://gist.github.com/dperini/729294
|
|
||||||
// For test cases: https://mathiasbynens.be/demo/url-regex
|
|
||||||
// @todo Delete current URL in favour of the commented out URL rule when this issue is fixed https://github.com/eslint/eslint/issues/7983.
|
|
||||||
// var URL = /^(?:(?:https?|ftp):\/\/)(?:\S+(?::\S*)?@)?(?:(?!10(?:\.\d{1,3}){3})(?!127(?:\.\d{1,3}){3})(?!169\.254(?:\.\d{1,3}){2})(?!192\.168(?:\.\d{1,3}){2})(?!172\.(?:1[6-9]|2\d|3[0-1])(?:\.\d{1,3}){2})(?:[1-9]\d?|1\d\d|2[01]\d|22[0-3])(?:\.(?:1?\d{1,2}|2[0-4]\d|25[0-5])){2}(?:\.(?:[1-9]\d?|1\d\d|2[0-4]\d|25[0-4]))|(?:(?:[a-z\u{00a1}-\u{ffff}0-9]+-)*[a-z\u{00a1}-\u{ffff}0-9]+)(?:\.(?:[a-z\u{00a1}-\u{ffff}0-9]+-)*[a-z\u{00a1}-\u{ffff}0-9]+)*(?:\.(?:[a-z\u{00a1}-\u{ffff}]{2,})))(?::\d{2,5})?(?:\/[^\s]*)?$/iu;
|
|
||||||
var URL = /^(?:(?:http[s\u017F]?|ftp):\/\/)(?:(?:[\0-\x08\x0E-\x1F!-\x9F\xA1-\u167F\u1681-\u1FFF\u200B-\u2027\u202A-\u202E\u2030-\u205E\u2060-\u2FFF\u3001-\uD7FF\uE000-\uFEFE\uFF00-\uFFFF]|[\uD800-\uDBFF][\uDC00-\uDFFF]|[\uD800-\uDBFF](?![\uDC00-\uDFFF])|(?:[^\uD800-\uDBFF]|^)[\uDC00-\uDFFF])+(?::(?:[\0-\x08\x0E-\x1F!-\x9F\xA1-\u167F\u1681-\u1FFF\u200B-\u2027\u202A-\u202E\u2030-\u205E\u2060-\u2FFF\u3001-\uD7FF\uE000-\uFEFE\uFF00-\uFFFF]|[\uD800-\uDBFF][\uDC00-\uDFFF]|[\uD800-\uDBFF](?![\uDC00-\uDFFF])|(?:[^\uD800-\uDBFF]|^)[\uDC00-\uDFFF])*)?@)?(?:(?!10(?:\.[0-9]{1,3}){3})(?!127(?:\.[0-9]{1,3}){3})(?!169\.254(?:\.[0-9]{1,3}){2})(?!192\.168(?:\.[0-9]{1,3}){2})(?!172\.(?:1[6-9]|2[0-9]|3[01])(?:\.[0-9]{1,3}){2})(?:[1-9][0-9]?|1[0-9][0-9]|2[01][0-9]|22[0-3])(?:\.(?:1?[0-9]{1,2}|2[0-4][0-9]|25[0-5])){2}(?:\.(?:[1-9][0-9]?|1[0-9][0-9]|2[0-4][0-9]|25[0-4]))|(?:(?:(?:[0-9a-z\xA1-\uD7FF\uE000-\uFFFF]|[\uD800-\uDBFF](?![\uDC00-\uDFFF])|(?:[^\uD800-\uDBFF]|^)[\uDC00-\uDFFF])+-)*(?:[0-9a-z\xA1-\uD7FF\uE000-\uFFFF]|[\uD800-\uDBFF](?![\uDC00-\uDFFF])|(?:[^\uD800-\uDBFF]|^)[\uDC00-\uDFFF])+)(?:\.(?:(?:[0-9a-z\xA1-\uD7FF\uE000-\uFFFF]|[\uD800-\uDBFF](?![\uDC00-\uDFFF])|(?:[^\uD800-\uDBFF]|^)[\uDC00-\uDFFF])+-)*(?:[0-9a-z\xA1-\uD7FF\uE000-\uFFFF]|[\uD800-\uDBFF](?![\uDC00-\uDFFF])|(?:[^\uD800-\uDBFF]|^)[\uDC00-\uDFFF])+)*(?:\.(?:(?:[a-z\xA1-\uD7FF\uE000-\uFFFF]|[\uD800-\uDBFF](?![\uDC00-\uDFFF])|(?:[^\uD800-\uDBFF]|^)[\uDC00-\uDFFF]){2,})))(?::[0-9]{2,5})?(?:\/(?:[\0-\x08\x0E-\x1F!-\x9F\xA1-\u167F\u1681-\u1FFF\u200B-\u2027\u202A-\u202E\u2030-\u205E\u2060-\u2FFF\u3001-\uD7FF\uE000-\uFEFE\uFF00-\uFFFF]|[\uD800-\uDBFF][\uDC00-\uDFFF]|[\uD800-\uDBFF](?![\uDC00-\uDFFF])|(?:[^\uD800-\uDBFF]|^)[\uDC00-\uDFFF])*)?$/i;
|
|
||||||
var UUID = /^(?:urn:uuid:)?[0-9a-f]{8}-(?:[0-9a-f]{4}-){3}[0-9a-f]{12}$/i;
|
|
||||||
var JSON_POINTER = /^(?:\/(?:[^~/]|~0|~1)*)*$/;
|
|
||||||
var JSON_POINTER_URI_FRAGMENT = /^#(?:\/(?:[a-z0-9_\-.!$&'()*+,;:=@]|%[0-9a-f]{2}|~0|~1)*)*$/i;
|
|
||||||
var RELATIVE_JSON_POINTER = /^(?:0|[1-9][0-9]*)(?:#|(?:\/(?:[^~/]|~0|~1)*)*)$/;
|
|
||||||
|
|
||||||
|
|
||||||
module.exports = formats;
|
|
||||||
|
|
||||||
function formats(mode) {
|
|
||||||
mode = mode == 'full' ? 'full' : 'fast';
|
|
||||||
return util.copy(formats[mode]);
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
formats.fast = {
|
|
||||||
// date: http://tools.ietf.org/html/rfc3339#section-5.6
|
|
||||||
date: /^\d\d\d\d-[0-1]\d-[0-3]\d$/,
|
|
||||||
// date-time: http://tools.ietf.org/html/rfc3339#section-5.6
|
|
||||||
time: /^(?:[0-2]\d:[0-5]\d:[0-5]\d|23:59:60)(?:\.\d+)?(?:z|[+-]\d\d(?::?\d\d)?)?$/i,
|
|
||||||
'date-time': /^\d\d\d\d-[0-1]\d-[0-3]\d[t\s](?:[0-2]\d:[0-5]\d:[0-5]\d|23:59:60)(?:\.\d+)?(?:z|[+-]\d\d(?::?\d\d)?)$/i,
|
|
||||||
// uri: https://github.com/mafintosh/is-my-json-valid/blob/master/formats.js
|
|
||||||
uri: /^(?:[a-z][a-z0-9+\-.]*:)(?:\/?\/)?[^\s]*$/i,
|
|
||||||
'uri-reference': /^(?:(?:[a-z][a-z0-9+\-.]*:)?\/?\/)?(?:[^\\\s#][^\s#]*)?(?:#[^\\\s]*)?$/i,
|
|
||||||
'uri-template': URITEMPLATE,
|
|
||||||
url: URL,
|
|
||||||
// email (sources from jsen validator):
|
|
||||||
// http://stackoverflow.com/questions/201323/using-a-regular-expression-to-validate-an-email-address#answer-8829363
|
|
||||||
// http://www.w3.org/TR/html5/forms.html#valid-e-mail-address (search for 'willful violation')
|
|
||||||
email: /^[a-z0-9.!#$%&'*+/=?^_`{|}~-]+@[a-z0-9](?:[a-z0-9-]{0,61}[a-z0-9])?(?:\.[a-z0-9](?:[a-z0-9-]{0,61}[a-z0-9])?)*$/i,
|
|
||||||
hostname: HOSTNAME,
|
|
||||||
// optimized https://www.safaribooksonline.com/library/view/regular-expressions-cookbook/9780596802837/ch07s16.html
|
|
||||||
ipv4: /^(?:(?:25[0-5]|2[0-4]\d|[01]?\d\d?)\.){3}(?:25[0-5]|2[0-4]\d|[01]?\d\d?)$/,
|
|
||||||
// optimized http://stackoverflow.com/questions/53497/regular-expression-that-matches-valid-ipv6-addresses
|
|
||||||
ipv6: /^\s*(?:(?:(?:[0-9a-f]{1,4}:){7}(?:[0-9a-f]{1,4}|:))|(?:(?:[0-9a-f]{1,4}:){6}(?::[0-9a-f]{1,4}|(?:(?:25[0-5]|2[0-4]\d|1\d\d|[1-9]?\d)(?:\.(?:25[0-5]|2[0-4]\d|1\d\d|[1-9]?\d)){3})|:))|(?:(?:[0-9a-f]{1,4}:){5}(?:(?:(?::[0-9a-f]{1,4}){1,2})|:(?:(?:25[0-5]|2[0-4]\d|1\d\d|[1-9]?\d)(?:\.(?:25[0-5]|2[0-4]\d|1\d\d|[1-9]?\d)){3})|:))|(?:(?:[0-9a-f]{1,4}:){4}(?:(?:(?::[0-9a-f]{1,4}){1,3})|(?:(?::[0-9a-f]{1,4})?:(?:(?:25[0-5]|2[0-4]\d|1\d\d|[1-9]?\d)(?:\.(?:25[0-5]|2[0-4]\d|1\d\d|[1-9]?\d)){3}))|:))|(?:(?:[0-9a-f]{1,4}:){3}(?:(?:(?::[0-9a-f]{1,4}){1,4})|(?:(?::[0-9a-f]{1,4}){0,2}:(?:(?:25[0-5]|2[0-4]\d|1\d\d|[1-9]?\d)(?:\.(?:25[0-5]|2[0-4]\d|1\d\d|[1-9]?\d)){3}))|:))|(?:(?:[0-9a-f]{1,4}:){2}(?:(?:(?::[0-9a-f]{1,4}){1,5})|(?:(?::[0-9a-f]{1,4}){0,3}:(?:(?:25[0-5]|2[0-4]\d|1\d\d|[1-9]?\d)(?:\.(?:25[0-5]|2[0-4]\d|1\d\d|[1-9]?\d)){3}))|:))|(?:(?:[0-9a-f]{1,4}:){1}(?:(?:(?::[0-9a-f]{1,4}){1,6})|(?:(?::[0-9a-f]{1,4}){0,4}:(?:(?:25[0-5]|2[0-4]\d|1\d\d|[1-9]?\d)(?:\.(?:25[0-5]|2[0-4]\d|1\d\d|[1-9]?\d)){3}))|:))|(?::(?:(?:(?::[0-9a-f]{1,4}){1,7})|(?:(?::[0-9a-f]{1,4}){0,5}:(?:(?:25[0-5]|2[0-4]\d|1\d\d|[1-9]?\d)(?:\.(?:25[0-5]|2[0-4]\d|1\d\d|[1-9]?\d)){3}))|:)))(?:%.+)?\s*$/i,
|
|
||||||
regex: regex,
|
|
||||||
// uuid: http://tools.ietf.org/html/rfc4122
|
|
||||||
uuid: UUID,
|
|
||||||
// JSON-pointer: https://tools.ietf.org/html/rfc6901
|
|
||||||
// uri fragment: https://tools.ietf.org/html/rfc3986#appendix-A
|
|
||||||
'json-pointer': JSON_POINTER,
|
|
||||||
'json-pointer-uri-fragment': JSON_POINTER_URI_FRAGMENT,
|
|
||||||
// relative JSON-pointer: http://tools.ietf.org/html/draft-luff-relative-json-pointer-00
|
|
||||||
'relative-json-pointer': RELATIVE_JSON_POINTER
|
|
||||||
};
|
|
||||||
|
|
||||||
|
|
||||||
formats.full = {
|
|
||||||
date: date,
|
|
||||||
time: time,
|
|
||||||
'date-time': date_time,
|
|
||||||
uri: uri,
|
|
||||||
'uri-reference': URIREF,
|
|
||||||
'uri-template': URITEMPLATE,
|
|
||||||
url: URL,
|
|
||||||
email: /^[a-z0-9!#$%&'*+/=?^_`{|}~-]+(?:\.[a-z0-9!#$%&'*+/=?^_`{|}~-]+)*@(?:[a-z0-9](?:[a-z0-9-]*[a-z0-9])?\.)+[a-z0-9](?:[a-z0-9-]*[a-z0-9])?$/i,
|
|
||||||
hostname: HOSTNAME,
|
|
||||||
ipv4: /^(?:(?:25[0-5]|2[0-4]\d|[01]?\d\d?)\.){3}(?:25[0-5]|2[0-4]\d|[01]?\d\d?)$/,
|
|
||||||
ipv6: /^\s*(?:(?:(?:[0-9a-f]{1,4}:){7}(?:[0-9a-f]{1,4}|:))|(?:(?:[0-9a-f]{1,4}:){6}(?::[0-9a-f]{1,4}|(?:(?:25[0-5]|2[0-4]\d|1\d\d|[1-9]?\d)(?:\.(?:25[0-5]|2[0-4]\d|1\d\d|[1-9]?\d)){3})|:))|(?:(?:[0-9a-f]{1,4}:){5}(?:(?:(?::[0-9a-f]{1,4}){1,2})|:(?:(?:25[0-5]|2[0-4]\d|1\d\d|[1-9]?\d)(?:\.(?:25[0-5]|2[0-4]\d|1\d\d|[1-9]?\d)){3})|:))|(?:(?:[0-9a-f]{1,4}:){4}(?:(?:(?::[0-9a-f]{1,4}){1,3})|(?:(?::[0-9a-f]{1,4})?:(?:(?:25[0-5]|2[0-4]\d|1\d\d|[1-9]?\d)(?:\.(?:25[0-5]|2[0-4]\d|1\d\d|[1-9]?\d)){3}))|:))|(?:(?:[0-9a-f]{1,4}:){3}(?:(?:(?::[0-9a-f]{1,4}){1,4})|(?:(?::[0-9a-f]{1,4}){0,2}:(?:(?:25[0-5]|2[0-4]\d|1\d\d|[1-9]?\d)(?:\.(?:25[0-5]|2[0-4]\d|1\d\d|[1-9]?\d)){3}))|:))|(?:(?:[0-9a-f]{1,4}:){2}(?:(?:(?::[0-9a-f]{1,4}){1,5})|(?:(?::[0-9a-f]{1,4}){0,3}:(?:(?:25[0-5]|2[0-4]\d|1\d\d|[1-9]?\d)(?:\.(?:25[0-5]|2[0-4]\d|1\d\d|[1-9]?\d)){3}))|:))|(?:(?:[0-9a-f]{1,4}:){1}(?:(?:(?::[0-9a-f]{1,4}){1,6})|(?:(?::[0-9a-f]{1,4}){0,4}:(?:(?:25[0-5]|2[0-4]\d|1\d\d|[1-9]?\d)(?:\.(?:25[0-5]|2[0-4]\d|1\d\d|[1-9]?\d)){3}))|:))|(?::(?:(?:(?::[0-9a-f]{1,4}){1,7})|(?:(?::[0-9a-f]{1,4}){0,5}:(?:(?:25[0-5]|2[0-4]\d|1\d\d|[1-9]?\d)(?:\.(?:25[0-5]|2[0-4]\d|1\d\d|[1-9]?\d)){3}))|:)))(?:%.+)?\s*$/i,
|
|
||||||
regex: regex,
|
|
||||||
uuid: UUID,
|
|
||||||
'json-pointer': JSON_POINTER,
|
|
||||||
'json-pointer-uri-fragment': JSON_POINTER_URI_FRAGMENT,
|
|
||||||
'relative-json-pointer': RELATIVE_JSON_POINTER
|
|
||||||
};
|
|
||||||
|
|
||||||
|
|
||||||
function isLeapYear(year) {
|
|
||||||
// https://tools.ietf.org/html/rfc3339#appendix-C
|
|
||||||
return year % 4 === 0 && (year % 100 !== 0 || year % 400 === 0);
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
function date(str) {
|
|
||||||
// full-date from http://tools.ietf.org/html/rfc3339#section-5.6
|
|
||||||
var matches = str.match(DATE);
|
|
||||||
if (!matches) return false;
|
|
||||||
|
|
||||||
var year = +matches[1];
|
|
||||||
var month = +matches[2];
|
|
||||||
var day = +matches[3];
|
|
||||||
|
|
||||||
return month >= 1 && month <= 12 && day >= 1 &&
|
|
||||||
day <= (month == 2 && isLeapYear(year) ? 29 : DAYS[month]);
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
function time(str, full) {
|
|
||||||
var matches = str.match(TIME);
|
|
||||||
if (!matches) return false;
|
|
||||||
|
|
||||||
var hour = matches[1];
|
|
||||||
var minute = matches[2];
|
|
||||||
var second = matches[3];
|
|
||||||
var timeZone = matches[5];
|
|
||||||
return ((hour <= 23 && minute <= 59 && second <= 59) ||
|
|
||||||
(hour == 23 && minute == 59 && second == 60)) &&
|
|
||||||
(!full || timeZone);
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
var DATE_TIME_SEPARATOR = /t|\s/i;
|
|
||||||
function date_time(str) {
|
|
||||||
// http://tools.ietf.org/html/rfc3339#section-5.6
|
|
||||||
var dateTime = str.split(DATE_TIME_SEPARATOR);
|
|
||||||
return dateTime.length == 2 && date(dateTime[0]) && time(dateTime[1], true);
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
var NOT_URI_FRAGMENT = /\/|:/;
|
|
||||||
function uri(str) {
|
|
||||||
// http://jmrware.com/articles/2009/uri_regexp/URI_regex.html + optional protocol + required "."
|
|
||||||
return NOT_URI_FRAGMENT.test(str) && URI.test(str);
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
var Z_ANCHOR = /[^\\]\\Z/;
|
|
||||||
function regex(str) {
|
|
||||||
if (Z_ANCHOR.test(str)) return false;
|
|
||||||
try {
|
|
||||||
new RegExp(str);
|
|
||||||
return true;
|
|
||||||
} catch(e) {
|
|
||||||
return false;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
387
node_modules/ajv/lib/compile/index.js
generated
vendored
387
node_modules/ajv/lib/compile/index.js
generated
vendored
@@ -1,387 +0,0 @@
|
|||||||
'use strict';
|
|
||||||
|
|
||||||
var resolve = require('./resolve')
|
|
||||||
, util = require('./util')
|
|
||||||
, errorClasses = require('./error_classes')
|
|
||||||
, stableStringify = require('fast-json-stable-stringify');
|
|
||||||
|
|
||||||
var validateGenerator = require('../dotjs/validate');
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Functions below are used inside compiled validations function
|
|
||||||
*/
|
|
||||||
|
|
||||||
var ucs2length = util.ucs2length;
|
|
||||||
var equal = require('fast-deep-equal');
|
|
||||||
|
|
||||||
// this error is thrown by async schemas to return validation errors via exception
|
|
||||||
var ValidationError = errorClasses.Validation;
|
|
||||||
|
|
||||||
module.exports = compile;
|
|
||||||
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Compiles schema to validation function
|
|
||||||
* @this Ajv
|
|
||||||
* @param {Object} schema schema object
|
|
||||||
* @param {Object} root object with information about the root schema for this schema
|
|
||||||
* @param {Object} localRefs the hash of local references inside the schema (created by resolve.id), used for inline resolution
|
|
||||||
* @param {String} baseId base ID for IDs in the schema
|
|
||||||
* @return {Function} validation function
|
|
||||||
*/
|
|
||||||
function compile(schema, root, localRefs, baseId) {
|
|
||||||
/* jshint validthis: true, evil: true */
|
|
||||||
/* eslint no-shadow: 0 */
|
|
||||||
var self = this
|
|
||||||
, opts = this._opts
|
|
||||||
, refVal = [ undefined ]
|
|
||||||
, refs = {}
|
|
||||||
, patterns = []
|
|
||||||
, patternsHash = {}
|
|
||||||
, defaults = []
|
|
||||||
, defaultsHash = {}
|
|
||||||
, customRules = [];
|
|
||||||
|
|
||||||
root = root || { schema: schema, refVal: refVal, refs: refs };
|
|
||||||
|
|
||||||
var c = checkCompiling.call(this, schema, root, baseId);
|
|
||||||
var compilation = this._compilations[c.index];
|
|
||||||
if (c.compiling) return (compilation.callValidate = callValidate);
|
|
||||||
|
|
||||||
var formats = this._formats;
|
|
||||||
var RULES = this.RULES;
|
|
||||||
|
|
||||||
try {
|
|
||||||
var v = localCompile(schema, root, localRefs, baseId);
|
|
||||||
compilation.validate = v;
|
|
||||||
var cv = compilation.callValidate;
|
|
||||||
if (cv) {
|
|
||||||
cv.schema = v.schema;
|
|
||||||
cv.errors = null;
|
|
||||||
cv.refs = v.refs;
|
|
||||||
cv.refVal = v.refVal;
|
|
||||||
cv.root = v.root;
|
|
||||||
cv.$async = v.$async;
|
|
||||||
if (opts.sourceCode) cv.source = v.source;
|
|
||||||
}
|
|
||||||
return v;
|
|
||||||
} finally {
|
|
||||||
endCompiling.call(this, schema, root, baseId);
|
|
||||||
}
|
|
||||||
|
|
||||||
/* @this {*} - custom context, see passContext option */
|
|
||||||
function callValidate() {
|
|
||||||
/* jshint validthis: true */
|
|
||||||
var validate = compilation.validate;
|
|
||||||
var result = validate.apply(this, arguments);
|
|
||||||
callValidate.errors = validate.errors;
|
|
||||||
return result;
|
|
||||||
}
|
|
||||||
|
|
||||||
function localCompile(_schema, _root, localRefs, baseId) {
|
|
||||||
var isRoot = !_root || (_root && _root.schema == _schema);
|
|
||||||
if (_root.schema != root.schema)
|
|
||||||
return compile.call(self, _schema, _root, localRefs, baseId);
|
|
||||||
|
|
||||||
var $async = _schema.$async === true;
|
|
||||||
|
|
||||||
var sourceCode = validateGenerator({
|
|
||||||
isTop: true,
|
|
||||||
schema: _schema,
|
|
||||||
isRoot: isRoot,
|
|
||||||
baseId: baseId,
|
|
||||||
root: _root,
|
|
||||||
schemaPath: '',
|
|
||||||
errSchemaPath: '#',
|
|
||||||
errorPath: '""',
|
|
||||||
MissingRefError: errorClasses.MissingRef,
|
|
||||||
RULES: RULES,
|
|
||||||
validate: validateGenerator,
|
|
||||||
util: util,
|
|
||||||
resolve: resolve,
|
|
||||||
resolveRef: resolveRef,
|
|
||||||
usePattern: usePattern,
|
|
||||||
useDefault: useDefault,
|
|
||||||
useCustomRule: useCustomRule,
|
|
||||||
opts: opts,
|
|
||||||
formats: formats,
|
|
||||||
logger: self.logger,
|
|
||||||
self: self
|
|
||||||
});
|
|
||||||
|
|
||||||
sourceCode = vars(refVal, refValCode) + vars(patterns, patternCode)
|
|
||||||
+ vars(defaults, defaultCode) + vars(customRules, customRuleCode)
|
|
||||||
+ sourceCode;
|
|
||||||
|
|
||||||
if (opts.processCode) sourceCode = opts.processCode(sourceCode, _schema);
|
|
||||||
// console.log('\n\n\n *** \n', JSON.stringify(sourceCode));
|
|
||||||
var validate;
|
|
||||||
try {
|
|
||||||
var makeValidate = new Function(
|
|
||||||
'self',
|
|
||||||
'RULES',
|
|
||||||
'formats',
|
|
||||||
'root',
|
|
||||||
'refVal',
|
|
||||||
'defaults',
|
|
||||||
'customRules',
|
|
||||||
'equal',
|
|
||||||
'ucs2length',
|
|
||||||
'ValidationError',
|
|
||||||
sourceCode
|
|
||||||
);
|
|
||||||
|
|
||||||
validate = makeValidate(
|
|
||||||
self,
|
|
||||||
RULES,
|
|
||||||
formats,
|
|
||||||
root,
|
|
||||||
refVal,
|
|
||||||
defaults,
|
|
||||||
customRules,
|
|
||||||
equal,
|
|
||||||
ucs2length,
|
|
||||||
ValidationError
|
|
||||||
);
|
|
||||||
|
|
||||||
refVal[0] = validate;
|
|
||||||
} catch(e) {
|
|
||||||
self.logger.error('Error compiling schema, function code:', sourceCode);
|
|
||||||
throw e;
|
|
||||||
}
|
|
||||||
|
|
||||||
validate.schema = _schema;
|
|
||||||
validate.errors = null;
|
|
||||||
validate.refs = refs;
|
|
||||||
validate.refVal = refVal;
|
|
||||||
validate.root = isRoot ? validate : _root;
|
|
||||||
if ($async) validate.$async = true;
|
|
||||||
if (opts.sourceCode === true) {
|
|
||||||
validate.source = {
|
|
||||||
code: sourceCode,
|
|
||||||
patterns: patterns,
|
|
||||||
defaults: defaults
|
|
||||||
};
|
|
||||||
}
|
|
||||||
|
|
||||||
return validate;
|
|
||||||
}
|
|
||||||
|
|
||||||
function resolveRef(baseId, ref, isRoot) {
|
|
||||||
ref = resolve.url(baseId, ref);
|
|
||||||
var refIndex = refs[ref];
|
|
||||||
var _refVal, refCode;
|
|
||||||
if (refIndex !== undefined) {
|
|
||||||
_refVal = refVal[refIndex];
|
|
||||||
refCode = 'refVal[' + refIndex + ']';
|
|
||||||
return resolvedRef(_refVal, refCode);
|
|
||||||
}
|
|
||||||
if (!isRoot && root.refs) {
|
|
||||||
var rootRefId = root.refs[ref];
|
|
||||||
if (rootRefId !== undefined) {
|
|
||||||
_refVal = root.refVal[rootRefId];
|
|
||||||
refCode = addLocalRef(ref, _refVal);
|
|
||||||
return resolvedRef(_refVal, refCode);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
refCode = addLocalRef(ref);
|
|
||||||
var v = resolve.call(self, localCompile, root, ref);
|
|
||||||
if (v === undefined) {
|
|
||||||
var localSchema = localRefs && localRefs[ref];
|
|
||||||
if (localSchema) {
|
|
||||||
v = resolve.inlineRef(localSchema, opts.inlineRefs)
|
|
||||||
? localSchema
|
|
||||||
: compile.call(self, localSchema, root, localRefs, baseId);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
if (v === undefined) {
|
|
||||||
removeLocalRef(ref);
|
|
||||||
} else {
|
|
||||||
replaceLocalRef(ref, v);
|
|
||||||
return resolvedRef(v, refCode);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
function addLocalRef(ref, v) {
|
|
||||||
var refId = refVal.length;
|
|
||||||
refVal[refId] = v;
|
|
||||||
refs[ref] = refId;
|
|
||||||
return 'refVal' + refId;
|
|
||||||
}
|
|
||||||
|
|
||||||
function removeLocalRef(ref) {
|
|
||||||
delete refs[ref];
|
|
||||||
}
|
|
||||||
|
|
||||||
function replaceLocalRef(ref, v) {
|
|
||||||
var refId = refs[ref];
|
|
||||||
refVal[refId] = v;
|
|
||||||
}
|
|
||||||
|
|
||||||
function resolvedRef(refVal, code) {
|
|
||||||
return typeof refVal == 'object' || typeof refVal == 'boolean'
|
|
||||||
? { code: code, schema: refVal, inline: true }
|
|
||||||
: { code: code, $async: refVal && !!refVal.$async };
|
|
||||||
}
|
|
||||||
|
|
||||||
function usePattern(regexStr) {
|
|
||||||
var index = patternsHash[regexStr];
|
|
||||||
if (index === undefined) {
|
|
||||||
index = patternsHash[regexStr] = patterns.length;
|
|
||||||
patterns[index] = regexStr;
|
|
||||||
}
|
|
||||||
return 'pattern' + index;
|
|
||||||
}
|
|
||||||
|
|
||||||
function useDefault(value) {
|
|
||||||
switch (typeof value) {
|
|
||||||
case 'boolean':
|
|
||||||
case 'number':
|
|
||||||
return '' + value;
|
|
||||||
case 'string':
|
|
||||||
return util.toQuotedString(value);
|
|
||||||
case 'object':
|
|
||||||
if (value === null) return 'null';
|
|
||||||
var valueStr = stableStringify(value);
|
|
||||||
var index = defaultsHash[valueStr];
|
|
||||||
if (index === undefined) {
|
|
||||||
index = defaultsHash[valueStr] = defaults.length;
|
|
||||||
defaults[index] = value;
|
|
||||||
}
|
|
||||||
return 'default' + index;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
function useCustomRule(rule, schema, parentSchema, it) {
|
|
||||||
if (self._opts.validateSchema !== false) {
|
|
||||||
var deps = rule.definition.dependencies;
|
|
||||||
if (deps && !deps.every(function(keyword) {
|
|
||||||
return Object.prototype.hasOwnProperty.call(parentSchema, keyword);
|
|
||||||
}))
|
|
||||||
throw new Error('parent schema must have all required keywords: ' + deps.join(','));
|
|
||||||
|
|
||||||
var validateSchema = rule.definition.validateSchema;
|
|
||||||
if (validateSchema) {
|
|
||||||
var valid = validateSchema(schema);
|
|
||||||
if (!valid) {
|
|
||||||
var message = 'keyword schema is invalid: ' + self.errorsText(validateSchema.errors);
|
|
||||||
if (self._opts.validateSchema == 'log') self.logger.error(message);
|
|
||||||
else throw new Error(message);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
var compile = rule.definition.compile
|
|
||||||
, inline = rule.definition.inline
|
|
||||||
, macro = rule.definition.macro;
|
|
||||||
|
|
||||||
var validate;
|
|
||||||
if (compile) {
|
|
||||||
validate = compile.call(self, schema, parentSchema, it);
|
|
||||||
} else if (macro) {
|
|
||||||
validate = macro.call(self, schema, parentSchema, it);
|
|
||||||
if (opts.validateSchema !== false) self.validateSchema(validate, true);
|
|
||||||
} else if (inline) {
|
|
||||||
validate = inline.call(self, it, rule.keyword, schema, parentSchema);
|
|
||||||
} else {
|
|
||||||
validate = rule.definition.validate;
|
|
||||||
if (!validate) return;
|
|
||||||
}
|
|
||||||
|
|
||||||
if (validate === undefined)
|
|
||||||
throw new Error('custom keyword "' + rule.keyword + '"failed to compile');
|
|
||||||
|
|
||||||
var index = customRules.length;
|
|
||||||
customRules[index] = validate;
|
|
||||||
|
|
||||||
return {
|
|
||||||
code: 'customRule' + index,
|
|
||||||
validate: validate
|
|
||||||
};
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Checks if the schema is currently compiled
|
|
||||||
* @this Ajv
|
|
||||||
* @param {Object} schema schema to compile
|
|
||||||
* @param {Object} root root object
|
|
||||||
* @param {String} baseId base schema ID
|
|
||||||
* @return {Object} object with properties "index" (compilation index) and "compiling" (boolean)
|
|
||||||
*/
|
|
||||||
function checkCompiling(schema, root, baseId) {
|
|
||||||
/* jshint validthis: true */
|
|
||||||
var index = compIndex.call(this, schema, root, baseId);
|
|
||||||
if (index >= 0) return { index: index, compiling: true };
|
|
||||||
index = this._compilations.length;
|
|
||||||
this._compilations[index] = {
|
|
||||||
schema: schema,
|
|
||||||
root: root,
|
|
||||||
baseId: baseId
|
|
||||||
};
|
|
||||||
return { index: index, compiling: false };
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Removes the schema from the currently compiled list
|
|
||||||
* @this Ajv
|
|
||||||
* @param {Object} schema schema to compile
|
|
||||||
* @param {Object} root root object
|
|
||||||
* @param {String} baseId base schema ID
|
|
||||||
*/
|
|
||||||
function endCompiling(schema, root, baseId) {
|
|
||||||
/* jshint validthis: true */
|
|
||||||
var i = compIndex.call(this, schema, root, baseId);
|
|
||||||
if (i >= 0) this._compilations.splice(i, 1);
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Index of schema compilation in the currently compiled list
|
|
||||||
* @this Ajv
|
|
||||||
* @param {Object} schema schema to compile
|
|
||||||
* @param {Object} root root object
|
|
||||||
* @param {String} baseId base schema ID
|
|
||||||
* @return {Integer} compilation index
|
|
||||||
*/
|
|
||||||
function compIndex(schema, root, baseId) {
|
|
||||||
/* jshint validthis: true */
|
|
||||||
for (var i=0; i<this._compilations.length; i++) {
|
|
||||||
var c = this._compilations[i];
|
|
||||||
if (c.schema == schema && c.root == root && c.baseId == baseId) return i;
|
|
||||||
}
|
|
||||||
return -1;
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
function patternCode(i, patterns) {
|
|
||||||
return 'var pattern' + i + ' = new RegExp(' + util.toQuotedString(patterns[i]) + ');';
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
function defaultCode(i) {
|
|
||||||
return 'var default' + i + ' = defaults[' + i + '];';
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
function refValCode(i, refVal) {
|
|
||||||
return refVal[i] === undefined ? '' : 'var refVal' + i + ' = refVal[' + i + '];';
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
function customRuleCode(i) {
|
|
||||||
return 'var customRule' + i + ' = customRules[' + i + '];';
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
function vars(arr, statement) {
|
|
||||||
if (!arr.length) return '';
|
|
||||||
var code = '';
|
|
||||||
for (var i=0; i<arr.length; i++)
|
|
||||||
code += statement(i, arr);
|
|
||||||
return code;
|
|
||||||
}
|
|
||||||
270
node_modules/ajv/lib/compile/resolve.js
generated
vendored
270
node_modules/ajv/lib/compile/resolve.js
generated
vendored
@@ -1,270 +0,0 @@
|
|||||||
'use strict';
|
|
||||||
|
|
||||||
var URI = require('uri-js')
|
|
||||||
, equal = require('fast-deep-equal')
|
|
||||||
, util = require('./util')
|
|
||||||
, SchemaObject = require('./schema_obj')
|
|
||||||
, traverse = require('json-schema-traverse');
|
|
||||||
|
|
||||||
module.exports = resolve;
|
|
||||||
|
|
||||||
resolve.normalizeId = normalizeId;
|
|
||||||
resolve.fullPath = getFullPath;
|
|
||||||
resolve.url = resolveUrl;
|
|
||||||
resolve.ids = resolveIds;
|
|
||||||
resolve.inlineRef = inlineRef;
|
|
||||||
resolve.schema = resolveSchema;
|
|
||||||
|
|
||||||
/**
|
|
||||||
* [resolve and compile the references ($ref)]
|
|
||||||
* @this Ajv
|
|
||||||
* @param {Function} compile reference to schema compilation funciton (localCompile)
|
|
||||||
* @param {Object} root object with information about the root schema for the current schema
|
|
||||||
* @param {String} ref reference to resolve
|
|
||||||
* @return {Object|Function} schema object (if the schema can be inlined) or validation function
|
|
||||||
*/
|
|
||||||
function resolve(compile, root, ref) {
|
|
||||||
/* jshint validthis: true */
|
|
||||||
var refVal = this._refs[ref];
|
|
||||||
if (typeof refVal == 'string') {
|
|
||||||
if (this._refs[refVal]) refVal = this._refs[refVal];
|
|
||||||
else return resolve.call(this, compile, root, refVal);
|
|
||||||
}
|
|
||||||
|
|
||||||
refVal = refVal || this._schemas[ref];
|
|
||||||
if (refVal instanceof SchemaObject) {
|
|
||||||
return inlineRef(refVal.schema, this._opts.inlineRefs)
|
|
||||||
? refVal.schema
|
|
||||||
: refVal.validate || this._compile(refVal);
|
|
||||||
}
|
|
||||||
|
|
||||||
var res = resolveSchema.call(this, root, ref);
|
|
||||||
var schema, v, baseId;
|
|
||||||
if (res) {
|
|
||||||
schema = res.schema;
|
|
||||||
root = res.root;
|
|
||||||
baseId = res.baseId;
|
|
||||||
}
|
|
||||||
|
|
||||||
if (schema instanceof SchemaObject) {
|
|
||||||
v = schema.validate || compile.call(this, schema.schema, root, undefined, baseId);
|
|
||||||
} else if (schema !== undefined) {
|
|
||||||
v = inlineRef(schema, this._opts.inlineRefs)
|
|
||||||
? schema
|
|
||||||
: compile.call(this, schema, root, undefined, baseId);
|
|
||||||
}
|
|
||||||
|
|
||||||
return v;
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Resolve schema, its root and baseId
|
|
||||||
* @this Ajv
|
|
||||||
* @param {Object} root root object with properties schema, refVal, refs
|
|
||||||
* @param {String} ref reference to resolve
|
|
||||||
* @return {Object} object with properties schema, root, baseId
|
|
||||||
*/
|
|
||||||
function resolveSchema(root, ref) {
|
|
||||||
/* jshint validthis: true */
|
|
||||||
var p = URI.parse(ref)
|
|
||||||
, refPath = _getFullPath(p)
|
|
||||||
, baseId = getFullPath(this._getId(root.schema));
|
|
||||||
if (Object.keys(root.schema).length === 0 || refPath !== baseId) {
|
|
||||||
var id = normalizeId(refPath);
|
|
||||||
var refVal = this._refs[id];
|
|
||||||
if (typeof refVal == 'string') {
|
|
||||||
return resolveRecursive.call(this, root, refVal, p);
|
|
||||||
} else if (refVal instanceof SchemaObject) {
|
|
||||||
if (!refVal.validate) this._compile(refVal);
|
|
||||||
root = refVal;
|
|
||||||
} else {
|
|
||||||
refVal = this._schemas[id];
|
|
||||||
if (refVal instanceof SchemaObject) {
|
|
||||||
if (!refVal.validate) this._compile(refVal);
|
|
||||||
if (id == normalizeId(ref))
|
|
||||||
return { schema: refVal, root: root, baseId: baseId };
|
|
||||||
root = refVal;
|
|
||||||
} else {
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
if (!root.schema) return;
|
|
||||||
baseId = getFullPath(this._getId(root.schema));
|
|
||||||
}
|
|
||||||
return getJsonPointer.call(this, p, baseId, root.schema, root);
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
/* @this Ajv */
|
|
||||||
function resolveRecursive(root, ref, parsedRef) {
|
|
||||||
/* jshint validthis: true */
|
|
||||||
var res = resolveSchema.call(this, root, ref);
|
|
||||||
if (res) {
|
|
||||||
var schema = res.schema;
|
|
||||||
var baseId = res.baseId;
|
|
||||||
root = res.root;
|
|
||||||
var id = this._getId(schema);
|
|
||||||
if (id) baseId = resolveUrl(baseId, id);
|
|
||||||
return getJsonPointer.call(this, parsedRef, baseId, schema, root);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
var PREVENT_SCOPE_CHANGE = util.toHash(['properties', 'patternProperties', 'enum', 'dependencies', 'definitions']);
|
|
||||||
/* @this Ajv */
|
|
||||||
function getJsonPointer(parsedRef, baseId, schema, root) {
|
|
||||||
/* jshint validthis: true */
|
|
||||||
parsedRef.fragment = parsedRef.fragment || '';
|
|
||||||
if (parsedRef.fragment.slice(0,1) != '/') return;
|
|
||||||
var parts = parsedRef.fragment.split('/');
|
|
||||||
|
|
||||||
for (var i = 1; i < parts.length; i++) {
|
|
||||||
var part = parts[i];
|
|
||||||
if (part) {
|
|
||||||
part = util.unescapeFragment(part);
|
|
||||||
schema = schema[part];
|
|
||||||
if (schema === undefined) break;
|
|
||||||
var id;
|
|
||||||
if (!PREVENT_SCOPE_CHANGE[part]) {
|
|
||||||
id = this._getId(schema);
|
|
||||||
if (id) baseId = resolveUrl(baseId, id);
|
|
||||||
if (schema.$ref) {
|
|
||||||
var $ref = resolveUrl(baseId, schema.$ref);
|
|
||||||
var res = resolveSchema.call(this, root, $ref);
|
|
||||||
if (res) {
|
|
||||||
schema = res.schema;
|
|
||||||
root = res.root;
|
|
||||||
baseId = res.baseId;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
if (schema !== undefined && schema !== root.schema)
|
|
||||||
return { schema: schema, root: root, baseId: baseId };
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
var SIMPLE_INLINED = util.toHash([
|
|
||||||
'type', 'format', 'pattern',
|
|
||||||
'maxLength', 'minLength',
|
|
||||||
'maxProperties', 'minProperties',
|
|
||||||
'maxItems', 'minItems',
|
|
||||||
'maximum', 'minimum',
|
|
||||||
'uniqueItems', 'multipleOf',
|
|
||||||
'required', 'enum'
|
|
||||||
]);
|
|
||||||
function inlineRef(schema, limit) {
|
|
||||||
if (limit === false) return false;
|
|
||||||
if (limit === undefined || limit === true) return checkNoRef(schema);
|
|
||||||
else if (limit) return countKeys(schema) <= limit;
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
function checkNoRef(schema) {
|
|
||||||
var item;
|
|
||||||
if (Array.isArray(schema)) {
|
|
||||||
for (var i=0; i<schema.length; i++) {
|
|
||||||
item = schema[i];
|
|
||||||
if (typeof item == 'object' && !checkNoRef(item)) return false;
|
|
||||||
}
|
|
||||||
} else {
|
|
||||||
for (var key in schema) {
|
|
||||||
if (key == '$ref') return false;
|
|
||||||
item = schema[key];
|
|
||||||
if (typeof item == 'object' && !checkNoRef(item)) return false;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
return true;
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
function countKeys(schema) {
|
|
||||||
var count = 0, item;
|
|
||||||
if (Array.isArray(schema)) {
|
|
||||||
for (var i=0; i<schema.length; i++) {
|
|
||||||
item = schema[i];
|
|
||||||
if (typeof item == 'object') count += countKeys(item);
|
|
||||||
if (count == Infinity) return Infinity;
|
|
||||||
}
|
|
||||||
} else {
|
|
||||||
for (var key in schema) {
|
|
||||||
if (key == '$ref') return Infinity;
|
|
||||||
if (SIMPLE_INLINED[key]) {
|
|
||||||
count++;
|
|
||||||
} else {
|
|
||||||
item = schema[key];
|
|
||||||
if (typeof item == 'object') count += countKeys(item) + 1;
|
|
||||||
if (count == Infinity) return Infinity;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
return count;
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
function getFullPath(id, normalize) {
|
|
||||||
if (normalize !== false) id = normalizeId(id);
|
|
||||||
var p = URI.parse(id);
|
|
||||||
return _getFullPath(p);
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
function _getFullPath(p) {
|
|
||||||
return URI.serialize(p).split('#')[0] + '#';
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
var TRAILING_SLASH_HASH = /#\/?$/;
|
|
||||||
function normalizeId(id) {
|
|
||||||
return id ? id.replace(TRAILING_SLASH_HASH, '') : '';
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
function resolveUrl(baseId, id) {
|
|
||||||
id = normalizeId(id);
|
|
||||||
return URI.resolve(baseId, id);
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
/* @this Ajv */
|
|
||||||
function resolveIds(schema) {
|
|
||||||
var schemaId = normalizeId(this._getId(schema));
|
|
||||||
var baseIds = {'': schemaId};
|
|
||||||
var fullPaths = {'': getFullPath(schemaId, false)};
|
|
||||||
var localRefs = {};
|
|
||||||
var self = this;
|
|
||||||
|
|
||||||
traverse(schema, {allKeys: true}, function(sch, jsonPtr, rootSchema, parentJsonPtr, parentKeyword, parentSchema, keyIndex) {
|
|
||||||
if (jsonPtr === '') return;
|
|
||||||
var id = self._getId(sch);
|
|
||||||
var baseId = baseIds[parentJsonPtr];
|
|
||||||
var fullPath = fullPaths[parentJsonPtr] + '/' + parentKeyword;
|
|
||||||
if (keyIndex !== undefined)
|
|
||||||
fullPath += '/' + (typeof keyIndex == 'number' ? keyIndex : util.escapeFragment(keyIndex));
|
|
||||||
|
|
||||||
if (typeof id == 'string') {
|
|
||||||
id = baseId = normalizeId(baseId ? URI.resolve(baseId, id) : id);
|
|
||||||
|
|
||||||
var refVal = self._refs[id];
|
|
||||||
if (typeof refVal == 'string') refVal = self._refs[refVal];
|
|
||||||
if (refVal && refVal.schema) {
|
|
||||||
if (!equal(sch, refVal.schema))
|
|
||||||
throw new Error('id "' + id + '" resolves to more than one schema');
|
|
||||||
} else if (id != normalizeId(fullPath)) {
|
|
||||||
if (id[0] == '#') {
|
|
||||||
if (localRefs[id] && !equal(sch, localRefs[id]))
|
|
||||||
throw new Error('id "' + id + '" resolves to more than one schema');
|
|
||||||
localRefs[id] = sch;
|
|
||||||
} else {
|
|
||||||
self._refs[id] = fullPath;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
baseIds[jsonPtr] = baseId;
|
|
||||||
fullPaths[jsonPtr] = fullPath;
|
|
||||||
});
|
|
||||||
|
|
||||||
return localRefs;
|
|
||||||
}
|
|
||||||
66
node_modules/ajv/lib/compile/rules.js
generated
vendored
66
node_modules/ajv/lib/compile/rules.js
generated
vendored
@@ -1,66 +0,0 @@
|
|||||||
'use strict';
|
|
||||||
|
|
||||||
var ruleModules = require('../dotjs')
|
|
||||||
, toHash = require('./util').toHash;
|
|
||||||
|
|
||||||
module.exports = function rules() {
|
|
||||||
var RULES = [
|
|
||||||
{ type: 'number',
|
|
||||||
rules: [ { 'maximum': ['exclusiveMaximum'] },
|
|
||||||
{ 'minimum': ['exclusiveMinimum'] }, 'multipleOf', 'format'] },
|
|
||||||
{ type: 'string',
|
|
||||||
rules: [ 'maxLength', 'minLength', 'pattern', 'format' ] },
|
|
||||||
{ type: 'array',
|
|
||||||
rules: [ 'maxItems', 'minItems', 'items', 'contains', 'uniqueItems' ] },
|
|
||||||
{ type: 'object',
|
|
||||||
rules: [ 'maxProperties', 'minProperties', 'required', 'dependencies', 'propertyNames',
|
|
||||||
{ 'properties': ['additionalProperties', 'patternProperties'] } ] },
|
|
||||||
{ rules: [ '$ref', 'const', 'enum', 'not', 'anyOf', 'oneOf', 'allOf', 'if' ] }
|
|
||||||
];
|
|
||||||
|
|
||||||
var ALL = [ 'type', '$comment' ];
|
|
||||||
var KEYWORDS = [
|
|
||||||
'$schema', '$id', 'id', '$data', '$async', 'title',
|
|
||||||
'description', 'default', 'definitions',
|
|
||||||
'examples', 'readOnly', 'writeOnly',
|
|
||||||
'contentMediaType', 'contentEncoding',
|
|
||||||
'additionalItems', 'then', 'else'
|
|
||||||
];
|
|
||||||
var TYPES = [ 'number', 'integer', 'string', 'array', 'object', 'boolean', 'null' ];
|
|
||||||
RULES.all = toHash(ALL);
|
|
||||||
RULES.types = toHash(TYPES);
|
|
||||||
|
|
||||||
RULES.forEach(function (group) {
|
|
||||||
group.rules = group.rules.map(function (keyword) {
|
|
||||||
var implKeywords;
|
|
||||||
if (typeof keyword == 'object') {
|
|
||||||
var key = Object.keys(keyword)[0];
|
|
||||||
implKeywords = keyword[key];
|
|
||||||
keyword = key;
|
|
||||||
implKeywords.forEach(function (k) {
|
|
||||||
ALL.push(k);
|
|
||||||
RULES.all[k] = true;
|
|
||||||
});
|
|
||||||
}
|
|
||||||
ALL.push(keyword);
|
|
||||||
var rule = RULES.all[keyword] = {
|
|
||||||
keyword: keyword,
|
|
||||||
code: ruleModules[keyword],
|
|
||||||
implements: implKeywords
|
|
||||||
};
|
|
||||||
return rule;
|
|
||||||
});
|
|
||||||
|
|
||||||
RULES.all.$comment = {
|
|
||||||
keyword: '$comment',
|
|
||||||
code: ruleModules.$comment
|
|
||||||
};
|
|
||||||
|
|
||||||
if (group.type) RULES.types[group.type] = group;
|
|
||||||
});
|
|
||||||
|
|
||||||
RULES.keywords = toHash(ALL.concat(KEYWORDS));
|
|
||||||
RULES.custom = {};
|
|
||||||
|
|
||||||
return RULES;
|
|
||||||
};
|
|
||||||
9
node_modules/ajv/lib/compile/schema_obj.js
generated
vendored
9
node_modules/ajv/lib/compile/schema_obj.js
generated
vendored
@@ -1,9 +0,0 @@
|
|||||||
'use strict';
|
|
||||||
|
|
||||||
var util = require('./util');
|
|
||||||
|
|
||||||
module.exports = SchemaObject;
|
|
||||||
|
|
||||||
function SchemaObject(obj) {
|
|
||||||
util.copy(obj, this);
|
|
||||||
}
|
|
||||||
20
node_modules/ajv/lib/compile/ucs2length.js
generated
vendored
20
node_modules/ajv/lib/compile/ucs2length.js
generated
vendored
@@ -1,20 +0,0 @@
|
|||||||
'use strict';
|
|
||||||
|
|
||||||
// https://mathiasbynens.be/notes/javascript-encoding
|
|
||||||
// https://github.com/bestiejs/punycode.js - punycode.ucs2.decode
|
|
||||||
module.exports = function ucs2length(str) {
|
|
||||||
var length = 0
|
|
||||||
, len = str.length
|
|
||||||
, pos = 0
|
|
||||||
, value;
|
|
||||||
while (pos < len) {
|
|
||||||
length++;
|
|
||||||
value = str.charCodeAt(pos++);
|
|
||||||
if (value >= 0xD800 && value <= 0xDBFF && pos < len) {
|
|
||||||
// high surrogate, and there is a next character
|
|
||||||
value = str.charCodeAt(pos);
|
|
||||||
if ((value & 0xFC00) == 0xDC00) pos++; // low surrogate
|
|
||||||
}
|
|
||||||
}
|
|
||||||
return length;
|
|
||||||
};
|
|
||||||
239
node_modules/ajv/lib/compile/util.js
generated
vendored
239
node_modules/ajv/lib/compile/util.js
generated
vendored
@@ -1,239 +0,0 @@
|
|||||||
'use strict';
|
|
||||||
|
|
||||||
|
|
||||||
module.exports = {
|
|
||||||
copy: copy,
|
|
||||||
checkDataType: checkDataType,
|
|
||||||
checkDataTypes: checkDataTypes,
|
|
||||||
coerceToTypes: coerceToTypes,
|
|
||||||
toHash: toHash,
|
|
||||||
getProperty: getProperty,
|
|
||||||
escapeQuotes: escapeQuotes,
|
|
||||||
equal: require('fast-deep-equal'),
|
|
||||||
ucs2length: require('./ucs2length'),
|
|
||||||
varOccurences: varOccurences,
|
|
||||||
varReplace: varReplace,
|
|
||||||
schemaHasRules: schemaHasRules,
|
|
||||||
schemaHasRulesExcept: schemaHasRulesExcept,
|
|
||||||
schemaUnknownRules: schemaUnknownRules,
|
|
||||||
toQuotedString: toQuotedString,
|
|
||||||
getPathExpr: getPathExpr,
|
|
||||||
getPath: getPath,
|
|
||||||
getData: getData,
|
|
||||||
unescapeFragment: unescapeFragment,
|
|
||||||
unescapeJsonPointer: unescapeJsonPointer,
|
|
||||||
escapeFragment: escapeFragment,
|
|
||||||
escapeJsonPointer: escapeJsonPointer
|
|
||||||
};
|
|
||||||
|
|
||||||
|
|
||||||
function copy(o, to) {
|
|
||||||
to = to || {};
|
|
||||||
for (var key in o) to[key] = o[key];
|
|
||||||
return to;
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
function checkDataType(dataType, data, strictNumbers, negate) {
|
|
||||||
var EQUAL = negate ? ' !== ' : ' === '
|
|
||||||
, AND = negate ? ' || ' : ' && '
|
|
||||||
, OK = negate ? '!' : ''
|
|
||||||
, NOT = negate ? '' : '!';
|
|
||||||
switch (dataType) {
|
|
||||||
case 'null': return data + EQUAL + 'null';
|
|
||||||
case 'array': return OK + 'Array.isArray(' + data + ')';
|
|
||||||
case 'object': return '(' + OK + data + AND +
|
|
||||||
'typeof ' + data + EQUAL + '"object"' + AND +
|
|
||||||
NOT + 'Array.isArray(' + data + '))';
|
|
||||||
case 'integer': return '(typeof ' + data + EQUAL + '"number"' + AND +
|
|
||||||
NOT + '(' + data + ' % 1)' +
|
|
||||||
AND + data + EQUAL + data +
|
|
||||||
(strictNumbers ? (AND + OK + 'isFinite(' + data + ')') : '') + ')';
|
|
||||||
case 'number': return '(typeof ' + data + EQUAL + '"' + dataType + '"' +
|
|
||||||
(strictNumbers ? (AND + OK + 'isFinite(' + data + ')') : '') + ')';
|
|
||||||
default: return 'typeof ' + data + EQUAL + '"' + dataType + '"';
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
function checkDataTypes(dataTypes, data, strictNumbers) {
|
|
||||||
switch (dataTypes.length) {
|
|
||||||
case 1: return checkDataType(dataTypes[0], data, strictNumbers, true);
|
|
||||||
default:
|
|
||||||
var code = '';
|
|
||||||
var types = toHash(dataTypes);
|
|
||||||
if (types.array && types.object) {
|
|
||||||
code = types.null ? '(': '(!' + data + ' || ';
|
|
||||||
code += 'typeof ' + data + ' !== "object")';
|
|
||||||
delete types.null;
|
|
||||||
delete types.array;
|
|
||||||
delete types.object;
|
|
||||||
}
|
|
||||||
if (types.number) delete types.integer;
|
|
||||||
for (var t in types)
|
|
||||||
code += (code ? ' && ' : '' ) + checkDataType(t, data, strictNumbers, true);
|
|
||||||
|
|
||||||
return code;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
var COERCE_TO_TYPES = toHash([ 'string', 'number', 'integer', 'boolean', 'null' ]);
|
|
||||||
function coerceToTypes(optionCoerceTypes, dataTypes) {
|
|
||||||
if (Array.isArray(dataTypes)) {
|
|
||||||
var types = [];
|
|
||||||
for (var i=0; i<dataTypes.length; i++) {
|
|
||||||
var t = dataTypes[i];
|
|
||||||
if (COERCE_TO_TYPES[t]) types[types.length] = t;
|
|
||||||
else if (optionCoerceTypes === 'array' && t === 'array') types[types.length] = t;
|
|
||||||
}
|
|
||||||
if (types.length) return types;
|
|
||||||
} else if (COERCE_TO_TYPES[dataTypes]) {
|
|
||||||
return [dataTypes];
|
|
||||||
} else if (optionCoerceTypes === 'array' && dataTypes === 'array') {
|
|
||||||
return ['array'];
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
function toHash(arr) {
|
|
||||||
var hash = {};
|
|
||||||
for (var i=0; i<arr.length; i++) hash[arr[i]] = true;
|
|
||||||
return hash;
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
var IDENTIFIER = /^[a-z$_][a-z$_0-9]*$/i;
|
|
||||||
var SINGLE_QUOTE = /'|\\/g;
|
|
||||||
function getProperty(key) {
|
|
||||||
return typeof key == 'number'
|
|
||||||
? '[' + key + ']'
|
|
||||||
: IDENTIFIER.test(key)
|
|
||||||
? '.' + key
|
|
||||||
: "['" + escapeQuotes(key) + "']";
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
function escapeQuotes(str) {
|
|
||||||
return str.replace(SINGLE_QUOTE, '\\$&')
|
|
||||||
.replace(/\n/g, '\\n')
|
|
||||||
.replace(/\r/g, '\\r')
|
|
||||||
.replace(/\f/g, '\\f')
|
|
||||||
.replace(/\t/g, '\\t');
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
function varOccurences(str, dataVar) {
|
|
||||||
dataVar += '[^0-9]';
|
|
||||||
var matches = str.match(new RegExp(dataVar, 'g'));
|
|
||||||
return matches ? matches.length : 0;
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
function varReplace(str, dataVar, expr) {
|
|
||||||
dataVar += '([^0-9])';
|
|
||||||
expr = expr.replace(/\$/g, '$$$$');
|
|
||||||
return str.replace(new RegExp(dataVar, 'g'), expr + '$1');
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
function schemaHasRules(schema, rules) {
|
|
||||||
if (typeof schema == 'boolean') return !schema;
|
|
||||||
for (var key in schema) if (rules[key]) return true;
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
function schemaHasRulesExcept(schema, rules, exceptKeyword) {
|
|
||||||
if (typeof schema == 'boolean') return !schema && exceptKeyword != 'not';
|
|
||||||
for (var key in schema) if (key != exceptKeyword && rules[key]) return true;
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
function schemaUnknownRules(schema, rules) {
|
|
||||||
if (typeof schema == 'boolean') return;
|
|
||||||
for (var key in schema) if (!rules[key]) return key;
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
function toQuotedString(str) {
|
|
||||||
return '\'' + escapeQuotes(str) + '\'';
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
function getPathExpr(currentPath, expr, jsonPointers, isNumber) {
|
|
||||||
var path = jsonPointers // false by default
|
|
||||||
? '\'/\' + ' + expr + (isNumber ? '' : '.replace(/~/g, \'~0\').replace(/\\//g, \'~1\')')
|
|
||||||
: (isNumber ? '\'[\' + ' + expr + ' + \']\'' : '\'[\\\'\' + ' + expr + ' + \'\\\']\'');
|
|
||||||
return joinPaths(currentPath, path);
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
function getPath(currentPath, prop, jsonPointers) {
|
|
||||||
var path = jsonPointers // false by default
|
|
||||||
? toQuotedString('/' + escapeJsonPointer(prop))
|
|
||||||
: toQuotedString(getProperty(prop));
|
|
||||||
return joinPaths(currentPath, path);
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
var JSON_POINTER = /^\/(?:[^~]|~0|~1)*$/;
|
|
||||||
var RELATIVE_JSON_POINTER = /^([0-9]+)(#|\/(?:[^~]|~0|~1)*)?$/;
|
|
||||||
function getData($data, lvl, paths) {
|
|
||||||
var up, jsonPointer, data, matches;
|
|
||||||
if ($data === '') return 'rootData';
|
|
||||||
if ($data[0] == '/') {
|
|
||||||
if (!JSON_POINTER.test($data)) throw new Error('Invalid JSON-pointer: ' + $data);
|
|
||||||
jsonPointer = $data;
|
|
||||||
data = 'rootData';
|
|
||||||
} else {
|
|
||||||
matches = $data.match(RELATIVE_JSON_POINTER);
|
|
||||||
if (!matches) throw new Error('Invalid JSON-pointer: ' + $data);
|
|
||||||
up = +matches[1];
|
|
||||||
jsonPointer = matches[2];
|
|
||||||
if (jsonPointer == '#') {
|
|
||||||
if (up >= lvl) throw new Error('Cannot access property/index ' + up + ' levels up, current level is ' + lvl);
|
|
||||||
return paths[lvl - up];
|
|
||||||
}
|
|
||||||
|
|
||||||
if (up > lvl) throw new Error('Cannot access data ' + up + ' levels up, current level is ' + lvl);
|
|
||||||
data = 'data' + ((lvl - up) || '');
|
|
||||||
if (!jsonPointer) return data;
|
|
||||||
}
|
|
||||||
|
|
||||||
var expr = data;
|
|
||||||
var segments = jsonPointer.split('/');
|
|
||||||
for (var i=0; i<segments.length; i++) {
|
|
||||||
var segment = segments[i];
|
|
||||||
if (segment) {
|
|
||||||
data += getProperty(unescapeJsonPointer(segment));
|
|
||||||
expr += ' && ' + data;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
return expr;
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
function joinPaths (a, b) {
|
|
||||||
if (a == '""') return b;
|
|
||||||
return (a + ' + ' + b).replace(/([^\\])' \+ '/g, '$1');
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
function unescapeFragment(str) {
|
|
||||||
return unescapeJsonPointer(decodeURIComponent(str));
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
function escapeFragment(str) {
|
|
||||||
return encodeURIComponent(escapeJsonPointer(str));
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
function escapeJsonPointer(str) {
|
|
||||||
return str.replace(/~/g, '~0').replace(/\//g, '~1');
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
function unescapeJsonPointer(str) {
|
|
||||||
return str.replace(/~1/g, '/').replace(/~0/g, '~');
|
|
||||||
}
|
|
||||||
49
node_modules/ajv/lib/data.js
generated
vendored
49
node_modules/ajv/lib/data.js
generated
vendored
@@ -1,49 +0,0 @@
|
|||||||
'use strict';
|
|
||||||
|
|
||||||
var KEYWORDS = [
|
|
||||||
'multipleOf',
|
|
||||||
'maximum',
|
|
||||||
'exclusiveMaximum',
|
|
||||||
'minimum',
|
|
||||||
'exclusiveMinimum',
|
|
||||||
'maxLength',
|
|
||||||
'minLength',
|
|
||||||
'pattern',
|
|
||||||
'additionalItems',
|
|
||||||
'maxItems',
|
|
||||||
'minItems',
|
|
||||||
'uniqueItems',
|
|
||||||
'maxProperties',
|
|
||||||
'minProperties',
|
|
||||||
'required',
|
|
||||||
'additionalProperties',
|
|
||||||
'enum',
|
|
||||||
'format',
|
|
||||||
'const'
|
|
||||||
];
|
|
||||||
|
|
||||||
module.exports = function (metaSchema, keywordsJsonPointers) {
|
|
||||||
for (var i=0; i<keywordsJsonPointers.length; i++) {
|
|
||||||
metaSchema = JSON.parse(JSON.stringify(metaSchema));
|
|
||||||
var segments = keywordsJsonPointers[i].split('/');
|
|
||||||
var keywords = metaSchema;
|
|
||||||
var j;
|
|
||||||
for (j=1; j<segments.length; j++)
|
|
||||||
keywords = keywords[segments[j]];
|
|
||||||
|
|
||||||
for (j=0; j<KEYWORDS.length; j++) {
|
|
||||||
var key = KEYWORDS[j];
|
|
||||||
var schema = keywords[key];
|
|
||||||
if (schema) {
|
|
||||||
keywords[key] = {
|
|
||||||
anyOf: [
|
|
||||||
schema,
|
|
||||||
{ $ref: 'https://raw.githubusercontent.com/ajv-validator/ajv/master/lib/refs/data.json#' }
|
|
||||||
]
|
|
||||||
};
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
return metaSchema;
|
|
||||||
};
|
|
||||||
37
node_modules/ajv/lib/definition_schema.js
generated
vendored
37
node_modules/ajv/lib/definition_schema.js
generated
vendored
@@ -1,37 +0,0 @@
|
|||||||
'use strict';
|
|
||||||
|
|
||||||
var metaSchema = require('./refs/json-schema-draft-07.json');
|
|
||||||
|
|
||||||
module.exports = {
|
|
||||||
$id: 'https://github.com/ajv-validator/ajv/blob/master/lib/definition_schema.js',
|
|
||||||
definitions: {
|
|
||||||
simpleTypes: metaSchema.definitions.simpleTypes
|
|
||||||
},
|
|
||||||
type: 'object',
|
|
||||||
dependencies: {
|
|
||||||
schema: ['validate'],
|
|
||||||
$data: ['validate'],
|
|
||||||
statements: ['inline'],
|
|
||||||
valid: {not: {required: ['macro']}}
|
|
||||||
},
|
|
||||||
properties: {
|
|
||||||
type: metaSchema.properties.type,
|
|
||||||
schema: {type: 'boolean'},
|
|
||||||
statements: {type: 'boolean'},
|
|
||||||
dependencies: {
|
|
||||||
type: 'array',
|
|
||||||
items: {type: 'string'}
|
|
||||||
},
|
|
||||||
metaSchema: {type: 'object'},
|
|
||||||
modifying: {type: 'boolean'},
|
|
||||||
valid: {type: 'boolean'},
|
|
||||||
$data: {type: 'boolean'},
|
|
||||||
async: {type: 'boolean'},
|
|
||||||
errors: {
|
|
||||||
anyOf: [
|
|
||||||
{type: 'boolean'},
|
|
||||||
{const: 'full'}
|
|
||||||
]
|
|
||||||
}
|
|
||||||
}
|
|
||||||
};
|
|
||||||
113
node_modules/ajv/lib/dot/_limit.jst
generated
vendored
113
node_modules/ajv/lib/dot/_limit.jst
generated
vendored
@@ -1,113 +0,0 @@
|
|||||||
{{# def.definitions }}
|
|
||||||
{{# def.errors }}
|
|
||||||
{{# def.setupKeyword }}
|
|
||||||
{{# def.$data }}
|
|
||||||
|
|
||||||
{{## def.setExclusiveLimit:
|
|
||||||
$exclusive = true;
|
|
||||||
$errorKeyword = $exclusiveKeyword;
|
|
||||||
$errSchemaPath = it.errSchemaPath + '/' + $exclusiveKeyword;
|
|
||||||
#}}
|
|
||||||
|
|
||||||
{{
|
|
||||||
var $isMax = $keyword == 'maximum'
|
|
||||||
, $exclusiveKeyword = $isMax ? 'exclusiveMaximum' : 'exclusiveMinimum'
|
|
||||||
, $schemaExcl = it.schema[$exclusiveKeyword]
|
|
||||||
, $isDataExcl = it.opts.$data && $schemaExcl && $schemaExcl.$data
|
|
||||||
, $op = $isMax ? '<' : '>'
|
|
||||||
, $notOp = $isMax ? '>' : '<'
|
|
||||||
, $errorKeyword = undefined;
|
|
||||||
|
|
||||||
if (!($isData || typeof $schema == 'number' || $schema === undefined)) {
|
|
||||||
throw new Error($keyword + ' must be number');
|
|
||||||
}
|
|
||||||
if (!($isDataExcl || $schemaExcl === undefined
|
|
||||||
|| typeof $schemaExcl == 'number'
|
|
||||||
|| typeof $schemaExcl == 'boolean')) {
|
|
||||||
throw new Error($exclusiveKeyword + ' must be number or boolean');
|
|
||||||
}
|
|
||||||
}}
|
|
||||||
|
|
||||||
{{? $isDataExcl }}
|
|
||||||
{{
|
|
||||||
var $schemaValueExcl = it.util.getData($schemaExcl.$data, $dataLvl, it.dataPathArr)
|
|
||||||
, $exclusive = 'exclusive' + $lvl
|
|
||||||
, $exclType = 'exclType' + $lvl
|
|
||||||
, $exclIsNumber = 'exclIsNumber' + $lvl
|
|
||||||
, $opExpr = 'op' + $lvl
|
|
||||||
, $opStr = '\' + ' + $opExpr + ' + \'';
|
|
||||||
}}
|
|
||||||
var schemaExcl{{=$lvl}} = {{=$schemaValueExcl}};
|
|
||||||
{{ $schemaValueExcl = 'schemaExcl' + $lvl; }}
|
|
||||||
|
|
||||||
var {{=$exclusive}};
|
|
||||||
var {{=$exclType}} = typeof {{=$schemaValueExcl}};
|
|
||||||
if ({{=$exclType}} != 'boolean' && {{=$exclType}} != 'undefined' && {{=$exclType}} != 'number') {
|
|
||||||
{{ var $errorKeyword = $exclusiveKeyword; }}
|
|
||||||
{{# def.error:'_exclusiveLimit' }}
|
|
||||||
} else if ({{# def.$dataNotType:'number' }}
|
|
||||||
{{=$exclType}} == 'number'
|
|
||||||
? (
|
|
||||||
({{=$exclusive}} = {{=$schemaValue}} === undefined || {{=$schemaValueExcl}} {{=$op}}= {{=$schemaValue}})
|
|
||||||
? {{=$data}} {{=$notOp}}= {{=$schemaValueExcl}}
|
|
||||||
: {{=$data}} {{=$notOp}} {{=$schemaValue}}
|
|
||||||
)
|
|
||||||
: (
|
|
||||||
({{=$exclusive}} = {{=$schemaValueExcl}} === true)
|
|
||||||
? {{=$data}} {{=$notOp}}= {{=$schemaValue}}
|
|
||||||
: {{=$data}} {{=$notOp}} {{=$schemaValue}}
|
|
||||||
)
|
|
||||||
|| {{=$data}} !== {{=$data}}) {
|
|
||||||
var op{{=$lvl}} = {{=$exclusive}} ? '{{=$op}}' : '{{=$op}}=';
|
|
||||||
{{
|
|
||||||
if ($schema === undefined) {
|
|
||||||
$errorKeyword = $exclusiveKeyword;
|
|
||||||
$errSchemaPath = it.errSchemaPath + '/' + $exclusiveKeyword;
|
|
||||||
$schemaValue = $schemaValueExcl;
|
|
||||||
$isData = $isDataExcl;
|
|
||||||
}
|
|
||||||
}}
|
|
||||||
{{??}}
|
|
||||||
{{
|
|
||||||
var $exclIsNumber = typeof $schemaExcl == 'number'
|
|
||||||
, $opStr = $op; /*used in error*/
|
|
||||||
}}
|
|
||||||
|
|
||||||
{{? $exclIsNumber && $isData }}
|
|
||||||
{{ var $opExpr = '\'' + $opStr + '\''; /*used in error*/ }}
|
|
||||||
if ({{# def.$dataNotType:'number' }}
|
|
||||||
( {{=$schemaValue}} === undefined
|
|
||||||
|| {{=$schemaExcl}} {{=$op}}= {{=$schemaValue}}
|
|
||||||
? {{=$data}} {{=$notOp}}= {{=$schemaExcl}}
|
|
||||||
: {{=$data}} {{=$notOp}} {{=$schemaValue}} )
|
|
||||||
|| {{=$data}} !== {{=$data}}) {
|
|
||||||
{{??}}
|
|
||||||
{{
|
|
||||||
if ($exclIsNumber && $schema === undefined) {
|
|
||||||
{{# def.setExclusiveLimit }}
|
|
||||||
$schemaValue = $schemaExcl;
|
|
||||||
$notOp += '=';
|
|
||||||
} else {
|
|
||||||
if ($exclIsNumber)
|
|
||||||
$schemaValue = Math[$isMax ? 'min' : 'max']($schemaExcl, $schema);
|
|
||||||
|
|
||||||
if ($schemaExcl === ($exclIsNumber ? $schemaValue : true)) {
|
|
||||||
{{# def.setExclusiveLimit }}
|
|
||||||
$notOp += '=';
|
|
||||||
} else {
|
|
||||||
$exclusive = false;
|
|
||||||
$opStr += '=';
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
var $opExpr = '\'' + $opStr + '\''; /*used in error*/
|
|
||||||
}}
|
|
||||||
|
|
||||||
if ({{# def.$dataNotType:'number' }}
|
|
||||||
{{=$data}} {{=$notOp}} {{=$schemaValue}}
|
|
||||||
|| {{=$data}} !== {{=$data}}) {
|
|
||||||
{{?}}
|
|
||||||
{{?}}
|
|
||||||
{{ $errorKeyword = $errorKeyword || $keyword; }}
|
|
||||||
{{# def.error:'_limit' }}
|
|
||||||
} {{? $breakOnError }} else { {{?}}
|
|
||||||
12
node_modules/ajv/lib/dot/_limitItems.jst
generated
vendored
12
node_modules/ajv/lib/dot/_limitItems.jst
generated
vendored
@@ -1,12 +0,0 @@
|
|||||||
{{# def.definitions }}
|
|
||||||
{{# def.errors }}
|
|
||||||
{{# def.setupKeyword }}
|
|
||||||
{{# def.$data }}
|
|
||||||
|
|
||||||
{{# def.numberKeyword }}
|
|
||||||
|
|
||||||
{{ var $op = $keyword == 'maxItems' ? '>' : '<'; }}
|
|
||||||
if ({{# def.$dataNotType:'number' }} {{=$data}}.length {{=$op}} {{=$schemaValue}}) {
|
|
||||||
{{ var $errorKeyword = $keyword; }}
|
|
||||||
{{# def.error:'_limitItems' }}
|
|
||||||
} {{? $breakOnError }} else { {{?}}
|
|
||||||
12
node_modules/ajv/lib/dot/_limitLength.jst
generated
vendored
12
node_modules/ajv/lib/dot/_limitLength.jst
generated
vendored
@@ -1,12 +0,0 @@
|
|||||||
{{# def.definitions }}
|
|
||||||
{{# def.errors }}
|
|
||||||
{{# def.setupKeyword }}
|
|
||||||
{{# def.$data }}
|
|
||||||
|
|
||||||
{{# def.numberKeyword }}
|
|
||||||
|
|
||||||
{{ var $op = $keyword == 'maxLength' ? '>' : '<'; }}
|
|
||||||
if ({{# def.$dataNotType:'number' }} {{# def.strLength }} {{=$op}} {{=$schemaValue}}) {
|
|
||||||
{{ var $errorKeyword = $keyword; }}
|
|
||||||
{{# def.error:'_limitLength' }}
|
|
||||||
} {{? $breakOnError }} else { {{?}}
|
|
||||||
12
node_modules/ajv/lib/dot/_limitProperties.jst
generated
vendored
12
node_modules/ajv/lib/dot/_limitProperties.jst
generated
vendored
@@ -1,12 +0,0 @@
|
|||||||
{{# def.definitions }}
|
|
||||||
{{# def.errors }}
|
|
||||||
{{# def.setupKeyword }}
|
|
||||||
{{# def.$data }}
|
|
||||||
|
|
||||||
{{# def.numberKeyword }}
|
|
||||||
|
|
||||||
{{ var $op = $keyword == 'maxProperties' ? '>' : '<'; }}
|
|
||||||
if ({{# def.$dataNotType:'number' }} Object.keys({{=$data}}).length {{=$op}} {{=$schemaValue}}) {
|
|
||||||
{{ var $errorKeyword = $keyword; }}
|
|
||||||
{{# def.error:'_limitProperties' }}
|
|
||||||
} {{? $breakOnError }} else { {{?}}
|
|
||||||
32
node_modules/ajv/lib/dot/allOf.jst
generated
vendored
32
node_modules/ajv/lib/dot/allOf.jst
generated
vendored
@@ -1,32 +0,0 @@
|
|||||||
{{# def.definitions }}
|
|
||||||
{{# def.errors }}
|
|
||||||
{{# def.setupKeyword }}
|
|
||||||
{{# def.setupNextLevel }}
|
|
||||||
|
|
||||||
{{
|
|
||||||
var $currentBaseId = $it.baseId
|
|
||||||
, $allSchemasEmpty = true;
|
|
||||||
}}
|
|
||||||
|
|
||||||
{{~ $schema:$sch:$i }}
|
|
||||||
{{? {{# def.nonEmptySchema:$sch }} }}
|
|
||||||
{{
|
|
||||||
$allSchemasEmpty = false;
|
|
||||||
$it.schema = $sch;
|
|
||||||
$it.schemaPath = $schemaPath + '[' + $i + ']';
|
|
||||||
$it.errSchemaPath = $errSchemaPath + '/' + $i;
|
|
||||||
}}
|
|
||||||
|
|
||||||
{{# def.insertSubschemaCode }}
|
|
||||||
|
|
||||||
{{# def.ifResultValid }}
|
|
||||||
{{?}}
|
|
||||||
{{~}}
|
|
||||||
|
|
||||||
{{? $breakOnError }}
|
|
||||||
{{? $allSchemasEmpty }}
|
|
||||||
if (true) {
|
|
||||||
{{??}}
|
|
||||||
{{= $closingBraces.slice(0,-1) }}
|
|
||||||
{{?}}
|
|
||||||
{{?}}
|
|
||||||
46
node_modules/ajv/lib/dot/anyOf.jst
generated
vendored
46
node_modules/ajv/lib/dot/anyOf.jst
generated
vendored
@@ -1,46 +0,0 @@
|
|||||||
{{# def.definitions }}
|
|
||||||
{{# def.errors }}
|
|
||||||
{{# def.setupKeyword }}
|
|
||||||
{{# def.setupNextLevel }}
|
|
||||||
|
|
||||||
{{
|
|
||||||
var $noEmptySchema = $schema.every(function($sch) {
|
|
||||||
return {{# def.nonEmptySchema:$sch }};
|
|
||||||
});
|
|
||||||
}}
|
|
||||||
{{? $noEmptySchema }}
|
|
||||||
{{ var $currentBaseId = $it.baseId; }}
|
|
||||||
var {{=$errs}} = errors;
|
|
||||||
var {{=$valid}} = false;
|
|
||||||
|
|
||||||
{{# def.setCompositeRule }}
|
|
||||||
|
|
||||||
{{~ $schema:$sch:$i }}
|
|
||||||
{{
|
|
||||||
$it.schema = $sch;
|
|
||||||
$it.schemaPath = $schemaPath + '[' + $i + ']';
|
|
||||||
$it.errSchemaPath = $errSchemaPath + '/' + $i;
|
|
||||||
}}
|
|
||||||
|
|
||||||
{{# def.insertSubschemaCode }}
|
|
||||||
|
|
||||||
{{=$valid}} = {{=$valid}} || {{=$nextValid}};
|
|
||||||
|
|
||||||
if (!{{=$valid}}) {
|
|
||||||
{{ $closingBraces += '}'; }}
|
|
||||||
{{~}}
|
|
||||||
|
|
||||||
{{# def.resetCompositeRule }}
|
|
||||||
|
|
||||||
{{= $closingBraces }}
|
|
||||||
|
|
||||||
if (!{{=$valid}}) {
|
|
||||||
{{# def.extraError:'anyOf' }}
|
|
||||||
} else {
|
|
||||||
{{# def.resetErrors }}
|
|
||||||
{{? it.opts.allErrors }} } {{?}}
|
|
||||||
{{??}}
|
|
||||||
{{? $breakOnError }}
|
|
||||||
if (true) {
|
|
||||||
{{?}}
|
|
||||||
{{?}}
|
|
||||||
51
node_modules/ajv/lib/dot/coerce.def
generated
vendored
51
node_modules/ajv/lib/dot/coerce.def
generated
vendored
@@ -1,51 +0,0 @@
|
|||||||
{{## def.coerceType:
|
|
||||||
{{
|
|
||||||
var $dataType = 'dataType' + $lvl
|
|
||||||
, $coerced = 'coerced' + $lvl;
|
|
||||||
}}
|
|
||||||
var {{=$dataType}} = typeof {{=$data}};
|
|
||||||
var {{=$coerced}} = undefined;
|
|
||||||
|
|
||||||
{{? it.opts.coerceTypes == 'array' }}
|
|
||||||
if ({{=$dataType}} == 'object' && Array.isArray({{=$data}}) && {{=$data}}.length == 1) {
|
|
||||||
{{=$data}} = {{=$data}}[0];
|
|
||||||
{{=$dataType}} = typeof {{=$data}};
|
|
||||||
if ({{=it.util.checkDataType(it.schema.type, $data, it.opts.strictNumbers)}}) {{=$coerced}} = {{=$data}};
|
|
||||||
}
|
|
||||||
{{?}}
|
|
||||||
|
|
||||||
if ({{=$coerced}} !== undefined) ;
|
|
||||||
{{~ $coerceToTypes:$type:$i }}
|
|
||||||
{{? $type == 'string' }}
|
|
||||||
else if ({{=$dataType}} == 'number' || {{=$dataType}} == 'boolean')
|
|
||||||
{{=$coerced}} = '' + {{=$data}};
|
|
||||||
else if ({{=$data}} === null) {{=$coerced}} = '';
|
|
||||||
{{?? $type == 'number' || $type == 'integer' }}
|
|
||||||
else if ({{=$dataType}} == 'boolean' || {{=$data}} === null
|
|
||||||
|| ({{=$dataType}} == 'string' && {{=$data}} && {{=$data}} == +{{=$data}}
|
|
||||||
{{? $type == 'integer' }} && !({{=$data}} % 1){{?}}))
|
|
||||||
{{=$coerced}} = +{{=$data}};
|
|
||||||
{{?? $type == 'boolean' }}
|
|
||||||
else if ({{=$data}} === 'false' || {{=$data}} === 0 || {{=$data}} === null)
|
|
||||||
{{=$coerced}} = false;
|
|
||||||
else if ({{=$data}} === 'true' || {{=$data}} === 1)
|
|
||||||
{{=$coerced}} = true;
|
|
||||||
{{?? $type == 'null' }}
|
|
||||||
else if ({{=$data}} === '' || {{=$data}} === 0 || {{=$data}} === false)
|
|
||||||
{{=$coerced}} = null;
|
|
||||||
{{?? it.opts.coerceTypes == 'array' && $type == 'array' }}
|
|
||||||
else if ({{=$dataType}} == 'string' || {{=$dataType}} == 'number' || {{=$dataType}} == 'boolean' || {{=$data}} == null)
|
|
||||||
{{=$coerced}} = [{{=$data}}];
|
|
||||||
{{?}}
|
|
||||||
{{~}}
|
|
||||||
else {
|
|
||||||
{{# def.error:'type' }}
|
|
||||||
}
|
|
||||||
|
|
||||||
if ({{=$coerced}} !== undefined) {
|
|
||||||
{{# def.setParentData }}
|
|
||||||
{{=$data}} = {{=$coerced}};
|
|
||||||
{{? !$dataLvl }}if ({{=$parentData}} !== undefined){{?}}
|
|
||||||
{{=$parentData}}[{{=$parentDataProperty}}] = {{=$coerced}};
|
|
||||||
}
|
|
||||||
#}}
|
|
||||||
9
node_modules/ajv/lib/dot/comment.jst
generated
vendored
9
node_modules/ajv/lib/dot/comment.jst
generated
vendored
@@ -1,9 +0,0 @@
|
|||||||
{{# def.definitions }}
|
|
||||||
{{# def.setupKeyword }}
|
|
||||||
|
|
||||||
{{ var $comment = it.util.toQuotedString($schema); }}
|
|
||||||
{{? it.opts.$comment === true }}
|
|
||||||
console.log({{=$comment}});
|
|
||||||
{{?? typeof it.opts.$comment == 'function' }}
|
|
||||||
self._opts.$comment({{=$comment}}, {{=it.util.toQuotedString($errSchemaPath)}}, validate.root.schema);
|
|
||||||
{{?}}
|
|
||||||
11
node_modules/ajv/lib/dot/const.jst
generated
vendored
11
node_modules/ajv/lib/dot/const.jst
generated
vendored
@@ -1,11 +0,0 @@
|
|||||||
{{# def.definitions }}
|
|
||||||
{{# def.errors }}
|
|
||||||
{{# def.setupKeyword }}
|
|
||||||
{{# def.$data }}
|
|
||||||
|
|
||||||
{{? !$isData }}
|
|
||||||
var schema{{=$lvl}} = validate.schema{{=$schemaPath}};
|
|
||||||
{{?}}
|
|
||||||
var {{=$valid}} = equal({{=$data}}, schema{{=$lvl}});
|
|
||||||
{{# def.checkError:'const' }}
|
|
||||||
{{? $breakOnError }} else { {{?}}
|
|
||||||
55
node_modules/ajv/lib/dot/contains.jst
generated
vendored
55
node_modules/ajv/lib/dot/contains.jst
generated
vendored
@@ -1,55 +0,0 @@
|
|||||||
{{# def.definitions }}
|
|
||||||
{{# def.errors }}
|
|
||||||
{{# def.setupKeyword }}
|
|
||||||
{{# def.setupNextLevel }}
|
|
||||||
|
|
||||||
|
|
||||||
{{
|
|
||||||
var $idx = 'i' + $lvl
|
|
||||||
, $dataNxt = $it.dataLevel = it.dataLevel + 1
|
|
||||||
, $nextData = 'data' + $dataNxt
|
|
||||||
, $currentBaseId = it.baseId
|
|
||||||
, $nonEmptySchema = {{# def.nonEmptySchema:$schema }};
|
|
||||||
}}
|
|
||||||
|
|
||||||
var {{=$errs}} = errors;
|
|
||||||
var {{=$valid}};
|
|
||||||
|
|
||||||
{{? $nonEmptySchema }}
|
|
||||||
{{# def.setCompositeRule }}
|
|
||||||
|
|
||||||
{{
|
|
||||||
$it.schema = $schema;
|
|
||||||
$it.schemaPath = $schemaPath;
|
|
||||||
$it.errSchemaPath = $errSchemaPath;
|
|
||||||
}}
|
|
||||||
|
|
||||||
var {{=$nextValid}} = false;
|
|
||||||
|
|
||||||
for (var {{=$idx}} = 0; {{=$idx}} < {{=$data}}.length; {{=$idx}}++) {
|
|
||||||
{{
|
|
||||||
$it.errorPath = it.util.getPathExpr(it.errorPath, $idx, it.opts.jsonPointers, true);
|
|
||||||
var $passData = $data + '[' + $idx + ']';
|
|
||||||
$it.dataPathArr[$dataNxt] = $idx;
|
|
||||||
}}
|
|
||||||
|
|
||||||
{{# def.generateSubschemaCode }}
|
|
||||||
{{# def.optimizeValidate }}
|
|
||||||
|
|
||||||
if ({{=$nextValid}}) break;
|
|
||||||
}
|
|
||||||
|
|
||||||
{{# def.resetCompositeRule }}
|
|
||||||
{{= $closingBraces }}
|
|
||||||
|
|
||||||
if (!{{=$nextValid}}) {
|
|
||||||
{{??}}
|
|
||||||
if ({{=$data}}.length == 0) {
|
|
||||||
{{?}}
|
|
||||||
|
|
||||||
{{# def.error:'contains' }}
|
|
||||||
} else {
|
|
||||||
{{? $nonEmptySchema }}
|
|
||||||
{{# def.resetErrors }}
|
|
||||||
{{?}}
|
|
||||||
{{? it.opts.allErrors }} } {{?}}
|
|
||||||
191
node_modules/ajv/lib/dot/custom.jst
generated
vendored
191
node_modules/ajv/lib/dot/custom.jst
generated
vendored
@@ -1,191 +0,0 @@
|
|||||||
{{# def.definitions }}
|
|
||||||
{{# def.errors }}
|
|
||||||
{{# def.setupKeyword }}
|
|
||||||
{{# def.$data }}
|
|
||||||
|
|
||||||
{{
|
|
||||||
var $rule = this
|
|
||||||
, $definition = 'definition' + $lvl
|
|
||||||
, $rDef = $rule.definition
|
|
||||||
, $closingBraces = '';
|
|
||||||
var $validate = $rDef.validate;
|
|
||||||
var $compile, $inline, $macro, $ruleValidate, $validateCode;
|
|
||||||
}}
|
|
||||||
|
|
||||||
{{? $isData && $rDef.$data }}
|
|
||||||
{{
|
|
||||||
$validateCode = 'keywordValidate' + $lvl;
|
|
||||||
var $validateSchema = $rDef.validateSchema;
|
|
||||||
}}
|
|
||||||
var {{=$definition}} = RULES.custom['{{=$keyword}}'].definition;
|
|
||||||
var {{=$validateCode}} = {{=$definition}}.validate;
|
|
||||||
{{??}}
|
|
||||||
{{
|
|
||||||
$ruleValidate = it.useCustomRule($rule, $schema, it.schema, it);
|
|
||||||
if (!$ruleValidate) return;
|
|
||||||
$schemaValue = 'validate.schema' + $schemaPath;
|
|
||||||
$validateCode = $ruleValidate.code;
|
|
||||||
$compile = $rDef.compile;
|
|
||||||
$inline = $rDef.inline;
|
|
||||||
$macro = $rDef.macro;
|
|
||||||
}}
|
|
||||||
{{?}}
|
|
||||||
|
|
||||||
{{
|
|
||||||
var $ruleErrs = $validateCode + '.errors'
|
|
||||||
, $i = 'i' + $lvl
|
|
||||||
, $ruleErr = 'ruleErr' + $lvl
|
|
||||||
, $asyncKeyword = $rDef.async;
|
|
||||||
|
|
||||||
if ($asyncKeyword && !it.async)
|
|
||||||
throw new Error('async keyword in sync schema');
|
|
||||||
}}
|
|
||||||
|
|
||||||
|
|
||||||
{{? !($inline || $macro) }}{{=$ruleErrs}} = null;{{?}}
|
|
||||||
var {{=$errs}} = errors;
|
|
||||||
var {{=$valid}};
|
|
||||||
|
|
||||||
{{## def.callRuleValidate:
|
|
||||||
{{=$validateCode}}.call(
|
|
||||||
{{? it.opts.passContext }}this{{??}}self{{?}}
|
|
||||||
{{? $compile || $rDef.schema === false }}
|
|
||||||
, {{=$data}}
|
|
||||||
{{??}}
|
|
||||||
, {{=$schemaValue}}
|
|
||||||
, {{=$data}}
|
|
||||||
, validate.schema{{=it.schemaPath}}
|
|
||||||
{{?}}
|
|
||||||
, {{# def.dataPath }}
|
|
||||||
{{# def.passParentData }}
|
|
||||||
, rootData
|
|
||||||
)
|
|
||||||
#}}
|
|
||||||
|
|
||||||
{{## def.extendErrors:_inline:
|
|
||||||
for (var {{=$i}}={{=$errs}}; {{=$i}}<errors; {{=$i}}++) {
|
|
||||||
var {{=$ruleErr}} = vErrors[{{=$i}}];
|
|
||||||
if ({{=$ruleErr}}.dataPath === undefined)
|
|
||||||
{{=$ruleErr}}.dataPath = (dataPath || '') + {{= it.errorPath }};
|
|
||||||
{{# _inline ? 'if (\{\{=$ruleErr\}\}.schemaPath === undefined) {' : '' }}
|
|
||||||
{{=$ruleErr}}.schemaPath = "{{=$errSchemaPath}}";
|
|
||||||
{{# _inline ? '}' : '' }}
|
|
||||||
{{? it.opts.verbose }}
|
|
||||||
{{=$ruleErr}}.schema = {{=$schemaValue}};
|
|
||||||
{{=$ruleErr}}.data = {{=$data}};
|
|
||||||
{{?}}
|
|
||||||
}
|
|
||||||
#}}
|
|
||||||
|
|
||||||
|
|
||||||
{{? $isData && $rDef.$data }}
|
|
||||||
{{ $closingBraces += '}'; }}
|
|
||||||
if ({{=$schemaValue}} === undefined) {
|
|
||||||
{{=$valid}} = true;
|
|
||||||
} else {
|
|
||||||
{{? $validateSchema }}
|
|
||||||
{{ $closingBraces += '}'; }}
|
|
||||||
{{=$valid}} = {{=$definition}}.validateSchema({{=$schemaValue}});
|
|
||||||
if ({{=$valid}}) {
|
|
||||||
{{?}}
|
|
||||||
{{?}}
|
|
||||||
|
|
||||||
{{? $inline }}
|
|
||||||
{{? $rDef.statements }}
|
|
||||||
{{= $ruleValidate.validate }}
|
|
||||||
{{??}}
|
|
||||||
{{=$valid}} = {{= $ruleValidate.validate }};
|
|
||||||
{{?}}
|
|
||||||
{{?? $macro }}
|
|
||||||
{{# def.setupNextLevel }}
|
|
||||||
{{
|
|
||||||
$it.schema = $ruleValidate.validate;
|
|
||||||
$it.schemaPath = '';
|
|
||||||
}}
|
|
||||||
{{# def.setCompositeRule }}
|
|
||||||
{{ var $code = it.validate($it).replace(/validate\.schema/g, $validateCode); }}
|
|
||||||
{{# def.resetCompositeRule }}
|
|
||||||
{{= $code }}
|
|
||||||
{{??}}
|
|
||||||
{{# def.beginDefOut}}
|
|
||||||
{{# def.callRuleValidate }}
|
|
||||||
{{# def.storeDefOut:def_callRuleValidate }}
|
|
||||||
|
|
||||||
{{? $rDef.errors === false }}
|
|
||||||
{{=$valid}} = {{? $asyncKeyword }}await {{?}}{{= def_callRuleValidate }};
|
|
||||||
{{??}}
|
|
||||||
{{? $asyncKeyword }}
|
|
||||||
{{ $ruleErrs = 'customErrors' + $lvl; }}
|
|
||||||
var {{=$ruleErrs}} = null;
|
|
||||||
try {
|
|
||||||
{{=$valid}} = await {{= def_callRuleValidate }};
|
|
||||||
} catch (e) {
|
|
||||||
{{=$valid}} = false;
|
|
||||||
if (e instanceof ValidationError) {{=$ruleErrs}} = e.errors;
|
|
||||||
else throw e;
|
|
||||||
}
|
|
||||||
{{??}}
|
|
||||||
{{=$ruleErrs}} = null;
|
|
||||||
{{=$valid}} = {{= def_callRuleValidate }};
|
|
||||||
{{?}}
|
|
||||||
{{?}}
|
|
||||||
{{?}}
|
|
||||||
|
|
||||||
{{? $rDef.modifying }}
|
|
||||||
if ({{=$parentData}}) {{=$data}} = {{=$parentData}}[{{=$parentDataProperty}}];
|
|
||||||
{{?}}
|
|
||||||
|
|
||||||
{{= $closingBraces }}
|
|
||||||
|
|
||||||
{{## def.notValidationResult:
|
|
||||||
{{? $rDef.valid === undefined }}
|
|
||||||
!{{? $macro }}{{=$nextValid}}{{??}}{{=$valid}}{{?}}
|
|
||||||
{{??}}
|
|
||||||
{{= !$rDef.valid }}
|
|
||||||
{{?}}
|
|
||||||
#}}
|
|
||||||
|
|
||||||
{{? $rDef.valid }}
|
|
||||||
{{? $breakOnError }} if (true) { {{?}}
|
|
||||||
{{??}}
|
|
||||||
if ({{# def.notValidationResult }}) {
|
|
||||||
{{ $errorKeyword = $rule.keyword; }}
|
|
||||||
{{# def.beginDefOut}}
|
|
||||||
{{# def.error:'custom' }}
|
|
||||||
{{# def.storeDefOut:def_customError }}
|
|
||||||
|
|
||||||
{{? $inline }}
|
|
||||||
{{? $rDef.errors }}
|
|
||||||
{{? $rDef.errors != 'full' }}
|
|
||||||
{{# def.extendErrors:true }}
|
|
||||||
{{?}}
|
|
||||||
{{??}}
|
|
||||||
{{? $rDef.errors === false}}
|
|
||||||
{{= def_customError }}
|
|
||||||
{{??}}
|
|
||||||
if ({{=$errs}} == errors) {
|
|
||||||
{{= def_customError }}
|
|
||||||
} else {
|
|
||||||
{{# def.extendErrors:true }}
|
|
||||||
}
|
|
||||||
{{?}}
|
|
||||||
{{?}}
|
|
||||||
{{?? $macro }}
|
|
||||||
{{# def.extraError:'custom' }}
|
|
||||||
{{??}}
|
|
||||||
{{? $rDef.errors === false}}
|
|
||||||
{{= def_customError }}
|
|
||||||
{{??}}
|
|
||||||
if (Array.isArray({{=$ruleErrs}})) {
|
|
||||||
if (vErrors === null) vErrors = {{=$ruleErrs}};
|
|
||||||
else vErrors = vErrors.concat({{=$ruleErrs}});
|
|
||||||
errors = vErrors.length;
|
|
||||||
{{# def.extendErrors:false }}
|
|
||||||
} else {
|
|
||||||
{{= def_customError }}
|
|
||||||
}
|
|
||||||
{{?}}
|
|
||||||
{{?}}
|
|
||||||
|
|
||||||
} {{? $breakOnError }} else { {{?}}
|
|
||||||
{{?}}
|
|
||||||
47
node_modules/ajv/lib/dot/defaults.def
generated
vendored
47
node_modules/ajv/lib/dot/defaults.def
generated
vendored
@@ -1,47 +0,0 @@
|
|||||||
{{## def.assignDefault:
|
|
||||||
{{? it.compositeRule }}
|
|
||||||
{{
|
|
||||||
if (it.opts.strictDefaults) {
|
|
||||||
var $defaultMsg = 'default is ignored for: ' + $passData;
|
|
||||||
if (it.opts.strictDefaults === 'log') it.logger.warn($defaultMsg);
|
|
||||||
else throw new Error($defaultMsg);
|
|
||||||
}
|
|
||||||
}}
|
|
||||||
{{??}}
|
|
||||||
if ({{=$passData}} === undefined
|
|
||||||
{{? it.opts.useDefaults == 'empty' }}
|
|
||||||
|| {{=$passData}} === null
|
|
||||||
|| {{=$passData}} === ''
|
|
||||||
{{?}}
|
|
||||||
)
|
|
||||||
{{=$passData}} = {{? it.opts.useDefaults == 'shared' }}
|
|
||||||
{{= it.useDefault($sch.default) }}
|
|
||||||
{{??}}
|
|
||||||
{{= JSON.stringify($sch.default) }}
|
|
||||||
{{?}};
|
|
||||||
{{?}}
|
|
||||||
#}}
|
|
||||||
|
|
||||||
|
|
||||||
{{## def.defaultProperties:
|
|
||||||
{{
|
|
||||||
var $schema = it.schema.properties
|
|
||||||
, $schemaKeys = Object.keys($schema); }}
|
|
||||||
{{~ $schemaKeys:$propertyKey }}
|
|
||||||
{{ var $sch = $schema[$propertyKey]; }}
|
|
||||||
{{? $sch.default !== undefined }}
|
|
||||||
{{ var $passData = $data + it.util.getProperty($propertyKey); }}
|
|
||||||
{{# def.assignDefault }}
|
|
||||||
{{?}}
|
|
||||||
{{~}}
|
|
||||||
#}}
|
|
||||||
|
|
||||||
|
|
||||||
{{## def.defaultItems:
|
|
||||||
{{~ it.schema.items:$sch:$i }}
|
|
||||||
{{? $sch.default !== undefined }}
|
|
||||||
{{ var $passData = $data + '[' + $i + ']'; }}
|
|
||||||
{{# def.assignDefault }}
|
|
||||||
{{?}}
|
|
||||||
{{~}}
|
|
||||||
#}}
|
|
||||||
203
node_modules/ajv/lib/dot/definitions.def
generated
vendored
203
node_modules/ajv/lib/dot/definitions.def
generated
vendored
@@ -1,203 +0,0 @@
|
|||||||
{{## def.setupKeyword:
|
|
||||||
{{
|
|
||||||
var $lvl = it.level;
|
|
||||||
var $dataLvl = it.dataLevel;
|
|
||||||
var $schema = it.schema[$keyword];
|
|
||||||
var $schemaPath = it.schemaPath + it.util.getProperty($keyword);
|
|
||||||
var $errSchemaPath = it.errSchemaPath + '/' + $keyword;
|
|
||||||
var $breakOnError = !it.opts.allErrors;
|
|
||||||
var $errorKeyword;
|
|
||||||
|
|
||||||
var $data = 'data' + ($dataLvl || '');
|
|
||||||
var $valid = 'valid' + $lvl;
|
|
||||||
var $errs = 'errs__' + $lvl;
|
|
||||||
}}
|
|
||||||
#}}
|
|
||||||
|
|
||||||
|
|
||||||
{{## def.setCompositeRule:
|
|
||||||
{{
|
|
||||||
var $wasComposite = it.compositeRule;
|
|
||||||
it.compositeRule = $it.compositeRule = true;
|
|
||||||
}}
|
|
||||||
#}}
|
|
||||||
|
|
||||||
|
|
||||||
{{## def.resetCompositeRule:
|
|
||||||
{{ it.compositeRule = $it.compositeRule = $wasComposite; }}
|
|
||||||
#}}
|
|
||||||
|
|
||||||
|
|
||||||
{{## def.setupNextLevel:
|
|
||||||
{{
|
|
||||||
var $it = it.util.copy(it);
|
|
||||||
var $closingBraces = '';
|
|
||||||
$it.level++;
|
|
||||||
var $nextValid = 'valid' + $it.level;
|
|
||||||
}}
|
|
||||||
#}}
|
|
||||||
|
|
||||||
|
|
||||||
{{## def.ifValid:
|
|
||||||
{{? $breakOnError }}
|
|
||||||
if ({{=$valid}}) {
|
|
||||||
{{ $closingBraces += '}'; }}
|
|
||||||
{{?}}
|
|
||||||
#}}
|
|
||||||
|
|
||||||
|
|
||||||
{{## def.ifResultValid:
|
|
||||||
{{? $breakOnError }}
|
|
||||||
if ({{=$nextValid}}) {
|
|
||||||
{{ $closingBraces += '}'; }}
|
|
||||||
{{?}}
|
|
||||||
#}}
|
|
||||||
|
|
||||||
|
|
||||||
{{## def.elseIfValid:
|
|
||||||
{{? $breakOnError }}
|
|
||||||
{{ $closingBraces += '}'; }}
|
|
||||||
else {
|
|
||||||
{{?}}
|
|
||||||
#}}
|
|
||||||
|
|
||||||
|
|
||||||
{{## def.nonEmptySchema:_schema:
|
|
||||||
(it.opts.strictKeywords
|
|
||||||
? (typeof _schema == 'object' && Object.keys(_schema).length > 0)
|
|
||||||
|| _schema === false
|
|
||||||
: it.util.schemaHasRules(_schema, it.RULES.all))
|
|
||||||
#}}
|
|
||||||
|
|
||||||
|
|
||||||
{{## def.strLength:
|
|
||||||
{{? it.opts.unicode === false }}
|
|
||||||
{{=$data}}.length
|
|
||||||
{{??}}
|
|
||||||
ucs2length({{=$data}})
|
|
||||||
{{?}}
|
|
||||||
#}}
|
|
||||||
|
|
||||||
|
|
||||||
{{## def.willOptimize:
|
|
||||||
it.util.varOccurences($code, $nextData) < 2
|
|
||||||
#}}
|
|
||||||
|
|
||||||
|
|
||||||
{{## def.generateSubschemaCode:
|
|
||||||
{{
|
|
||||||
var $code = it.validate($it);
|
|
||||||
$it.baseId = $currentBaseId;
|
|
||||||
}}
|
|
||||||
#}}
|
|
||||||
|
|
||||||
|
|
||||||
{{## def.insertSubschemaCode:
|
|
||||||
{{= it.validate($it) }}
|
|
||||||
{{ $it.baseId = $currentBaseId; }}
|
|
||||||
#}}
|
|
||||||
|
|
||||||
|
|
||||||
{{## def._optimizeValidate:
|
|
||||||
it.util.varReplace($code, $nextData, $passData)
|
|
||||||
#}}
|
|
||||||
|
|
||||||
|
|
||||||
{{## def.optimizeValidate:
|
|
||||||
{{? {{# def.willOptimize}} }}
|
|
||||||
{{= {{# def._optimizeValidate }} }}
|
|
||||||
{{??}}
|
|
||||||
var {{=$nextData}} = {{=$passData}};
|
|
||||||
{{= $code }}
|
|
||||||
{{?}}
|
|
||||||
#}}
|
|
||||||
|
|
||||||
|
|
||||||
{{## def.$data:
|
|
||||||
{{
|
|
||||||
var $isData = it.opts.$data && $schema && $schema.$data
|
|
||||||
, $schemaValue;
|
|
||||||
}}
|
|
||||||
{{? $isData }}
|
|
||||||
var schema{{=$lvl}} = {{= it.util.getData($schema.$data, $dataLvl, it.dataPathArr) }};
|
|
||||||
{{ $schemaValue = 'schema' + $lvl; }}
|
|
||||||
{{??}}
|
|
||||||
{{ $schemaValue = $schema; }}
|
|
||||||
{{?}}
|
|
||||||
#}}
|
|
||||||
|
|
||||||
|
|
||||||
{{## def.$dataNotType:_type:
|
|
||||||
{{?$isData}} ({{=$schemaValue}} !== undefined && typeof {{=$schemaValue}} != _type) || {{?}}
|
|
||||||
#}}
|
|
||||||
|
|
||||||
|
|
||||||
{{## def.check$dataIsArray:
|
|
||||||
if (schema{{=$lvl}} === undefined) {{=$valid}} = true;
|
|
||||||
else if (!Array.isArray(schema{{=$lvl}})) {{=$valid}} = false;
|
|
||||||
else {
|
|
||||||
#}}
|
|
||||||
|
|
||||||
|
|
||||||
{{## def.numberKeyword:
|
|
||||||
{{? !($isData || typeof $schema == 'number') }}
|
|
||||||
{{ throw new Error($keyword + ' must be number'); }}
|
|
||||||
{{?}}
|
|
||||||
#}}
|
|
||||||
|
|
||||||
|
|
||||||
{{## def.beginDefOut:
|
|
||||||
{{
|
|
||||||
var $$outStack = $$outStack || [];
|
|
||||||
$$outStack.push(out);
|
|
||||||
out = '';
|
|
||||||
}}
|
|
||||||
#}}
|
|
||||||
|
|
||||||
|
|
||||||
{{## def.storeDefOut:_variable:
|
|
||||||
{{
|
|
||||||
var _variable = out;
|
|
||||||
out = $$outStack.pop();
|
|
||||||
}}
|
|
||||||
#}}
|
|
||||||
|
|
||||||
|
|
||||||
{{## def.dataPath:(dataPath || ''){{? it.errorPath != '""'}} + {{= it.errorPath }}{{?}}#}}
|
|
||||||
|
|
||||||
{{## def.setParentData:
|
|
||||||
{{
|
|
||||||
var $parentData = $dataLvl ? 'data' + (($dataLvl-1)||'') : 'parentData'
|
|
||||||
, $parentDataProperty = $dataLvl ? it.dataPathArr[$dataLvl] : 'parentDataProperty';
|
|
||||||
}}
|
|
||||||
#}}
|
|
||||||
|
|
||||||
{{## def.passParentData:
|
|
||||||
{{# def.setParentData }}
|
|
||||||
, {{= $parentData }}
|
|
||||||
, {{= $parentDataProperty }}
|
|
||||||
#}}
|
|
||||||
|
|
||||||
|
|
||||||
{{## def.iterateProperties:
|
|
||||||
{{? $ownProperties }}
|
|
||||||
{{=$dataProperties}} = {{=$dataProperties}} || Object.keys({{=$data}});
|
|
||||||
for (var {{=$idx}}=0; {{=$idx}}<{{=$dataProperties}}.length; {{=$idx}}++) {
|
|
||||||
var {{=$key}} = {{=$dataProperties}}[{{=$idx}}];
|
|
||||||
{{??}}
|
|
||||||
for (var {{=$key}} in {{=$data}}) {
|
|
||||||
{{?}}
|
|
||||||
#}}
|
|
||||||
|
|
||||||
|
|
||||||
{{## def.noPropertyInData:
|
|
||||||
{{=$useData}} === undefined
|
|
||||||
{{? $ownProperties }}
|
|
||||||
|| !{{# def.isOwnProperty }}
|
|
||||||
{{?}}
|
|
||||||
#}}
|
|
||||||
|
|
||||||
|
|
||||||
{{## def.isOwnProperty:
|
|
||||||
Object.prototype.hasOwnProperty.call({{=$data}}, '{{=it.util.escapeQuotes($propertyKey)}}')
|
|
||||||
#}}
|
|
||||||
Some files were not shown because too many files have changed in this diff Show More
Reference in New Issue
Block a user