Varlet Release
English |
中文
Intro
Varlet Release is a tool to release all packages, generate changelogs and lint commit message.
Installation
npm
yarn
yarn add @varlet/release -D
pnpm
pnpm add @varlet/release -D
Usage
Using Command
npx vr release
npx vr release -r https://github.com/varletjs/varlet-release
npx vr release --remote https://github.com/varletjs/varlet-release
npx vr changelog
npx vr changelog -f changelog.md
npx vr changelog --file changelog.md
npx vr lint-commit -p .git/COMMIT_EDITMSG
npx vr publish
Configuration
release
| Params |
Instructions |
| -r --remote <remote> |
Specify remote name |
| -s --skip-npm-publish |
Skip npm publish |
| -sc --skip-changelog |
Skip generate changelog |
| -sgt --skip-git-tag |
Skip git tag |
| -nt --npm-tag <npmTag> |
npm tag |
changelog
| Params |
Instructions |
| -f --file <filename> |
Specify changelog filename |
| -rc --releaseCount <releaseCount> |
Release count |
lint-commit
| Params |
Instructions |
| -p --commitMessagePath <path> |
The path of the temporary file to which the git message is submitted. The git hook commit-msg will pass this parameter |
| -r --commitMessageRe <reg> |
Validate the regular of whether the commit message passes |
| -e --errorMessage <message> |
Validation failed to display error messages |
| -w --warningMessage <message> |
Validation failed to display warning messages |
publish
| Params |
Instructions |
| -c --check-remote-version |
Detects whether the remote version of the npm package is the same as the package version to be published locally, and if it is, skip the release |
| -nt --npm-tag <npmTag> |
npm tag |
Custom Handle
Example
import { release, changelog } from '@varlet/release'
release()You can pass in a task that will be called before the publish after the package version is changed.
import { release, changelog } from '@varlet/release'
async function task() {
await doSomething1()
await doSomething2()
}
release({ task })Types
interface PublishCommandOptions {
preRelease?: boolean
checkRemoteVersion?: boolean
npmTag?: string
}
function publish({ preRelease, checkRemoteVersion, npmTag }: PublishCommandOptions): Promise<void>
function updateVersion(version: string): void
interface ReleaseCommandOptions {
remote?: string
skipNpmPublish?: boolean
skipChangelog?: boolean
skipGitTag?: boolean
npmTag?: string
task?(): Promise<void>
}
function release(options: ReleaseCommandOptions): Promise<void>
interface ChangelogCommandOptions {
file?: string
releaseCount?: number
}
function changelog({ releaseCount, file }?: ChangelogCommandOptions): Promise<void>
const COMMIT_MESSAGE_RE: RegExp
function isVersionCommitMessage(message: string): string | false | null
function getCommitMessage(commitMessagePath: string): string
interface CommitLintCommandOptions {
commitMessagePath: string
commitMessageRe?: string | RegExp
errorMessage?: string
warningMessage?: string
}
function commitLint(options: CommitLintCommandOptions): voidLicense
MIT