����JFIF���������
__ __ __ __ _____ _ _ _____ _ _ _ | \/ | \ \ / / | __ \ (_) | | / ____| | | | | | \ / |_ __\ V / | |__) | __ ___ ____ _| |_ ___ | (___ | |__ ___| | | | |\/| | '__|> < | ___/ '__| \ \ / / _` | __/ _ \ \___ \| '_ \ / _ \ | | | | | | |_ / . \ | | | | | |\ V / (_| | || __/ ____) | | | | __/ | | |_| |_|_(_)_/ \_\ |_| |_| |_| \_/ \__,_|\__\___| |_____/|_| |_|\___V 2.1 if you need WebShell for Seo everyday contact me on Telegram Telegram Address : @jackleetFor_More_Tools:
const { statSync } = require('node:fs')
const { relative, resolve } = require('node:path')
const { mkdir } = require('node:fs/promises')
const initJson = require('init-package-json')
const npa = require('npm-package-arg')
const libexec = require('libnpmexec')
const mapWorkspaces = require('@npmcli/map-workspaces')
const PackageJson = require('@npmcli/package-json')
const { log, output, input } = require('proc-log')
const updateWorkspaces = require('../utils/update-workspaces.js')
const BaseCommand = require('../base-cmd.js')
const posixPath = p => p.split('\\').join('/')
class Init extends BaseCommand {
static description = 'Create a package.json file'
static params = [
'init-author-name',
'init-author-url',
'init-license',
'init-module',
'init-type',
'init-version',
'init-private',
'yes',
'force',
'scope',
'workspace',
'workspaces',
'workspaces-update',
'include-workspace-root',
]
static name = 'init'
static usage = [
'<package-spec> (same as `npx create-<package-spec>`)',
'<@scope> (same as `npx <@scope>/create`)',
]
static workspaces = true
static ignoreImplicitWorkspace = false
async exec (args) {
// npm exec style
if (args.length) {
return await this.execCreate(args)
}
// no args, uses classic init-package-json boilerplate
await this.template()
}
async execWorkspaces (args) {
// if the root package is uninitiated, take care of it first
if (this.npm.flatOptions.includeWorkspaceRoot) {
await this.exec(args)
}
// reads package.json for the top-level folder first
// by doing this we ensure the command throw if no package.json is found before trying to create a workspace package.json file or its folders
const { content: pkg } = await PackageJson.normalize(this.npm.localPrefix).catch(err => {
if (err.code === 'ENOENT') {
log.warn('init', 'Missing package.json. Try with `--include-workspace-root`.')
}
throw err
})
// these are workspaces that are being created, so we can't use this.setWorkspaces()
const filters = this.npm.config.get('workspace')
const wPath = filterArg => resolve(this.npm.localPrefix, filterArg)
const workspacesPaths = []
// npm-exec style, runs in the context of each workspace filter
if (args.length) {
for (const filterArg of filters) {
const path = wPath(filterArg)
await mkdir(path, { recursive: true })
workspacesPaths.push(path)
await this.execCreate(args, path)
await this.setWorkspace(pkg, path)
}
return
}
// no args, uses classic init-package-json boilerplate
for (const filterArg of filters) {
const path = wPath(filterArg)
await mkdir(path, { recursive: true })
workspacesPaths.push(path)
await this.template(path)
await this.setWorkspace(pkg, path)
}
// reify packages once all workspaces have been initialized
await this.update(workspacesPaths)
}
async execCreate (args, runPath = process.cwd()) {
const [initerName, ...otherArgs] = args
let packageName = initerName
// Only a scope, possibly with a version
if (/^@[^/]+$/.test(initerName)) {
const [, scope, version] = initerName.split('@')
packageName = `@${scope}/create`
if (version) {
packageName = `${packageName}@${version}`
}
} else {
const req = npa(initerName)
if (req.type === 'git' && req.hosted) {
const { user, project } = req.hosted
packageName = initerName.replace(`${user}/${project}`, `${user}/create-${project}`)
} else if (req.registry) {
packageName = `${req.name.replace(/^(@[^/]+\/)?/, '$1create-')}@${req.rawSpec}`
} else {
throw Object.assign(new Error(
'Unrecognized initializer: ' + initerName +
'\nFor more package binary executing power check out `npx`:' +
'\nhttps://docs.npmjs.com/cli/commands/npx'
), { code: 'EUNSUPPORTED' })
}
}
const newArgs = [packageName, ...otherArgs]
const {
flatOptions,
localBin,
globalBin,
chalk,
} = this.npm
const scriptShell = this.npm.config.get('script-shell') || undefined
const yes = this.npm.config.get('yes')
// only send the init-private flag if it is set
const opts = { ...flatOptions }
if (this.npm.config.isDefault('init-private')) {
delete opts.initPrivate
}
await libexec({
...opts,
args: newArgs,
localBin,
globalBin,
output,
chalk,
path: this.npm.localPrefix,
runPath,
scriptShell,
yes,
})
}
async template (path = process.cwd()) {
const initFile = this.npm.config.get('init-module')
if (!this.npm.config.get('yes') && !this.npm.config.get('force')) {
output.standard([
'This utility will walk you through creating a package.json file.',
'It only covers the most common items, and tries to guess sensible defaults.',
'',
'See `npm help init` for definitive documentation on these fields and exactly what they do.',
'',
'Use `npm install <pkg>` afterwards to install a package and save it as a dependency in the package.json file.',
'',
'Press ^C at any time to quit.',
].join('\n'))
}
try {
const data = await input.read(() => initJson(path, initFile, this.npm.config))
log.silly('package data', data)
return data
} catch (er) {
if (er.message === 'canceled') {
output.flush()
log.warn('init', 'canceled')
} else {
throw er
}
}
}
async setWorkspace (pkg, workspacePath) {
const workspaces = await mapWorkspaces({ cwd: this.npm.localPrefix, pkg })
// skip setting workspace if current package.json glob already satisfies it
for (const wPath of workspaces.values()) {
if (wPath === workspacePath) {
return
}
}
// if a create-pkg didn't generate a package.json at the workspace folder level, it might not be recognized as a workspace by mapWorkspaces, so we're just going to avoid touching the top-level package.json
try {
statSync(resolve(workspacePath, 'package.json'))
} catch {
return
}
const pkgJson = await PackageJson.load(this.npm.localPrefix)
pkgJson.update({
workspaces: [
...(pkgJson.content.workspaces || []),
posixPath(relative(this.npm.localPrefix, workspacePath)),
],
})
await pkgJson.save()
}
async update (workspacesPaths) {
// translate workspaces paths into an array containing workspaces names
const workspaces = []
for (const path of workspacesPaths) {
const { content: { name } } = await PackageJson.normalize(path).catch(() => ({ content: {} }))
if (name) {
workspaces.push(name)
}
}
const {
config,
flatOptions,
localPrefix,
} = this.npm
await updateWorkspaces({
config,
flatOptions,
localPrefix,
npm: this.npm,
workspaces,
})
}
}
module.exports = Init
| Name | Type | Size | Permission | Actions |
|---|---|---|---|---|
| trust | Folder | 0755 |
|
|
| access.js | File | 6.17 KB | 0644 |
|
| adduser.js | File | 1.29 KB | 0644 |
|
| audit.js | File | 3.17 KB | 0644 |
|
| bugs.js | File | 847 B | 0644 |
|
| cache.js | File | 11.48 KB | 0644 |
|
| ci.js | File | 4.24 KB | 0644 |
|
| completion.js | File | 10.83 KB | 0644 |
|
| config.js | File | 11.48 KB | 0644 |
|
| dedupe.js | File | 1.42 KB | 0644 |
|
| deprecate.js | File | 2.43 KB | 0644 |
|
| diff.js | File | 7.92 KB | 0644 |
|
| dist-tag.js | File | 5.5 KB | 0644 |
|
| docs.js | File | 449 B | 0644 |
|
| doctor.js | File | 9.99 KB | 0644 |
|
| edit.js | File | 1.72 KB | 0644 |
|
| exec.js | File | 3.39 KB | 0644 |
|
| explain.js | File | 3.55 KB | 0644 |
|
| explore.js | File | 2.11 KB | 0644 |
|
| find-dupes.js | File | 578 B | 0644 |
|
| fund.js | File | 6.38 KB | 0644 |
|
| get.js | File | 538 B | 0644 |
|
| help-search.js | File | 5.53 KB | 0644 |
|
| help.js | File | 3.64 KB | 0644 |
|
| init.js | File | 7.02 KB | 0644 |
|
| install-ci-test.js | File | 308 B | 0644 |
|
| install-test.js | File | 303 B | 0644 |
|
| install.js | File | 5.1 KB | 0644 |
|
| link.js | File | 5.24 KB | 0644 |
|
| ll.js | File | 234 B | 0644 |
|
| login.js | File | 1.29 KB | 0644 |
|
| logout.js | File | 1.42 KB | 0644 |
|
| ls.js | File | 18.03 KB | 0644 |
|
| org.js | File | 3.96 KB | 0644 |
|
| outdated.js | File | 7.92 KB | 0644 |
|
| owner.js | File | 5.95 KB | 0644 |
|
| pack.js | File | 2.77 KB | 0644 |
|
| ping.js | File | 873 B | 0644 |
|
| pkg.js | File | 3.58 KB | 0644 |
|
| prefix.js | File | 309 B | 0644 |
|
| profile.js | File | 10.3 KB | 0644 |
|
| prune.js | File | 770 B | 0644 |
|
| publish.js | File | 9.47 KB | 0644 |
|
| query.js | File | 3.75 KB | 0644 |
|
| rebuild.js | File | 2.15 KB | 0644 |
|
| repo.js | File | 1.24 KB | 0644 |
|
| restart.js | File | 303 B | 0644 |
|
| root.js | File | 295 B | 0644 |
|
| run.js | File | 6.27 KB | 0644 |
|
| sbom.js | File | 4.47 KB | 0644 |
|
| search.js | File | 1.83 KB | 0644 |
|
| set.js | File | 632 B | 0644 |
|
| shrinkwrap.js | File | 2.63 KB | 0644 |
|
| star.js | File | 1.88 KB | 0644 |
|
| stars.js | File | 1.03 KB | 0644 |
|
| start.js | File | 293 B | 0644 |
|
| stop.js | File | 288 B | 0644 |
|
| team.js | File | 4.33 KB | 0644 |
|
| test.js | File | 288 B | 0644 |
|
| token.js | File | 7.96 KB | 0644 |
|
| undeprecate.js | File | 302 B | 0644 |
|
| uninstall.js | File | 1.49 KB | 0644 |
|
| unpublish.js | File | 5.24 KB | 0644 |
|
| unstar.js | File | 183 B | 0644 |
|
| update.js | File | 1.69 KB | 0644 |
|
| version.js | File | 3.54 KB | 0644 |
|
| view.js | File | 13.48 KB | 0644 |
|
| whoami.js | File | 527 B | 0644 |
|