// They control scanner behavior.
 //
 const (
-       ScanComments = 1 << iota // return comments as COMMENT tokens
-       InsertSemis              // automatically insert semicolons
+       ScanComments    = 1 << iota // return comments as COMMENT tokens
+       dontInsertSemis             // do not automatically insert semicolons - for testing only
 )
 
 // Init prepares the scanner S to tokenize the text src by setting the
 // Calls to Scan will use the error handler err if they encounter a
 // syntax error and err is not nil. Also, for each error encountered,
 // the Scanner field ErrorCount is incremented by one. The mode parameter
-// determines how comments and semicolons are handled.
+// determines how comments are handled.
 //
 // Note that Init may call err if there is an error in the first character
 // of the file.
                }
        }
 
-       if S.mode&InsertSemis != 0 {
+       if S.mode&dontInsertSemis == 0 {
                S.insertSemi = insertSemi
        }
 
 
 
        // verify scan
        var s Scanner
-       s.Init(fset.AddFile("", fset.Base(), len(src)), []byte(src), &testErrorHandler{t}, ScanComments)
+       s.Init(fset.AddFile("", fset.Base(), len(src)), []byte(src), &testErrorHandler{t}, ScanComments|dontInsertSemis)
        index := 0
        epos := token.Position{"", 0, 1, 1} // expected position
        for {
 
 func TestSemis(t *testing.T) {
        for _, line := range lines {
-               checkSemi(t, line, InsertSemis)
-               checkSemi(t, line, InsertSemis|ScanComments)
+               checkSemi(t, line, 0)
+               checkSemi(t, line, ScanComments)
 
                // if the input ended in newlines, the input must tokenize the
                // same with or without those newlines
                for i := len(line) - 1; i >= 0 && line[i] == '\n'; i-- {
-                       checkSemi(t, line[0:i], InsertSemis)
-                       checkSemi(t, line[0:i], InsertSemis|ScanComments)
+                       checkSemi(t, line[0:i], 0)
+                       checkSemi(t, line[0:i], ScanComments)
                }
        }
 }
        // verify scan
        var S Scanner
        file := fset.AddFile(filepath.Join("dir", "TestLineComments"), fset.Base(), len(src))
-       S.Init(file, []byte(src), nil, 0)
+       S.Init(file, []byte(src), nil, dontInsertSemis)
        for _, s := range segs {
                p, _, lit := S.Scan()
                pos := file.Position(p)
        // 1st init
        src1 := "if true { }"
        f1 := fset.AddFile("src1", fset.Base(), len(src1))
-       s.Init(f1, []byte(src1), nil, 0)
+       s.Init(f1, []byte(src1), nil, dontInsertSemis)
        if f1.Size() != len(src1) {
                t.Errorf("bad file size: got %d, expected %d", f1.Size(), len(src1))
        }
        // 2nd init
        src2 := "go true { ]"
        f2 := fset.AddFile("src2", fset.Base(), len(src2))
-       s.Init(f2, []byte(src2), nil, 0)
+       s.Init(f2, []byte(src2), nil, dontInsertSemis)
        if f2.Size() != len(src2) {
                t.Errorf("bad file size: got %d, expected %d", f2.Size(), len(src2))
        }
 
        v := new(ErrorVector)
        var s Scanner
-       s.Init(fset.AddFile("File1", fset.Base(), len(src)), []byte(src), v, 0)
+       s.Init(fset.AddFile("File1", fset.Base(), len(src)), []byte(src), v, dontInsertSemis)
        for {
                if _, tok, _ := s.Scan(); tok == token.EOF {
                        break
 func checkError(t *testing.T, src string, tok token.Token, pos int, err string) {
        var s Scanner
        var h errorCollector
-       s.Init(fset.AddFile("", fset.Base(), len(src)), []byte(src), &h, ScanComments)
+       s.Init(fset.AddFile("", fset.Base(), len(src)), []byte(src), &h, ScanComments|dontInsertSemis)
        _, tok0, _ := s.Scan()
        _, tok1, _ := s.Scan()
        if tok0 != tok {