From 34bafccb84d77f21232dced1778c9a739815d317 Mon Sep 17 00:00:00 2001 From: Joel Hendrix Date: Mon, 11 Feb 2019 09:00:52 -0800 Subject: [PATCH] Fix loading of child types Per Delve documentation type names should be enclosed in quotes; this fixes parsing of type names with e.g. '-' characters in them. --- src/debugAdapter/goDebug.ts | 14 ++------------ 1 file changed, 2 insertions(+), 12 deletions(-) diff --git a/src/debugAdapter/goDebug.ts b/src/debugAdapter/goDebug.ts index c1c13eeb4..09b28ed1a 100644 --- a/src/debugAdapter/goDebug.ts +++ b/src/debugAdapter/goDebug.ts @@ -1115,7 +1115,7 @@ class GoDebugSession extends LoggingDebugSession { // expressions passed to loadChildren defined per https://github.com/derekparker/delve/blob/master/Documentation/api/ClientHowto.md#loading-more-of-a-variable if (vari.kind === GoReflectKind.Array || vari.kind === GoReflectKind.Slice) { variablesPromise = Promise.all(vari.children.map((v, i) => { - return loadChildren(`*(*${this.removeRepoFromTypeName(v.type)})(${v.addr})`, v).then((): DebugProtocol.Variable => { + return loadChildren(`*(*"${v.type}")(${v.addr})`, v).then((): DebugProtocol.Variable => { let { result, variablesReference } = this.convertDebugVariableToProtocolVariable(v); return { name: '[' + i + ']', @@ -1147,7 +1147,7 @@ class GoDebugSession extends LoggingDebugSession { if (v.fullyQualifiedName === undefined) { v.fullyQualifiedName = vari.fullyQualifiedName + '.' + v.name; } - return loadChildren(`*(*${this.removeRepoFromTypeName(v.type)})(${v.addr})`, v).then((): DebugProtocol.Variable => { + return loadChildren(`*(*"${v.type}")(${v.addr})`, v).then((): DebugProtocol.Variable => { let { result, variablesReference } = this.convertDebugVariableToProtocolVariable(v); return { name: v.name, @@ -1165,16 +1165,6 @@ class GoDebugSession extends LoggingDebugSession { }); } - // removes all parts of the repo path from a type name. - // e.g. github.com/some/repo/package.TypeName becomes package.TypeName - private removeRepoFromTypeName(typeName: string): string { - const i = typeName.lastIndexOf('/'); - if (i === -1) { - return typeName; - } - return typeName.substr(i + 1); - } - private cleanupHandles(): void { this._variableHandles.reset(); this.stackFrameHandles.reset();