|
@ -408,10 +408,7 @@ export class Repository implements Disposable { |
|
|
} |
|
|
} |
|
|
|
|
|
|
|
|
@log() |
|
|
@log() |
|
|
branchDelete( |
|
|
|
|
|
branches: GitBranchReference | GitBranchReference[], |
|
|
|
|
|
{ force, remote }: { force?: boolean; remote?: boolean } = {}, |
|
|
|
|
|
) { |
|
|
|
|
|
|
|
|
branchDelete(branches: GitBranchReference | GitBranchReference[], options?: { force?: boolean; remote?: boolean }) { |
|
|
if (!Array.isArray(branches)) { |
|
|
if (!Array.isArray(branches)) { |
|
|
branches = [branches]; |
|
|
branches = [branches]; |
|
|
} |
|
|
} |
|
@ -419,12 +416,12 @@ export class Repository implements Disposable { |
|
|
const localBranches = branches.filter(b => !b.remote); |
|
|
const localBranches = branches.filter(b => !b.remote); |
|
|
if (localBranches.length !== 0) { |
|
|
if (localBranches.length !== 0) { |
|
|
const args = ['--delete']; |
|
|
const args = ['--delete']; |
|
|
if (force) { |
|
|
|
|
|
|
|
|
if (options?.force) { |
|
|
args.push('--force'); |
|
|
args.push('--force'); |
|
|
} |
|
|
} |
|
|
this.runTerminalCommand('branch', ...args, ...branches.map(b => b.ref)); |
|
|
this.runTerminalCommand('branch', ...args, ...branches.map(b => b.ref)); |
|
|
|
|
|
|
|
|
if (remote) { |
|
|
|
|
|
|
|
|
if (options?.remote) { |
|
|
const trackingBranches = localBranches.filter(b => b.upstream != null); |
|
|
const trackingBranches = localBranches.filter(b => b.upstream != null); |
|
|
if (trackingBranches.length !== 0) { |
|
|
if (trackingBranches.length !== 0) { |
|
|
const branchesByOrigin = groupByMap(trackingBranches, b => GitBranch.getRemote(b.upstream!.name)); |
|
|
const branchesByOrigin = groupByMap(trackingBranches, b => GitBranch.getRemote(b.upstream!.name)); |
|
@ -467,16 +464,14 @@ export class Repository implements Disposable { |
|
|
|
|
|
|
|
|
@gate() |
|
|
@gate() |
|
|
@log() |
|
|
@log() |
|
|
async fetch( |
|
|
|
|
|
options: { |
|
|
|
|
|
all?: boolean; |
|
|
|
|
|
branch?: GitBranchReference; |
|
|
|
|
|
progress?: boolean; |
|
|
|
|
|
prune?: boolean; |
|
|
|
|
|
pull?: boolean; |
|
|
|
|
|
remote?: string; |
|
|
|
|
|
} = {}, |
|
|
|
|
|
) { |
|
|
|
|
|
|
|
|
async fetch(options?: { |
|
|
|
|
|
all?: boolean; |
|
|
|
|
|
branch?: GitBranchReference; |
|
|
|
|
|
progress?: boolean; |
|
|
|
|
|
prune?: boolean; |
|
|
|
|
|
pull?: boolean; |
|
|
|
|
|
remote?: string; |
|
|
|
|
|
}) { |
|
|
const { progress, ...opts } = { progress: true, ...options }; |
|
|
const { progress, ...opts } = { progress: true, ...options }; |
|
|
if (!progress) return this.fetchCore(opts); |
|
|
if (!progress) return this.fetchCore(opts); |
|
|
|
|
|
|
|
@ -492,9 +487,13 @@ export class Repository implements Disposable { |
|
|
)); |
|
|
)); |
|
|
} |
|
|
} |
|
|
|
|
|
|
|
|
private async fetchCore( |
|
|
|
|
|
options: { all?: boolean; branch?: GitBranchReference; prune?: boolean; pull?: boolean; remote?: string } = {}, |
|
|
|
|
|
) { |
|
|
|
|
|
|
|
|
private async fetchCore(options?: { |
|
|
|
|
|
all?: boolean; |
|
|
|
|
|
branch?: GitBranchReference; |
|
|
|
|
|
prune?: boolean; |
|
|
|
|
|
pull?: boolean; |
|
|
|
|
|
remote?: string; |
|
|
|
|
|
}) { |
|
|
try { |
|
|
try { |
|
|
void (await this.container.git.fetch(this.path, options)); |
|
|
void (await this.container.git.fetch(this.path, options)); |
|
|
|
|
|
|
|
@ -519,13 +518,11 @@ export class Repository implements Disposable { |
|
|
return this._branch; |
|
|
return this._branch; |
|
|
} |
|
|
} |
|
|
|
|
|
|
|
|
getBranches( |
|
|
|
|
|
options: { |
|
|
|
|
|
filter?: (b: GitBranch) => boolean; |
|
|
|
|
|
paging?: { cursor?: string; limit?: number }; |
|
|
|
|
|
sort?: boolean | BranchSortOptions; |
|
|
|
|
|
} = {}, |
|
|
|
|
|
) { |
|
|
|
|
|
|
|
|
getBranches(options?: { |
|
|
|
|
|
filter?: (b: GitBranch) => boolean; |
|
|
|
|
|
paging?: { cursor?: string; limit?: number }; |
|
|
|
|
|
sort?: boolean | BranchSortOptions; |
|
|
|
|
|
}) { |
|
|
return this.container.git.getBranches(this.path, options); |
|
|
return this.container.git.getBranches(this.path, options); |
|
|
} |
|
|
} |
|
|
|
|
|
|
|
@ -573,7 +570,7 @@ export class Repository implements Disposable { |
|
|
return (await this.getRemotes()).find(r => r.name === remote); |
|
|
return (await this.getRemotes()).find(r => r.name === remote); |
|
|
} |
|
|
} |
|
|
|
|
|
|
|
|
async getRemotes(options: { filter?: (remote: GitRemote) => boolean; sort?: boolean } = {}): Promise<GitRemote[]> { |
|
|
|
|
|
|
|
|
async getRemotes(options?: { filter?: (remote: GitRemote) => boolean; sort?: boolean }): Promise<GitRemote[]> { |
|
|
if (this._remotes == null) { |
|
|
if (this._remotes == null) { |
|
|
if (this._providers == null) { |
|
|
if (this._providers == null) { |
|
|
const remotesCfg = configuration.get('remotes', this.folder?.uri); |
|
|
const remotesCfg = configuration.get('remotes', this.folder?.uri); |
|
@ -585,7 +582,7 @@ export class Repository implements Disposable { |
|
|
void this.subscribeToRemotes(this._remotes); |
|
|
void this.subscribeToRemotes(this._remotes); |
|
|
} |
|
|
} |
|
|
|
|
|
|
|
|
return options.filter != null ? (await this._remotes).filter(options.filter) : this._remotes; |
|
|
|
|
|
|
|
|
return options?.filter != null ? (await this._remotes).filter(options.filter) : this._remotes; |
|
|
} |
|
|
} |
|
|
|
|
|
|
|
|
async getRichRemote(connectedOnly: boolean = false): Promise<GitRemote<RichRemoteProvider> | undefined> { |
|
|
async getRichRemote(connectedOnly: boolean = false): Promise<GitRemote<RichRemoteProvider> | undefined> { |
|
@ -660,7 +657,7 @@ export class Repository implements Disposable { |
|
|
|
|
|
|
|
|
@gate() |
|
|
@gate() |
|
|
@log() |
|
|
@log() |
|
|
async pull(options: { progress?: boolean; rebase?: boolean } = {}) { |
|
|
|
|
|
|
|
|
async pull(options?: { progress?: boolean; rebase?: boolean }) { |
|
|
const { progress, ...opts } = { progress: true, ...options }; |
|
|
const { progress, ...opts } = { progress: true, ...options }; |
|
|
if (!progress) return this.pullCore(); |
|
|
if (!progress) return this.pullCore(); |
|
|
|
|
|
|
|
@ -673,12 +670,12 @@ export class Repository implements Disposable { |
|
|
)); |
|
|
)); |
|
|
} |
|
|
} |
|
|
|
|
|
|
|
|
private async pullCore(options: { rebase?: boolean } = {}) { |
|
|
|
|
|
|
|
|
private async pullCore(options?: { rebase?: boolean }) { |
|
|
try { |
|
|
try { |
|
|
const upstream = await this.hasUpstreamBranch(); |
|
|
const upstream = await this.hasUpstreamBranch(); |
|
|
if (upstream) { |
|
|
if (upstream) { |
|
|
void (await executeCoreGitCommand( |
|
|
void (await executeCoreGitCommand( |
|
|
options.rebase ? CoreGitCommands.PullRebase : CoreGitCommands.Pull, |
|
|
|
|
|
|
|
|
options?.rebase ? CoreGitCommands.PullRebase : CoreGitCommands.Pull, |
|
|
this.path, |
|
|
this.path, |
|
|
)); |
|
|
)); |
|
|
} else if (configuration.getAny<boolean>(CoreGitConfiguration.FetchOnPull, Uri.file(this.path))) { |
|
|
} else if (configuration.getAny<boolean>(CoreGitConfiguration.FetchOnPull, Uri.file(this.path))) { |
|
@ -694,16 +691,14 @@ export class Repository implements Disposable { |
|
|
|
|
|
|
|
|
@gate() |
|
|
@gate() |
|
|
@log() |
|
|
@log() |
|
|
async push( |
|
|
|
|
|
options: { |
|
|
|
|
|
force?: boolean; |
|
|
|
|
|
progress?: boolean; |
|
|
|
|
|
reference?: GitReference; |
|
|
|
|
|
publish?: { |
|
|
|
|
|
remote: string; |
|
|
|
|
|
}; |
|
|
|
|
|
} = {}, |
|
|
|
|
|
) { |
|
|
|
|
|
|
|
|
async push(options?: { |
|
|
|
|
|
force?: boolean; |
|
|
|
|
|
progress?: boolean; |
|
|
|
|
|
reference?: GitReference; |
|
|
|
|
|
publish?: { |
|
|
|
|
|
remote: string; |
|
|
|
|
|
}; |
|
|
|
|
|
}) { |
|
|
const { progress, ...opts } = { progress: true, ...options }; |
|
|
const { progress, ...opts } = { progress: true, ...options }; |
|
|
if (!progress) return this.pushCore(opts); |
|
|
if (!progress) return this.pushCore(opts); |
|
|
|
|
|
|
|
@ -749,38 +744,36 @@ export class Repository implements Disposable { |
|
|
}); |
|
|
}); |
|
|
} |
|
|
} |
|
|
|
|
|
|
|
|
private async pushCore( |
|
|
|
|
|
options: { |
|
|
|
|
|
force?: boolean; |
|
|
|
|
|
reference?: GitReference; |
|
|
|
|
|
publish?: { |
|
|
|
|
|
remote: string; |
|
|
|
|
|
}; |
|
|
|
|
|
} = {}, |
|
|
|
|
|
) { |
|
|
|
|
|
|
|
|
private async pushCore(options?: { |
|
|
|
|
|
force?: boolean; |
|
|
|
|
|
reference?: GitReference; |
|
|
|
|
|
publish?: { |
|
|
|
|
|
remote: string; |
|
|
|
|
|
}; |
|
|
|
|
|
}) { |
|
|
try { |
|
|
try { |
|
|
if (GitReference.isBranch(options.reference)) { |
|
|
|
|
|
|
|
|
if (GitReference.isBranch(options?.reference)) { |
|
|
const repo = await this.container.git.getOrOpenScmRepository(this.path); |
|
|
const repo = await this.container.git.getOrOpenScmRepository(this.path); |
|
|
if (repo == null) return; |
|
|
if (repo == null) return; |
|
|
|
|
|
|
|
|
if (options.publish != null) { |
|
|
|
|
|
|
|
|
if (options?.publish != null) { |
|
|
await repo?.push(options.publish.remote, options.reference.name, true); |
|
|
await repo?.push(options.publish.remote, options.reference.name, true); |
|
|
void this.showCreatePullRequestPrompt(options.publish.remote, options.reference); |
|
|
void this.showCreatePullRequestPrompt(options.publish.remote, options.reference); |
|
|
} else { |
|
|
} else { |
|
|
const branch = await this.getBranch(options.reference.name); |
|
|
|
|
|
|
|
|
const branch = await this.getBranch(options?.reference.name); |
|
|
if (branch == null) return; |
|
|
if (branch == null) return; |
|
|
|
|
|
|
|
|
const currentBranch = await this.getBranch(); |
|
|
const currentBranch = await this.getBranch(); |
|
|
if (branch.id === currentBranch?.id) { |
|
|
if (branch.id === currentBranch?.id) { |
|
|
void (await executeCoreGitCommand( |
|
|
void (await executeCoreGitCommand( |
|
|
options.force ? CoreGitCommands.PushForce : CoreGitCommands.Push, |
|
|
|
|
|
|
|
|
options?.force ? CoreGitCommands.PushForce : CoreGitCommands.Push, |
|
|
this.path, |
|
|
this.path, |
|
|
)); |
|
|
)); |
|
|
} else { |
|
|
} else { |
|
|
await repo?.push(branch.getRemoteName(), branch.name); |
|
|
await repo?.push(branch.getRemoteName(), branch.name); |
|
|
} |
|
|
} |
|
|
} |
|
|
} |
|
|
} else if (options.reference != null) { |
|
|
|
|
|
|
|
|
} else if (options?.reference != null) { |
|
|
const repo = await this.container.git.getOrOpenScmRepository(this.path); |
|
|
const repo = await this.container.git.getOrOpenScmRepository(this.path); |
|
|
if (repo == null) return; |
|
|
if (repo == null) return; |
|
|
|
|
|
|
|
@ -790,7 +783,7 @@ export class Repository implements Disposable { |
|
|
await repo?.push(branch.getRemoteName(), `${options.reference.ref}:${branch.getNameWithoutRemote()}`); |
|
|
await repo?.push(branch.getRemoteName(), `${options.reference.ref}:${branch.getNameWithoutRemote()}`); |
|
|
} else { |
|
|
} else { |
|
|
void (await executeCoreGitCommand( |
|
|
void (await executeCoreGitCommand( |
|
|
options.force ? CoreGitCommands.PushForce : CoreGitCommands.Push, |
|
|
|
|
|
|
|
|
options?.force ? CoreGitCommands.PushForce : CoreGitCommands.Push, |
|
|
this.path, |
|
|
this.path, |
|
|
)); |
|
|
)); |
|
|
} |
|
|
} |
|
@ -848,10 +841,7 @@ export class Repository implements Disposable { |
|
|
this.runTerminalCommand('revert', ...args); |
|
|
this.runTerminalCommand('revert', ...args); |
|
|
} |
|
|
} |
|
|
|
|
|
|
|
|
searchForCommits( |
|
|
|
|
|
search: SearchPattern, |
|
|
|
|
|
options: { limit?: number; skip?: number } = {}, |
|
|
|
|
|
): Promise<GitLog | undefined> { |
|
|
|
|
|
|
|
|
searchForCommits(search: SearchPattern, options?: { limit?: number; skip?: number }): Promise<GitLog | undefined> { |
|
|
return this.container.git.getLogForSearch(this.path, search, options); |
|
|
return this.container.git.getLogForSearch(this.path, search, options); |
|
|
} |
|
|
} |
|
|
|
|
|
|
|
@ -866,7 +856,7 @@ export class Repository implements Disposable { |
|
|
|
|
|
|
|
|
@gate() |
|
|
@gate() |
|
|
@log() |
|
|
@log() |
|
|
async stashApply(stashName: string, options: { deleteAfter?: boolean } = {}) { |
|
|
|
|
|
|
|
|
async stashApply(stashName: string, options?: { deleteAfter?: boolean }) { |
|
|
void (await this.container.git.stashApply(this.path, stashName, options)); |
|
|
void (await this.container.git.stashApply(this.path, stashName, options)); |
|
|
|
|
|
|
|
|
this.fireChange(RepositoryChange.Stash); |
|
|
this.fireChange(RepositoryChange.Stash); |
|
@ -882,7 +872,7 @@ export class Repository implements Disposable { |
|
|
|
|
|
|
|
|
@gate() |
|
|
@gate() |
|
|
@log() |
|
|
@log() |
|
|
async stashSave(message?: string, uris?: Uri[], options: { includeUntracked?: boolean; keepIndex?: boolean } = {}) { |
|
|
|
|
|
|
|
|
async stashSave(message?: string, uris?: Uri[], options?: { includeUntracked?: boolean; keepIndex?: boolean }) { |
|
|
void (await this.container.git.stashSave(this.path, message, uris, options)); |
|
|
void (await this.container.git.stashSave(this.path, message, uris, options)); |
|
|
|
|
|
|
|
|
this.fireChange(RepositoryChange.Stash); |
|
|
this.fireChange(RepositoryChange.Stash); |
|
@ -890,7 +880,7 @@ export class Repository implements Disposable { |
|
|
|
|
|
|
|
|
@gate() |
|
|
@gate() |
|
|
@log() |
|
|
@log() |
|
|
async switch(ref: string, options: { createBranch?: string | undefined; progress?: boolean } = {}) { |
|
|
|
|
|
|
|
|
async switch(ref: string, options?: { createBranch?: string | undefined; progress?: boolean }) { |
|
|
const { progress, ...opts } = { progress: true, ...options }; |
|
|
const { progress, ...opts } = { progress: true, ...options }; |
|
|
if (!progress) return this.switchCore(ref, opts); |
|
|
if (!progress) return this.switchCore(ref, opts); |
|
|
|
|
|
|
|
@ -904,7 +894,7 @@ export class Repository implements Disposable { |
|
|
)); |
|
|
)); |
|
|
} |
|
|
} |
|
|
|
|
|
|
|
|
private async switchCore(ref: string, options: { createBranch?: string } = {}) { |
|
|
|
|
|
|
|
|
private async switchCore(ref: string, options?: { createBranch?: string }) { |
|
|
try { |
|
|
try { |
|
|
void (await this.container.git.checkout(this.path, ref, options)); |
|
|
void (await this.container.git.checkout(this.path, ref, options)); |
|
|
|
|
|
|
|
|