1125 lines
35 KiB
TypeScript
1125 lines
35 KiB
TypeScript
/* tslint:disable */
|
|
/* eslint-disable */
|
|
|
|
/* auto-generated by NAPI-RS */
|
|
|
|
export const enum DiffFlags {
|
|
/**
|
|
* File(s) treated as binary data.
|
|
* 1 << 0
|
|
*/
|
|
Binary = 1,
|
|
/**
|
|
* File(s) treated as text data.
|
|
* 1 << 1
|
|
*/
|
|
NotBinary = 2,
|
|
/**
|
|
* `id` value is known correct.
|
|
* 1 << 2
|
|
*/
|
|
ValidId = 4,
|
|
/**
|
|
* File exists at this side of the delta.
|
|
* 1 << 3
|
|
*/
|
|
Exists = 8
|
|
}
|
|
/** Valid modes for index and tree entries. */
|
|
export const enum FileMode {
|
|
/** Unreadable */
|
|
Unreadable = 0,
|
|
/** Tree */
|
|
Tree = 1,
|
|
/** Blob */
|
|
Blob = 2,
|
|
/** Group writable blob. Obsolete mode kept for compatibility reasons */
|
|
BlobGroupWritable = 3,
|
|
/** Blob executable */
|
|
BlobExecutable = 4,
|
|
/** Link */
|
|
Link = 5,
|
|
/** Commit */
|
|
Commit = 6
|
|
}
|
|
export const enum Delta {
|
|
/** No changes */
|
|
Unmodified = 0,
|
|
/** Entry does not exist in old version */
|
|
Added = 1,
|
|
/** Entry does not exist in new version */
|
|
Deleted = 2,
|
|
/** Entry content changed between old and new */
|
|
Modified = 3,
|
|
/** Entry was renamed between old and new */
|
|
Renamed = 4,
|
|
/** Entry was copied from another old entry */
|
|
Copied = 5,
|
|
/** Entry is ignored item in workdir */
|
|
Ignored = 6,
|
|
/** Entry is untracked item in workdir */
|
|
Untracked = 7,
|
|
/** Type of entry changed between old and new */
|
|
Typechange = 8,
|
|
/** Entry is unreadable */
|
|
Unreadable = 9,
|
|
/** Entry in the index is conflicted */
|
|
Conflicted = 10
|
|
}
|
|
export interface DiffOptions {
|
|
/**
|
|
* When generating output, include the names of unmodified files if they
|
|
* are included in the `Diff`. Normally these are skipped in the formats
|
|
* that list files (e.g. name-only, name-status, raw). Even with this these
|
|
* will not be included in the patch format.
|
|
*/
|
|
showUnmodified?: boolean
|
|
}
|
|
export const enum ObjectType {
|
|
/** Any kind of git object */
|
|
Any = 0,
|
|
/** An object which corresponds to a git commit */
|
|
Commit = 1,
|
|
/** An object which corresponds to a git tree */
|
|
Tree = 2,
|
|
/** An object which corresponds to a git blob */
|
|
Blob = 3,
|
|
/** An object which corresponds to a git tag */
|
|
Tag = 4
|
|
}
|
|
/** An enumeration of all possible kinds of references. */
|
|
export const enum ReferenceType {
|
|
/** A reference which points at an object id. */
|
|
Direct = 0,
|
|
/** A reference which points at another reference. */
|
|
Symbolic = 1,
|
|
Unknown = 2
|
|
}
|
|
/** An enumeration of the possible directions for a remote. */
|
|
export const enum Direction {
|
|
/** Data will be fetched (read) from this remote. */
|
|
Fetch = 0,
|
|
/** Data will be pushed (written) to this remote. */
|
|
Push = 1
|
|
}
|
|
/** Configuration for how pruning is done on a fetch */
|
|
export const enum FetchPrune {
|
|
/** Use the setting from the configuration */
|
|
Unspecified = 0,
|
|
/** Force pruning on */
|
|
On = 1,
|
|
/** Force pruning off */
|
|
Off = 2
|
|
}
|
|
/** Automatic tag following options. */
|
|
export const enum AutotagOption {
|
|
/** Use the setting from the remote's configuration */
|
|
Unspecified = 0,
|
|
/** Ask the server for tags pointing to objects we're already downloading */
|
|
Auto = 1,
|
|
/** Don't ask for any tags beyond the refspecs */
|
|
None = 2,
|
|
/** Ask for all the tags */
|
|
All = 3
|
|
}
|
|
/**
|
|
* Remote redirection settings; whether redirects to another host are
|
|
* permitted.
|
|
*
|
|
* By default, git will follow a redirect on the initial request
|
|
* (`/info/refs`), but not subsequent requests.
|
|
*/
|
|
export const enum RemoteRedirect {
|
|
/** Do not follow any off-site redirects at any stage of the fetch or push. */
|
|
None = 0,
|
|
/**
|
|
* Allow off-site redirects only upon the initial request. This is the
|
|
* default.
|
|
*/
|
|
Initial = 1,
|
|
/** Allow redirects at any stage in the fetch or push. */
|
|
All = 2
|
|
}
|
|
/** Types of credentials that can be requested by a credential callback. */
|
|
export const enum CredentialType {
|
|
/** 1 << 0 */
|
|
UserPassPlaintext = 1,
|
|
/** 1 << 1 */
|
|
SshKey = 2,
|
|
/** 1 << 6 */
|
|
SshMemory = 64,
|
|
/** 1 << 2 */
|
|
SshCustom = 4,
|
|
/** 1 << 3 */
|
|
Default = 8,
|
|
/** 1 << 4 */
|
|
SshInteractive = 16,
|
|
/** 1 << 5 */
|
|
Username = 32
|
|
}
|
|
export interface CredInfo {
|
|
credType: CredentialType
|
|
url: string
|
|
username: string
|
|
}
|
|
export interface Progress {
|
|
totalObjects: number
|
|
indexedObjects: number
|
|
receivedObjects: number
|
|
localObjects: number
|
|
totalDeltas: number
|
|
indexedDeltas: number
|
|
receivedBytes: number
|
|
}
|
|
export interface PushTransferProgress {
|
|
current: number
|
|
total: number
|
|
bytes: number
|
|
}
|
|
/** Check whether a cred_type contains another credential type. */
|
|
export function credTypeContains(credType: CredentialType, another: CredentialType): boolean
|
|
export const enum RepositoryState {
|
|
Clean = 0,
|
|
Merge = 1,
|
|
Revert = 2,
|
|
RevertSequence = 3,
|
|
CherryPick = 4,
|
|
CherryPickSequence = 5,
|
|
Bisect = 6,
|
|
Rebase = 7,
|
|
RebaseInteractive = 8,
|
|
RebaseMerge = 9,
|
|
ApplyMailbox = 10,
|
|
ApplyMailboxOrRebase = 11
|
|
}
|
|
export const enum RepositoryOpenFlags {
|
|
/** Only open the specified path; don't walk upward searching. */
|
|
NoSearch = 0,
|
|
/** Search across filesystem boundaries. */
|
|
CrossFS = 1,
|
|
/** Force opening as bare repository, and defer loading its config. */
|
|
Bare = 2,
|
|
/** Don't try appending `/.git` to the specified repository path. */
|
|
NoDotGit = 3,
|
|
/** Respect environment variables like `$GIT_DIR`. */
|
|
FromEnv = 4
|
|
}
|
|
export const enum CloneLocal {
|
|
/**
|
|
* Auto-detect (default)
|
|
*
|
|
* Here libgit2 will bypass the git-aware transport for local paths, but
|
|
* use a normal fetch for `file://` URLs.
|
|
*/
|
|
Auto = 0,
|
|
/** Bypass the git-aware transport even for `file://` URLs. */
|
|
Local = 1,
|
|
/** Never bypass the git-aware transport */
|
|
None = 2,
|
|
/** Bypass the git-aware transport, but don't try to use hardlinks. */
|
|
NoLinks = 3
|
|
}
|
|
/** Orderings that may be specified for Revwalk iteration. */
|
|
export const enum Sort {
|
|
/**
|
|
* Sort the repository contents in no particular ordering.
|
|
*
|
|
* This sorting is arbitrary, implementation-specific, and subject to
|
|
* change at any time. This is the default sorting for new walkers.
|
|
*/
|
|
None = 0,
|
|
/**
|
|
* Sort the repository contents in topological order (children before
|
|
* parents).
|
|
*
|
|
* This sorting mode can be combined with time sorting.
|
|
* 1 << 0
|
|
*/
|
|
Topological = 1,
|
|
/**
|
|
* Sort the repository contents by commit time.
|
|
*
|
|
* This sorting mode can be combined with topological sorting.
|
|
* 1 << 1
|
|
*/
|
|
Time = 2,
|
|
/**
|
|
* Iterate through the repository contents in reverse order.
|
|
*
|
|
* This sorting mode can be combined with any others.
|
|
* 1 << 2
|
|
*/
|
|
Reverse = 4
|
|
}
|
|
export class Commit {
|
|
/** Get the id (SHA1) of a repository object */
|
|
id(): string
|
|
/**
|
|
* Get the id of the tree pointed to by this commit.
|
|
*
|
|
* No attempts are made to fetch an object from the ODB.
|
|
*/
|
|
treeId(): string
|
|
/** Get the tree pointed to by this commit. */
|
|
tree(): Tree
|
|
/**
|
|
*
|
|
* The returned message will be slightly prettified by removing any
|
|
* potential leading newlines.
|
|
*
|
|
* `None` will be returned if the message is not valid utf-8
|
|
*/
|
|
message(): string | null
|
|
/**
|
|
* Get the full message of a commit as a byte slice.
|
|
*
|
|
* The returned message will be slightly prettified by removing any
|
|
* potential leading newlines.
|
|
*/
|
|
messageBytes(): Buffer
|
|
/**
|
|
* Get the encoding for the message of a commit, as a string representing a
|
|
* standard encoding name.
|
|
*
|
|
* `None` will be returned if the encoding is not known
|
|
*/
|
|
messageEncoding(): string | null
|
|
/**
|
|
* Get the full raw message of a commit.
|
|
*
|
|
* `None` will be returned if the message is not valid utf-8
|
|
*/
|
|
messageRaw(): string | null
|
|
/** Get the full raw message of a commit. */
|
|
messageRawBytes(): Buffer
|
|
/**
|
|
* Get the full raw text of the commit header.
|
|
*
|
|
* `None` will be returned if the message is not valid utf-8
|
|
*/
|
|
rawHeader(): string | null
|
|
/** Get an arbitrary header field. */
|
|
headerFieldBytes(field: string): Buffer
|
|
/** Get the full raw text of the commit header. */
|
|
rawHeaderBytes(): Buffer
|
|
/**
|
|
* Get the short "summary" of the git commit message.
|
|
*
|
|
* The returned message is the summary of the commit, comprising the first
|
|
* paragraph of the message with whitespace trimmed and squashed.
|
|
*
|
|
* `None` may be returned if an error occurs or if the summary is not valid
|
|
* utf-8.
|
|
*/
|
|
summary(): string | null
|
|
/**
|
|
* Get the short "summary" of the git commit message.
|
|
*
|
|
* The returned message is the summary of the commit, comprising the first
|
|
* paragraph of the message with whitespace trimmed and squashed.
|
|
*
|
|
* `None` may be returned if an error occurs
|
|
*/
|
|
summaryBytes(): Buffer | null
|
|
/**
|
|
* Get the long "body" of the git commit message.
|
|
*
|
|
* The returned message is the body of the commit, comprising everything
|
|
* but the first paragraph of the message. Leading and trailing whitespaces
|
|
* are trimmed.
|
|
*
|
|
* `None` may be returned if an error occurs or if the summary is not valid
|
|
* utf-8.
|
|
*/
|
|
body(): string | null
|
|
/**
|
|
* Get the long "body" of the git commit message.
|
|
*
|
|
* The returned message is the body of the commit, comprising everything
|
|
* but the first paragraph of the message. Leading and trailing whitespaces
|
|
* are trimmed.
|
|
*
|
|
* `None` may be returned if an error occurs.
|
|
*/
|
|
bodyBytes(): Buffer | null
|
|
/**
|
|
* Get the commit time (i.e. committer time) of a commit.
|
|
*
|
|
* The first element of the tuple is the time, in seconds, since the epoch.
|
|
* The second element is the offset, in minutes, of the time zone of the
|
|
* committer's preferred time zone.
|
|
*/
|
|
time(): Date
|
|
/** Get the author of this commit. */
|
|
author(): Signature
|
|
/** Get the committer of this commit. */
|
|
committer(): Signature
|
|
/**
|
|
* Get the number of parents of this commit.
|
|
*
|
|
* Use the `parents` iterator to return an iterator over all parents.
|
|
*/
|
|
parentCount(): bigint
|
|
}
|
|
/** An iterator over the diffs in a delta */
|
|
export class Deltas {
|
|
[Symbol.iterator](): Iterator<DiffDelta, void, void>
|
|
}
|
|
export class DiffDelta {
|
|
/**
|
|
* Returns the flags on the delta.
|
|
*
|
|
* For more information, see `DiffFlags`'s documentation.
|
|
*/
|
|
flags(): DiffFlags
|
|
/** Returns the number of files in this delta. */
|
|
numFiles(): number
|
|
/** Returns the status of this entry */
|
|
status(): Delta
|
|
/**
|
|
* Return the file which represents the "from" side of the diff.
|
|
*
|
|
* What side this means depends on the function that was used to generate
|
|
* the diff and will be documented on the function itself.
|
|
*/
|
|
oldFile(): DiffFile
|
|
/**
|
|
* Return the file which represents the "to" side of the diff.
|
|
*
|
|
* What side this means depends on the function that was used to generate
|
|
* the diff and will be documented on the function itself.
|
|
*/
|
|
newFile(): DiffFile
|
|
}
|
|
export class DiffFile {
|
|
/**
|
|
* Returns the Oid of this item.
|
|
*
|
|
* If this entry represents an absent side of a diff (e.g. the `old_file`
|
|
* of a `Added` delta), then the oid returned will be zeroes.
|
|
*/
|
|
id(): string
|
|
/**
|
|
* Returns the path, in bytes, of the entry relative to the working
|
|
* directory of the repository.
|
|
*/
|
|
path(): string | null
|
|
/** Returns the size of this entry, in bytes */
|
|
size(): bigint
|
|
/** Returns `true` if file(s) are treated as binary data. */
|
|
isBinary(): boolean
|
|
/** Returns `true` if file(s) are treated as text data. */
|
|
isNotBinary(): boolean
|
|
/** Returns `true` if `id` value is known correct. */
|
|
isValidId(): boolean
|
|
/** Returns `true` if file exists at this side of the delta. */
|
|
exists(): boolean
|
|
/** Returns file mode. */
|
|
mode(): FileMode
|
|
}
|
|
export class Diff {
|
|
/**
|
|
* Merge one diff into another.
|
|
*
|
|
* This merges items from the "from" list into the "self" list. The
|
|
* resulting diff will have all items that appear in either list.
|
|
* If an item appears in both lists, then it will be "merged" to appear
|
|
* as if the old version was from the "onto" list and the new version
|
|
* is from the "from" list (with the exception that if the item has a
|
|
* pending DELETE in the middle, then it will show as deleted).
|
|
*/
|
|
merge(diff: Diff): void
|
|
/** Returns an iterator over the deltas in this diff. */
|
|
deltas(): Deltas
|
|
/** Check if deltas are sorted case sensitively or insensitively. */
|
|
isSortedIcase(): boolean
|
|
}
|
|
export class GitObject {
|
|
/** Get the id (SHA1) of a repository object */
|
|
id(): string
|
|
/** Get the type of the object. */
|
|
kind(): ObjectType | null
|
|
peel(kind: ObjectType): GitObject
|
|
}
|
|
export class Reference {
|
|
/**
|
|
* Ensure the reference name is well-formed.
|
|
*
|
|
* Validation is performed as if [`ReferenceFormat::ALLOW_ONELEVEL`]
|
|
* was given to [`Reference.normalize_name`]. No normalization is
|
|
* performed, however.
|
|
*
|
|
* ```ts
|
|
* import { Reference } from '@napi-rs/simple-git'
|
|
*
|
|
* console.assert(Reference.is_valid_name("HEAD"));
|
|
* console.assert(Reference.is_valid_name("refs/heads/main"));
|
|
*
|
|
* // But:
|
|
* console.assert(!Reference.is_valid_name("main"));
|
|
* console.assert(!Reference.is_valid_name("refs/heads/*"));
|
|
* console.assert(!Reference.is_valid_name("foo//bar"));
|
|
* ```
|
|
*/
|
|
static isValidName(name: string): boolean
|
|
/** Check if a reference is a local branch. */
|
|
isBranch(): boolean
|
|
/** Check if a reference is a note. */
|
|
isNote(): boolean
|
|
/** Check if a reference is a remote tracking branch */
|
|
isRemote(): boolean
|
|
/** Check if a reference is a tag */
|
|
isTag(): boolean
|
|
kind(): ReferenceType
|
|
/**
|
|
* Get the full name of a reference.
|
|
*
|
|
* Returns `None` if the name is not valid utf-8.
|
|
*/
|
|
name(): string | null
|
|
/**
|
|
* Get the full shorthand of a reference.
|
|
*
|
|
* This will transform the reference name into a name "human-readable"
|
|
* version. If no shortname is appropriate, it will return the full name.
|
|
*
|
|
* Returns `None` if the shorthand is not valid utf-8.
|
|
*/
|
|
shorthand(): string | null
|
|
/**
|
|
* Get the OID pointed to by a direct reference.
|
|
*
|
|
* Only available if the reference is direct (i.e. an object id reference,
|
|
* not a symbolic one).
|
|
*/
|
|
target(): string | null
|
|
/**
|
|
* Return the peeled OID target of this reference.
|
|
*
|
|
* This peeled OID only applies to direct references that point to a hard
|
|
* Tag object: it is the result of peeling such Tag.
|
|
*/
|
|
targetPeel(): string | null
|
|
/**
|
|
* Peel a reference to a tree
|
|
*
|
|
* This method recursively peels the reference until it reaches
|
|
* a tree.
|
|
*/
|
|
peelToTree(): Tree
|
|
/**
|
|
* Get full name to the reference pointed to by a symbolic reference.
|
|
*
|
|
* May return `None` if the reference is either not symbolic or not a
|
|
* valid utf-8 string.
|
|
*/
|
|
symbolicTarget(): string | null
|
|
/**
|
|
* Resolve a symbolic reference to a direct reference.
|
|
*
|
|
* This method iteratively peels a symbolic reference until it resolves to
|
|
* a direct reference to an OID.
|
|
*
|
|
* If a direct reference is passed as an argument, a copy of that
|
|
* reference is returned.
|
|
*/
|
|
resolve(): Reference
|
|
/**
|
|
* Rename an existing reference.
|
|
*
|
|
* This method works for both direct and symbolic references.
|
|
*
|
|
* If the force flag is not enabled, and there's already a reference with
|
|
* the given name, the renaming will fail.
|
|
*/
|
|
rename(newName: string, force: boolean, msg: string): Reference
|
|
}
|
|
export class Remote {
|
|
/** Ensure the remote name is well-formed. */
|
|
static isValidName(name: string): boolean
|
|
/**
|
|
* Get the remote's name.
|
|
*
|
|
* Returns `None` if this remote has not yet been named or if the name is
|
|
* not valid utf-8
|
|
*/
|
|
name(): string | null
|
|
/**
|
|
* Get the remote's url.
|
|
*
|
|
* Returns `None` if the url is not valid utf-8
|
|
*/
|
|
url(): string | null
|
|
/**
|
|
* Get the remote's pushurl.
|
|
*
|
|
* Returns `None` if the pushurl is not valid utf-8
|
|
*/
|
|
pushurl(): string | null
|
|
/**
|
|
* Get the remote's default branch.
|
|
*
|
|
* The remote (or more exactly its transport) must have connected to the
|
|
* remote repository. This default branch is available as soon as the
|
|
* connection to the remote is initiated and it remains available after
|
|
* disconnecting.
|
|
*/
|
|
defaultBranch(): string
|
|
/** Open a connection to a remote. */
|
|
connect(dir: Direction): void
|
|
/** Check whether the remote is connected */
|
|
connected(): boolean
|
|
/** Disconnect from the remote */
|
|
disconnect(): void
|
|
/**
|
|
* Cancel the operation
|
|
*
|
|
* At certain points in its operation, the network code checks whether the
|
|
* operation has been cancelled and if so stops the operation.
|
|
*/
|
|
stop(): void
|
|
/**
|
|
* Download new data and update tips
|
|
*
|
|
* Convenience function to connect to a remote, download the data,
|
|
* disconnect and update the remote-tracking branches.
|
|
*
|
|
*/
|
|
fetch(refspecs: Array<string>, fetchOptions?: FetchOptions | undefined | null): void
|
|
/** Update the tips to the new state */
|
|
updateTips(updateFetchhead: boolean, downloadTags: AutotagOption, callbacks?: RemoteCallbacks | undefined | null, msg?: string | undefined | null): void
|
|
}
|
|
export class RemoteCallbacks {
|
|
constructor()
|
|
/**
|
|
* The callback through which to fetch credentials if required.
|
|
*
|
|
* # Example
|
|
*
|
|
* Prepare a callback to authenticate using the `$HOME/.ssh/id_rsa` SSH key, and
|
|
* extracting the username from the URL (i.e. git@github.com:rust-lang/git2-rs.git):
|
|
*
|
|
* ```js
|
|
* import { join } from 'node:path'
|
|
* import { homedir } from 'node:os'
|
|
*
|
|
* import { Cred, FetchOptions, RemoteCallbacks, RepoBuilder, credTypeContains } from '@napi-rs/simple-git'
|
|
*
|
|
* const builder = new RepoBuilder()
|
|
* const remoteCallbacks = new RemoteCallbacks()
|
|
* .credentials((cred) => {
|
|
* return Cred.sshKey(cred.username, null, join(homedir(), '.ssh', 'id_rsa'), null)
|
|
* })
|
|
*
|
|
* const fetchOptions = new FetchOptions().depth(0).remoteCallback(remoteCallbacks)
|
|
*
|
|
* const repo = builder.branch('master')
|
|
* .fetchOptions(fetchOptions)
|
|
* .clone("git@github.com:rust-lang/git2-rs.git", "git2-rs")
|
|
* ```
|
|
*/
|
|
credentials(callback: (arg: CredInfo) => Cred): this
|
|
/** The callback through which progress is monitored. */
|
|
transferProgress(callback: (arg: Progress) => void): this
|
|
/** The callback through which progress of push transfer is monitored */
|
|
pushTransferProgress(callback: (current: number, total: number, bytes: number) => void): this
|
|
}
|
|
export class FetchOptions {
|
|
constructor()
|
|
/** Set the callbacks to use for the fetch operation. */
|
|
remoteCallback(callback: RemoteCallbacks): this
|
|
/** Set the proxy options to use for the fetch operation. */
|
|
proxyOptions(options: ProxyOptions): this
|
|
/** Set whether to perform a prune after the fetch. */
|
|
prune(prune: FetchPrune): this
|
|
/**
|
|
* Set whether to write the results to FETCH_HEAD.
|
|
*
|
|
* Defaults to `true`.
|
|
*/
|
|
updateFetchhead(update: boolean): this
|
|
/**
|
|
* Set fetch depth, a value less or equal to 0 is interpreted as pull
|
|
* everything (effectively the same as not declaring a limit depth).
|
|
*/
|
|
depth(depth: number): this
|
|
/**
|
|
* Set how to behave regarding tags on the remote, such as auto-downloading
|
|
* tags for objects we're downloading or downloading all of them.
|
|
*
|
|
* The default is to auto-follow tags.
|
|
*/
|
|
downloadTags(opt: AutotagOption): this
|
|
/**
|
|
* Set remote redirection settings; whether redirects to another host are
|
|
* permitted.
|
|
*
|
|
* By default, git will follow a redirect on the initial request
|
|
* (`/info/refs`), but not subsequent requests.
|
|
*/
|
|
followRedirects(opt: RemoteRedirect): this
|
|
/** Set extra headers for this fetch operation. */
|
|
customHeaders(headers: Array<string>): this
|
|
}
|
|
export class ProxyOptions {
|
|
constructor()
|
|
/**
|
|
* Try to auto-detect the proxy from the git configuration.
|
|
*
|
|
* Note that this will override `url` specified before.
|
|
*/
|
|
auto(): this
|
|
/**
|
|
* Specify the exact URL of the proxy to use.
|
|
*
|
|
* Note that this will override `auto` specified before.
|
|
*/
|
|
url(url: string): this
|
|
}
|
|
export class Cred {
|
|
/**
|
|
* Create a "default" credential usable for Negotiate mechanisms like NTLM
|
|
* or Kerberos authentication.
|
|
*/
|
|
constructor()
|
|
/**
|
|
* Create a new ssh key credential object used for querying an ssh-agent.
|
|
*
|
|
* The username specified is the username to authenticate.
|
|
*/
|
|
static sshKeyFromAgent(username: string): Cred
|
|
/** Create a new passphrase-protected ssh key credential object. */
|
|
static sshKey(username: string, publickey: string | undefined | null, privatekey: string, passphrase?: string | undefined | null): Cred
|
|
/** Create a new ssh key credential object reading the keys from memory. */
|
|
static sshKeyFromMemory(username: string, publickey: string | undefined | null, privatekey: string, passphrase?: string | undefined | null): Cred
|
|
/** Create a new plain-text username and password credential object. */
|
|
static userpassPlaintext(username: string, password: string): Cred
|
|
/**
|
|
* Create a credential to specify a username.
|
|
*
|
|
* This is used with ssh authentication to query for the username if none is
|
|
* specified in the URL.
|
|
*/
|
|
static username(username: string): Cred
|
|
/** Check whether a credential object contains username information. */
|
|
hasUsername(): boolean
|
|
/** Return the type of credentials that this object represents. */
|
|
credtype(): CredentialType
|
|
}
|
|
export class Repository {
|
|
static init(p: string): Repository
|
|
/**
|
|
* Find and open an existing repository, with additional options.
|
|
*
|
|
* If flags contains REPOSITORY_OPEN_NO_SEARCH, the path must point
|
|
* directly to a repository; otherwise, this may point to a subdirectory
|
|
* of a repository, and `open_ext` will search up through parent
|
|
* directories.
|
|
*
|
|
* If flags contains REPOSITORY_OPEN_CROSS_FS, the search through parent
|
|
* directories will not cross a filesystem boundary (detected when the
|
|
* stat st_dev field changes).
|
|
*
|
|
* If flags contains REPOSITORY_OPEN_BARE, force opening the repository as
|
|
* bare even if it isn't, ignoring any working directory, and defer
|
|
* loading the repository configuration for performance.
|
|
*
|
|
* If flags contains REPOSITORY_OPEN_NO_DOTGIT, don't try appending
|
|
* `/.git` to `path`.
|
|
*
|
|
* If flags contains REPOSITORY_OPEN_FROM_ENV, `open_ext` will ignore
|
|
* other flags and `ceiling_dirs`, and respect the same environment
|
|
* variables git does. Note, however, that `path` overrides `$GIT_DIR`; to
|
|
* respect `$GIT_DIR` as well, use `open_from_env`.
|
|
*
|
|
* ceiling_dirs specifies a list of paths that the search through parent
|
|
* directories will stop before entering. Use the functions in std::env
|
|
* to construct or manipulate such a path list.
|
|
*/
|
|
static openExt(path: string, flags: RepositoryOpenFlags, ceilingDirs: Array<string>): Repository
|
|
/**
|
|
* Attempt to open an already-existing repository at or above `path`
|
|
*
|
|
* This starts at `path` and looks up the filesystem hierarchy
|
|
* until it finds a repository.
|
|
*/
|
|
static discover(path: string): Repository
|
|
/**
|
|
* Creates a new `--bare` repository in the specified folder.
|
|
*
|
|
* The folder must exist prior to invoking this function.
|
|
*/
|
|
static initBare(path: string): Repository
|
|
/**
|
|
* Clone a remote repository.
|
|
*
|
|
* See the `RepoBuilder` struct for more information. This function will
|
|
* delegate to a fresh `RepoBuilder`
|
|
*/
|
|
static clone(url: string, path: string): Repository
|
|
/**
|
|
* Clone a remote repository, initialize and update its submodules
|
|
* recursively.
|
|
*
|
|
* This is similar to `git clone --recursive`.
|
|
*/
|
|
static cloneRecurse(url: string, path: string): Repository
|
|
/**
|
|
* Attempt to open an already-existing repository at `path`.
|
|
*
|
|
* The path can point to either a normal or bare repository.
|
|
*/
|
|
constructor(gitDir: string)
|
|
/** Retrieve and resolve the reference pointed at by HEAD. */
|
|
head(): Reference
|
|
/** Tests whether this repository is a shallow clone. */
|
|
isShallow(): boolean
|
|
/** Tests whether this repository is empty. */
|
|
isEmpty(): boolean
|
|
/** Tests whether this repository is a worktree. */
|
|
isWorktree(): boolean
|
|
/**
|
|
* Returns the path to the `.git` folder for normal repositories or the
|
|
* repository itself for bare repositories.
|
|
*/
|
|
path(): string
|
|
/** Returns the current state of this repository */
|
|
state(): RepositoryState
|
|
/**
|
|
* Get the path of the working directory for this repository.
|
|
*
|
|
* If this repository is bare, then `None` is returned.
|
|
*/
|
|
workdir(): string | null
|
|
/**
|
|
* Set the path to the working directory for this repository.
|
|
*
|
|
* If `update_link` is true, create/update the gitlink file in the workdir
|
|
* and set config "core.worktree" (if workdir is not the parent of the .git
|
|
* directory).
|
|
*/
|
|
setWorkdir(path: string, updateGitlink: boolean): void
|
|
/**
|
|
* Get the currently active namespace for this repository.
|
|
*
|
|
* If there is no namespace, or the namespace is not a valid utf8 string,
|
|
* `None` is returned.
|
|
*/
|
|
namespace(): string | null
|
|
/** Set the active namespace for this repository. */
|
|
setNamespace(namespace: string): void
|
|
/** Remove the active namespace for this repository. */
|
|
removeNamespace(): void
|
|
/**
|
|
* Retrieves the Git merge message.
|
|
* Remember to remove the message when finished.
|
|
*/
|
|
message(): string
|
|
/** Remove the Git merge message. */
|
|
removeMessage(): void
|
|
/** List all remotes for a given repository */
|
|
remotes(): Array<string>
|
|
/** Get the information for a particular remote */
|
|
findRemote(name: string): Remote
|
|
/**
|
|
* Add a remote with the default fetch refspec to the repository's
|
|
* configuration.
|
|
*/
|
|
remote(name: string, url: string): Remote
|
|
/**
|
|
* Add a remote with the provided fetch refspec to the repository's
|
|
* configuration.
|
|
*/
|
|
remoteWithFetch(name: string, url: string, refspect: string): Remote
|
|
/**
|
|
* Create an anonymous remote
|
|
*
|
|
* Create a remote with the given URL and refspec in memory. You can use
|
|
* this when you have a URL instead of a remote's name. Note that anonymous
|
|
* remotes cannot be converted to persisted remotes.
|
|
*/
|
|
remoteAnonymous(url: string): Remote
|
|
/**
|
|
* Give a remote a new name
|
|
*
|
|
* All remote-tracking branches and configuration settings for the remote
|
|
* are updated.
|
|
*
|
|
* A temporary in-memory remote cannot be given a name with this method.
|
|
*
|
|
* No loaded instances of the remote with the old name will change their
|
|
* name or their list of refspecs.
|
|
*
|
|
* The returned array of strings is a list of the non-default refspecs
|
|
* which cannot be renamed and are returned for further processing by the
|
|
* caller.
|
|
*/
|
|
remoteRename(name: string, newName: string): Array<string>
|
|
/**
|
|
* Delete an existing persisted remote.
|
|
*
|
|
* All remote-tracking branches and configuration settings for the remote
|
|
* will be removed.
|
|
*/
|
|
remoteDelete(name: string): this
|
|
/**
|
|
* Add a fetch refspec to the remote's configuration
|
|
*
|
|
* Add the given refspec to the fetch list in the configuration. No loaded
|
|
*/
|
|
remoteAddFetch(name: string, refspec: string): this
|
|
/**
|
|
* Add a push refspec to the remote's configuration.
|
|
*
|
|
* Add the given refspec to the push list in the configuration. No
|
|
* loaded remote instances will be affected.
|
|
*/
|
|
remoteAddPush(name: string, refspec: string): this
|
|
/**
|
|
* Add a push refspec to the remote's configuration.
|
|
*
|
|
* Add the given refspec to the push list in the configuration. No
|
|
* loaded remote instances will be affected.
|
|
*/
|
|
remoteSetUrl(name: string, url: string): this
|
|
/**
|
|
* Set the remote's URL for pushing in the configuration.
|
|
*
|
|
* Remote objects already in memory will not be affected. This assumes
|
|
* the common case of a single-url remote and will otherwise return an
|
|
* error.
|
|
*
|
|
* `None` indicates that it should be cleared.
|
|
*/
|
|
remoteSetPushurl(name: string, url?: string | undefined | null): this
|
|
/** Lookup a reference to one of the objects in a repository. */
|
|
findTree(oid: string): Tree
|
|
findCommit(oid: string): Commit
|
|
/**
|
|
* Create a diff between a tree and the working directory.
|
|
*
|
|
* The tree you provide will be used for the "old_file" side of the delta,
|
|
* and the working directory will be used for the "new_file" side.
|
|
*
|
|
* This is not the same as `git diff <treeish>` or `git diff-index
|
|
* <treeish>`. Those commands use information from the index, whereas this
|
|
* function strictly returns the differences between the tree and the files
|
|
* in the working directory, regardless of the state of the index. Use
|
|
* `tree_to_workdir_with_index` to emulate those commands.
|
|
*
|
|
* To see difference between this and `tree_to_workdir_with_index`,
|
|
* consider the example of a staged file deletion where the file has then
|
|
* been put back into the working dir and further modified. The
|
|
* tree-to-workdir diff for that file is 'modified', but `git diff` would
|
|
* show status 'deleted' since there is a staged delete.
|
|
*
|
|
* If `None` is passed for `tree`, then an empty tree is used.
|
|
*/
|
|
diffTreeToWorkdir(oldTree?: Tree | undefined | null): Diff
|
|
/**
|
|
* Create a diff between a tree and the working directory using index data
|
|
* to account for staged deletes, tracked files, etc.
|
|
*
|
|
* This emulates `git diff <tree>` by diffing the tree to the index and
|
|
* the index to the working directory and blending the results into a
|
|
* single diff that includes staged deleted, etc.
|
|
*/
|
|
diffTreeToWorkdirWithIndex(oldTree?: Tree | undefined | null): Diff
|
|
treeEntryToObject(treeEntry: TreeEntry): GitObject
|
|
/**
|
|
* Create new commit in the repository
|
|
*
|
|
* If the `update_ref` is not `None`, name of the reference that will be
|
|
* updated to point to this commit. If the reference is not direct, it will
|
|
* be resolved to a direct reference. Use "HEAD" to update the HEAD of the
|
|
* current branch and make it point to this commit. If the reference
|
|
* doesn't exist yet, it will be created. If it does exist, the first
|
|
* parent must be the tip of this branch.
|
|
*/
|
|
commit(updateRef: string | undefined | null, author: Signature, committer: Signature, message: string, tree: Tree): string
|
|
/** Create a revwalk that can be used to traverse the commit graph. */
|
|
revWalk(): RevWalk
|
|
getFileLatestModifiedDate(filepath: string): number
|
|
getFileLatestModifiedDateAsync(filepath: string, signal?: AbortSignal | undefined | null): Promise<number>
|
|
}
|
|
export class RepoBuilder {
|
|
constructor()
|
|
/**
|
|
* Indicate whether the repository will be cloned as a bare repository or
|
|
* not.
|
|
*/
|
|
bare(bare: boolean): this
|
|
/**
|
|
* Specify the name of the branch to check out after the clone.
|
|
*
|
|
* If not specified, the remote's default branch will be used.
|
|
*/
|
|
branch(branch: string): this
|
|
/**
|
|
* Configures options for bypassing the git-aware transport on clone.
|
|
*
|
|
* Bypassing it means that instead of a fetch libgit2 will copy the object
|
|
* database directory instead of figuring out what it needs, which is
|
|
* faster. If possible, it will hardlink the files to save space.
|
|
*/
|
|
cloneLocal(cloneLocal: CloneLocal): this
|
|
/**
|
|
* Options which control the fetch, including callbacks.
|
|
*
|
|
* The callbacks are used for reporting fetch progress, and for acquiring
|
|
* credentials in the event they are needed.
|
|
*/
|
|
fetchOptions(fetchOptions: FetchOptions): this
|
|
clone(url: string, path: string): Repository
|
|
}
|
|
export class RevWalk {
|
|
[Symbol.iterator](): Iterator<string, void, void>
|
|
/**
|
|
* Reset a revwalk to allow re-configuring it.
|
|
*
|
|
* The revwalk is automatically reset when iteration of its commits
|
|
* completes.
|
|
*/
|
|
reset(): this
|
|
/** Set the sorting mode for a revwalk. */
|
|
setSorting(sorting: Sort): this
|
|
/**
|
|
* Simplify the history by first-parent
|
|
*
|
|
* No parents other than the first for each commit will be enqueued.
|
|
*/
|
|
simplifyFirstParent(): this
|
|
/**
|
|
* Mark a commit to start traversal from.
|
|
*
|
|
* The given OID must belong to a commitish on the walked repository.
|
|
*
|
|
* The given commit will be used as one of the roots when starting the
|
|
* revision walk. At least one commit must be pushed onto the walker before
|
|
* a walk can be started.
|
|
*/
|
|
push(oid: string): this
|
|
/**
|
|
* Push the repository's HEAD
|
|
*
|
|
* For more information, see `push`.
|
|
*/
|
|
pushHead(): this
|
|
/**
|
|
* Push matching references
|
|
*
|
|
* The OIDs pointed to by the references that match the given glob pattern
|
|
* will be pushed to the revision walker.
|
|
*
|
|
* A leading 'refs/' is implied if not present as well as a trailing `/ \
|
|
* *` if the glob lacks '?', ' \ *' or '['.
|
|
*
|
|
* Any references matching this glob which do not point to a commitish
|
|
* will be ignored.
|
|
*/
|
|
pushGlob(glob: string): this
|
|
/**
|
|
* Push and hide the respective endpoints of the given range.
|
|
*
|
|
* The range should be of the form `<commit>..<commit>` where each
|
|
* `<commit>` is in the form accepted by `revparse_single`. The left-hand
|
|
* commit will be hidden and the right-hand commit pushed.
|
|
*/
|
|
pushRange(range: string): this
|
|
/**
|
|
* Push the OID pointed to by a reference
|
|
*
|
|
* The reference must point to a commitish.
|
|
*/
|
|
pushRef(reference: string): this
|
|
/** Mark a commit as not of interest to this revwalk. */
|
|
hide(oid: string): this
|
|
/**
|
|
* Hide the repository's HEAD
|
|
*
|
|
* For more information, see `hide`.
|
|
*/
|
|
hideHead(): this
|
|
/**
|
|
* Hide matching references.
|
|
*
|
|
* The OIDs pointed to by the references that match the given glob pattern
|
|
* and their ancestors will be hidden from the output on the revision walk.
|
|
*
|
|
* A leading 'refs/' is implied if not present as well as a trailing `/ \
|
|
* *` if the glob lacks '?', ' \ *' or '['.
|
|
*
|
|
* Any references matching this glob which do not point to a commitish
|
|
* will be ignored.
|
|
*/
|
|
hideGlob(glob: string): this
|
|
/**
|
|
* Hide the OID pointed to by a reference.
|
|
*
|
|
* The reference must point to a commitish.
|
|
*/
|
|
hideRef(reference: string): this
|
|
}
|
|
/**
|
|
* A Signature is used to indicate authorship of various actions throughout the
|
|
* library.
|
|
*
|
|
* Signatures contain a name, email, and timestamp. All fields can be specified
|
|
* with `new` while the `now` constructor omits the timestamp. The
|
|
* [`Repository::signature`] method can be used to create a default signature
|
|
* with name and email values read from the configuration.
|
|
*
|
|
* [`Repository::signature`]: struct.Repository.html#method.signature
|
|
*/
|
|
export class Signature {
|
|
/**
|
|
* Create a new action signature with a timestamp of 'now'.
|
|
*
|
|
* See `new` for more information
|
|
*/
|
|
static now(name: string, email: string): Signature
|
|
/**
|
|
* Create a new action signature.
|
|
*
|
|
* The `time` specified is in seconds since the epoch, and the `offset` is
|
|
* the time zone offset in minutes.
|
|
*
|
|
* Returns error if either `name` or `email` contain angle brackets.
|
|
*/
|
|
constructor(name: string, email: string, time: number)
|
|
/**
|
|
* Gets the name on the signature.
|
|
*
|
|
* Returns `None` if the name is not valid utf-8
|
|
*/
|
|
name(): string | null
|
|
/**
|
|
* Gets the email on the signature.
|
|
*
|
|
* Returns `None` if the email is not valid utf-8
|
|
*/
|
|
email(): string | null
|
|
/** Return the time, in seconds, from epoch */
|
|
when(): number
|
|
}
|
|
export class Tree {
|
|
/** Get the id (SHA1) of a repository object */
|
|
id(): string
|
|
/** Get the number of entries listed in a tree. */
|
|
len(): bigint
|
|
/** Return `true` if there is not entry */
|
|
isEmpty(): boolean
|
|
/** Returns an iterator over the entries in this tree. */
|
|
iter(): TreeIter
|
|
}
|
|
export class TreeIter {
|
|
[Symbol.iterator](): Iterator<TreeEntry, void, void>
|
|
}
|
|
export class TreeEntry {
|
|
/** Get the id of the object pointed by the entry */
|
|
id(): string
|
|
/** Get the name of a tree entry */
|
|
name(): string
|
|
/** Get the filename of a tree entry */
|
|
nameBytes(): Buffer
|
|
}
|