Skip to content

Commit

Permalink
Add DEBUG_FS flag with extra ignored paths (fixes #341)
Browse files Browse the repository at this point in the history
  • Loading branch information
SchoofsKelvin committed Jun 2, 2022
1 parent 1fb7a52 commit 76a28be
Show file tree
Hide file tree
Showing 3 changed files with 31 additions and 5 deletions.
3 changes: 3 additions & 0 deletions CHANGELOG.md
Original file line number Diff line number Diff line change
Expand Up @@ -8,6 +8,9 @@
- Currently, this makes it that changing the global flags can immediately have an effect for some flags
- Global flags are those defined in your User Settings or Workspace(Folder) Settings
- Mind that if you override those flags by specifying them in your SSH FS config, it'll keep using them
- Added the `DEBUG_FS` flag to allow enabling detailed conditional logging in `sshFileSystem` (#341)
- This flag will auto-update when it changes in global flags, unless it's overriden in your SSH FS config
- Mostly meant for internal debugging or helping with debugging specific user-reported issues

## v1.25.0 (2022-06-01)

Expand Down
8 changes: 8 additions & 0 deletions src/config.ts
Original file line number Diff line number Diff line change
Expand Up @@ -386,6 +386,14 @@ function parseFlagList(list: string[] | undefined, origin: string): Record<strin
- Enables attempting to inject a file to be sourced by the remote shells (which adds the `code` alias)
DEBUG_REMOTE_COMMANDS (boolean) (default=false)
- Enables debug logging for the remote command terminal (thus useless if REMOTE_COMMANDS isn't true)
DEBUG_FS (string) (default='')
- A comma-separated list of debug flags for logging errors in the sshFileSystem
- The presence of `ignoredmissing` will log `FileNotFound` that got ignored
- The presence of `minimal` will log all errors as single lines, but not `FileNotFound`
- The presence of `full` is the same as `minimal` but with full stacktraces
- The presence of `missing` will log `FileNotFound` errors in `minimal` and `full` (except `ignoredmissing` ones)
- The presence of `converted` will log the resulting converted errors (if required and successful)
- The presence of `all` enables all of the above (similar to `ignoredmissing,full,missing,converted,reads`)
FS_NOTIFY_ERRORS (boolean) (default=false)
- Enables displaying error notifications when a file system operation fails and isn't automatically ignored
- Automatically enabled VS Code 1.56 and later (see issue #282)
Expand Down
25 changes: 20 additions & 5 deletions src/sshFileSystem.ts
Original file line number Diff line number Diff line change
Expand Up @@ -3,7 +3,7 @@ import type { FileSystemConfig } from 'common/fileSystemConfig';
import * as path from 'path';
import type * as ssh2 from 'ssh2';
import * as vscode from 'vscode';
import { getFlagBoolean } from './config';
import { getFlag, getFlagBoolean, subscribeToGlobalFlags } from './config';
import { Logger, Logging, LOGGING_NO_STACKTRACE, LOGGING_SINGLE_LINE_STACKTRACE, withStacktraceOffset } from './logging';
import { toPromise } from './utils';

Expand All @@ -21,6 +21,8 @@ const IGNORE_NOT_FOUND: string[] = [
'/node_modules',
'/pom.xml',
'/app/src/main/AndroidManifest.xml',
'/build.gradle',
'/.devcontainer/devcontainer.json',
];
function shouldIgnoreNotFound(target: string) {
if (IGNORE_NOT_FOUND.some(entry => entry === target || entry.endsWith('/') && target.startsWith(entry))) return true;
Expand All @@ -36,6 +38,7 @@ function shouldIgnoreNotFound(target: string) {
export class SSHFileSystem implements vscode.FileSystemProvider {
protected onCloseEmitter = new vscode.EventEmitter<void>();
protected onDidChangeFileEmitter = new vscode.EventEmitter<vscode.FileChangeEvent[]>();
protected debugFlags: string[];
public closed = false;
public closing = false;
public copy = undefined;
Expand All @@ -46,6 +49,11 @@ export class SSHFileSystem implements vscode.FileSystemProvider {
this.logging = Logging.scope(`SSHFileSystem(${authority})`, false);
this.sftp.on('end', () => (this.closed = true, this.onCloseEmitter.fire()));
this.logging.info('SSHFileSystem created');
const subscription = subscribeToGlobalFlags(() => {
this.debugFlags = `${getFlag('DEBUG_FS', this.config.flags)?.[0] || ''}`.toLowerCase().split(/,\s*|\s+/g);
if (this.debugFlags.includes('all')) this.debugFlags.push('ignoredmissing', 'full', 'missing', 'converted');
});
this.onClose(() => subscription.dispose());
}
public disconnect() {
this.closing = true;
Expand Down Expand Up @@ -162,11 +170,17 @@ export class SSHFileSystem implements vscode.FileSystemProvider {
e = vscode.FileSystemError.FileNotFound(uri);
// Whenever a workspace opens, VSCode (and extensions) (indirectly) stat a bunch of files
// (.vscode/tasks.json etc, .git/, node_modules for NodeJS, pom.xml for Maven, ...)
const flags = `${ignore[0] ? 'F' : ''}${ignore[1] ? 'A' : ''}`;
this.logging.debug(`Ignored (${flags}) FileNotFound error for: ${uri}`, LOGGING_NO_STACKTRACE);
if (this.debugFlags.includes('ignoredmissing')) {
const flags = `${ignore[0] ? 'F' : ''}${ignore[1] ? 'A' : ''}`;
this.logging.debug(`Ignored (${flags}) FileNotFound error for: ${uri}`, LOGGING_NO_STACKTRACE);
}
if (doThrow === true) throw e; else if (doThrow) return doThrow(e); else return;
}
Logging.error.withOptions(LOGGING_HANDLE_ERROR)`Error handling uri: ${uri}\n${e}`;
else if (this.debugFlags.includes('full')) {
this.logging.debug.withOptions(LOGGING_HANDLE_ERROR)`Error in ${uri}: ${e}`;
} else if (this.debugFlags.includes('minimal')) {
this.logging.debug.withOptions({ ...LOGGING_NO_STACKTRACE, maxErrorStack: 0 })`Error in ${uri}: ${e.name}: ${e.message}`;
}
// Convert SSH2Stream error codes into VS Code errors
if (doThrow && typeof e.code === 'number') {
const oldE = e;
Expand All @@ -179,7 +193,8 @@ export class SSHFileSystem implements vscode.FileSystemProvider {
} else if (e.code === 7) { // Connection lost
e = vscode.FileSystemError.Unavailable(uri);
}
if (e !== oldE) Logging.debug(`Error converted to: ${e}`);
if (e !== oldE && this.debugFlags.includes('converted'))
Logging.debug(`Error converted to: ${e}`);
}
// Display an error notification if the FS_ERROR_NOTIFICATION flag is enabled
const [flagCH] = getFlagBoolean('FS_NOTIFY_ERRORS', true, this.config.flags);
Expand Down

0 comments on commit 76a28be

Please sign in to comment.