From 330f08ca9833221619433286d0cc89cfb43c512a Mon Sep 17 00:00:00 2001 From: Hyang-Ah Hana Kim Date: Wed, 11 Mar 2020 12:32:52 -0400 Subject: [PATCH 1/4] telemetry.ts: send telemetry only if aiKey is not an empty string(#3091) --- src/telemetry.ts | 3 +++ 1 file changed, 3 insertions(+) diff --git a/src/telemetry.ts b/src/telemetry.ts index 5f789aad3..b06ae390f 100644 --- a/src/telemetry.ts +++ b/src/telemetry.ts @@ -183,6 +183,9 @@ function sendTelemetryEvent( properties?: { [key: string]: string }, measures?: { [key: string]: number } ): void { + if (!aiKey) { + return; // cannot enable telemetry + } telemtryReporter = telemtryReporter ? telemtryReporter : new TelemetryReporter(extensionId, extensionVersion, aiKey); From 5dc0357d681f05a7d7c78869a751728e7e86579a Mon Sep 17 00:00:00 2001 From: Alan Fregtman <941331+darkvertex@users.noreply.github.com> Date: Sat, 14 Mar 2020 17:16:23 -0400 Subject: [PATCH 2/4] bug_report.md: Fix "architecture" typo. (#3095) --- .github/ISSUE_TEMPLATE/bug_report.md | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/.github/ISSUE_TEMPLATE/bug_report.md b/.github/ISSUE_TEMPLATE/bug_report.md index 466cf56ea..2e9768d5c 100644 --- a/.github/ISSUE_TEMPLATE/bug_report.md +++ b/.github/ISSUE_TEMPLATE/bug_report.md @@ -27,7 +27,7 @@ Please answer these questions before submitting your issue. Thanks! - - Check your installed extensions to get the version of the VS Code Go extension - -- Run `go env GOOS GOARCH` to get the operating system and processor arhcitecture details +- Run `go env GOOS GOARCH` to get the operating system and processor architecture details - ### Share the Go related settings you have added/edited From 6d1bf5c7999d5af0adcc15141ca012c34a9ca71c Mon Sep 17 00:00:00 2001 From: Hyang-Ah Hana Kim Date: Sun, 15 Mar 2020 23:35:24 -0400 Subject: [PATCH 3/4] Include the link to release note/package overview in the update prompt, and update gopls default version (#3041) --- src/goInstallTools.ts | 9 ++++++++- 1 file changed, 8 insertions(+), 1 deletion(-) diff --git a/src/goInstallTools.ts b/src/goInstallTools.ts index bbe06d3b8..9c9071438 100644 --- a/src/goInstallTools.ts +++ b/src/goInstallTools.ts @@ -361,11 +361,18 @@ export async function promptForUpdatingTool(toolName: string) { } const goVersion = await getGoVersion(); const updateMsg = `Your version of ${tool.name} appears to be out of date. Please update for an improved experience.`; - vscode.window.showInformationMessage(updateMsg, 'Update').then((selected) => { + const choices: string[] = ['Update']; + if (toolName === `gopls`) { + choices.push('Release Notes'); // TODO(hyangah): pass more info such as version, release note location. + } + vscode.window.showInformationMessage(updateMsg, ...choices).then((selected) => { switch (selected) { case 'Update': installTools([tool], goVersion); break; + case 'Release Notes': + vscode.commands.executeCommand('vscode.open', vscode.Uri.parse('https://github.com/golang/go/issues/33030#issuecomment-510151934')); + break; default: declinedUpdates.push(tool); break; From 7da50774f84578b5ec6c46b27c0a3446d485f4a6 Mon Sep 17 00:00:00 2001 From: Quoc Truong Date: Thu, 19 Mar 2020 12:55:24 -0700 Subject: [PATCH 4/4] Address mismatch on path separators in debug config (#2010) (#3108) --- src/debugAdapter/goDebug.ts | 26 ++++++++++++++------------ 1 file changed, 14 insertions(+), 12 deletions(-) diff --git a/src/debugAdapter/goDebug.ts b/src/debugAdapter/goDebug.ts index c83a2a037..35447a552 100644 --- a/src/debugAdapter/goDebug.ts +++ b/src/debugAdapter/goDebug.ts @@ -305,9 +305,16 @@ function logError(...args: any[]) { logger.error(logArgsToString(args)); } +function findPathSeparator(filePath: string) { + return filePath.includes('/') ? '/' : '\\'; +} + function normalizePath(filePath: string) { if (process.platform === 'win32') { + const pathSeparator = findPathSeparator(filePath); filePath = path.normalize(filePath); + // Normalize will replace everything with backslash on Windows. + filePath = filePath.replace(/\\/g, pathSeparator); return fixDriveCasingInWindows(filePath); } return filePath; @@ -754,13 +761,6 @@ class GoDebugSession extends LoggingDebugSession { log('InitializeResponse'); } - protected findPathSeperator(filePath: string) { - if (/^(\w:[\\/]|\\\\)/.test(filePath)) { - return '\\'; - } - return filePath.includes('/') ? '/' : '\\'; - } - protected launchRequest(response: DebugProtocol.LaunchResponse, args: LaunchRequestArguments): void { if (!args.program) { this.sendErrorResponse( @@ -835,10 +835,12 @@ class GoDebugSession extends LoggingDebugSession { if (this.delve.remotePath.length === 0) { return this.convertClientPathToDebugger(filePath); } + // The filePath may have a different path separator than the localPath + // So, update it to use the same separator as the remote path to ease + // in replacing the local path in it with remote path + filePath = filePath.replace(/\/|\\/g, this.remotePathSeparator); return filePath - .replace(this.delve.program, this.delve.remotePath) - .split(this.localPathSeparator) - .join(this.remotePathSeparator); + .replace(this.delve.program.replace(/\/|\\/g, this.remotePathSeparator), this.delve.remotePath); } protected toLocalPath(pathToConvert: string): string { @@ -1392,8 +1394,8 @@ class GoDebugSession extends LoggingDebugSession { } if (args.remotePath.length > 0) { - this.localPathSeparator = this.findPathSeperator(localPath); - this.remotePathSeparator = this.findPathSeperator(args.remotePath); + this.localPathSeparator = findPathSeparator(localPath); + this.remotePathSeparator = findPathSeparator(args.remotePath); const llist = localPath.split(/\/|\\/).reverse(); const rlist = args.remotePath.split(/\/|\\/).reverse();