diff --git a/extensions/git/src/git.ts b/extensions/git/src/git.ts index 327903aa959..b000245a0f2 100644 --- a/extensions/git/src/git.ts +++ b/extensions/git/src/git.ts @@ -2779,8 +2779,8 @@ export class Repository { return Promise.reject(new Error(`No such branch: ${name}.`)); } - async getDefaultBranch(): Promise { - const result = await this.exec(['symbolic-ref', '--short', 'refs/remotes/origin/HEAD']); + async getDefaultBranch(remoteName: string): Promise { + const result = await this.exec(['symbolic-ref', '--short', `refs/remotes/${remoteName}/HEAD`]); if (!result.stdout || result.stderr) { throw new Error('No default branch'); } diff --git a/extensions/git/src/repository.ts b/extensions/git/src/repository.ts index 2a722502b75..00419ef85fc 100644 --- a/extensions/git/src/repository.ts +++ b/extensions/git/src/repository.ts @@ -1593,7 +1593,12 @@ export class Repository implements Disposable { private async getDefaultBranch(): Promise { try { - const defaultBranch = await this.repository.getDefaultBranch(); + if (this.remotes.length === 0) { + return undefined; + } + + const remote = this.remotes.find(r => r.name === 'origin') ?? this.remotes[0]; + const defaultBranch = await this.repository.getDefaultBranch(remote.name); return defaultBranch; } catch (err) {