mirror of https://github.com/freeCodeCamp/devdocs
You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
577 lines
19 KiB
577 lines
19 KiB
import * as resp from "./typings/response";
|
|
|
|
declare function simplegit(basePath?: string): simplegit.SimpleGit;
|
|
|
|
declare namespace simplegit {
|
|
|
|
interface SimpleGit {
|
|
/**
|
|
* Adds one or more files to source control
|
|
*
|
|
* @param {string|string[]} files
|
|
* @returns {Promise<void>}
|
|
*/
|
|
add(files: string | string[]): Promise<void>;
|
|
|
|
/**
|
|
* Add an annotated tag to the head of the current branch
|
|
*
|
|
* @param {string} tagName
|
|
* @param {string} tagMessage
|
|
* @returns {Promise<void>}
|
|
*/
|
|
addAnnotatedTag(tagName: string, tagMessage: string): Promise<void>;
|
|
|
|
/**
|
|
* Add config to local git instance
|
|
*
|
|
* @param {string} key configuration key (e.g user.name)
|
|
* @param {string} value for the given key (e.g your name)
|
|
* @returns {Promise<string>}
|
|
*/
|
|
addConfig(key: string, value: string): Promise<string>;
|
|
|
|
/**
|
|
* Adds a remote to the list of remotes.
|
|
*
|
|
* @param {string} remoteName Name of the repository - eg "upstream"
|
|
* @param {string} remoteRepo Fully qualified SSH or HTTP(S) path to the remote repo
|
|
* @returns {Promise<void>}
|
|
*/
|
|
addRemote(remoteName: string, remoteRepo: string): Promise<void>;
|
|
|
|
/**
|
|
* Add a lightweight tag to the head of the current branch
|
|
*
|
|
* @param {string} name
|
|
* @returns {Promise<string>}
|
|
*/
|
|
addTag(name: string): Promise<string>;
|
|
|
|
/**
|
|
* Equivalent to `catFile` but will return the native `Buffer` of content from the git command's stdout.
|
|
*
|
|
* @param {string[]} options
|
|
*/
|
|
binaryCatFile(options: string[]): Promise<any>;
|
|
|
|
/**
|
|
* List all branches
|
|
*/
|
|
branch(): Promise<BranchSummary>;
|
|
branch(options: Options | string[]): Promise<BranchSummary>;
|
|
|
|
/**
|
|
* List of local branches
|
|
*
|
|
* @returns {Promise<BranchSummary>}
|
|
*/
|
|
branchLocal(): Promise<BranchSummary>;
|
|
|
|
/**
|
|
* Returns a list of objects in a tree based on commit hash.
|
|
* Passing in an object hash returns the object's content, size, and type.
|
|
*
|
|
* Passing "-p" will instruct cat-file to determine the object type, and display its formatted contents.
|
|
*
|
|
* @param {string[]} [options]
|
|
* @returns {Promise<string>}
|
|
*
|
|
* @see https://git-scm.com/docs/git-cat-file
|
|
*/
|
|
catFile(options: string[]): Promise<string>;
|
|
|
|
/**
|
|
* Check if a pathname or pathnames are excluded by .gitignore
|
|
*
|
|
* @param {string|string[]} pathnames
|
|
*/
|
|
checkIgnore(pathnames: string[]): Promise<string[]>;
|
|
|
|
checkIgnore(path: string): Promise<string[]>;
|
|
|
|
/**
|
|
* Validates that the current repo is a Git repo.
|
|
*
|
|
* @returns {Promise<boolean>}
|
|
*/
|
|
checkIsRepo(): Promise<boolean>;
|
|
|
|
/**
|
|
* Checkout a tag or revision, any number of additional arguments can be passed to the `git* checkout` command
|
|
by supplying either a string or array of strings as the `what` parameter.
|
|
*
|
|
* @param {(string | string[])} what one or more commands to pass to `git checkout`.
|
|
* @returns {Promise<void>}
|
|
*/
|
|
checkout(what: string | string[]): Promise<void>;
|
|
|
|
/**
|
|
* Checkout a remote branch.
|
|
*
|
|
* @param {string} branchName name of branch.
|
|
* @param {string} startPoint (e.g origin/development).
|
|
* @returns {Promise<void>}
|
|
*/
|
|
checkoutBranch(branchName: string, startPoint: string): Promise<void>;
|
|
|
|
/**
|
|
* Internally uses pull and tags to get the list of tags then checks out the latest tag.
|
|
*/
|
|
checkoutLatestTag(branchName: string, startPoint: string): Promise<void>;
|
|
|
|
/**
|
|
* Checkout a local branch
|
|
*
|
|
* @param {string} branchName name of branch.
|
|
* @returns {Promise<void>}
|
|
*/
|
|
checkoutLocalBranch(branchName: string): Promise<void>;
|
|
|
|
/**
|
|
* @param {string} mode Required parameter "n" or "f"
|
|
* @param {string[]} options
|
|
*/
|
|
clean(
|
|
mode: 'd' | 'f' | 'i' | 'n' | 'q' | 'x' | 'X',
|
|
options?: string[]
|
|
): Promise<string>;
|
|
|
|
/**
|
|
* Clears the queue of pending commands and returns the wrapper instance for chaining.
|
|
*/
|
|
clearQueue(): this;
|
|
|
|
/**
|
|
* Clone a repository into a new directory.
|
|
*
|
|
* @param {string} repoPath repository url to clone e.g. https://github.com/steveukx/git-js.git
|
|
* @param {string} localPath local folder path to clone to.
|
|
* @param {string[]} [options] options supported by [git](https://git-scm.com/docs/git-clone).
|
|
* @returns {Promise<void>}
|
|
*/
|
|
clone(repoPath: string, localPath: string, options?: Options | string[]): Promise<string>;
|
|
clone(repoPath: string, options?: Options | string[]): Promise<string>;
|
|
|
|
/**
|
|
* Commits changes in the current working directory - when specific file paths are supplied, only changes on those
|
|
* files will be committed.
|
|
*
|
|
* @param {string|string[]} message
|
|
* @param {string|string[]} [files]
|
|
* @param {Object} [options]
|
|
*/
|
|
commit(
|
|
message: string | string[],
|
|
files?: string | string[],
|
|
options?: Options
|
|
): Promise<resp.CommitSummary>;
|
|
|
|
/**
|
|
* Sets the path to a custom git binary, should either be `git` when there is an installation of git available on
|
|
* the system path, or a fully qualified path to the executable.
|
|
*
|
|
* @param {string} command
|
|
*/
|
|
customBinary(command: string): this;
|
|
|
|
/**
|
|
* Sets the working directory of the subsequent commands.
|
|
*
|
|
* @param {string} workingDirectory
|
|
*/
|
|
cwd<path extends string>(workingDirectory: path): Promise<path>;
|
|
|
|
/**
|
|
* Delete a local branch
|
|
*
|
|
* @param {string} branchName name of branch
|
|
*/
|
|
deleteLocalBranch(branchName: string):
|
|
Promise<resp.BranchDeletionSummary>;
|
|
|
|
/**
|
|
* Get the diff of the current repo compared to the last commit with a set of options supplied as a string.
|
|
*
|
|
* @param {string[]} [options] options supported by [git](https://git-scm.com/docs/git-diff).
|
|
* @returns {Promise<string>} raw string result.
|
|
*/
|
|
diff(options?: string[]): Promise<string>;
|
|
|
|
/**
|
|
* Gets a summary of the diff for files in the repo, uses the `git diff --stat` format to calculate changes.
|
|
*
|
|
* in order to get staged (only): `--cached` or `--staged`.
|
|
*
|
|
* @param {string[]} [options] options supported by [git](https://git-scm.com/docs/git-diff).
|
|
* @returns {Promise<DiffResult>} Parsed diff summary result.
|
|
*/
|
|
diffSummary(options?: string[]): Promise<DiffResult>;
|
|
|
|
/**
|
|
* Sets an environment variable for the spawned child process, either supply both a name and value as strings or
|
|
* a single object to entirely replace the current environment variables.
|
|
*
|
|
* @param {string|Object} name
|
|
* @param {string} [value]
|
|
*/
|
|
env(name: string, value: string): this;
|
|
|
|
env(env: object): this;
|
|
|
|
/**
|
|
* Updates the local working copy database with changes from the default remote repo and branch.
|
|
*
|
|
* @param {string | string[]} [remote] remote to fetch from.
|
|
* @param {string} [branch] branch to fetch from.
|
|
* @param {string[]} [options] options supported by [git](https://git-scm.com/docs/git-fetch).
|
|
* @returns {Promise<FetchResult>} Parsed fetch result.
|
|
*/
|
|
fetch(remote?: string | string[], branch?: string, options?: Options): Promise<FetchResult>;
|
|
|
|
/**
|
|
* Gets the currently available remotes, setting the optional verbose argument to true includes additional
|
|
* detail on the remotes themselves.
|
|
*
|
|
* @param {boolean} [verbose=false]
|
|
*/
|
|
getRemotes(verbose: false | undefined): Promise<resp.RemoteWithoutRefs[]>;
|
|
|
|
getRemotes(verbose: true): Promise<resp.RemoteWithRefs[]>;
|
|
|
|
/**
|
|
* Initialize a git repo
|
|
*
|
|
* @param {Boolean} [bare=false]
|
|
*/
|
|
init(bare?: boolean): Promise<void>;
|
|
|
|
/**
|
|
* List remote
|
|
*
|
|
* @param {string[]} [args]
|
|
*/
|
|
listRemote(args: string[]): Promise<string>;
|
|
|
|
/**
|
|
* Show commit logs from `HEAD` to the first commit.
|
|
* If provided between `options.from` and `options.to` tags or branch.
|
|
*
|
|
* You can provide `options.file`, which is the path to a file in your repository. Then only this file will be considered.
|
|
*
|
|
* To use a custom splitter in the log format, set `options.splitter` to be the string the log should be split on.
|
|
*
|
|
* By default the following fields will be part of the result:
|
|
* `hash`: full commit hash
|
|
* `date`: author date, ISO 8601-like format
|
|
* `message`: subject + ref names, like the --decorate option of git-log
|
|
* `author_name`: author name
|
|
* `author_email`: author mail
|
|
* You can specify `options.format` to be an mapping from key to a format option like `%H` (for commit hash).
|
|
* The fields specified in `options.format` will be the fields in the result.
|
|
*
|
|
* Options can also be supplied as a standard options object for adding custom properties supported by the git log command.
|
|
* For any other set of options, supply options as an array of strings to be appended to the git log command.
|
|
*
|
|
* @param {LogOptions} [options]
|
|
*
|
|
* @returns Promise<ListLogSummary>
|
|
*
|
|
* @see https://git-scm.com/docs/git-log
|
|
*/
|
|
log<T = resp.DefaultLogFields>(options?: LogOptions<T>): Promise<resp.ListLogSummary<T>>;
|
|
|
|
/**
|
|
* Runs a merge, `options` can be either an array of arguments
|
|
* supported by the [`git merge`](https://git-scm.com/docs/git-merge)
|
|
* or an options object.
|
|
*
|
|
* Conflicts during the merge result in an error response,
|
|
* the response type whether it was an error or success will be a MergeSummary instance.
|
|
* When successful, the MergeSummary has all detail from a the PullSummary
|
|
*
|
|
* @param {Options | string[]} [options] options supported by [git](https://git-scm.com/docs/git-merge).
|
|
* @returns {Promise<any>}
|
|
*
|
|
* @see https://github.com/steveukx/git-js/blob/master/src/responses/MergeSummary.js
|
|
* @see https://github.com/steveukx/git-js/blob/master/src/responses/PullSummary.js
|
|
*/
|
|
merge(options: Options | string[]): Promise<MergeSummary>;
|
|
|
|
/**
|
|
* Merges from one branch to another, equivalent to running `git merge ${from} $[to}`, the `options` argument can
|
|
* either be an array of additional parameters to pass to the command or null / omitted to be ignored.
|
|
*
|
|
* @param {string} from branch to merge from.
|
|
* @param {string} to branch to merge to.
|
|
* @param {string[]} [options] options supported by [git](https://git-scm.com/docs/git-merge).
|
|
* @returns {Promise<string>}
|
|
*/
|
|
mergeFromTo(from: string, to: string, options?: string[]): Promise<string>;
|
|
|
|
/**
|
|
* Mirror a git repo
|
|
*
|
|
* @param {string} repoPath
|
|
* @param {string} localPath
|
|
*/
|
|
mirror(repoPath: string, localPath: string): Promise<string>;
|
|
|
|
/**
|
|
* Moves one or more files to a new destination.
|
|
*
|
|
* @see https://git-scm.com/docs/git-mv
|
|
*
|
|
* @param {string|string[]} from
|
|
* @param {string} to
|
|
*/
|
|
mv(from: string | string[], to: string): Promise<resp.MoveSummary>;
|
|
|
|
/**
|
|
* Sets a handler function to be called whenever a new child process is created, the handler function will be called
|
|
* with the name of the command being run and the stdout & stderr streams used by the ChildProcess.
|
|
*
|
|
* @example
|
|
* require('simple-git')
|
|
* .outputHandler(function (command, stdout, stderr) {
|
|
* stdout.pipe(process.stdout);
|
|
* })
|
|
* .checkout('https://github.com/user/repo.git');
|
|
*
|
|
* @see https://nodejs.org/api/child_process.html#child_process_class_childprocess
|
|
* @see https://nodejs.org/api/stream.html#stream_class_stream_readable
|
|
* @param {Function} outputHandler
|
|
*/
|
|
outputHandler(handler: outputHandler | void): this;
|
|
|
|
/**
|
|
* Fetch from and integrate with another repository or a local branch.
|
|
*
|
|
* @param {string} [remote] remote to pull from.
|
|
* @param {string} [branch] branch to pull from.
|
|
* @param {Options} [options] options supported by [git](https://git-scm.com/docs/git-pull).
|
|
* @returns {Promise<PullResult>} Parsed pull result.
|
|
*/
|
|
pull(remote?: string, branch?: string, options?: Options): Promise<PullResult>;
|
|
|
|
/**
|
|
* Update remote refs along with associated objects.
|
|
*
|
|
* @param {string} [remote] remote to push to.
|
|
* @param {string} [branch] branch to push to.
|
|
* @param {Options} [options] options supported by [git](https://git-scm.com/docs/git-push).
|
|
* @returns {Promise<void>}
|
|
*/
|
|
push(remote?: string, branch?: string, options?: Options): Promise<void>;
|
|
|
|
/**
|
|
* Pushes the current tag changes to a remote which can be either a URL or named remote. When not specified uses the
|
|
* default configured remote spec.
|
|
*
|
|
* @param {string} [remote]
|
|
*/
|
|
pushTags(remote?: string): Promise<string>;
|
|
|
|
/**
|
|
* Executes any command against the git binary.
|
|
*
|
|
* @param {string[]|Object} commands
|
|
*/
|
|
raw(commands: string | string[]): Promise<string>;
|
|
|
|
/**
|
|
* Rebases the current working copy. Options can be supplied either as an array of string parameters
|
|
* to be sent to the `git rebase` command, or a standard options object.
|
|
*
|
|
* @param {Object|String[]} [options]
|
|
*/
|
|
rebase(options?: Options | string[]): Promise<string>;
|
|
|
|
/**
|
|
* Call any `git remote` function with arguments passed as an array of strings.
|
|
*
|
|
* @param {string[]} options
|
|
*/
|
|
remote(options: string[]): Promise<void | string>;
|
|
|
|
/**
|
|
* Removes an entry from the list of remotes.
|
|
*
|
|
* @param {string} remoteName Name of the repository - eg "upstream"
|
|
* @returns {*}
|
|
*/
|
|
removeRemote(remote: string): Promise<void>;
|
|
|
|
/**
|
|
* Reset a repo
|
|
*
|
|
* @param {string|string[]} [mode=soft] Either an array of arguments supported by the 'git reset' command, or the string value 'soft' or 'hard' to set the reset mode.
|
|
*/
|
|
reset(mode?: 'soft' | 'mixed' | 'hard' | 'merge' | 'keep'): Promise<null>;
|
|
|
|
reset(commands?: string[]): Promise<void>;
|
|
|
|
/**
|
|
* Revert one or more commits in the local working copy
|
|
*
|
|
* @param {string} commit The commit to revert. Can be any hash, offset (eg: `HEAD~2`) or range (eg: `master~5..master~2`)
|
|
* @param {Object} [options] Optional options object
|
|
*/
|
|
revert(commit: String, options?: Options): Promise<void>;
|
|
|
|
/**
|
|
* Wraps `git rev-parse`. Primarily used to convert friendly commit references (ie branch names) to SHA1 hashes.
|
|
*
|
|
* Options should be an array of string options compatible with the `git rev-parse`
|
|
*
|
|
* @param {string[]} [options]
|
|
*
|
|
* @returns Promise<string>
|
|
*
|
|
* @see https://git-scm.com/docs/git-rev-parse
|
|
*/
|
|
revparse(options?: string[]): Promise<string>;
|
|
|
|
/**
|
|
* Removes the named files from source control.
|
|
*
|
|
* @param {string|string[]} files
|
|
*/
|
|
rm(paths: string | string[]): Promise<void>;
|
|
|
|
/**
|
|
* Removes the named files from source control but keeps them on disk rather than deleting them entirely. To
|
|
* completely remove the files, use `rm`.
|
|
*
|
|
* @param {string|string[]} files
|
|
*/
|
|
rmKeepLocal(paths: string | string[]): Promise<void>;
|
|
|
|
/**
|
|
* Show various types of objects, for example the file at a certain commit
|
|
*
|
|
* @param {string[]} [options]
|
|
*/
|
|
show(options?: string[]): Promise<string>;
|
|
|
|
/**
|
|
* Disables/enables the use of the console for printing warnings and errors, by default messages are not shown in
|
|
* a production environment.
|
|
*
|
|
* @param {boolean} silence
|
|
* @returns {simplegit.SimpleGit}
|
|
*/
|
|
silent(silence?: boolean): simplegit.SimpleGit;
|
|
|
|
/**
|
|
* Stash the local repo
|
|
*
|
|
* @param {Object|Array} [options]
|
|
*/
|
|
stash(options?: Options | any[]): Promise<string>;
|
|
|
|
/**
|
|
* List the stash(s) of the local repo
|
|
*
|
|
* @param {Object|Array} [options]
|
|
*/
|
|
stashList(options?: Options | string[]): Promise<resp.ListLogSummary>;
|
|
|
|
/**
|
|
* Show the working tree status.
|
|
*
|
|
* @returns {Promise<StatusResult>} Parsed status result.
|
|
*/
|
|
status(): Promise<StatusResult>;
|
|
|
|
/**
|
|
* Call any `git submodule` function with arguments passed as an array of strings.
|
|
*
|
|
* @param {string[]} options
|
|
*/
|
|
subModule(options: string[]): Promise<string>;
|
|
|
|
/**
|
|
* Add a submodule
|
|
*
|
|
* @param {string} repo
|
|
* @param {string} path
|
|
*/
|
|
submoduleAdd(repo: string, path: string): Promise<void>;
|
|
|
|
/**
|
|
* Initialize submodules
|
|
*
|
|
* @param {string[]} [args]
|
|
*/
|
|
submoduleInit(options?: string[]): Promise<string>;
|
|
|
|
/**
|
|
* Update submodules
|
|
*
|
|
* @param {string[]} [args]
|
|
*/
|
|
submoduleUpdate(options?: string[]): Promise<string>;
|
|
|
|
/**
|
|
* List all tags. When using git 2.7.0 or above, include an options object with `"--sort": "property-name"` to
|
|
* sort the tags by that property instead of using the default semantic versioning sort.
|
|
*
|
|
* Note, supplying this option when it is not supported by your Git version will cause the operation to fail.
|
|
*
|
|
* @param {Object} [options]
|
|
*/
|
|
tag(options?: Options | string[]): Promise<string>;
|
|
|
|
/**
|
|
* Gets a list of tagged versions.
|
|
*
|
|
* @param {Options} options
|
|
* @returns {Promise<TagResult>} Parsed tag list.
|
|
*/
|
|
tags(options?: Options): Promise<TagResult>;
|
|
|
|
/**
|
|
* Updates repository server info
|
|
*/
|
|
updateServerInfo(): Promise<string>;
|
|
}
|
|
|
|
type Options = { [key: string]: null | string | any };
|
|
|
|
type LogOptions<T = resp.DefaultLogFields> = Options & {
|
|
format?: T;
|
|
file?: string;
|
|
from?: string;
|
|
multiLine?: boolean;
|
|
symmetric?: boolean;
|
|
to?: string;
|
|
};
|
|
|
|
// responses
|
|
// ---------------------
|
|
interface BranchSummary extends resp.BranchSummary {}
|
|
|
|
interface CommitSummary extends resp.CommitSummary {}
|
|
|
|
interface MergeSummary extends resp.MergeSummary {}
|
|
|
|
interface PullResult extends resp.PullResult {}
|
|
|
|
interface FetchResult extends resp.FetchResult {}
|
|
|
|
interface StatusResult extends resp.StatusResult {}
|
|
|
|
interface DiffResult extends resp.DiffResult {}
|
|
|
|
interface TagResult extends resp.TagResult {}
|
|
|
|
type outputHandler = (
|
|
command: string,
|
|
stdout: NodeJS.ReadableStream,
|
|
stderr: NodeJS.ReadableStream
|
|
) => void
|
|
}
|
|
|
|
export = simplegit;
|