mirror of
https://github.com/golang/go
synced 2024-11-25 06:27:57 -07:00
af065a0c77
(this code doesn't match the existing language at this point, but it's a large code base which compiles - will eventually go away) - enable compilation of it again in run.bash R=r DELTA=1147 (534 added, 311 deleted, 302 changed) OCL=22176 CL=22176
177 lines
3.7 KiB
Go
177 lines
3.7 KiB
Go
// Copyright 2009 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 Compilation
|
|
|
|
import Platform "platform"
|
|
import Utils "utils"
|
|
import Globals "globals"
|
|
import Object "object"
|
|
import Type "type"
|
|
import Universe "universe"
|
|
import Scanner "scanner"
|
|
import AST "ast"
|
|
import Parser "parser"
|
|
import Importer "import"
|
|
import Exporter "export"
|
|
import Printer "printer"
|
|
import Verifier "verifier"
|
|
|
|
|
|
// Compute (line, column) information for a given source position.
|
|
func LineCol(src string, pos int) (line, col int) {
|
|
line = 1;
|
|
lpos := 0;
|
|
|
|
if pos > len(src) {
|
|
pos = len(src);
|
|
}
|
|
|
|
for i := 0; i < pos; i++ {
|
|
if src[i] == '\n' {
|
|
line++;
|
|
lpos = i;
|
|
}
|
|
}
|
|
|
|
return line, pos - lpos;
|
|
}
|
|
|
|
|
|
export func Error(comp *Globals.Compilation, pos int, msg string) {
|
|
const errdist = 10;
|
|
delta := pos - comp.errpos; // may be negative!
|
|
if delta < 0 {
|
|
delta = -delta;
|
|
}
|
|
if delta > errdist || comp.nerrors == 0 /* always report first error */ {
|
|
print(comp.src_file);
|
|
if pos >= 0 {
|
|
// print position
|
|
line, col := LineCol(comp.src, pos);
|
|
if Platform.USER == "gri" {
|
|
print(":", line, ":", col);
|
|
} else {
|
|
print(":", line);
|
|
}
|
|
}
|
|
print(": ", msg, "\n");
|
|
comp.nerrors++;
|
|
comp.errpos = pos;
|
|
}
|
|
|
|
if comp.nerrors >= 10 {
|
|
sys.exit(1);
|
|
}
|
|
}
|
|
|
|
|
|
func ReadImport(comp* Globals.Compilation, filename string, update bool) (data string, ok bool) {
|
|
if filename == "" {
|
|
panic("illegal package file name");
|
|
}
|
|
|
|
// see if it just works
|
|
data, ok = Platform.ReadObjectFile(filename);
|
|
if ok {
|
|
return data, ok;
|
|
}
|
|
|
|
if filename[0] == '/' {
|
|
// absolute path
|
|
panic(`don't know how to handle absolute import file path "` + filename + `"`);
|
|
}
|
|
|
|
// relative path
|
|
// try relative to the $GOROOT/pkg directory
|
|
std_filename := Platform.GOROOT + "/pkg/" + filename;
|
|
data, ok = Platform.ReadObjectFile(std_filename);
|
|
if ok {
|
|
return data, ok;
|
|
}
|
|
|
|
if !update {
|
|
return "", false;
|
|
}
|
|
|
|
// TODO BIG HACK - fix this!
|
|
// look for a src file
|
|
// see if it just works
|
|
data, ok = Platform.ReadSourceFile(filename);
|
|
if ok {
|
|
comp.env.Compile(comp, filename + Platform.src_file_ext);
|
|
data, ok = ReadImport(comp, filename, false);
|
|
if ok {
|
|
return data, ok;
|
|
}
|
|
}
|
|
|
|
return "", false;
|
|
}
|
|
|
|
|
|
export func Import(comp *Globals.Compilation, pkg_file string) *Globals.Package {
|
|
data, ok := ReadImport(comp, pkg_file, comp.flags.update_packages);
|
|
var pkg *Globals.Package;
|
|
if ok {
|
|
pkg = Importer.Import(comp, data);
|
|
}
|
|
return pkg;
|
|
}
|
|
|
|
|
|
export func Export(comp *Globals.Compilation, pkg_file string) {
|
|
data := Exporter.Export(comp);
|
|
ok := Platform.WriteObjectFile(pkg_file, data);
|
|
if !ok {
|
|
panic("export failed");
|
|
}
|
|
}
|
|
|
|
|
|
export func Compile(comp *Globals.Compilation, src_file string) {
|
|
// TODO This is incorrect: When compiling with the -r flag, we are
|
|
// calling this function recursively w/o setting up a new comp - this
|
|
// is broken and leads to an assertion error (more then one package
|
|
// upon parsing of the package header).
|
|
|
|
src, ok := Platform.ReadSourceFile(src_file);
|
|
if !ok {
|
|
print("cannot open ", src_file, "\n");
|
|
return;
|
|
}
|
|
|
|
comp.src_file = src_file;
|
|
comp.src = src;
|
|
|
|
if comp.flags.verbosity > 0 {
|
|
print(src_file, "\n");
|
|
}
|
|
|
|
scanner := new(Scanner.Scanner);
|
|
scanner.Open(src_file, src);
|
|
|
|
var tstream chan *Scanner.Token;
|
|
if comp.flags.token_chan {
|
|
tstream = make(chan *Scanner.Token, 100);
|
|
go scanner.Server(tstream);
|
|
}
|
|
|
|
parser := new(Parser.Parser);
|
|
parser.Open(comp, scanner, tstream);
|
|
|
|
parser.ParseProgram();
|
|
if parser.scanner.nerrors > 0 {
|
|
return;
|
|
}
|
|
|
|
Verifier.Verify(comp);
|
|
|
|
if comp.flags.print_interface {
|
|
Printer.PrintObject(comp, comp.pkg_list[0].obj, false);
|
|
}
|
|
|
|
Export(comp, src_file);
|
|
}
|