From 5a6c2fa66d074f011abe59725941ea23f4257236 Mon Sep 17 00:00:00 2001 From: Ladislau Szomoru <3372902+lszomoru@users.noreply.github.com> Date: Tue, 21 Jan 2025 20:31:44 +0100 Subject: [PATCH] Git - FS stat should also throw if the file does not exist (#238395) --- extensions/git/src/fileSystemProvider.ts | 13 ++++++------- 1 file changed, 6 insertions(+), 7 deletions(-) diff --git a/extensions/git/src/fileSystemProvider.ts b/extensions/git/src/fileSystemProvider.ts index 896d933cddf..6e30118128d 100644 --- a/extensions/git/src/fileSystemProvider.ts +++ b/extensions/git/src/fileSystemProvider.ts @@ -140,14 +140,14 @@ export class GitFileSystemProvider implements FileSystemProvider { throw FileSystemError.FileNotFound(); } - let size = 0; try { const details = await repository.getObjectDetails(sanitizeRef(ref, path, repository), path); - size = details.size; + return { type: FileType.File, size: details.size, mtime: this.mtime, ctime: 0 }; } catch { - // noop + // File does not exist in git. This could be because the file is untracked or ignored + this.logger.warn(`[GitFileSystemProvider][stat] File not found - ${uri.toString()}`); + throw FileSystemError.FileNotFound(); } - return { type: FileType.File, size: size, mtime: this.mtime, ctime: 0 }; } readDirectory(): Thenable<[string, FileType][]> { @@ -193,10 +193,9 @@ export class GitFileSystemProvider implements FileSystemProvider { try { return await repository.buffer(sanitizeRef(ref, path, repository), path); - } catch (err) { + } catch { + // File does not exist in git. This could be because the file is untracked or ignored this.logger.warn(`[GitFileSystemProvider][readFile] File not found - ${uri.toString()}`); - // File does not exist in git. This could be - // because the file is untracked or ignored throw FileSystemError.FileNotFound(); } }