Files
pnpm/exec/commands/src/create.ts
Zoltan Kochan 7a304b17c4 refactor: rename directories and unify command packages per domain (#10993)
- Rename `installing/core` → `installing/deps-installer` and `installing/headless` → `installing/deps-restorer` for clearer naming
- Rename all `plugin-commands-*` directories to use `-commands` suffix convention
- Merge multiple command packages per domain into a single `commands/` directory (one commands package per domain rule):
  - `building/{build-commands,policy-commands}` → `building/commands`
  - `deps/compliance/{audit-commands,licenses-commands,sbom-commands}` → `deps/compliance/commands`
  - `deps/inspection/{listing-commands,outdated-commands}` → `deps/inspection/commands`
  - `store/{store-commands,inspecting-commands}` → `store/commands`
  - `releasing/{publish-commands,deploy-commands}` → `releasing/commands`
  - `cli/{completion-commands,doctor-commands}` → `cli/commands`
  - `engine/pm/{self-updater-commands,setup-commands}` → `engine/pm/commands`
  - `engine/runtime/{runtime-commands,env-commands}` → `engine/runtime/commands`
  - `cache/cache-commands` → `cache/commands`
- Fix relative paths in merged test files (pnpmBin, __typings__ references)
- Update jest config to ignore `utils/` dirs at any nesting depth under `test/`
- Fix stale package names in changeset files
2026-03-17 17:42:20 +01:00

106 lines
3.0 KiB
TypeScript

import { docsUrl } from '@pnpm/cli-utils'
import { PnpmError } from '@pnpm/error'
import { renderHelp } from 'render-help'
import * as dlx from './dlx.js'
export const commandNames = ['create']
export async function handler (_opts: dlx.DlxCommandOptions, params: string[]): Promise<{ exitCode: number } | string> {
// If the first argument is --help or -h, we show the help message.
if (params[0] === '--help' || params[0] === '-h') {
return help()
}
const [packageName, ...packageArgs] = params
if (packageName === undefined) {
throw new PnpmError(
'MISSING_ARGS',
'Missing the template package name.\n' +
'The correct usage is `pnpm create <name>` ' +
'with <name> substituted for a package name.'
)
}
const createPackageName = convertToCreateName(packageName)
return dlx.handler(_opts, [createPackageName, ...packageArgs])
}
export function rcOptionsTypes (): Record<string, unknown> {
return {}
}
export function cliOptionsTypes (): Record<string, unknown> {
return {
...rcOptionsTypes(),
'allow-build': [String, Array],
}
}
export function help (): string {
return renderHelp({
description: 'Creates a project from a `create-*` starter kit.',
descriptionLists: [
{
title: 'Options',
list: [
{
description: 'A list of package names that are allowed to run postinstall scripts during installation',
name: '--allow-build',
},
],
},
],
url: docsUrl('create'),
usages: [
'pnpm create <name>',
'pnpm create <name-without-create>',
'pnpm create <@scope>',
],
})
}
const CREATE_PREFIX = 'create-'
/**
* Defines the npm's algorithm for resolving a package name
* for create-* packages.
*
* Example:
* - `foo` -> `create-foo`
* - `@usr/foo` -> `@usr/create-foo`
* - `@usr` -> `@usr/create`
* - `@usr@2.0.0` -> `@usr/create@2.0.0`
* - `@usr/foo@2.0.0` -> `@usr/create-foo@2.0.0`
* - `@usr@latest` -> `@user/create@latest`
*
* For more info, see https://docs.npmjs.com/cli/v9/commands/npm-init#description
*/
function convertToCreateName (packageName: string): string {
if (packageName[0] === '@') {
const preferredVersionPosition = packageName.indexOf('@', 1)
let preferredVersion = ''
if (preferredVersionPosition > -1) {
preferredVersion = packageName.substring(preferredVersionPosition)
packageName = packageName.substring(0, preferredVersionPosition)
}
const [scope, scopedPackage = ''] = packageName.split('/')
if (scopedPackage === '') {
return `${scope}/create${preferredVersion}`
} else {
return `${scope}/${ensureCreatePrefixed(scopedPackage)}${preferredVersion}`
}
} else {
return ensureCreatePrefixed(packageName)
}
}
function ensureCreatePrefixed (packageName: string): string {
if (packageName.startsWith(CREATE_PREFIX)) {
return packageName
} else {
return `${CREATE_PREFIX}${packageName}`
}
}