cmd/compile: eliminate pushedio and savedstate

While here, get drop the lexlineno{++,--} hacks for canned imports.
They were added in commit d3237f9, but don't seem to serve any
purpose.

Change-Id: I00f9e6be0ae9f217f2fa113b85e041dfd0303757
Reviewed-on: https://go-review.googlesource.com/19652
Reviewed-by: Robert Griesemer <gri@golang.org>
Run-TryBot: Matthew Dempsky <mdempsky@google.com>
diff --git a/src/cmd/compile/internal/gc/go.go b/src/cmd/compile/internal/gc/go.go
index 71a5d88c..7cfc2c9 100644
--- a/src/cmd/compile/internal/gc/go.go
+++ b/src/cmd/compile/internal/gc/go.go
@@ -451,8 +451,6 @@
 
 var curio Io
 
-var pushedio Io
-
 var lexlineno int32
 
 var lineno int32
diff --git a/src/cmd/compile/internal/gc/lex.go b/src/cmd/compile/internal/gc/lex.go
index ae201a7..91b521e 100644
--- a/src/cmd/compile/internal/gc/lex.go
+++ b/src/cmd/compile/internal/gc/lex.go
@@ -320,22 +320,15 @@
 
 		linehistpush(infile)
 
-		var err error
-		curio.bin, err = obj.Bopenr(infile)
+		bin, err := obj.Bopenr(infile)
 		if err != nil {
 			fmt.Printf("open %s: %v\n", infile, err)
 			errorexit()
 		}
 
-		curio.peekc = 0
-		curio.peekc1 = 0
-		curio.nlsemi = false
-		curio.eofnl = false
-		curio.last = 0
-
 		// Skip initial BOM if present.
-		if obj.Bgetrune(curio.bin) != BOM {
-			obj.Bungetrune(curio.bin)
+		if obj.Bgetrune(bin) != BOM {
+			obj.Bungetrune(bin)
 		}
 
 		block = 1
@@ -343,15 +336,13 @@
 
 		imported_unsafe = false
 
-		parse_file()
+		parse_file(bin)
 		if nsyntaxerrors != 0 {
 			errorexit()
 		}
 
 		linehistpop()
-		if curio.bin != nil {
-			obj.Bterm(curio.bin)
-		}
+		obj.Bterm(bin)
 	}
 
 	testdclstack()
@@ -667,14 +658,16 @@
 
 	block = 1
 	iota_ = -1000000
+	incannedimport = 1
 
 	importpkg = Runtimepkg
-	cannedimports("runtime.Builtin", runtimeimport)
+	parse_import(obj.Binitr(strings.NewReader(runtimeimport)))
 
 	importpkg = unsafepkg
-	cannedimports("unsafe.o", unsafeimport)
+	parse_import(obj.Binitr(strings.NewReader(unsafeimport)))
 
 	importpkg = nil
+	incannedimport = 0
 }
 
 func importfile(f *Val) {
@@ -822,15 +815,7 @@
 	switch c {
 	case '\n':
 		// old export format
-		pushedio = curio
-		curio = Io{bin: imp}
-		typecheckok = true
-
-		parse_import()
-
-		typecheckok = false
-		curio = pushedio
-		pushedio.bin = nil
+		parse_import(imp)
 
 	case 'B':
 		// new export format
@@ -847,22 +832,6 @@
 	}
 }
 
-func cannedimports(file string, cp string) {
-	lexlineno++ // if sys.6 is included on line 1,
-	pushedio = curio
-	curio = Io{bin: obj.Binitr(strings.NewReader(cp))}
-	typecheckok = true
-	incannedimport = 1
-
-	parse_import()
-
-	typecheckok = false
-	incannedimport = 0
-	curio = pushedio
-	pushedio.bin = nil
-	lexlineno-- // re correct sys.6 line number
-}
-
 func isSpace(c int) bool {
 	return c == ' ' || c == '\t' || c == '\n' || c == '\r'
 }
diff --git a/src/cmd/compile/internal/gc/parser.go b/src/cmd/compile/internal/gc/parser.go
index 4a49836..e41f3b9 100644
--- a/src/cmd/compile/internal/gc/parser.go
+++ b/src/cmd/compile/internal/gc/parser.go
@@ -13,6 +13,7 @@
 // to handle optional commas and semicolons before a closing ) or } .
 
 import (
+	"cmd/internal/obj"
 	"fmt"
 	"strconv"
 	"strings"
@@ -24,7 +25,10 @@
 // we can get rid of this (issue 13242).
 var fileparser parser // the Go source file parser in use
 
-func parse_import() {
+func parse_import(bin *obj.Biobuf) {
+	pushedio := curio
+	curio = Io{bin: bin}
+
 	// Indentation (for tracing) must be preserved across parsers
 	// since we are changing the lexer source (and parser state)
 	// under foot, in the middle of productions. This won't be
@@ -35,10 +39,14 @@
 	importparser := parser{indent: fileparser.indent} // preserve indentation
 	importparser.next()
 	importparser.import_package()
+
+	curio = pushedio
 }
 
 // parse_file sets up a new parser and parses a single Go source file.
-func parse_file() {
+func parse_file(bin *obj.Biobuf) {
+	curio = Io{bin: bin}
+
 	fileparser = parser{}
 	fileparser.next()
 	fileparser.file()
@@ -428,6 +436,7 @@
 	}
 	importpkg.Safe = importsafe
 
+	typecheckok = true
 	defercheckwidth()
 
 	p.hidden_import_list()
@@ -438,6 +447,7 @@
 	}
 
 	resumecheckwidth()
+	typecheckok = false
 }
 
 // Declaration = ConstDecl | TypeDecl | VarDecl .