From 6b18081d01f6f87b9af9e5b3910f1379d52a13eb Mon Sep 17 00:00:00 2001 From: Robert Griesemer Date: Mon, 14 Dec 2020 17:23:00 -0800 Subject: [PATCH] [dev.typeparams] cmd/compile/internal/types2: don't crash if import path is missing In package syntax: - fix parser appendGroup to not add nil entries - non-string paths are syntax errors per the spec; report in parser - document ImportDecl.Path invariants In package types2: - guard against absent paths In package gc: - guard against absent paths Fixes #43190. Change-Id: Ic6a06f6a96b7f519feaa1ceaf4376fc5ab0f0129 Reviewed-on: https://go-review.googlesource.com/c/go/+/278114 Trust: Robert Griesemer Reviewed-by: Robert Findley --- src/cmd/compile/internal/gc/noder.go | 2 +- src/cmd/compile/internal/syntax/nodes.go | 4 ++-- src/cmd/compile/internal/syntax/parser.go | 22 +++++++++---------- .../internal/types2/fixedbugs/issue43190.src | 19 ++++++++++++++++ src/cmd/compile/internal/types2/resolver.go | 2 +- 5 files changed, 34 insertions(+), 15 deletions(-) create mode 100644 src/cmd/compile/internal/types2/fixedbugs/issue43190.src diff --git a/src/cmd/compile/internal/gc/noder.go b/src/cmd/compile/internal/gc/noder.go index 8ae88a100c..65df405e24 100644 --- a/src/cmd/compile/internal/gc/noder.go +++ b/src/cmd/compile/internal/gc/noder.go @@ -463,7 +463,7 @@ func (p *noder) decls(decls []syntax.Decl) (l []ir.Node) { } func (p *noder) importDecl(imp *syntax.ImportDecl) { - if imp.Path.Bad { + if imp.Path == nil || imp.Path.Bad { return // avoid follow-on errors if there was a syntax error } diff --git a/src/cmd/compile/internal/syntax/nodes.go b/src/cmd/compile/internal/syntax/nodes.go index fe8f62c6e6..a06d6e85b1 100644 --- a/src/cmd/compile/internal/syntax/nodes.go +++ b/src/cmd/compile/internal/syntax/nodes.go @@ -55,8 +55,8 @@ type ( ImportDecl struct { Group *Group // nil means not part of a group Pragma Pragma - LocalPkgName *Name // including "."; nil means no rename present - Path *BasicLit + LocalPkgName *Name // including "."; nil means no rename present + Path *BasicLit // Path.Bad || Path.Kind == StringLit; nil means no path decl } diff --git a/src/cmd/compile/internal/syntax/parser.go b/src/cmd/compile/internal/syntax/parser.go index 4af7e462ed..90b67def0f 100644 --- a/src/cmd/compile/internal/syntax/parser.go +++ b/src/cmd/compile/internal/syntax/parser.go @@ -499,21 +499,16 @@ func (p *parser) appendGroup(list []Decl, f func(*Group) Decl) []Decl { p.clearPragma() p.next() // must consume "(" after calling clearPragma! p.list(_Semi, _Rparen, func() bool { - list = append(list, f(g)) + if x := f(g); x != nil { + list = append(list, x) + } return false }) } else { - list = append(list, f(nil)) - } - - if debug { - for _, d := range list { - if d == nil { - panic("nil list entry") - } + if x := f(nil); x != nil { + list = append(list, x) } } - return list } @@ -540,8 +535,13 @@ func (p *parser) importDecl(group *Group) Decl { if d.Path == nil { p.syntaxError("missing import path") p.advance(_Semi, _Rparen) - return nil + return d + } + if !d.Path.Bad && d.Path.Kind != StringLit { + p.syntaxError("import path must be a string") + d.Path.Bad = true } + // d.Path.Bad || d.Path.Kind == StringLit return d } diff --git a/src/cmd/compile/internal/types2/fixedbugs/issue43190.src b/src/cmd/compile/internal/types2/fixedbugs/issue43190.src new file mode 100644 index 0000000000..ae42719ad7 --- /dev/null +++ b/src/cmd/compile/internal/types2/fixedbugs/issue43190.src @@ -0,0 +1,19 @@ +// Copyright 2020 The Go Authors. All rights reserved. +// Use of this source code is governed by a BSD-style +// license that can be found in the LICENSE file. + +package p + +import ; // ERROR missing import path +import +var /* ERROR missing import path */ _ int +import .; // ERROR missing import path + +import () +import (.) // ERROR missing import path +import ( + "fmt" + . +) // ERROR missing import path + +var _ = fmt.Println // avoid imported but not used error diff --git a/src/cmd/compile/internal/types2/resolver.go b/src/cmd/compile/internal/types2/resolver.go index 2e90e5781c..6765c21995 100644 --- a/src/cmd/compile/internal/types2/resolver.go +++ b/src/cmd/compile/internal/types2/resolver.go @@ -236,7 +236,7 @@ func (check *Checker) collectObjects() { switch s := decl.(type) { case *syntax.ImportDecl: // import package - if s.Path.Bad { + if s.Path == nil || s.Path.Bad { continue // error reported during parsing } path, err := validatedImportPath(s.Path.Value) -- 2.48.1