From 712891dd774c59aefe6d0fc3c6503e729a5ea917 Mon Sep 17 00:00:00 2001 From: Marc Vertes Date: Mon, 3 Feb 2020 17:08:05 +0100 Subject: [PATCH] fix: allow reuse of _ symbol in the same scope --- _test/var10.go | 11 +++++++++++ _test/var11.go | 10 ++++++++++ interp/run.go | 16 +++++++++++++--- 3 files changed, 34 insertions(+), 3 deletions(-) create mode 100644 _test/var10.go create mode 100644 _test/var11.go diff --git a/_test/var10.go b/_test/var10.go new file mode 100644 index 000000000..3c1024fd0 --- /dev/null +++ b/_test/var10.go @@ -0,0 +1,11 @@ +package main + +var _ = true +var _ = "hello" + +func main() { + println("hello") +} + +// Output: +// hello diff --git a/_test/var11.go b/_test/var11.go new file mode 100644 index 000000000..f0419ad8b --- /dev/null +++ b/_test/var11.go @@ -0,0 +1,10 @@ +package main + +var a, _, _, b = 1, true, "foo", 2 + +func main() { + println(a, b) +} + +// Output: +// 1 2 diff --git a/interp/run.go b/interp/run.go index 5baec21c9..204cc9aa1 100644 --- a/interp/run.go +++ b/interp/run.go @@ -293,12 +293,17 @@ func assign(n *node) { } if n.nleft == 1 { - if s, d, i := svalue[0], dvalue[0], ivalue[0]; i != nil { + switch s, d, i := svalue[0], dvalue[0], ivalue[0]; { + case n.child[0].ident == "_": + n.exec = func(f *frame) bltn { + return next + } + case i != nil: n.exec = func(f *frame) bltn { d(f).SetMapIndex(i(f), s(f)) return next } - } else { + default: n.exec = func(f *frame) bltn { d(f).Set(s(f)) return next @@ -316,7 +321,6 @@ func assign(n *node) { default: t = typ.TypeOf() } - //types[i] = n.child[sbase+i].typ.TypeOf() types[i] = t } @@ -326,10 +330,16 @@ func assign(n *node) { n.exec = func(f *frame) bltn { t := make([]reflect.Value, len(svalue)) for i, s := range svalue { + if n.child[i].ident == "_" { + continue + } t[i] = reflect.New(types[i]).Elem() t[i].Set(s(f)) } for i, d := range dvalue { + if n.child[i].ident == "_" { + continue + } if j := ivalue[i]; j != nil { d(f).SetMapIndex(j(f), t[i]) // Assign a map entry } else {