Options - Control Related
alias
- description : define commonly used commit message alias
- type : { [alias: string]: string }
- default : { fd: "docs: fix typos" }
TIP
More usage and demo ⇒ can see the recipes
scopes
- description : custom selection module scope command line display information
- type : string[] | Array<{ name: string, value?: string }>
- default : []
TIP
If you define a scope-enum using the commitlint rule, it will be imported automatically.
⇒ can see the recipes
scopeOverrides
- description : After customizing a specific type, override module scope command line display information
- type : { [type: string]: string[] | Array<{ name: string, value?: string }> } | undefined
- default : undefined
- example : scopeOverrides: { "test": ["e2eTest", "unitTest"] }
- use : Displays custom module scope selection when selecting module scope after selecting specific commit type : type
TIP
If you define scopeOverrides then define generic scopes
scopeFilters
- description : Filter select of prompt to select module scopes by the scope.value
- type : string[]
- default : [".DS_Store"]
enableMultipleScopes
- description : Whether to enable the use of multiple scopes mode
- type : boolean
- default : false
TIP
Try running command to enable multiple scopes mode in the current session
- Commitizen CLI + cz-git: checkbox=1 cz
- czg CLI: czg checkbox
Demo And Usage ⇒ see the recipes
scopeEnumSeparator
- description : Separator between scopes in multiple scopes mode
- type : string
- default : ,
allowCustomScopes
- description : whether to display custom options when selecting module scope (custom)
- type : boolean
- default : true
- use : not using commitlintand want to turn off custom options in select.
TIP
It will automatically detect whether the definition of the commitlint rule scope-enum is strict, and it will not be displayed automatically.
allowEmptyScopes
- description : whether to display an empty option when selecting module scope (empty)
- type : boolean
- default : true
TIP
It will automatically detect whether the definition of the commitlint rule scope-empty is strict, and it will not be displayed automatically.
markBreakingChangeMode
- description : Add an extra BREAKINGCHANGE question asking if you need to add the "!" mark in the header
- use : When you want to add the ! mark in the header, Highlight that the commit message belongs to BREAKINGCHANGE. you can use this option.
- type : boolean
- default : false
TIP
more usage and demo ⇒ see the recipes
allowBreakingChanges
- description : a specific type that allows display BREAKING CHANGES prompt
- type : string[]
- default : ["feat", "fix"]
useAI
- description : Turn on use OpenAI API to auto generate subject short description for commit message mode
- type : boolean
- default : false
TIP
Try running command to use OpenAI API to auto generate subject in the current session
- Commitizen CLI + cz-git: czai=1 cz
- czg CLI: czg ai
Demo And Usage ⇒ see the recipes
aiNumber
- description : If >1 will turn on select mode, select generate options like returned by OpenAI
- type : number
- default : 1
TIP
Try running command to select multiple results returned by OpenAI in the current session
- Commitizen CLI + cz-git: czai=1 cz_ainum=3 cz
- czg CLI: czg ai -N=3
Demo And Usage ⇒ see the recipes
aiType
- description : Choose the AI model you want to use
| aiType | Model | Description | 
|---|---|---|
| openAI-Turbo | gpt-3.5-turbo | faster and optimized for chat at 1/10th the cost of text-davinci-003 | 
| openAI-Davinci | text-davinci-003 | better quality, longer output, and consistent instruction-following | 
- type : "openAI-Turbo" | "openAI-Davinci"
- default : openAI-Turbo
aiDiffIgnore
- description : To ignore selection diff codes when sending AI API requests
- type : string[]
- default : [ "package-lock.json", "yarn.lock", "pnpm-lock.yaml" ]
- example : [ "pnpm-lock.yaml", "docs/public" ]
aiQuestionCB
- description : Use the callback fn can customize edit AI question content
- type : (param: GenerateAIPromptType) => string
export interface GenerateAIPromptType {
  type: string
  defaultScope?: string
  maxSubjectLength?: number
  upperCaseSubject?: boolean
  diff?: string
}
export interface GenerateAIPromptType {
  type: string
  defaultScope?: string
  maxSubjectLength?: number
  upperCaseSubject?: boolean
  diff?: string
}
- example :
module.exports = {
  aiQuestionCB: ({ maxSubjectLength, diff }) => `Write an insightful and concise Git commit message in the present tense for the following Git diff code, without any prefixes, and no longer than ${maxSubjectLength} characters.: \`\`\`diff\n${diff}\n\`\`\``,
}
module.exports = {
  aiQuestionCB: ({ maxSubjectLength, diff }) => `Write an insightful and concise Git commit message in the present tense for the following Git diff code, without any prefixes, and no longer than ${maxSubjectLength} characters.: \`\`\`diff\n${diff}\n\`\`\``,
}
upperCaseSubject
- description : Whether to automatically capitalize the first character of the short description (subject)
- type : boolean
- default : false
breaklineNumber
- description : body and BREAKING CHANGES the line wraps automatically according to the character exceeding this value
- type : number
- default : 100
- use : When commitlint is not used and normalization is to be used
TIP
Line breaks mainly based on word completeness 
 If commitlint is used, it will automatically read body-max-line-length and set it.
breaklineChar
- description : newline characters in detailed descriptions (body) and breaking changes (BREAKING CHANGES)
- type : string
- default : "|"
issuePrefixes
- description : custom select issue prefix
- type : Array<{ value: string, name: string }>
- default : [{ value: "closed", name: "closed: ISSUES has been processed" }]
allowCustomIssuePrefix
- description : whether to display custom options when selecting ISSUES prefix (custom)
- type : boolean
- default : true
allowEmptyIssuePrefix
- description : whether to display an empty option when selecting ISSUES prefix (skip)
- type : boolean
- default : true
maxHeaderLength
- description: Define the length of the header in the commit message, giving the verification information on the command line
- type: number
- default: Infinity
- use : when commitlint is not used and normalization is to be used
TIP
If you use commitlint, it will automatically read header-max-length and set it to give a prompt on the command line
maxSubjectLength
- description: Define the length of the subject in the commit message, giving the verification information on the command line
- type: number
- default: Infinity
- use : When commitlint is not used and normalization is to be used
TIP
If using commitlint will automatically read subject-max-length and set it to give a prompt on the command line.
minSubjectLength
- description: Define the length of the subject in the commit message, giving the verification information on the command line
- type: number
- default : 0
- use : When commitlint is not used and normalization is to be used
TIP
If commitlint is used, it will automatically read subject-min-length and set it to give a prompt on the command line
useCommitSignGPG
- description : use GPG sign commit message
- type : boolean
- default : false
TIP
- Only take effect czgcz-git CLI
- Try running command to enable directly use GPG sign commit message in the current session- cz-git CLI: czg gpg
 
- cz-git CLI: 
About GPG sign commit message information. can see: Zhengqbbb/cz-git#58
skipQuestions
- description : The question specified by the custom selection is not displayed
- type : Array<'scope' | 'body' | 'breaking' | 'footerPrefix' | 'footer' | 'confirmCommit'>
- default : []
formatMessageCB
- description : Use the callback fn can custom finally message formatter
- type : (messageMod: CommitMessageOptions) => string
interface CommitMessageOptions {
  type: string
  scope: string
  emoji: string
  markBreaking: string
  subject: string
  defaultHeader: string
  body: string
  breaking: string
  footer: string
  defaultMessage: string
}
interface CommitMessageOptions {
  type: string
  scope: string
  emoji: string
  markBreaking: string
  subject: string
  defaultHeader: string
  body: string
  breaking: string
  footer: string
  defaultMessage: string
}
- default : ({ defaultMessage }) => defaultMessage
 cz-git
cz-git