@conventional-changelog/git-client
v1.0.1
Published
Simple git client for conventional changelog packages.
Downloads
645,753
Readme
@conventional-changelog/git-client
Simple git client for conventional changelog packages.
Install
# pnpm
pnpm add @conventional-changelog/git-client conventional-commits-filter conventional-commits-parser
# yarn
yarn add @conventional-changelog/git-client conventional-commits-filter conventional-commits-parser
# npm
npm i @conventional-changelog/git-client conventional-commits-filter conventional-commits-parser
Note: conventional-commits-filter
and conventional-commits-parser
are required only if you need ConventionalGitClient#getCommits
method.
Usage
import {
GitClient,
ConventionalGitClient
} from '@conventional-changelog/git-client'
// Basic git client
const client = new GitClient(process.cwd())
await client.add('package.json')
await client.commit({ message: 'chore: release v1.0.0' })
await client.tag({ name: 'v1.0.0' })
await client.push('master')
// Conventional git client, which extends basic git client
const conventionalClient = new ConventionalGitClient(process.cwd())
console.log(await conventionalClient.getVersionFromTags()) // v1.0.0
API
new GitClient(cwd: string)
Create a wrapper around git
CLI instance.
getRawCommits(params?: GitLogParams, restRawArgs?: string[]): AsyncIterable<string>
Get raw commits stream.
getTags(restRawArgs?: string[]): AsyncIterable<string>
Get tags stream.
checkIgnore(file: string, restRawArgs?: string[]): Promise<boolean>
Check file is ignored via .gitignore.
add(files: string | string[], restRawArgs?: string[]): Promise<void>
Add files to git index.
commit(params: GitCommitParams, restRawArgs?: string[]): Promise<void>
Commit changes.
tag(params: GitTagParams, restRawArgs?: string[]): Promise<void>
Create a tag for the current commit.
getCurrentBranch(restRawArgs?: string[]): Promise<string>
Get current branch name.
push(branch: string, restRawArgs?: string[]): Promise<void>
Push changes to remote.
new ConventionalGitClient(cwd: string)
Wrapper around Git CLI with conventional commits support.
getCommits(params?: ConventionalGitLogParams, parserOptions?: ParserStreamOptions, restRawArgs?: string[]): AsyncIterable<Commit>
Get parsed commits stream.
getSemverTags(params?: GitTagsLogParams, restRawArgs?: string[]): AsyncIterable<string>
Get semver tags stream.
getVersionFromTags(prefix?: string, restRawArgs?: string[]): Promise<string | null>
Get current sematic version from git tags.
License
MIT © Dan Onoshko