schnee effeckt und fehler Korektur
This commit is contained in:
45
node_modules/browserslist/README.md
generated
vendored
45
node_modules/browserslist/README.md
generated
vendored
@@ -1,7 +1,7 @@
|
||||
# Browserslist [![Cult Of Martians][cult-img]][cult]
|
||||
|
||||
<img width="120" height="120" alt="Browserslist logo by Anton Lovchikov"
|
||||
src="https://browserslist.github.io/browserslist/logo.svg" align="right">
|
||||
<img width="120" height="120" alt="Browserslist logo by Anton Popov"
|
||||
src="https://browsersl.ist/logo.svg" align="right">
|
||||
|
||||
The config to share target browsers and Node.js versions between different
|
||||
front-end tools. It is used in:
|
||||
@@ -19,8 +19,7 @@ when you add the following to `package.json`:
|
||||
|
||||
```json
|
||||
"browserslist": [
|
||||
"defaults",
|
||||
"not IE 11",
|
||||
"defaults and supports es6-module",
|
||||
"maintained node versions"
|
||||
]
|
||||
```
|
||||
@@ -30,8 +29,7 @@ Or in `.browserslistrc` config:
|
||||
```yaml
|
||||
# Browsers that we support
|
||||
|
||||
defaults
|
||||
not IE 11
|
||||
defaults and supports es6-module
|
||||
maintained node versions
|
||||
```
|
||||
|
||||
@@ -39,28 +37,37 @@ Developers set their version lists using queries like `last 2 versions`
|
||||
to be free from updating versions manually.
|
||||
Browserslist will use [`caniuse-lite`] with [Can I Use] data for this queries.
|
||||
|
||||
Browserslist will take queries from tool option,
|
||||
`browserslist` config, `.browserslistrc` config,
|
||||
`browserslist` section in `package.json` or environment variables.
|
||||
You can check how config works at our playground: [`browsersl.ist`](https://browsersl.ist/)
|
||||
|
||||
[cult-img]: https://cultofmartians.com/assets/badges/badge.svg
|
||||
[cult]: https://cultofmartians.com/done.html
|
||||
|
||||
<a href="https://evilmartians.com/?utm_source=browserslist">
|
||||
<img src="https://evilmartians.com/badges/sponsored-by-evil-martians.svg"
|
||||
alt="Sponsored by Evil Martians" width="236" height="54">
|
||||
<a href="https://browsersl.ist/">
|
||||
<img src="/img/screenshot.webp" alt="browsersl.ist website">
|
||||
</a>
|
||||
|
||||
<br>
|
||||
<br>
|
||||
<div align="center">
|
||||
<a href="https://evilmartians.com/?utm_source=browserslist">
|
||||
<img src="https://evilmartians.com/badges/sponsored-by-evil-martians.svg"
|
||||
alt="Sponsored by Evil Martians" width="236" height="54">
|
||||
</a> <a href="https://cube.dev/?ref=eco-browserslist-github">
|
||||
<img src="https://user-images.githubusercontent.com/986756/154330861-d79ab8ec-aacb-4af8-9e17-1b28f1eccb01.svg"
|
||||
alt="Supported by Cube" width="227" height="46">
|
||||
</a>
|
||||
</div>
|
||||
|
||||
[stylelint-no-unsupported-browser-features]: https://github.com/ismay/stylelint-no-unsupported-browser-features
|
||||
[obsolete-webpack-plugin]: https://github.com/ElemeFE/obsolete-webpack-plugin
|
||||
[eslint-plugin-compat]: https://github.com/amilajack/eslint-plugin-compat
|
||||
[Browserslist Example]: https://github.com/browserslist/browserslist-example
|
||||
[postcss-preset-env]: https://github.com/jonathantneal/postcss-preset-env
|
||||
[postcss-normalize]: https://github.com/jonathantneal/postcss-normalize
|
||||
[postcss-preset-env]: https://github.com/csstools/postcss-plugins/tree/main/plugin-packs/postcss-preset-env
|
||||
[postcss-normalize]: https://github.com/csstools/postcss-normalize
|
||||
[`browsersl.ist`]: https://browsersl.ist/
|
||||
[`caniuse-lite`]: https://github.com/ben-eb/caniuse-lite
|
||||
[Autoprefixer]: https://github.com/postcss/autoprefixer
|
||||
[Can I Use]: https://caniuse.com/
|
||||
[Babel]: https://github.com/babel/babel/tree/master/packages/babel-preset-env
|
||||
[obsolete-webpack-plugin]: https://github.com/ElemeFE/obsolete-webpack-plugin
|
||||
[cult-img]: https://cultofmartians.com/assets/badges/badge.svg
|
||||
[cult]: https://cultofmartians.com/done.html
|
||||
|
||||
## Docs
|
||||
Read **[full docs](https://github.com/browserslist/browserslist#readme)** on GitHub.
|
||||
Read full docs **[here](https://github.com/browserslist/browserslist#readme)**.
|
||||
|
||||
4
node_modules/browserslist/browser.js
generated
vendored
4
node_modules/browserslist/browser.js
generated
vendored
@@ -46,5 +46,7 @@ module.exports = {
|
||||
|
||||
clearCaches: noop,
|
||||
|
||||
oldDataWarning: noop
|
||||
oldDataWarning: noop,
|
||||
|
||||
env: {}
|
||||
}
|
||||
|
||||
12
node_modules/browserslist/cli.js
generated
vendored
12
node_modules/browserslist/cli.js
generated
vendored
@@ -1,9 +1,9 @@
|
||||
#!/usr/bin/env node
|
||||
|
||||
var updateDb = require('update-browserslist-db')
|
||||
var fs = require('fs')
|
||||
|
||||
var browserslist = require('./')
|
||||
var updateDb = require('./update-db')
|
||||
var pkg = require('./package.json')
|
||||
|
||||
var args = process.argv.slice(2)
|
||||
@@ -20,8 +20,7 @@ var USAGE =
|
||||
' npx browserslist --env="environment name defined in config"\n' +
|
||||
' npx browserslist --stats="path/to/browserlist/stats/file"\n' +
|
||||
' npx browserslist --mobile-to-desktop\n' +
|
||||
' npx browserslist --ignore-unknown-versions' +
|
||||
' npx browserslist --update-db'
|
||||
' npx browserslist --ignore-unknown-versions\n'
|
||||
|
||||
function isArg(arg) {
|
||||
return args.some(function (str) {
|
||||
@@ -39,6 +38,7 @@ if (isArg('--help') || isArg('-h')) {
|
||||
} else if (isArg('--version') || isArg('-v')) {
|
||||
process.stdout.write('browserslist ' + pkg.version + '\n')
|
||||
} else if (isArg('--update-db')) {
|
||||
/* c8 ignore next 3 */
|
||||
updateDb(function (str) {
|
||||
process.stdout.write(str)
|
||||
})
|
||||
@@ -76,8 +76,10 @@ if (isArg('--help') || isArg('-h')) {
|
||||
} else if (name === '--json') {
|
||||
mode = 'json'
|
||||
} else if (name === '--mobile-to-desktop') {
|
||||
/* c8 ignore next */
|
||||
opts.mobileToDesktop = true
|
||||
} else if (name === '--ignore-unknown-versions') {
|
||||
/* c8 ignore next */
|
||||
opts.ignoreUnknownVersions = true
|
||||
} else {
|
||||
error('Unknown arguments ' + args[i] + '.\n\n' + USAGE)
|
||||
@@ -90,9 +92,9 @@ if (isArg('--help') || isArg('-h')) {
|
||||
} catch (e) {
|
||||
if (e.name === 'BrowserslistError') {
|
||||
error(e.message)
|
||||
} else {
|
||||
} /* c8 ignore start */ else {
|
||||
throw e
|
||||
}
|
||||
} /* c8 ignore end */
|
||||
}
|
||||
|
||||
var coverage
|
||||
|
||||
30
node_modules/browserslist/index.d.ts
generated
vendored
30
node_modules/browserslist/index.d.ts
generated
vendored
@@ -6,6 +6,7 @@
|
||||
* ```
|
||||
*
|
||||
* @param queries Browser queries.
|
||||
* @param opts Options.
|
||||
* @returns Array with browser names in Can I Use.
|
||||
*/
|
||||
declare function browserslist(
|
||||
@@ -14,6 +15,13 @@ declare function browserslist(
|
||||
): string[]
|
||||
|
||||
declare namespace browserslist {
|
||||
interface Query {
|
||||
compose: 'or' | 'and'
|
||||
type: string
|
||||
query: string
|
||||
not?: true
|
||||
}
|
||||
|
||||
interface Options {
|
||||
/**
|
||||
* Path to processed file. It will be used to find config files.
|
||||
@@ -36,6 +44,10 @@ declare namespace browserslist {
|
||||
* Do not throw on unknown version in direct query.
|
||||
*/
|
||||
ignoreUnknownVersions?: boolean
|
||||
/**
|
||||
* Throw an error if env is not found.
|
||||
*/
|
||||
throwOnMissing?: boolean
|
||||
/**
|
||||
* Disable security checks for extend query.
|
||||
*/
|
||||
@@ -98,6 +110,8 @@ declare namespace browserslist {
|
||||
| undefined
|
||||
}
|
||||
|
||||
let nodeVersions: string[]
|
||||
|
||||
interface Usage {
|
||||
[version: string]: number
|
||||
}
|
||||
@@ -110,7 +124,9 @@ declare namespace browserslist {
|
||||
|
||||
let cache: {
|
||||
[feature: string]: {
|
||||
[name: string]: 'y' | 'n'
|
||||
[name: string]: {
|
||||
[version: string]: string
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
@@ -138,6 +154,18 @@ declare namespace browserslist {
|
||||
*/
|
||||
function coverage(browsers: readonly string[], stats?: StatsOptions): number
|
||||
|
||||
/**
|
||||
* Get queries AST to analyze the config content.
|
||||
*
|
||||
* @param queries Browser queries.
|
||||
* @param opts Options.
|
||||
* @returns An array of the data of each query in the config.
|
||||
*/
|
||||
function parse(
|
||||
queries?: string | readonly string[] | null,
|
||||
opts?: browserslist.Options
|
||||
): Query[]
|
||||
|
||||
function clearCaches(): void
|
||||
|
||||
function parseConfig(string: string): Config
|
||||
|
||||
746
node_modules/browserslist/index.js
generated
vendored
746
node_modules/browserslist/index.js
generated
vendored
File diff suppressed because it is too large
Load Diff
41
node_modules/browserslist/node.js
generated
vendored
41
node_modules/browserslist/node.js
generated
vendored
@@ -82,11 +82,24 @@ function pickEnv(config, opts) {
|
||||
name = 'production'
|
||||
}
|
||||
|
||||
if (opts.throwOnMissing) {
|
||||
if (name && name !== 'defaults' && !config[name]) {
|
||||
throw new BrowserslistError(
|
||||
'Missing config for Browserslist environment `' + name + '`'
|
||||
)
|
||||
}
|
||||
}
|
||||
|
||||
return config[name] || config.defaults
|
||||
}
|
||||
|
||||
function parsePackage(file) {
|
||||
var config = JSON.parse(fs.readFileSync(file))
|
||||
var config = JSON.parse(
|
||||
fs
|
||||
.readFileSync(file)
|
||||
.toString()
|
||||
.replace(/^\uFEFF/m, '')
|
||||
)
|
||||
if (config.browserlist && !config.browserslist) {
|
||||
throw new BrowserslistError(
|
||||
'`browserlist` key instead of `browserslist` in ' + file
|
||||
@@ -230,7 +243,12 @@ module.exports = {
|
||||
loadCountry: function loadCountry(usage, country, data) {
|
||||
var code = country.replace(/[^\w-]/g, '')
|
||||
if (!usage[code]) {
|
||||
var compressed = require('caniuse-lite/data/regions/' + code + '.js')
|
||||
var compressed
|
||||
try {
|
||||
compressed = require('caniuse-lite/data/regions/' + code + '.js')
|
||||
} catch (e) {
|
||||
throw new BrowserslistError('Unknown region name `' + code + '`.')
|
||||
}
|
||||
var usageData = region(compressed)
|
||||
normalizeUsageData(usageData, data)
|
||||
usage[country] = {}
|
||||
@@ -245,13 +263,18 @@ module.exports = {
|
||||
loadFeature: function loadFeature(features, name) {
|
||||
name = name.replace(/[^\w-]/g, '')
|
||||
if (features[name]) return
|
||||
|
||||
var compressed = require('caniuse-lite/data/features/' + name + '.js')
|
||||
var compressed
|
||||
try {
|
||||
compressed = require('caniuse-lite/data/features/' + name + '.js')
|
||||
} catch (e) {
|
||||
throw new BrowserslistError('Unknown feature name `' + name + '`.')
|
||||
}
|
||||
var stats = feature(compressed).stats
|
||||
features[name] = {}
|
||||
for (var i in stats) {
|
||||
features[name][i] = {}
|
||||
for (var j in stats[i]) {
|
||||
features[name][i + ' ' + j] = stats[i][j]
|
||||
features[name][i][j] = stats[i][j]
|
||||
}
|
||||
}
|
||||
},
|
||||
@@ -372,14 +395,16 @@ module.exports = {
|
||||
if (latest !== 0 && latest < halfYearAgo) {
|
||||
console.warn(
|
||||
'Browserslist: caniuse-lite is outdated. Please run:\n' +
|
||||
' npx browserslist@latest --update-db\n' +
|
||||
' npx update-browserslist-db@latest\n' +
|
||||
' Why you should do it regularly: ' +
|
||||
'https://github.com/browserslist/browserslist#browsers-data-updating'
|
||||
'https://github.com/browserslist/update-db#readme'
|
||||
)
|
||||
}
|
||||
},
|
||||
|
||||
currentNode: function currentNode() {
|
||||
return 'node ' + process.versions.node
|
||||
}
|
||||
},
|
||||
|
||||
env: process.env
|
||||
}
|
||||
|
||||
29
node_modules/browserslist/package.json
generated
vendored
29
node_modules/browserslist/package.json
generated
vendored
@@ -1,25 +1,34 @@
|
||||
{
|
||||
"name": "browserslist",
|
||||
"version": "4.18.1",
|
||||
"version": "4.21.10",
|
||||
"description": "Share target browsers between different front-end tools, like Autoprefixer, Stylelint and babel-env-preset",
|
||||
"keywords": [
|
||||
"caniuse",
|
||||
"browsers",
|
||||
"target"
|
||||
],
|
||||
"funding": {
|
||||
"type": "opencollective",
|
||||
"url": "https://opencollective.com/browserslist"
|
||||
},
|
||||
"funding": [
|
||||
{
|
||||
"type": "opencollective",
|
||||
"url": "https://opencollective.com/browserslist"
|
||||
},
|
||||
{
|
||||
"type": "tidelift",
|
||||
"url": "https://tidelift.com/funding/github/npm/browserslist"
|
||||
},
|
||||
{
|
||||
"type": "github",
|
||||
"url": "https://github.com/sponsors/ai"
|
||||
}
|
||||
],
|
||||
"author": "Andrey Sitnik <andrey@sitnik.ru>",
|
||||
"license": "MIT",
|
||||
"repository": "browserslist/browserslist",
|
||||
"dependencies": {
|
||||
"caniuse-lite": "^1.0.30001280",
|
||||
"electron-to-chromium": "^1.3.896",
|
||||
"escalade": "^3.1.1",
|
||||
"node-releases": "^2.0.1",
|
||||
"picocolors": "^1.0.0"
|
||||
"caniuse-lite": "^1.0.30001517",
|
||||
"electron-to-chromium": "^1.4.477",
|
||||
"node-releases": "^2.0.13",
|
||||
"update-browserslist-db": "^1.0.11"
|
||||
},
|
||||
"engines": {
|
||||
"node": "^6 || ^7 || ^8 || ^9 || ^10 || ^11 || ^12 || >=13.7"
|
||||
|
||||
78
node_modules/browserslist/parse.js
generated
vendored
Normal file
78
node_modules/browserslist/parse.js
generated
vendored
Normal file
@@ -0,0 +1,78 @@
|
||||
var AND_REGEXP = /^\s+and\s+(.*)/i
|
||||
var OR_REGEXP = /^(?:,\s*|\s+or\s+)(.*)/i
|
||||
|
||||
function flatten(array) {
|
||||
if (!Array.isArray(array)) return [array]
|
||||
return array.reduce(function (a, b) {
|
||||
return a.concat(flatten(b))
|
||||
}, [])
|
||||
}
|
||||
|
||||
function find(string, predicate) {
|
||||
for (var n = 1, max = string.length; n <= max; n++) {
|
||||
var parsed = string.substr(-n, n)
|
||||
if (predicate(parsed, n, max)) {
|
||||
return string.slice(0, -n)
|
||||
}
|
||||
}
|
||||
return ''
|
||||
}
|
||||
|
||||
function matchQuery(all, query) {
|
||||
var node = { query: query }
|
||||
if (query.indexOf('not ') === 0) {
|
||||
node.not = true
|
||||
query = query.slice(4)
|
||||
}
|
||||
|
||||
for (var name in all) {
|
||||
var type = all[name]
|
||||
var match = query.match(type.regexp)
|
||||
if (match) {
|
||||
node.type = name
|
||||
for (var i = 0; i < type.matches.length; i++) {
|
||||
node[type.matches[i]] = match[i + 1]
|
||||
}
|
||||
return node
|
||||
}
|
||||
}
|
||||
|
||||
node.type = 'unknown'
|
||||
return node
|
||||
}
|
||||
|
||||
function matchBlock(all, string, qs) {
|
||||
var node
|
||||
return find(string, function (parsed, n, max) {
|
||||
if (AND_REGEXP.test(parsed)) {
|
||||
node = matchQuery(all, parsed.match(AND_REGEXP)[1])
|
||||
node.compose = 'and'
|
||||
qs.unshift(node)
|
||||
return true
|
||||
} else if (OR_REGEXP.test(parsed)) {
|
||||
node = matchQuery(all, parsed.match(OR_REGEXP)[1])
|
||||
node.compose = 'or'
|
||||
qs.unshift(node)
|
||||
return true
|
||||
} else if (n === max) {
|
||||
node = matchQuery(all, parsed.trim())
|
||||
node.compose = 'or'
|
||||
qs.unshift(node)
|
||||
return true
|
||||
}
|
||||
return false
|
||||
})
|
||||
}
|
||||
|
||||
module.exports = function parse(all, queries) {
|
||||
if (!Array.isArray(queries)) queries = [queries]
|
||||
return flatten(
|
||||
queries.map(function (block) {
|
||||
var qs = []
|
||||
do {
|
||||
block = matchBlock(all, block, qs)
|
||||
} while (block)
|
||||
return qs
|
||||
})
|
||||
)
|
||||
}
|
||||
363
node_modules/browserslist/update-db.js
generated
vendored
363
node_modules/browserslist/update-db.js
generated
vendored
@@ -1,363 +0,0 @@
|
||||
var childProcess = require('child_process')
|
||||
var escalade = require('escalade/sync')
|
||||
var pico = require('picocolors')
|
||||
var path = require('path')
|
||||
var fs = require('fs')
|
||||
|
||||
var BrowserslistError = require('./error')
|
||||
|
||||
function detectLockfile() {
|
||||
var packageDir = escalade('.', function (dir, names) {
|
||||
return names.indexOf('package.json') !== -1 ? dir : ''
|
||||
})
|
||||
|
||||
if (!packageDir) {
|
||||
throw new BrowserslistError(
|
||||
'Cannot find package.json. ' +
|
||||
'Is this the right directory to run `npx browserslist --update-db` in?'
|
||||
)
|
||||
}
|
||||
|
||||
var lockfileNpm = path.join(packageDir, 'package-lock.json')
|
||||
var lockfileShrinkwrap = path.join(packageDir, 'npm-shrinkwrap.json')
|
||||
var lockfileYarn = path.join(packageDir, 'yarn.lock')
|
||||
var lockfilePnpm = path.join(packageDir, 'pnpm-lock.yaml')
|
||||
|
||||
if (fs.existsSync(lockfilePnpm)) {
|
||||
return { mode: 'pnpm', file: lockfilePnpm }
|
||||
} else if (fs.existsSync(lockfileNpm)) {
|
||||
return { mode: 'npm', file: lockfileNpm }
|
||||
} else if (fs.existsSync(lockfileYarn)) {
|
||||
var lock = { mode: 'yarn', file: lockfileYarn }
|
||||
lock.content = fs.readFileSync(lock.file).toString()
|
||||
lock.version = /# yarn lockfile v1/.test(lock.content) ? 1 : 2
|
||||
return lock
|
||||
} else if (fs.existsSync(lockfileShrinkwrap)) {
|
||||
return { mode: 'npm', file: lockfileShrinkwrap }
|
||||
}
|
||||
throw new BrowserslistError(
|
||||
'No lockfile found. Run "npm install", "yarn install" or "pnpm install"'
|
||||
)
|
||||
}
|
||||
|
||||
function getLatestInfo(lock) {
|
||||
if (lock.mode === 'yarn') {
|
||||
if (lock.version === 1) {
|
||||
return JSON.parse(
|
||||
childProcess.execSync('yarn info caniuse-lite --json').toString()
|
||||
).data
|
||||
} else {
|
||||
return JSON.parse(
|
||||
childProcess.execSync('yarn npm info caniuse-lite --json').toString()
|
||||
)
|
||||
}
|
||||
}
|
||||
return JSON.parse(
|
||||
childProcess.execSync('npm show caniuse-lite --json').toString()
|
||||
)
|
||||
}
|
||||
|
||||
function getBrowsersList() {
|
||||
return childProcess
|
||||
.execSync('npx browserslist')
|
||||
.toString()
|
||||
.trim()
|
||||
.split('\n')
|
||||
.map(function (line) {
|
||||
return line.trim().split(' ')
|
||||
})
|
||||
.reduce(function (result, entry) {
|
||||
if (!result[entry[0]]) {
|
||||
result[entry[0]] = []
|
||||
}
|
||||
result[entry[0]].push(entry[1])
|
||||
return result
|
||||
}, {})
|
||||
}
|
||||
|
||||
function diffBrowsersLists(old, current) {
|
||||
var browsers = Object.keys(old).concat(
|
||||
Object.keys(current).filter(function (browser) {
|
||||
return old[browser] === undefined
|
||||
})
|
||||
)
|
||||
return browsers
|
||||
.map(function (browser) {
|
||||
var oldVersions = old[browser] || []
|
||||
var currentVersions = current[browser] || []
|
||||
var intersection = oldVersions.filter(function (version) {
|
||||
return currentVersions.indexOf(version) !== -1
|
||||
})
|
||||
var addedVersions = currentVersions.filter(function (version) {
|
||||
return intersection.indexOf(version) === -1
|
||||
})
|
||||
var removedVersions = oldVersions.filter(function (version) {
|
||||
return intersection.indexOf(version) === -1
|
||||
})
|
||||
return removedVersions
|
||||
.map(function (version) {
|
||||
return pico.red('- ' + browser + ' ' + version)
|
||||
})
|
||||
.concat(
|
||||
addedVersions.map(function (version) {
|
||||
return pico.green('+ ' + browser + ' ' + version)
|
||||
})
|
||||
)
|
||||
})
|
||||
.reduce(function (result, array) {
|
||||
return result.concat(array)
|
||||
}, [])
|
||||
.join('\n')
|
||||
}
|
||||
|
||||
function updateNpmLockfile(lock, latest) {
|
||||
var metadata = { latest: latest, versions: [] }
|
||||
var content = deletePackage(JSON.parse(lock.content), metadata)
|
||||
metadata.content = JSON.stringify(content, null, ' ')
|
||||
return metadata
|
||||
}
|
||||
|
||||
function deletePackage(node, metadata) {
|
||||
if (node.dependencies) {
|
||||
if (node.dependencies['caniuse-lite']) {
|
||||
var version = node.dependencies['caniuse-lite'].version
|
||||
metadata.versions[version] = true
|
||||
delete node.dependencies['caniuse-lite']
|
||||
}
|
||||
for (var i in node.dependencies) {
|
||||
node.dependencies[i] = deletePackage(node.dependencies[i], metadata)
|
||||
}
|
||||
}
|
||||
return node
|
||||
}
|
||||
|
||||
var yarnVersionRe = /version "(.*?)"/
|
||||
|
||||
function updateYarnLockfile(lock, latest) {
|
||||
var blocks = lock.content.split(/(\n{2,})/).map(function (block) {
|
||||
return block.split('\n')
|
||||
})
|
||||
var versions = {}
|
||||
blocks.forEach(function (lines) {
|
||||
if (lines[0].indexOf('caniuse-lite@') !== -1) {
|
||||
var match = yarnVersionRe.exec(lines[1])
|
||||
versions[match[1]] = true
|
||||
if (match[1] !== latest.version) {
|
||||
lines[1] = lines[1].replace(
|
||||
/version "[^"]+"/,
|
||||
'version "' + latest.version + '"'
|
||||
)
|
||||
lines[2] = lines[2].replace(
|
||||
/resolved "[^"]+"/,
|
||||
'resolved "' + latest.dist.tarball + '"'
|
||||
)
|
||||
lines[3] = latest.dist.integrity
|
||||
? lines[3].replace(
|
||||
/integrity .+/,
|
||||
'integrity ' + latest.dist.integrity
|
||||
)
|
||||
: ''
|
||||
}
|
||||
}
|
||||
})
|
||||
var content = blocks
|
||||
.map(function (lines) {
|
||||
return lines.join('\n')
|
||||
})
|
||||
.join('')
|
||||
return { content: content, versions: versions }
|
||||
}
|
||||
|
||||
function updatePnpmLockfile(lock, latest) {
|
||||
var versions = {}
|
||||
var lines = lock.content.split('\n')
|
||||
var i
|
||||
var j
|
||||
var lineParts
|
||||
|
||||
for (i = 0; i < lines.length; i++) {
|
||||
if (lines[i].indexOf('caniuse-lite:') >= 0) {
|
||||
lineParts = lines[i].split(/:\s?/, 2)
|
||||
if (lineParts[1].indexOf('/') >= 0) {
|
||||
var sublineParts = lineParts[1].split(/([/:])/)
|
||||
for (j = 0; j < sublineParts.length; j++) {
|
||||
if (sublineParts[j].indexOf('caniuse-lite') >= 0) {
|
||||
versions[sublineParts[j + 2]] = true
|
||||
sublineParts[j + 2] = latest.version
|
||||
break
|
||||
}
|
||||
}
|
||||
lineParts[1] = sublineParts.join('')
|
||||
} else {
|
||||
versions[lineParts[1]] = true
|
||||
}
|
||||
lines[i] = lineParts[0] + ': ' + latest.version
|
||||
} else if (lines[i].indexOf('/caniuse-lite') >= 0) {
|
||||
lineParts = lines[i].split(/([/:])/)
|
||||
for (j = 0; j < lineParts.length; j++) {
|
||||
if (lineParts[j].indexOf('caniuse-lite') >= 0) {
|
||||
versions[lineParts[j + 2]] = true
|
||||
lineParts[j + 2] = latest.version
|
||||
break
|
||||
}
|
||||
}
|
||||
lines[i] = lineParts.join('')
|
||||
for (i = i + 1; i < lines.length; i++) {
|
||||
if (lines[i].indexOf('integrity: ') !== -1) {
|
||||
lines[i] = lines[i].replace(
|
||||
/integrity: .+/,
|
||||
'integrity: ' + latest.dist.integrity
|
||||
)
|
||||
} else if (lines[i].indexOf(' /') !== -1) {
|
||||
break
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
return { content: lines.join('\n'), versions: versions }
|
||||
}
|
||||
|
||||
function updateLockfile(lock, latest) {
|
||||
if (!lock.content) lock.content = fs.readFileSync(lock.file).toString()
|
||||
|
||||
if (lock.mode === 'npm') {
|
||||
return updateNpmLockfile(lock, latest)
|
||||
} else if (lock.mode === 'yarn') {
|
||||
return updateYarnLockfile(lock, latest)
|
||||
}
|
||||
return updatePnpmLockfile(lock, latest)
|
||||
}
|
||||
|
||||
function updatePackageManually(print, lock, latest) {
|
||||
var lockfileData = updateLockfile(lock, latest)
|
||||
var caniuseVersions = Object.keys(lockfileData.versions).sort()
|
||||
if (caniuseVersions.length === 1 && caniuseVersions[0] === latest.version) {
|
||||
print(
|
||||
'Installed version: ' +
|
||||
pico.bold(pico.green(latest.version)) +
|
||||
'\n' +
|
||||
pico.bold(pico.green('caniuse-lite is up to date')) +
|
||||
'\n'
|
||||
)
|
||||
return
|
||||
}
|
||||
|
||||
if (caniuseVersions.length === 0) {
|
||||
caniuseVersions[0] = 'none'
|
||||
}
|
||||
print(
|
||||
'Installed version' +
|
||||
(caniuseVersions.length === 1 ? ': ' : 's: ') +
|
||||
pico.bold(pico.red(caniuseVersions.join(', '))) +
|
||||
'\n' +
|
||||
'Removing old caniuse-lite from lock file\n'
|
||||
)
|
||||
fs.writeFileSync(lock.file, lockfileData.content)
|
||||
|
||||
var install = lock.mode === 'yarn' ? 'yarn add -W' : lock.mode + ' install'
|
||||
print(
|
||||
'Installing new caniuse-lite version\n' +
|
||||
pico.yellow('$ ' + install + ' caniuse-lite') +
|
||||
'\n'
|
||||
)
|
||||
try {
|
||||
childProcess.execSync(install + ' caniuse-lite')
|
||||
} catch (e) /* istanbul ignore next */ {
|
||||
print(
|
||||
pico.red(
|
||||
'\n' +
|
||||
e.stack +
|
||||
'\n\n' +
|
||||
'Problem with `' +
|
||||
install +
|
||||
' caniuse-lite` call. ' +
|
||||
'Run it manually.\n'
|
||||
)
|
||||
)
|
||||
process.exit(1)
|
||||
}
|
||||
|
||||
var del = lock.mode === 'yarn' ? 'yarn remove -W' : lock.mode + ' uninstall'
|
||||
print(
|
||||
'Cleaning package.json dependencies from caniuse-lite\n' +
|
||||
pico.yellow('$ ' + del + ' caniuse-lite') +
|
||||
'\n'
|
||||
)
|
||||
childProcess.execSync(del + ' caniuse-lite')
|
||||
}
|
||||
|
||||
module.exports = function updateDB(print) {
|
||||
var lock = detectLockfile()
|
||||
var latest = getLatestInfo(lock)
|
||||
|
||||
var browsersListRetrievalError
|
||||
var oldBrowsersList
|
||||
try {
|
||||
oldBrowsersList = getBrowsersList()
|
||||
} catch (e) {
|
||||
browsersListRetrievalError = e
|
||||
}
|
||||
|
||||
print('Latest version: ' + pico.bold(pico.green(latest.version)) + '\n')
|
||||
|
||||
if (lock.mode === 'yarn' && lock.version !== 1) {
|
||||
var update = 'yarn up -R'
|
||||
print(
|
||||
'Updating caniuse-lite version\n' +
|
||||
pico.yellow('$ ' + update + ' caniuse-lite') +
|
||||
'\n'
|
||||
)
|
||||
try {
|
||||
childProcess.execSync(update + ' caniuse-lite')
|
||||
} catch (e) /* istanbul ignore next */ {
|
||||
print(
|
||||
pico.red(
|
||||
'\n' +
|
||||
e.stack +
|
||||
'\n\n' +
|
||||
'Problem with `' +
|
||||
update +
|
||||
' caniuse-lite` call. ' +
|
||||
'Run it manually.\n'
|
||||
)
|
||||
)
|
||||
process.exit(1)
|
||||
}
|
||||
} else {
|
||||
updatePackageManually(print, lock, latest)
|
||||
}
|
||||
|
||||
print('caniuse-lite has been successfully updated\n')
|
||||
|
||||
var currentBrowsersList
|
||||
if (!browsersListRetrievalError) {
|
||||
try {
|
||||
currentBrowsersList = getBrowsersList()
|
||||
} catch (e) /* istanbul ignore next */ {
|
||||
browsersListRetrievalError = e
|
||||
}
|
||||
}
|
||||
|
||||
if (browsersListRetrievalError) {
|
||||
print(
|
||||
pico.red(
|
||||
'\n' +
|
||||
browsersListRetrievalError.stack +
|
||||
'\n\n' +
|
||||
'Problem with browser list retrieval.\n' +
|
||||
'Target browser changes won’t be shown.\n'
|
||||
)
|
||||
)
|
||||
} else {
|
||||
var targetBrowserChanges = diffBrowsersLists(
|
||||
oldBrowsersList,
|
||||
currentBrowsersList
|
||||
)
|
||||
if (targetBrowserChanges) {
|
||||
print('\nTarget browser changes:\n')
|
||||
print(targetBrowserChanges + '\n')
|
||||
} else {
|
||||
print('\n' + pico.green('No target browser changes') + '\n')
|
||||
}
|
||||
}
|
||||
}
|
||||
Reference in New Issue
Block a user