@ -137,6 +137,7 @@ export class GitService implements Disposable {
private readonly _disposable : Disposable ;
private readonly _disposable : Disposable ;
private readonly _repositoryTree : TernarySearchTree < string , Repository > ;
private readonly _repositoryTree : TernarySearchTree < string , Repository > ;
private _repositoriesLoadingPromise : Promise < void > | undefined ;
private _repositoriesLoadingPromise : Promise < void > | undefined ;
private _repositoriesLoadingPromiseResolver : ( ( ) = > void ) | undefined ;
private readonly _branchesCache = new Map < string , Promise < GitBranch [ ] > > ( ) ;
private readonly _branchesCache = new Map < string , Promise < GitBranch [ ] > > ( ) ;
private readonly _contributorsCache = new Map < string , Promise < GitContributor [ ] > > ( ) ;
private readonly _contributorsCache = new Map < string , Promise < GitContributor [ ] > > ( ) ;
@ -148,10 +149,11 @@ export class GitService implements Disposable {
private readonly _trackedCache = new Map < string , boolean | Promise < boolean > > ( ) ;
private readonly _trackedCache = new Map < string , boolean | Promise < boolean > > ( ) ;
private readonly _userMapCache = new Map < string , GitUser | null > ( ) ;
private readonly _userMapCache = new Map < string , GitUser | null > ( ) ;
constructor ( ) {
constructor ( private readonly container : Container ) {
this . _repositoryTree = TernarySearchTree . forPaths ( ) ;
this . _repositoryTree = TernarySearchTree . forPaths ( ) ;
this . _disposable = Disposable . from (
this . _disposable = Disposable . from (
container . onReady ( this . onReady , this ) ,
window . onDidChangeWindowState ( this . onWindowStateChanged , this ) ,
window . onDidChangeWindowState ( this . onWindowStateChanged , this ) ,
workspace . onDidChangeWorkspaceFolders ( this . onWorkspaceFoldersChanged , this ) ,
workspace . onDidChangeWorkspaceFolders ( this . onWorkspaceFoldersChanged , this ) ,
configuration . onDidChange ( this . onConfigurationChanged , this ) ,
configuration . onDidChange ( this . onConfigurationChanged , this ) ,
@ -163,9 +165,10 @@ export class GitService implements Disposable {
void this . updateContext ( this . _repositoryTree ) ;
void this . updateContext ( this . _repositoryTree ) ;
} ) ,
} ) ,
) ;
) ;
this . onConfigurationChanged ( ) ;
this . _repositoriesLoadingPromise = this . onWorkspaceFoldersChanged ( ) ;
this . _repositoriesLoadingPromise = new Promise ( resolve = > ( this . _repositoriesLoadingPromiseResolver = resolve ) ) ;
this . onConfigurationChanged ( ) ;
}
}
dispose() {
dispose() {
@ -174,24 +177,16 @@ export class GitService implements Disposable {
this . _disposable . dispose ( ) ;
this . _disposable . dispose ( ) ;
}
}
@log ( )
static async initialize ( ) : Promise < void > {
// Try to use the same git as the built-in vscode git extension
let gitPath ;
const gitApi = await GitService . getBuiltInGitApi ( ) ;
if ( gitApi != null ) {
gitPath = gitApi . git . path ;
}
await Git . setOrFindGitPath ( gitPath ? ? configuration . getAny < string | string [ ] > ( 'git.path' ) ) ;
private onReady() {
this . onWorkspaceFoldersChanged ( ) . finally ( ( ) = > this . _repositoriesLoadingPromiseResolver ! ( ) ) ;
}
}
get readonly ( ) {
get readonly ( ) {
return C ontainer. vsls . readonly ;
return this . container . vsls . readonly ;
}
}
get useCaching() {
get useCaching() {
return C ontainer. config . advanced . caching . enabled ;
return this . container . config . advanced . caching . enabled ;
}
}
private onAnyRepositoryChanged ( repo : Repository , e : RepositoryChangeEvent ) {
private onAnyRepositoryChanged ( repo : Repository , e : RepositoryChangeEvent ) {
@ -287,8 +282,8 @@ export class GitService implements Disposable {
if ( scheme !== DocumentSchemes . File && scheme !== DocumentSchemes . Vsls ) continue ;
if ( scheme !== DocumentSchemes . File && scheme !== DocumentSchemes . Vsls ) continue ;
if ( scheme === DocumentSchemes . Vsls ) {
if ( scheme === DocumentSchemes . Vsls ) {
if ( C ontainer. vsls . isMaybeGuest ) {
const guest = await C ontainer. vsls . guest ( ) ;
if ( this . c ontainer. vsls . isMaybeGuest ) {
const guest = await this . c ontainer. vsls . guest ( ) ;
if ( guest != null ) {
if ( guest != null ) {
const repositories = await guest . getRepositoriesInFolder (
const repositories = await guest . getRepositoriesInFolder (
f ,
f ,
@ -859,7 +854,7 @@ export class GitService implements Disposable {
let repoPath ;
let repoPath ;
if ( editor != null ) {
if ( editor != null ) {
const doc = await C ontainer. tracker . getOrAdd ( editor . document . uri ) ;
const doc = await this . c ontainer. tracker . getOrAdd ( editor . document . uri ) ;
if ( doc != null ) {
if ( doc != null ) {
repoPath = doc . uri . repoPath ;
repoPath = doc . uri . repoPath ;
}
}
@ -888,7 +883,7 @@ export class GitService implements Disposable {
key += ` : ${ uri . sha } ` ;
key += ` : ${ uri . sha } ` ;
}
}
const doc = await C ontainer. tracker . getOrAdd ( uri ) ;
const doc = await this . c ontainer. tracker . getOrAdd ( uri ) ;
if ( this . useCaching ) {
if ( this . useCaching ) {
if ( doc . state != null ) {
if ( doc . state != null ) {
const cachedBlame = doc . state . get < CachedBlame > ( key ) ;
const cachedBlame = doc . state . get < CachedBlame > ( key ) ;
@ -934,8 +929,8 @@ export class GitService implements Disposable {
try {
try {
const data = await Git . blame ( root , file , uri . sha , {
const data = await Git . blame ( root , file , uri . sha , {
args : C ontainer.config.advanced.blame.customArguments,
ignoreWhitespace : C ontainer.config.blame.ignoreWhitespace,
args : this.c ontainer.config.advanced.blame.customArguments,
ignoreWhitespace : this.c ontainer.config.blame.ignoreWhitespace,
} ) ;
} ) ;
const blame = GitBlameParser . parse ( data , root , file , await this . getCurrentUser ( root ) ) ;
const blame = GitBlameParser . parse ( data , root , file , await this . getCurrentUser ( root ) ) ;
return blame ;
return blame ;
@ -970,7 +965,7 @@ export class GitService implements Disposable {
const key = ` blame: ${ Strings . sha1 ( contents ) } ` ;
const key = ` blame: ${ Strings . sha1 ( contents ) } ` ;
const doc = await C ontainer. tracker . getOrAdd ( uri ) ;
const doc = await this . c ontainer. tracker . getOrAdd ( uri ) ;
if ( this . useCaching ) {
if ( this . useCaching ) {
if ( doc . state != null ) {
if ( doc . state != null ) {
const cachedBlame = doc . state . get < CachedBlame > ( key ) ;
const cachedBlame = doc . state . get < CachedBlame > ( key ) ;
@ -1017,9 +1012,9 @@ export class GitService implements Disposable {
try {
try {
const data = await Git . blame__contents ( root , file , contents , {
const data = await Git . blame__contents ( root , file , contents , {
args : C ontainer.config.advanced.blame.customArguments,
args : this.c ontainer.config.advanced.blame.customArguments,
correlationKey : ` : ${ key } ` ,
correlationKey : ` : ${ key } ` ,
ignoreWhitespace : C ontainer.config.blame.ignoreWhitespace,
ignoreWhitespace : this.c ontainer.config.blame.ignoreWhitespace,
} ) ;
} ) ;
const blame = GitBlameParser . parse ( data , root , file , await this . getCurrentUser ( root ) ) ;
const blame = GitBlameParser . parse ( data , root , file , await this . getCurrentUser ( root ) ) ;
return blame ;
return blame ;
@ -1075,8 +1070,8 @@ export class GitService implements Disposable {
try {
try {
const data = await Git . blame ( uri . repoPath , fileName , uri . sha , {
const data = await Git . blame ( uri . repoPath , fileName , uri . sha , {
args : C ontainer.config.advanced.blame.customArguments,
ignoreWhitespace : C ontainer.config.blame.ignoreWhitespace,
args : this.c ontainer.config.advanced.blame.customArguments,
ignoreWhitespace : this.c ontainer.config.blame.ignoreWhitespace,
startLine : lineToBlame ,
startLine : lineToBlame ,
endLine : lineToBlame ,
endLine : lineToBlame ,
} ) ;
} ) ;
@ -1130,8 +1125,8 @@ export class GitService implements Disposable {
try {
try {
const data = await Git . blame__contents ( uri . repoPath , fileName , contents , {
const data = await Git . blame__contents ( uri . repoPath , fileName , contents , {
args : C ontainer.config.advanced.blame.customArguments,
ignoreWhitespace : C ontainer.config.blame.ignoreWhitespace,
args : this.c ontainer.config.advanced.blame.customArguments,
ignoreWhitespace : this.c ontainer.config.blame.ignoreWhitespace,
startLine : lineToBlame ,
startLine : lineToBlame ,
endLine : lineToBlame ,
endLine : lineToBlame ,
} ) ;
} ) ;
@ -1227,14 +1222,14 @@ export class GitService implements Disposable {
let [ branch ] = await this . getBranches ( repoPath , { filter : b = > b . current } ) ;
let [ branch ] = await this . getBranches ( repoPath , { filter : b = > b . current } ) ;
if ( branch != null ) return branch ;
if ( branch != null ) return branch ;
const data = await Git . rev_parse__currentBranch ( repoPath , C ontainer. config . advanced . commitOrdering ) ;
const data = await Git . rev_parse__currentBranch ( repoPath , this . c ontainer. config . advanced . commitOrdering ) ;
if ( data == null ) return undefined ;
if ( data == null ) return undefined ;
const [ name , upstream ] = data [ 0 ] . split ( '\n' ) ;
const [ name , upstream ] = data [ 0 ] . split ( '\n' ) ;
if ( GitBranch . isDetached ( name ) ) {
if ( GitBranch . isDetached ( name ) ) {
const [ rebaseStatus , committerDate ] = await Promise . all ( [
const [ rebaseStatus , committerDate ] = await Promise . all ( [
this . getRebaseStatus ( repoPath ) ,
this . getRebaseStatus ( repoPath ) ,
Git . log__recent_committerdate ( repoPath , C ontainer. config . advanced . commitOrdering ) ,
Git . log__recent_committerdate ( repoPath , this . c ontainer. config . advanced . commitOrdering ) ,
] ) ;
] ) ;
branch = new GitBranch (
branch = new GitBranch (
@ -1316,13 +1311,13 @@ export class GitService implements Disposable {
const data = await Git . rev_parse__currentBranch (
const data = await Git . rev_parse__currentBranch (
repoPath ! ,
repoPath ! ,
C ontainer. config . advanced . commitOrdering ,
this . c ontainer. config . advanced . commitOrdering ,
) ;
) ;
if ( data != null ) {
if ( data != null ) {
const [ name , upstream ] = data [ 0 ] . split ( '\n' ) ;
const [ name , upstream ] = data [ 0 ] . split ( '\n' ) ;
const [ rebaseStatus , committerDate ] = await Promise . all ( [
const [ rebaseStatus , committerDate ] = await Promise . all ( [
GitBranch . isDetached ( name ) ? this . getRebaseStatus ( repoPath ! ) : undefined ,
GitBranch . isDetached ( name ) ? this . getRebaseStatus ( repoPath ! ) : undefined ,
Git . log__recent_committerdate ( repoPath ! , C ontainer. config . advanced . commitOrdering ) ,
Git . log__recent_committerdate ( repoPath ! , this . c ontainer. config . advanced . commitOrdering ) ,
] ) ;
] ) ;
current = new GitBranch (
current = new GitBranch (
@ -1537,7 +1532,7 @@ export class GitService implements Disposable {
async getOldestUnpushedRefForFile ( repoPath : string , fileName : string ) : Promise < string | undefined > {
async getOldestUnpushedRefForFile ( repoPath : string , fileName : string ) : Promise < string | undefined > {
const data = await Git . log__file ( repoPath , fileName , '@{push}..' , {
const data = await Git . log__file ( repoPath , fileName , '@{push}..' , {
format : 'refs' ,
format : 'refs' ,
ordering : C ontainer.config.advanced.commitOrdering,
ordering : this.c ontainer.config.advanced.commitOrdering,
renames : true ,
renames : true ,
} ) ;
} ) ;
if ( data == null || data . length === 0 ) return undefined ;
if ( data == null || data . length === 0 ) return undefined ;
@ -1690,7 +1685,7 @@ export class GitService implements Disposable {
key += ` : ${ ref2 } ` ;
key += ` : ${ ref2 } ` ;
}
}
const doc = await C ontainer. tracker . getOrAdd ( uri ) ;
const doc = await this . c ontainer. tracker . getOrAdd ( uri ) ;
if ( this . useCaching ) {
if ( this . useCaching ) {
if ( doc . state != null ) {
if ( doc . state != null ) {
const cachedDiff = doc . state . get < CachedDiff > ( key ) ;
const cachedDiff = doc . state . get < CachedDiff > ( key ) ;
@ -1748,7 +1743,7 @@ export class GitService implements Disposable {
// let data;
// let data;
// if (ref2 == null && ref1 != null && !GitRevision.isUncommittedStaged(ref1)) {
// if (ref2 == null && ref1 != null && !GitRevision.isUncommittedStaged(ref1)) {
// data = await Git.show__diff(root, file, ref1, originalFileName, {
// data = await Git.show__diff(root, file, ref1, originalFileName, {
// similarityThreshold: C ontainer.config.advanced.similarityThreshold,
// similarityThreshold: this.c ontainer.config.advanced.similarityThreshold,
// });
// });
// } else {
// } else {
const data = await Git . diff ( root , file , ref1 , ref2 , {
const data = await Git . diff ( root , file , ref1 , ref2 , {
@ -1756,7 +1751,7 @@ export class GitService implements Disposable {
filters : [ 'M' ] ,
filters : [ 'M' ] ,
linesOfContext : 0 ,
linesOfContext : 0 ,
renames : true ,
renames : true ,
similarityThreshold : C ontainer.config.advanced.similarityThreshold,
similarityThreshold : this.c ontainer.config.advanced.similarityThreshold,
} ) ;
} ) ;
// }
// }
@ -1796,7 +1791,7 @@ export class GitService implements Disposable {
const key = ` diff: ${ Strings . sha1 ( contents ) } ` ;
const key = ` diff: ${ Strings . sha1 ( contents ) } ` ;
const doc = await C ontainer. tracker . getOrAdd ( uri ) ;
const doc = await this . c ontainer. tracker . getOrAdd ( uri ) ;
if ( this . useCaching ) {
if ( this . useCaching ) {
if ( doc . state != null ) {
if ( doc . state != null ) {
const cachedDiff = doc . state . get < CachedDiff > ( key ) ;
const cachedDiff = doc . state . get < CachedDiff > ( key ) ;
@ -1854,7 +1849,7 @@ export class GitService implements Disposable {
const data = await Git . diff__contents ( root , file , ref , contents , {
const data = await Git . diff__contents ( root , file , ref , contents , {
. . . options ,
. . . options ,
filters : [ 'M' ] ,
filters : [ 'M' ] ,
similarityThreshold : C ontainer.config.advanced.similarityThreshold,
similarityThreshold : this.c ontainer.config.advanced.similarityThreshold,
} ) ;
} ) ;
const diff = GitDiffParser . parse ( data ) ;
const diff = GitDiffParser . parse ( data ) ;
@ -1909,7 +1904,7 @@ export class GitService implements Disposable {
) : Promise < GitFile [ ] | undefined > {
) : Promise < GitFile [ ] | undefined > {
try {
try {
const data = await Git . diff__name_status ( repoPath , ref1 , ref2 , {
const data = await Git . diff__name_status ( repoPath , ref1 , ref2 , {
similarityThreshold : C ontainer.config.advanced.similarityThreshold,
similarityThreshold : this.c ontainer.config.advanced.similarityThreshold,
. . . options ,
. . . options ,
} ) ;
} ) ;
const files = GitDiffParser . parseNameStatus ( data , repoPath ) ;
const files = GitDiffParser . parseNameStatus ( data , repoPath ) ;
@ -1949,15 +1944,15 @@ export class GitService implements Disposable {
since? : string ;
since? : string ;
} = { } ,
} = { } ,
) : Promise < GitLog | undefined > {
) : Promise < GitLog | undefined > {
const limit = options . limit ? ? C ontainer. config . advanced . maxListItems ? ? 0 ;
const limit = options . limit ? ? this . c ontainer. config . advanced . maxListItems ? ? 0 ;
try {
try {
const data = await Git . log ( repoPath , ref , {
const data = await Git . log ( repoPath , ref , {
. . . options ,
. . . options ,
limit : limit ,
limit : limit ,
merges : options.merges == null ? true : options . merges ,
merges : options.merges == null ? true : options . merges ,
ordering : options.ordering ? ? C ontainer. config . advanced . commitOrdering ,
similarityThreshold : C ontainer.config.advanced.similarityThreshold,
ordering : options.ordering ? ? this . c ontainer. config . advanced . commitOrdering ,
similarityThreshold : this.c ontainer.config.advanced.similarityThreshold,
} ) ;
} ) ;
const log = GitLogParser . parse (
const log = GitLogParser . parse (
data ,
data ,
@ -2001,7 +1996,7 @@ export class GitService implements Disposable {
since? : string ;
since? : string ;
} = { } ,
} = { } ,
) : Promise < Set < string > | undefined > {
) : Promise < Set < string > | undefined > {
const limit = options . limit ? ? C ontainer. config . advanced . maxListItems ? ? 0 ;
const limit = options . limit ? ? this . c ontainer. config . advanced . maxListItems ? ? 0 ;
try {
try {
const data = await Git . log ( repoPath , ref , {
const data = await Git . log ( repoPath , ref , {
@ -2010,9 +2005,9 @@ export class GitService implements Disposable {
limit : limit ,
limit : limit ,
merges : options.merges == null ? true : options . merges ,
merges : options.merges == null ? true : options . merges ,
reverse : options.reverse ,
reverse : options.reverse ,
similarityThreshold : C ontainer.config.advanced.similarityThreshold,
similarityThreshold : this.c ontainer.config.advanced.similarityThreshold,
since : options.since ,
since : options.since ,
ordering : options.ordering ? ? C ontainer. config . advanced . commitOrdering ,
ordering : options.ordering ? ? this . c ontainer. config . advanced . commitOrdering ,
} ) ;
} ) ;
const commits = GitLogParser . parseRefsOnly ( data ) ;
const commits = GitLogParser . parseRefsOnly ( data ) ;
return new Set ( commits ) ;
return new Set ( commits ) ;
@ -2040,7 +2035,7 @@ export class GitService implements Disposable {
return log ;
return log ;
}
}
moreLimit = moreLimit ? ? C ontainer. config . advanced . maxSearchItems ? ? 0 ;
moreLimit = moreLimit ? ? this . c ontainer. config . advanced . maxSearchItems ? ? 0 ;
// If the log is for a range, then just get everything prior + more
// If the log is for a range, then just get everything prior + more
if ( GitRevision . isRange ( log . sha ) ) {
if ( GitRevision . isRange ( log . sha ) ) {
@ -2102,8 +2097,8 @@ export class GitService implements Disposable {
search = { matchAll : false , matchCase : false , matchRegex : true , . . . search } ;
search = { matchAll : false , matchCase : false , matchRegex : true , . . . search } ;
try {
try {
const limit = options . limit ? ? C ontainer. config . advanced . maxSearchItems ? ? 0 ;
const similarityThreshold = C ontainer. config . advanced . similarityThreshold ;
const limit = options . limit ? ? this . c ontainer. config . advanced . maxSearchItems ? ? 0 ;
const similarityThreshold = this . c ontainer. config . advanced . similarityThreshold ;
const operations = SearchPattern . parseSearchOperations ( search . pattern ) ;
const operations = SearchPattern . parseSearchOperations ( search . pattern ) ;
@ -2175,7 +2170,7 @@ export class GitService implements Disposable {
}
}
const data = await Git . log__search ( repoPath , args , {
const data = await Git . log__search ( repoPath , args , {
ordering : C ontainer.config.advanced.commitOrdering,
ordering : this.c ontainer.config.advanced.commitOrdering,
. . . options ,
. . . options ,
limit : limit ,
limit : limit ,
useShow : useShow ,
useShow : useShow ,
@ -2212,7 +2207,7 @@ export class GitService implements Disposable {
options : { limit? : number ; ordering? : string | null } ,
options : { limit? : number ; ordering? : string | null } ,
) : ( limit : number | undefined ) = > Promise < GitLog > {
) : ( limit : number | undefined ) = > Promise < GitLog > {
return async ( limit : number | undefined ) = > {
return async ( limit : number | undefined ) = > {
limit = limit ? ? C ontainer. config . advanced . maxSearchItems ? ? 0 ;
limit = limit ? ? this . c ontainer. config . advanced . maxSearchItems ? ? 0 ;
const moreLog = await this . getLogForSearch ( log . repoPath , search , {
const moreLog = await this . getLogForSearch ( log . repoPath , search , {
. . . options ,
. . . options ,
@ -2279,7 +2274,7 @@ export class GitService implements Disposable {
options = { reverse : false , . . . options } ;
options = { reverse : false , . . . options } ;
if ( options . renames == null ) {
if ( options . renames == null ) {
options . renames = C ontainer. config . advanced . fileHistoryFollowsRenames ;
options . renames = this . c ontainer. config . advanced . fileHistoryFollowsRenames ;
}
}
let key = 'log' ;
let key = 'log' ;
@ -2288,13 +2283,13 @@ export class GitService implements Disposable {
}
}
if ( options . all == null ) {
if ( options . all == null ) {
options . all = C ontainer. config . advanced . fileHistoryShowAllBranches ;
options . all = this . c ontainer. config . advanced . fileHistoryShowAllBranches ;
}
}
if ( options . all ) {
if ( options . all ) {
key += ':all' ;
key += ':all' ;
}
}
options . limit = options . limit == null ? C ontainer. config . advanced . maxListItems || 0 : options.limit ;
options . limit = options . limit == null ? this . c ontainer. config . advanced . maxListItems || 0 : options.limit ;
if ( options . limit ) {
if ( options . limit ) {
key += ` :n ${ options . limit } ` ;
key += ` :n ${ options . limit } ` ;
}
}
@ -2315,7 +2310,7 @@ export class GitService implements Disposable {
key += ` :skip ${ options . skip } ` ;
key += ` :skip ${ options . skip } ` ;
}
}
const doc = await C ontainer. tracker . getOrAdd ( GitUri . fromFile ( fileName , repoPath ! , options . ref ) ) ;
const doc = await this . c ontainer. tracker . getOrAdd ( GitUri . fromFile ( fileName , repoPath ! , options . ref ) ) ;
if ( this . useCaching && options . range == null ) {
if ( this . useCaching && options . range == null ) {
if ( doc . state != null ) {
if ( doc . state != null ) {
const cachedLog = doc . state . get < CachedLog > ( key ) ;
const cachedLog = doc . state . get < CachedLog > ( key ) ;
@ -2437,7 +2432,7 @@ export class GitService implements Disposable {
}
}
const data = await Git . log__file ( root , file , ref , {
const data = await Git . log__file ( root , file , ref , {
ordering : C ontainer.config.advanced.commitOrdering,
ordering : this.c ontainer.config.advanced.commitOrdering,
. . . options ,
. . . options ,
firstParent : options.renames ,
firstParent : options.renames ,
startLine : range == null ? undefined : range . start . line + 1 ,
startLine : range == null ? undefined : range . start . line + 1 ,
@ -2506,7 +2501,7 @@ export class GitService implements Disposable {
return log ;
return log ;
}
}
moreLimit = moreLimit ? ? C ontainer. config . advanced . maxSearchItems ? ? 0 ;
moreLimit = moreLimit ? ? this . c ontainer. config . advanced . maxSearchItems ? ? 0 ;
const ref = Iterables . last ( log . commits . values ( ) ) ? . ref ;
const ref = Iterables . last ( log . commits . values ( ) ) ? . ref ;
const moreLog = await this . getLogForFile ( log . repoPath , fileName , {
const moreLog = await this . getLogForFile ( log . repoPath , fileName , {
@ -2768,7 +2763,7 @@ export class GitService implements Disposable {
filters : filters ,
filters : filters ,
format : 'simple' ,
format : 'simple' ,
limit : skip + 1 ,
limit : skip + 1 ,
ordering : C ontainer.config.advanced.commitOrdering,
ordering : this.c ontainer.config.advanced.commitOrdering,
reverse : true ,
reverse : true ,
// startLine: editorLine != null ? editorLine + 1 : undefined,
// startLine: editorLine != null ? editorLine + 1 : undefined,
} ) ;
} ) ;
@ -2781,7 +2776,7 @@ export class GitService implements Disposable {
filters : [ 'R' , 'C' ] ,
filters : [ 'R' , 'C' ] ,
format : 'simple' ,
format : 'simple' ,
limit : 1 ,
limit : 1 ,
ordering : C ontainer.config.advanced.commitOrdering,
ordering : this.c ontainer.config.advanced.commitOrdering,
// startLine: editorLine != null ? editorLine + 1 : undefined
// startLine: editorLine != null ? editorLine + 1 : undefined
} ) ;
} ) ;
if ( data == null || data . length === 0 ) {
if ( data == null || data . length === 0 ) {
@ -3020,7 +3015,7 @@ export class GitService implements Disposable {
firstParent : firstParent ,
firstParent : firstParent ,
format : 'simple' ,
format : 'simple' ,
limit : skip + 2 ,
limit : skip + 2 ,
ordering : C ontainer.config.advanced.commitOrdering,
ordering : this.c ontainer.config.advanced.commitOrdering,
startLine : editorLine != null ? editorLine + 1 : undefined ,
startLine : editorLine != null ? editorLine + 1 : undefined ,
} ) ;
} ) ;
} catch ( ex ) {
} catch ( ex ) {
@ -3035,7 +3030,7 @@ export class GitService implements Disposable {
}
}
ref = await Git . log__file_recent ( repoPath , fileName , {
ref = await Git . log__file_recent ( repoPath , fileName , {
ordering : C ontainer.config.advanced.commitOrdering,
ordering : this.c ontainer.config.advanced.commitOrdering,
} ) ;
} ) ;
return GitUri . fromFile ( fileName , repoPath , ref ? ? GitRevision . deletedOrMissing ) ;
return GitUri . fromFile ( fileName , repoPath , ref ? ? GitRevision . deletedOrMissing ) ;
}
}
@ -3175,11 +3170,11 @@ export class GitService implements Disposable {
) : Promise < GitReflog | undefined > {
) : Promise < GitReflog | undefined > {
const cc = Logger . getCorrelationContext ( ) ;
const cc = Logger . getCorrelationContext ( ) ;
limit = limit ? ? C ontainer. config . advanced . maxListItems ? ? 0 ;
limit = limit ? ? this . c ontainer. config . advanced . maxListItems ? ? 0 ;
try {
try {
// Pass a much larger limit to reflog, because we aggregate the data and we won't know how many lines we'll need
// Pass a much larger limit to reflog, because we aggregate the data and we won't know how many lines we'll need
const data = await Git . reflog ( repoPath , {
const data = await Git . reflog ( repoPath , {
ordering : C ontainer.config.advanced.commitOrdering,
ordering : this.c ontainer.config.advanced.commitOrdering,
. . . options ,
. . . options ,
limit : limit * 100 ,
limit : limit * 100 ,
} ) ;
} ) ;
@ -3202,7 +3197,7 @@ export class GitService implements Disposable {
options : { all? : boolean ; branch? : string ; limit? : number ; ordering? : string | null ; skip? : number } ,
options : { all? : boolean ; branch? : string ; limit? : number ; ordering? : string | null ; skip? : number } ,
) : ( limit : number ) = > Promise < GitReflog > {
) : ( limit : number ) = > Promise < GitReflog > {
return async ( limit : number | undefined ) = > {
return async ( limit : number | undefined ) = > {
limit = limit ? ? C ontainer. config . advanced . maxSearchItems ? ? 0 ;
limit = limit ? ? this . c ontainer. config . advanced . maxSearchItems ? ? 0 ;
const moreLog = await this . getIncomingActivity ( reflog . repoPath , {
const moreLog = await this . getIncomingActivity ( reflog . repoPath , {
. . . options ,
. . . options ,
@ -3512,7 +3507,7 @@ export class GitService implements Disposable {
@gate ( ( ) = > '' )
@gate ( ( ) = > '' )
private async ensureProperWorkspaceCasing ( repoPath : string , filePath : string ) {
private async ensureProperWorkspaceCasing ( repoPath : string , filePath : string ) {
if ( C ontainer. config . advanced . messages . suppressImproperWorkspaceCasingWarning ) return ;
if ( this . c ontainer. config . advanced . messages . suppressImproperWorkspaceCasingWarning ) return ;
filePath = filePath . replace ( /\\/g , '/' ) ;
filePath = filePath . replace ( /\\/g , '/' ) ;
@ -3633,7 +3628,7 @@ export class GitService implements Disposable {
) : Repository | undefined {
) : Repository | undefined {
let repo = repositoryTree . findSubstr ( path ) ;
let repo = repositoryTree . findSubstr ( path ) ;
// If we can't find the repo and we are a guest, check if we are a "root" workspace
// If we can't find the repo and we are a guest, check if we are a "root" workspace
if ( repo == null && isVslsScheme !== false && C ontainer. vsls . isMaybeGuest ) {
if ( repo == null && isVslsScheme !== false && this . c ontainer. vsls . isMaybeGuest ) {
if ( ! vslsUriPrefixRegex . test ( path ) ) {
if ( ! vslsUriPrefixRegex . test ( path ) ) {
path = Strings . normalizePath ( path ) ;
path = Strings . normalizePath ( path ) ;
const vslsPath = ` /~0 ${ path . startsWith ( slash ) ? path : ` / ${ path } ` } ` ;
const vslsPath = ` /~0 ${ path . startsWith ( slash ) ? path : ` / ${ path } ` } ` ;
@ -3670,7 +3665,7 @@ export class GitService implements Disposable {
let stash = this . useCaching ? this . _stashesCache . get ( repoPath ) : undefined ;
let stash = this . useCaching ? this . _stashesCache . get ( repoPath ) : undefined ;
if ( stash === undefined ) {
if ( stash === undefined ) {
const data = await Git . stash__list ( repoPath , {
const data = await Git . stash__list ( repoPath , {
similarityThreshold : C ontainer.config.advanced.similarityThreshold,
similarityThreshold : this.c ontainer.config.advanced.similarityThreshold,
} ) ;
} ) ;
stash = GitStashParser . parse ( data , repoPath ) ;
stash = GitStashParser . parse ( data , repoPath ) ;
@ -3691,7 +3686,7 @@ export class GitService implements Disposable {
const porcelainVersion = Git . validateVersion ( 2 , 11 ) ? 2 : 1 ;
const porcelainVersion = Git . validateVersion ( 2 , 11 ) ? 2 : 1 ;
const data = await Git . status__file ( repoPath , fileName , porcelainVersion , {
const data = await Git . status__file ( repoPath , fileName , porcelainVersion , {
similarityThreshold : C ontainer.config.advanced.similarityThreshold,
similarityThreshold : this.c ontainer.config.advanced.similarityThreshold,
} ) ;
} ) ;
const status = GitStatusParser . parse ( data , repoPath , porcelainVersion ) ;
const status = GitStatusParser . parse ( data , repoPath , porcelainVersion ) ;
if ( status == null || ! status . files . length ) return undefined ;
if ( status == null || ! status . files . length ) return undefined ;
@ -3704,7 +3699,7 @@ export class GitService implements Disposable {
const porcelainVersion = Git . validateVersion ( 2 , 11 ) ? 2 : 1 ;
const porcelainVersion = Git . validateVersion ( 2 , 11 ) ? 2 : 1 ;
const data = await Git . status__file ( repoPath , path , porcelainVersion , {
const data = await Git . status__file ( repoPath , path , porcelainVersion , {
similarityThreshold : C ontainer.config.advanced.similarityThreshold,
similarityThreshold : this.c ontainer.config.advanced.similarityThreshold,
} ) ;
} ) ;
const status = GitStatusParser . parse ( data , repoPath , porcelainVersion ) ;
const status = GitStatusParser . parse ( data , repoPath , porcelainVersion ) ;
if ( status == null || ! status . files . length ) return [ ] ;
if ( status == null || ! status . files . length ) return [ ] ;
@ -3719,7 +3714,7 @@ export class GitService implements Disposable {
const porcelainVersion = Git . validateVersion ( 2 , 11 ) ? 2 : 1 ;
const porcelainVersion = Git . validateVersion ( 2 , 11 ) ? 2 : 1 ;
const data = await Git . status ( repoPath , porcelainVersion , {
const data = await Git . status ( repoPath , porcelainVersion , {
similarityThreshold : C ontainer.config.advanced.similarityThreshold,
similarityThreshold : this.c ontainer.config.advanced.similarityThreshold,
} ) ;
} ) ;
const status = GitStatusParser . parse ( data , repoPath , porcelainVersion ) ;
const status = GitStatusParser . parse ( data , repoPath , porcelainVersion ) ;
@ -3857,8 +3852,8 @@ export class GitService implements Disposable {
// TODO: Add caching
// TODO: Add caching
// Get the most recent commit for this file name
// Get the most recent commit for this file name
ref = await Git . log__file_recent ( repoPath , fileName , {
ref = await Git . log__file_recent ( repoPath , fileName , {
ordering : C ontainer.config.advanced.commitOrdering,
similarityThreshold : C ontainer.config.advanced.similarityThreshold,
ordering : this.c ontainer.config.advanced.commitOrdering,
similarityThreshold : this.c ontainer.config.advanced.similarityThreshold,
} ) ;
} ) ;
if ( ref == null ) return undefined ;
if ( ref == null ) return undefined ;
@ -3867,7 +3862,7 @@ export class GitService implements Disposable {
filters : [ 'R' , 'C' , 'D' ] ,
filters : [ 'R' , 'C' , 'D' ] ,
format : 'simple' ,
format : 'simple' ,
limit : 1 ,
limit : 1 ,
ordering : C ontainer.config.advanced.commitOrdering,
ordering : this.c ontainer.config.advanced.commitOrdering,
} ) ;
} ) ;
if ( data == null || data . length === 0 ) break ;
if ( data == null || data . length === 0 ) break ;
@ -3937,7 +3932,7 @@ export class GitService implements Disposable {
editor = editor ? ? window . activeTextEditor ;
editor = editor ? ? window . activeTextEditor ;
if ( editor == null ) return false ;
if ( editor == null ) return false ;
const doc = await C ontainer. tracker . getOrAdd ( editor . document . uri ) ;
const doc = await this . c ontainer. tracker . getOrAdd ( editor . document . uri ) ;
return repoPath === doc ? . uri . repoPath ;
return repoPath === doc ? . uri . repoPath ;
}
}
@ -4053,7 +4048,7 @@ export class GitService implements Disposable {
if ( ! options . tool ) {
if ( ! options . tool ) {
const cc = Logger . getCorrelationContext ( ) ;
const cc = Logger . getCorrelationContext ( ) ;
options . tool = C ontainer. config . advanced . externalDiffTool || ( await this . getDiffTool ( repoPath ) ) ;
options . tool = this . c ontainer. config . advanced . externalDiffTool || ( await this . getDiffTool ( repoPath ) ) ;
if ( options . tool == null ) throw new Error ( 'No diff tool found' ) ;
if ( options . tool == null ) throw new Error ( 'No diff tool found' ) ;
Logger . log ( cc , ` Using tool= ${ options . tool } ` ) ;
Logger . log ( cc , ` Using tool= ${ options . tool } ` ) ;
@ -4089,7 +4084,7 @@ export class GitService implements Disposable {
if ( ! tool ) {
if ( ! tool ) {
const cc = Logger . getCorrelationContext ( ) ;
const cc = Logger . getCorrelationContext ( ) ;
tool = C ontainer. config . advanced . externalDirectoryDiffTool || ( await this . getDiffTool ( repoPath ) ) ;
tool = this . c ontainer. config . advanced . externalDirectoryDiffTool || ( await this . getDiffTool ( repoPath ) ) ;
if ( tool == null ) throw new Error ( 'No diff tool found' ) ;
if ( tool == null ) throw new Error ( 'No diff tool found' ) ;
Logger . log ( cc , ` Using tool= ${ tool } ` ) ;
Logger . log ( cc , ` Using tool= ${ tool } ` ) ;
@ -4154,7 +4149,7 @@ export class GitService implements Disposable {
repoPath ,
repoPath ,
blob ,
blob ,
ref ,
ref ,
C ontainer. config . advanced . commitOrdering ,
this . c ontainer. config . advanced . commitOrdering ,
fileName ,
fileName ,
) ;
) ;
if ( options ? . timeout != null ) {
if ( options ? . timeout != null ) {
@ -4165,7 +4160,7 @@ export class GitService implements Disposable {
}
}
@log ( )
@log ( )
validateBranchOrTagName ( ref : string , repoPath? : string ) : Promise < boolean > {
validateBranchOrTagName ( repoPath : string , ref : string ) : Promise < boolean > {
return Git . check_ref_format ( ref , repoPath ) ;
return Git . check_ref_format ( ref , repoPath ) ;
}
}