checkout
Checkout a branch
| param | type [= default] | description | 
|---|---|---|
| core | string = 'default' | The plugin core identifier to use for plugin injection | 
| fs [deprecated] | FileSystem | The filesystem containing the git repo. Overrides the fs provided by the plugin system. | 
| dir | string | The working tree directory path | 
| gitdir | string = join(dir,'.git') | The git directory path | 
| emitter [deprecated] | EventEmitter | Overrides the emitter set via the 'emitter' plugin | 
| emitterPrefix | string = '' | Scope emitted events by prepending emitterPrefixto the event name | 
| ref | string | Which branch to checkout | 
| filepaths | Array<string> = ['.'] | Limit the checkout to the given files and directories | 
| pattern | string = null | Only checkout the files that match a glob pattern. (Pattern is relative to filepathsiffilepathsis provided.) | 
| remote | string = 'origin' | Which remote repository to use | 
| noCheckout | boolean = false | If true, will update HEAD but won't update the working directory | 
| noSubmodules | boolean = false | If true, will not print out an error about missing submodules support. TODO: Skip checkout out submodules when supported instead. | 
| return | Promise<void> | Resolves successfully when filesystem operations are complete | 
If the branch already exists it will check out that branch. Otherwise, it will create a new remote tracking branch set to track the remote branch of that name.
Example Code:
// checkout the master branch
await git.checkout({ dir: '$input((/))', ref: '$input((master))' })
console.log('done')
// checkout only JSON and Markdown files from master branch
await git.checkout({ dir: '$input((/))', ref: '$input((master))', pattern: '$input((**\/*.{json,md}))' })
console.log('done')