Updated the files.
This commit is contained in:
parent
1553e6b971
commit
753967d4f5
23418 changed files with 3784666 additions and 0 deletions
15
my-app/node_modules/read-package-json-fast/LICENSE
generated
vendored
Executable file
15
my-app/node_modules/read-package-json-fast/LICENSE
generated
vendored
Executable file
|
@ -0,0 +1,15 @@
|
|||
The ISC License
|
||||
|
||||
Copyright (c) npm, Inc. and Contributors
|
||||
|
||||
Permission to use, copy, modify, and/or distribute this software for any
|
||||
purpose with or without fee is hereby granted, provided that the above
|
||||
copyright notice and this permission notice appear in all copies.
|
||||
|
||||
THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES
|
||||
WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF
|
||||
MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR
|
||||
ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES
|
||||
WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN
|
||||
ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF OR
|
||||
IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE.
|
79
my-app/node_modules/read-package-json-fast/README.md
generated
vendored
Executable file
79
my-app/node_modules/read-package-json-fast/README.md
generated
vendored
Executable file
|
@ -0,0 +1,79 @@
|
|||
# read-package-json-fast
|
||||
|
||||
Like [`read-package-json`](http://npm.im/read-package-json), but faster and
|
||||
more accepting of "missing" data.
|
||||
|
||||
This is only suitable for reading package.json files in a node_modules
|
||||
tree, since it doesn't do the various cleanups, normalization, and warnings
|
||||
that are beneficial at the root level in a package being published.
|
||||
|
||||
## USAGE
|
||||
|
||||
```js
|
||||
const rpj = require('read-package-json-fast')
|
||||
|
||||
// typical promisey type API
|
||||
rpj('/path/to/package.json')
|
||||
.then(data => ...)
|
||||
.catch(er => ...)
|
||||
|
||||
// or just normalize a package manifest
|
||||
const normalized = rpj.normalize(packageJsonObject)
|
||||
```
|
||||
|
||||
Errors raised from parsing will use
|
||||
[`json-parse-even-better-errors`](http://npm.im/json-parse-even-better-errors),
|
||||
so they'll be of type `JSONParseError` and have a `code: 'EJSONPARSE'`
|
||||
property. Errors will also always have a `path` member referring to the
|
||||
path originally passed into the function.
|
||||
|
||||
## Indentation
|
||||
|
||||
To preserve indentation when the file is saved back to disk, use
|
||||
`data[Symbol.for('indent')]` as the third argument to `JSON.stringify`, and
|
||||
if you want to preserve windows `\r\n` newlines, replace the `\n` chars in
|
||||
the string with `data[Symbol.for('newline')]`.
|
||||
|
||||
For example:
|
||||
|
||||
```js
|
||||
const data = await readPackageJsonFast('./package.json')
|
||||
const indent = Symbol.for('indent')
|
||||
const newline = Symbol.for('newline')
|
||||
// .. do some stuff to the data ..
|
||||
const string = JSON.stringify(data, null, data[indent]) + '\n'
|
||||
const eolFixed = data[newline] === '\n' ? string
|
||||
: string.replace(/\n/g, data[newline])
|
||||
await writeFile('./package.json', eolFixed)
|
||||
```
|
||||
|
||||
Indentation is determined by looking at the whitespace between the initial
|
||||
`{` and the first `"` that follows it. If you have lots of weird
|
||||
inconsistent indentation, then it won't track that or give you any way to
|
||||
preserve it. Whether this is a bug or a feature is debatable ;)
|
||||
|
||||
## WHAT THIS MODULE DOES
|
||||
|
||||
- Parse JSON
|
||||
- Normalize `bundledDependencies`/`bundleDependencies` naming to just
|
||||
`bundleDependencies` (without the extra `d`)
|
||||
- Handle `true`, `false`, or object values passed to `bundleDependencies`
|
||||
- Normalize `funding: <string>` to `funding: { url: <string> }`
|
||||
- Remove any `scripts` members that are not a string value.
|
||||
- Normalize a string `bin` member to `{ [name]: bin }`.
|
||||
- Fold `optionalDependencies` into `dependencies`.
|
||||
- Set the `_id` property if name and version are set. (This is
|
||||
load-bearing in a few places within the npm CLI.)
|
||||
|
||||
## WHAT THIS MODULE DOES NOT DO
|
||||
|
||||
- Warn about invalid/missing name, version, repository, etc.
|
||||
- Extract a description from the `README.md` file, or attach the readme to
|
||||
the parsed data object.
|
||||
- Read the `HEAD` value out of the `.git` folder.
|
||||
- Warn about potentially typo'ed scripts (eg, `tset` instead of `test`)
|
||||
- Check to make sure that all the files in the `files` field exist and are
|
||||
valid files.
|
||||
- Fix bundleDependencies that are not listed in `dependencies`.
|
||||
- Fix `dependencies` fields that are not strictly objects of string values.
|
||||
- Anything involving the `directories` field (ie, bins, mans, and so on).
|
141
my-app/node_modules/read-package-json-fast/lib/index.js
generated
vendored
Executable file
141
my-app/node_modules/read-package-json-fast/lib/index.js
generated
vendored
Executable file
|
@ -0,0 +1,141 @@
|
|||
const { readFile, lstat, readdir } = require('fs/promises')
|
||||
const parse = require('json-parse-even-better-errors')
|
||||
const normalizePackageBin = require('npm-normalize-package-bin')
|
||||
const { resolve, dirname, join, relative } = require('path')
|
||||
|
||||
const rpj = path => readFile(path, 'utf8')
|
||||
.then(data => readBinDir(path, normalize(stripUnderscores(parse(data)))))
|
||||
.catch(er => {
|
||||
er.path = path
|
||||
throw er
|
||||
})
|
||||
|
||||
// load the directories.bin folder as a 'bin' object
|
||||
const readBinDir = async (path, data) => {
|
||||
if (data.bin) {
|
||||
return data
|
||||
}
|
||||
|
||||
const m = data.directories && data.directories.bin
|
||||
if (!m || typeof m !== 'string') {
|
||||
return data
|
||||
}
|
||||
|
||||
// cut off any monkey business, like setting directories.bin
|
||||
// to ../../../etc/passwd or /etc/passwd or something like that.
|
||||
const root = dirname(path)
|
||||
const dir = join('.', join('/', m))
|
||||
data.bin = await walkBinDir(root, dir, {})
|
||||
return data
|
||||
}
|
||||
|
||||
const walkBinDir = async (root, dir, obj) => {
|
||||
const entries = await readdir(resolve(root, dir)).catch(() => [])
|
||||
for (const entry of entries) {
|
||||
if (entry.charAt(0) === '.') {
|
||||
continue
|
||||
}
|
||||
const f = resolve(root, dir, entry)
|
||||
// ignore stat errors, weird file types, symlinks, etc.
|
||||
const st = await lstat(f).catch(() => null)
|
||||
if (!st) {
|
||||
continue
|
||||
} else if (st.isFile()) {
|
||||
obj[entry] = relative(root, f)
|
||||
} else if (st.isDirectory()) {
|
||||
await walkBinDir(root, join(dir, entry), obj)
|
||||
}
|
||||
}
|
||||
return obj
|
||||
}
|
||||
|
||||
// do not preserve _fields set in files, they are sus
|
||||
const stripUnderscores = data => {
|
||||
for (const key of Object.keys(data).filter(k => /^_/.test(k))) {
|
||||
delete data[key]
|
||||
}
|
||||
return data
|
||||
}
|
||||
|
||||
const normalize = data => {
|
||||
addId(data)
|
||||
fixBundled(data)
|
||||
pruneRepeatedOptionals(data)
|
||||
fixScripts(data)
|
||||
fixFunding(data)
|
||||
normalizePackageBin(data)
|
||||
return data
|
||||
}
|
||||
|
||||
rpj.normalize = normalize
|
||||
|
||||
const addId = data => {
|
||||
if (data.name && data.version) {
|
||||
data._id = `${data.name}@${data.version}`
|
||||
}
|
||||
return data
|
||||
}
|
||||
|
||||
// it was once common practice to list deps both in optionalDependencies
|
||||
// and in dependencies, to support npm versions that did not know abbout
|
||||
// optionalDependencies. This is no longer a relevant need, so duplicating
|
||||
// the deps in two places is unnecessary and excessive.
|
||||
const pruneRepeatedOptionals = data => {
|
||||
const od = data.optionalDependencies
|
||||
const dd = data.dependencies || {}
|
||||
if (od && typeof od === 'object') {
|
||||
for (const name of Object.keys(od)) {
|
||||
delete dd[name]
|
||||
}
|
||||
}
|
||||
if (Object.keys(dd).length === 0) {
|
||||
delete data.dependencies
|
||||
}
|
||||
return data
|
||||
}
|
||||
|
||||
const fixBundled = data => {
|
||||
const bdd = data.bundledDependencies
|
||||
const bd = data.bundleDependencies === undefined ? bdd
|
||||
: data.bundleDependencies
|
||||
|
||||
if (bd === false) {
|
||||
data.bundleDependencies = []
|
||||
} else if (bd === true) {
|
||||
data.bundleDependencies = Object.keys(data.dependencies || {})
|
||||
} else if (bd && typeof bd === 'object') {
|
||||
if (!Array.isArray(bd)) {
|
||||
data.bundleDependencies = Object.keys(bd)
|
||||
} else {
|
||||
data.bundleDependencies = bd
|
||||
}
|
||||
} else {
|
||||
delete data.bundleDependencies
|
||||
}
|
||||
|
||||
delete data.bundledDependencies
|
||||
return data
|
||||
}
|
||||
|
||||
const fixScripts = data => {
|
||||
if (!data.scripts || typeof data.scripts !== 'object') {
|
||||
delete data.scripts
|
||||
return data
|
||||
}
|
||||
|
||||
for (const [name, script] of Object.entries(data.scripts)) {
|
||||
if (typeof script !== 'string') {
|
||||
delete data.scripts[name]
|
||||
}
|
||||
}
|
||||
return data
|
||||
}
|
||||
|
||||
const fixFunding = data => {
|
||||
if (data.funding && typeof data.funding === 'string') {
|
||||
data.funding = { url: data.funding }
|
||||
}
|
||||
return data
|
||||
}
|
||||
|
||||
module.exports = rpj
|
47
my-app/node_modules/read-package-json-fast/package.json
generated
vendored
Executable file
47
my-app/node_modules/read-package-json-fast/package.json
generated
vendored
Executable file
|
@ -0,0 +1,47 @@
|
|||
{
|
||||
"name": "read-package-json-fast",
|
||||
"version": "3.0.2",
|
||||
"description": "Like read-package-json, but faster",
|
||||
"main": "lib/index.js",
|
||||
"author": "GitHub Inc.",
|
||||
"license": "ISC",
|
||||
"scripts": {
|
||||
"test": "tap",
|
||||
"snap": "tap",
|
||||
"lint": "eslint \"**/*.js\"",
|
||||
"postlint": "template-oss-check",
|
||||
"template-oss-apply": "template-oss-apply --force",
|
||||
"lintfix": "npm run lint -- --fix",
|
||||
"posttest": "npm run lint"
|
||||
},
|
||||
"engines": {
|
||||
"node": "^14.17.0 || ^16.13.0 || >=18.0.0"
|
||||
},
|
||||
"devDependencies": {
|
||||
"@npmcli/eslint-config": "^4.0.0",
|
||||
"@npmcli/template-oss": "4.11.0",
|
||||
"tap": "^16.3.0"
|
||||
},
|
||||
"dependencies": {
|
||||
"json-parse-even-better-errors": "^3.0.0",
|
||||
"npm-normalize-package-bin": "^3.0.0"
|
||||
},
|
||||
"repository": {
|
||||
"type": "git",
|
||||
"url": "https://github.com/npm/read-package-json-fast.git"
|
||||
},
|
||||
"files": [
|
||||
"bin/",
|
||||
"lib/"
|
||||
],
|
||||
"templateOSS": {
|
||||
"//@npmcli/template-oss": "This file is partially managed by @npmcli/template-oss. Edits may be overwritten.",
|
||||
"version": "4.11.0"
|
||||
},
|
||||
"tap": {
|
||||
"nyc-arg": [
|
||||
"--exclude",
|
||||
"tap-snapshots/**"
|
||||
]
|
||||
}
|
||||
}
|
Loading…
Add table
Add a link
Reference in a new issue