Merge pull request #1315 from nspcc-dev/debugger-compatibility-fixes
Debugger compatibility fixes, part 2
This commit is contained in:
commit
bf090a436b
4 changed files with 18 additions and 10 deletions
|
@ -195,7 +195,9 @@ func CompileAndSave(src string, o *Options) ([]byte, error) {
|
||||||
}
|
}
|
||||||
di.Events[i] = EventDebugInfo{
|
di.Events[i] = EventDebugInfo{
|
||||||
ID: e.Name,
|
ID: e.Name,
|
||||||
Name: e.Name,
|
// DebugInfo event name should be at the format {namespace},{name}
|
||||||
|
// but we don't provide namespace via .yml config
|
||||||
|
Name: "," + e.Name,
|
||||||
Parameters: params,
|
Parameters: params,
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -32,7 +32,7 @@ func TestCompiler(t *testing.T) {
|
||||||
require.NoError(t, err)
|
require.NoError(t, err)
|
||||||
m := map[string]bool{}
|
m := map[string]bool{}
|
||||||
for i := range di.Methods {
|
for i := range di.Methods {
|
||||||
m[di.Methods[i].Name.Name] = true
|
m[di.Methods[i].ID] = true
|
||||||
}
|
}
|
||||||
require.Contains(t, m, "Func1")
|
require.Contains(t, m, "Func1")
|
||||||
require.Contains(t, m, "Func2")
|
require.Contains(t, m, "Func2")
|
||||||
|
|
|
@ -8,6 +8,8 @@ import (
|
||||||
"go/types"
|
"go/types"
|
||||||
"strconv"
|
"strconv"
|
||||||
"strings"
|
"strings"
|
||||||
|
"unicode"
|
||||||
|
"unicode/utf8"
|
||||||
|
|
||||||
"github.com/nspcc-dev/neo-go/pkg/crypto/hash"
|
"github.com/nspcc-dev/neo-go/pkg/crypto/hash"
|
||||||
"github.com/nspcc-dev/neo-go/pkg/smartcontract"
|
"github.com/nspcc-dev/neo-go/pkg/smartcontract"
|
||||||
|
@ -26,8 +28,11 @@ type DebugInfo struct {
|
||||||
|
|
||||||
// MethodDebugInfo represents smart-contract's method debug information.
|
// MethodDebugInfo represents smart-contract's method debug information.
|
||||||
type MethodDebugInfo struct {
|
type MethodDebugInfo struct {
|
||||||
|
// ID is the actual name of the method.
|
||||||
ID string `json:"id"`
|
ID string `json:"id"`
|
||||||
// Name is the name of the method together with the namespace it belongs to.
|
// Name is the name of the method with the first letter in a lowercase
|
||||||
|
// together with the namespace it belongs to. We need to keep the first letter
|
||||||
|
// lowercased to match manifest standards.
|
||||||
Name DebugMethodName `json:"name"`
|
Name DebugMethodName `json:"name"`
|
||||||
// IsExported defines whether method is exported.
|
// IsExported defines whether method is exported.
|
||||||
IsExported bool `json:"-"`
|
IsExported bool `json:"-"`
|
||||||
|
@ -51,7 +56,7 @@ type DebugMethodName struct {
|
||||||
// EventDebugInfo represents smart-contract's event debug information.
|
// EventDebugInfo represents smart-contract's event debug information.
|
||||||
type EventDebugInfo struct {
|
type EventDebugInfo struct {
|
||||||
ID string `json:"id"`
|
ID string `json:"id"`
|
||||||
// Name is a human-readable event name in a format "{namespace}-{name}".
|
// Name is a human-readable event name in a format "{namespace},{name}".
|
||||||
Name string `json:"name"`
|
Name string `json:"name"`
|
||||||
Parameters []DebugParam `json:"params"`
|
Parameters []DebugParam `json:"params"`
|
||||||
}
|
}
|
||||||
|
@ -158,10 +163,11 @@ func (c *codegen) methodInfoFromScope(name string, scope *funcScope) *MethodDebu
|
||||||
}
|
}
|
||||||
ss := strings.Split(name, ".")
|
ss := strings.Split(name, ".")
|
||||||
name = ss[len(ss)-1]
|
name = ss[len(ss)-1]
|
||||||
|
r, n := utf8.DecodeRuneInString(name)
|
||||||
return &MethodDebugInfo{
|
return &MethodDebugInfo{
|
||||||
ID: name,
|
ID: name,
|
||||||
Name: DebugMethodName{
|
Name: DebugMethodName{
|
||||||
Name: name,
|
Name: string(unicode.ToLower(r)) + name[n:],
|
||||||
Namespace: scope.pkg.Name(),
|
Namespace: scope.pkg.Name(),
|
||||||
},
|
},
|
||||||
IsExported: scope.decl.Name.IsExported(),
|
IsExported: scope.decl.Name.IsExported(),
|
||||||
|
@ -292,7 +298,7 @@ func (m *MethodDebugInfo) ToManifestMethod() (manifest.Method, error) {
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return result, err
|
return result, err
|
||||||
}
|
}
|
||||||
result.Name = strings.ToLower(string(m.Name.Name[0])) + m.Name.Name[1:]
|
result.Name = m.Name.Name
|
||||||
result.Offset = int(m.Range.Start)
|
result.Offset = int(m.Range.Start)
|
||||||
result.Parameters = parameters
|
result.Parameters = parameters
|
||||||
result.ReturnType = returnType
|
result.ReturnType = returnType
|
||||||
|
|
|
@ -69,7 +69,7 @@ func unexportedMethod() int { return 1 }
|
||||||
"unexportedMethod": "Integer",
|
"unexportedMethod": "Integer",
|
||||||
}
|
}
|
||||||
for i := range d.Methods {
|
for i := range d.Methods {
|
||||||
name := d.Methods[i].Name.Name
|
name := d.Methods[i].ID
|
||||||
assert.Equal(t, returnTypes[name], d.Methods[i].ReturnType)
|
assert.Equal(t, returnTypes[name], d.Methods[i].ReturnType)
|
||||||
}
|
}
|
||||||
})
|
})
|
||||||
|
@ -79,7 +79,7 @@ func unexportedMethod() int { return 1 }
|
||||||
"Main": {"s,String", "res,Integer"},
|
"Main": {"s,String", "res,Integer"},
|
||||||
}
|
}
|
||||||
for i := range d.Methods {
|
for i := range d.Methods {
|
||||||
v, ok := vars[d.Methods[i].Name.Name]
|
v, ok := vars[d.Methods[i].ID]
|
||||||
if ok {
|
if ok {
|
||||||
require.Equal(t, v, d.Methods[i].Variables)
|
require.Equal(t, v, d.Methods[i].Variables)
|
||||||
}
|
}
|
||||||
|
@ -112,7 +112,7 @@ func unexportedMethod() int { return 1 }
|
||||||
}},
|
}},
|
||||||
}
|
}
|
||||||
for i := range d.Methods {
|
for i := range d.Methods {
|
||||||
v, ok := paramTypes[d.Methods[i].Name.Name]
|
v, ok := paramTypes[d.Methods[i].ID]
|
||||||
if ok {
|
if ok {
|
||||||
require.Equal(t, v, d.Methods[i].Parameters)
|
require.Equal(t, v, d.Methods[i].Parameters)
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in a new issue