From a54a179f9abb65c0069cf7eb08b6fdaed26b388e Mon Sep 17 00:00:00 2001 From: Eric Amodio Date: Tue, 20 Oct 2020 00:59:39 -0400 Subject: [PATCH] =?UTF-8?q?Fixes=20issue=20with=20repo=20event=20while=20s?= =?UTF-8?q?uspended=20=F0=9F=A4=9E?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- src/git/gitService.ts | 9 +++----- src/git/models/repository.ts | 49 ++++++++++++++++++++++++++++++++------------ src/vsls/guest.ts | 3 ++- 3 files changed, 41 insertions(+), 20 deletions(-) diff --git a/src/git/gitService.ts b/src/git/gitService.ts index 50d7866..925efff 100644 --- a/src/git/gitService.ts +++ b/src/git/gitService.ts @@ -126,7 +126,6 @@ export class GitService implements Disposable { private readonly _disposable: Disposable; private readonly _repositoryTree: TernarySearchTree; private _repositoriesLoadingPromise: Promise | undefined; - private _suspended: boolean = false; private readonly _branchesCache = new Map(); private readonly _remotesWithApiProviderCache = new Map | null>(); @@ -222,8 +221,6 @@ export class GitService implements Disposable { @debug() private onWindowStateChanged(e: WindowState) { - this._suspended = !e.focused; - if (e.focused) { this._repositoryTree.forEach(r => r.resume()); } else { @@ -333,7 +330,7 @@ export class GitService implements Disposable { const rootPath = await this.getRepoPathCore(uri.fsPath, true); if (rootPath != null) { Logger.log(cc, `found root repository in '${rootPath}'`); - repositories.push(new Repository(folder, rootPath, true, anyRepoChangedFn, this._suspended)); + repositories.push(new Repository(folder, rootPath, true, anyRepoChangedFn, !window.state.focused)); } if (depth <= 0) return repositories; @@ -382,7 +379,7 @@ export class GitService implements Disposable { if (rp == null) continue; Logger.log(cc, `found repository in '${rp}'`); - repositories.push(new Repository(folder, rp, false, anyRepoChangedFn, this._suspended)); + repositories.push(new Repository(folder, rp, false, anyRepoChangedFn, !window.state.focused)); } return repositories; @@ -2966,7 +2963,7 @@ export class GitService implements Disposable { } Logger.log(cc, `Repository found in '${rp}'`); - repo = new Repository(folder, rp, false, this.onAnyRepositoryChanged.bind(this), this._suspended); + repo = new Repository(folder, rp, false, this.onAnyRepositoryChanged.bind(this), !window.state.focused); this._repositoryTree.set(rp, repo); // Send a notification that the repositories changed diff --git a/src/git/models/repository.ts b/src/git/models/repository.ts index ffd0895..8fb242c 100644 --- a/src/git/models/repository.ts +++ b/src/git/models/repository.ts @@ -23,7 +23,7 @@ import { Logger } from '../../logger'; import { Messages } from '../../messages'; import { GitBranchReference, GitReference, GitTagReference } from './models'; import { RemoteProviderFactory, RemoteProviders, RemoteProviderWithApi } from '../remotes/factory'; -import { Arrays, Functions, gate, Iterables, log, logName } from '../../system'; +import { Arrays, debug, Functions, gate, Iterables, log, logName } from '../../system'; import { runGitCommandInTerminal } from '../../terminal'; const ignoreGitRegex = /\.git(?:\/|\\|$)/; @@ -91,8 +91,8 @@ export class Repository implements Disposable { private _branch: Promise | undefined; private readonly _disposable: Disposable; - private _fireChangeDebounced: ((e: RepositoryChangeEvent) => void) | undefined = undefined; - private _fireFileSystemChangeDebounced: ((e: RepositoryFileSystemChangeEvent) => void) | undefined = undefined; + private _fireChangeDebounced: (() => void) | undefined = undefined; + private _fireFileSystemChangeDebounced: (() => void) | undefined = undefined; private _fsWatchCounter = 0; private _fsWatcherDisposable: Disposable | undefined; private _pendingFileSystemChange?: RepositoryFileSystemChangeEvent; @@ -192,6 +192,7 @@ export class Repository implements Disposable { this.fireFileSystemChange(uri); } + @debug() private onRepositoryChanged(uri: Uri | undefined) { if (uri == null) { this.fireChange(RepositoryChange.Unknown); @@ -619,11 +620,11 @@ export class Repository implements Disposable { // If we've come back into focus and we are dirty, fire the change events if (this._pendingRepoChange != null) { - this._fireChangeDebounced!(this._pendingRepoChange); + this._fireChangeDebounced!(); } if (this._pendingFileSystemChange != null) { - this._fireFileSystemChangeDebounced!(this._pendingFileSystemChange); + this._fireFileSystemChangeDebounced!(); } } @@ -764,9 +765,8 @@ export class Repository implements Disposable { this.runTerminalCommand('tag', ...args, ...tags.map(t => t.ref)); } + @debug() private fireChange(...changes: RepositoryChange[]) { - this.onAnyRepositoryChanged(this, new RepositoryChangeEvent(this, changes)); - if (this._fireChangeDebounced == null) { this._fireChangeDebounced = Functions.debounce(this.fireChangeCore.bind(this), 250); } @@ -783,17 +783,28 @@ export class Repository implements Disposable { } } - if (this._suspended) return; + this.onAnyRepositoryChanged(this, new RepositoryChangeEvent(this, changes)); + + if (this._suspended) { + Logger.debug(`Repository[${this.name}(${this.id})] queueing suspended changes=${e.changes.join(', ')}`); + + return; + } - this._fireChangeDebounced(e); + this._fireChangeDebounced(); } - private fireChangeCore(e: RepositoryChangeEvent) { + private fireChangeCore() { + const e = this._pendingRepoChange; + if (e == null) return; + this._pendingRepoChange = undefined; + Logger.debug(`Repository[${this.name}(${this.id})] firing changes=${e.changes.join(', ')}`); this._onDidChange.fire(e); } + @debug() private fireFileSystemChange(uri: Uri) { if (this._fireFileSystemChangeDebounced == null) { this._fireFileSystemChangeDebounced = Functions.debounce(this.fireFileSystemChangeCore.bind(this), 2500); @@ -806,12 +817,22 @@ export class Repository implements Disposable { const e = this._pendingFileSystemChange; e.uris.push(uri); - if (this._suspended) return; + if (this._suspended) { + Logger.debug( + `Repository[${this.name}(${this.id})] queueing suspended fs changes=${e.uris + .map(u => u.fsPath) + .join(', ')}`, + ); + return; + } - this._fireFileSystemChangeDebounced(e); + this._fireFileSystemChangeDebounced(); } - private async fireFileSystemChangeCore(e: RepositoryFileSystemChangeEvent) { + private async fireFileSystemChangeCore() { + let e = this._pendingFileSystemChange; + if (e == null) return; + this._pendingFileSystemChange = undefined; const uris = await Container.git.excludeIgnoredUris(this.path, e.uris); @@ -821,6 +842,8 @@ export class Repository implements Disposable { e = { ...e, uris: uris }; } + Logger.debug(`Repository[${this.name}(${this.id})] firing fs changes=${e.uris.map(u => u.fsPath).join(', ')}`); + this._onDidChangeFileSystem.fire(e); } diff --git a/src/vsls/guest.ts b/src/vsls/guest.ts index 1e7364a..f8b5494 100644 --- a/src/vsls/guest.ts +++ b/src/vsls/guest.ts @@ -68,7 +68,8 @@ export class VslsGuestService implements Disposable { }); return response.repositories.map( - (r: RepositoryProxy) => new Repository(folder, r.path, r.root, onAnyRepositoryChanged, false, r.closed), + (r: RepositoryProxy) => + new Repository(folder, r.path, r.root, onAnyRepositoryChanged, !window.state.focused, r.closed), ); }