121 lines
3.6 KiB
Rust
121 lines
3.6 KiB
Rust
|
|
import syntax::ast;
|
|
import syntax::codemap;
|
|
import codemap::span;
|
|
import syntax::ast::ty_mach;
|
|
import std::uint;
|
|
import std::io;
|
|
import std::map;
|
|
import std::option;
|
|
import std::option::some;
|
|
import std::option::none;
|
|
import std::str;
|
|
import std::vec;
|
|
import syntax::parse::parser::parse_sess;
|
|
|
|
tag os { os_win32; os_macos; os_linux; }
|
|
|
|
tag arch { arch_x86; arch_x64; arch_arm; }
|
|
|
|
type config =
|
|
rec(os os,
|
|
arch arch,
|
|
ty_mach int_type,
|
|
ty_mach uint_type,
|
|
ty_mach float_type);
|
|
|
|
type options =
|
|
rec(bool library,
|
|
bool static,
|
|
uint optimize,
|
|
bool debuginfo,
|
|
bool verify,
|
|
bool run_typestate,
|
|
bool save_temps,
|
|
bool stats,
|
|
bool time_passes,
|
|
bool time_llvm_passes,
|
|
back::link::output_type output_type,
|
|
vec[str] library_search_paths,
|
|
str sysroot,
|
|
// The crate config requested for the session, which may be combined
|
|
// with additional crate configurations during the compile process
|
|
ast::crate_cfg cfg,
|
|
bool test);
|
|
|
|
type crate_metadata = rec(str name, vec[u8] data);
|
|
|
|
obj session(@config targ_cfg,
|
|
@options opts,
|
|
metadata::cstore::cstore cstore,
|
|
parse_sess parse_sess,
|
|
mutable uint err_count) {
|
|
fn get_targ_cfg() -> @config { ret targ_cfg; }
|
|
fn get_opts() -> @options { ret opts; }
|
|
fn get_cstore() -> metadata::cstore::cstore { cstore }
|
|
fn span_fatal(span sp, str msg) -> ! {
|
|
// FIXME: Use constants, but rustboot doesn't know how to export them.
|
|
codemap::emit_error(some(sp), msg, parse_sess.cm);
|
|
fail;
|
|
}
|
|
fn fatal(str msg) -> ! {
|
|
codemap::emit_error(none, msg, parse_sess.cm);
|
|
fail;
|
|
}
|
|
fn span_err(span sp, str msg) {
|
|
codemap::emit_error(some(sp), msg, parse_sess.cm);
|
|
err_count += 1u;
|
|
}
|
|
fn err(str msg) {
|
|
codemap::emit_error(none, msg, parse_sess.cm);
|
|
err_count += 1u;
|
|
}
|
|
fn abort_if_errors() {
|
|
if (err_count > 0u) {
|
|
self.fatal("aborting due to previous errors");
|
|
}
|
|
}
|
|
fn span_warn(span sp, str msg) {
|
|
// FIXME: Use constants, but rustboot doesn't know how to export them.
|
|
codemap::emit_warning(some(sp), msg, parse_sess.cm);
|
|
}
|
|
fn warn(str msg) {
|
|
codemap::emit_warning(none, msg, parse_sess.cm);
|
|
}
|
|
fn span_note(span sp, str msg) {
|
|
// FIXME: Use constants, but rustboot doesn't know how to export them.
|
|
codemap::emit_note(some(sp), msg, parse_sess.cm);
|
|
}
|
|
fn note(str msg) {
|
|
codemap::emit_note(none, msg, parse_sess.cm);
|
|
}
|
|
fn span_bug(span sp, str msg) -> ! {
|
|
self.span_fatal(sp, #fmt("internal compiler error %s", msg));
|
|
}
|
|
fn bug(str msg) -> ! {
|
|
self.fatal(#fmt("internal compiler error %s", msg));
|
|
}
|
|
fn span_unimpl(span sp, str msg) -> ! {
|
|
self.span_bug(sp, "unimplemented " + msg);
|
|
}
|
|
fn unimpl(str msg) -> ! { self.bug("unimplemented " + msg); }
|
|
fn get_codemap() -> codemap::codemap { ret parse_sess.cm; }
|
|
fn lookup_pos(uint pos) -> codemap::loc {
|
|
ret codemap::lookup_pos(parse_sess.cm, pos);
|
|
}
|
|
fn get_parse_sess() -> parse_sess { ret parse_sess; }
|
|
fn next_node_id() -> ast::node_id {
|
|
ret syntax::parse::parser::next_node_id(parse_sess);
|
|
}
|
|
fn span_str(span sp) -> str {
|
|
ret codemap::span_to_str(sp, self.get_codemap());
|
|
}
|
|
}
|
|
// Local Variables:
|
|
// fill-column: 78;
|
|
// indent-tabs-mode: nil
|
|
// c-basic-offset: 4
|
|
// buffer-file-coding-system: utf-8-unix
|
|
// compile-command: "make -k -C $RBUILD 2>&1 | sed -e 's/\\/x\\//x:\\//g'";
|
|
// End:
|