rust/src/comp/driver/session.rs

195 lines
5.5 KiB
Rust
Raw Normal View History

2011-09-12 18:13:28 -05:00
import syntax::{ast, codemap};
import syntax::ast::node_id;
import codemap::span;
import syntax::ast::{int_ty, uint_ty, float_ty};
import option;
import option::{some, none};
import syntax::parse::parser::parse_sess;
import util::filesearch;
import back::target_strs;
2011-12-30 02:18:55 -06:00
tag os { os_win32; os_macos; os_linux; os_freebsd; }
tag arch { arch_x86; arch_x86_64; arch_arm; }
tag crate_type { bin_crate; lib_crate; unknown_crate; }
type config =
2011-07-27 07:19:39 -05:00
{os: os,
arch: arch,
target_strs: target_strs::t,
int_type: int_ty,
uint_type: uint_ty,
float_type: float_ty};
type options =
2011-07-27 07:19:39 -05:00
// The crate config requested for the session, which may be combined
// with additional crate configurations during the compile process
{crate_type: crate_type,
2011-07-27 07:19:39 -05:00
static: bool,
libcore: bool,
2011-07-27 07:19:39 -05:00
optimize: uint,
debuginfo: bool,
extra_debuginfo: bool,
2011-07-27 07:19:39 -05:00
verify: bool,
save_temps: bool,
stats: bool,
time_passes: bool,
time_llvm_passes: bool,
output_type: back::link::output_type,
addl_lib_search_paths: [str],
maybe_sysroot: option::t<str>,
target_triple: str,
2011-07-27 07:19:39 -05:00
cfg: ast::crate_cfg,
test: bool,
parse_only: bool,
no_trans: bool,
do_gc: bool,
no_asm_comments: bool,
warn_unused_imports: bool};
2011-09-02 17:34:58 -05:00
type crate_metadata = {name: str, data: [u8]};
2011-07-27 07:19:39 -05:00
type session = @{targ_cfg: @config,
opts: @options,
cstore: metadata::cstore::cstore,
parse_sess: parse_sess,
codemap: codemap::codemap,
// For a library crate, this is always none
mutable main_fn: option::t<node_id>,
mutable err_count: uint,
filesearch: filesearch::filesearch,
mutable building_library: bool,
working_dir: str};
2011-03-25 12:42:57 -05:00
impl session for session {
fn span_fatal(sp: span, msg: str) -> ! {
codemap::emit_error(some(sp), msg, self.parse_sess.cm);
fail;
}
fn fatal(msg: str) -> ! {
codemap::emit_error(none, msg, self.parse_sess.cm);
fail;
}
fn span_err(sp: span, msg: str) {
codemap::emit_error(some(sp), msg, self.parse_sess.cm);
self.err_count += 1u;
}
fn err(msg: str) {
codemap::emit_error(none, msg, self.parse_sess.cm);
self.err_count += 1u;
}
fn has_errors() -> bool { self.err_count > 0u }
fn abort_if_errors() {
if self.err_count > 0u {
self.fatal("aborting due to previous errors");
}
}
fn span_warn(sp: span, msg: str) {
codemap::emit_warning(some(sp), msg, self.parse_sess.cm);
}
fn warn(msg: str) {
codemap::emit_warning(none, msg, self.parse_sess.cm);
}
fn span_note(sp: span, msg: str) {
codemap::emit_note(some(sp), msg, self.parse_sess.cm);
}
fn note(msg: str) {
codemap::emit_note(none, msg, self.parse_sess.cm);
}
fn span_bug(sp: span, msg: str) -> ! {
2011-09-02 17:34:58 -05:00
self.span_fatal(sp, #fmt["internal compiler error %s", msg]);
}
fn bug(msg: str) -> ! {
2011-09-02 17:34:58 -05:00
self.fatal(#fmt["internal compiler error %s", msg]);
}
fn span_unimpl(sp: span, msg: str) -> ! {
2011-09-02 17:34:58 -05:00
self.span_bug(sp, "unimplemented " + msg);
}
fn unimpl(msg: str) -> ! { self.bug("unimplemented " + msg); }
fn next_node_id() -> ast::node_id {
ret syntax::parse::parser::next_node_id(self.parse_sess);
}
}
fn building_library(req_crate_type: crate_type, crate: @ast::crate) -> bool {
alt req_crate_type {
bin_crate. { false }
lib_crate. { true }
unknown_crate. {
alt front::attr::get_meta_item_value_str_by_name(
crate.node.attrs,
"crate_type") {
option::some("lib") { true }
_ { false }
}
}
}
}
#[cfg(test)]
mod test {
import syntax::ast_util;
fn make_crate_type_attr(t: str) -> ast::attribute {
ast_util::respan(ast_util::dummy_sp(), {
style: ast::attr_outer,
value: ast_util::respan(ast_util::dummy_sp(),
ast::meta_name_value(
"crate_type",
ast_util::respan(ast_util::dummy_sp(),
ast::lit_str(t))))
})
}
fn make_crate(with_bin: bool, with_lib: bool) -> @ast::crate {
let attrs = [];
if with_bin { attrs += [make_crate_type_attr("bin")]; }
if with_lib { attrs += [make_crate_type_attr("lib")]; }
@ast_util::respan(ast_util::dummy_sp(), {
directives: [],
module: {view_items: [], items: []},
attrs: attrs,
config: []
})
}
#[test]
fn bin_crate_type_attr_results_in_bin_output() {
let crate = make_crate(true, false);
assert !building_library(unknown_crate, crate);
}
#[test]
fn lib_crate_type_attr_results_in_lib_output() {
let crate = make_crate(false, true);
assert building_library(unknown_crate, crate);
}
#[test]
fn bin_option_overrides_lib_crate_type() {
let crate = make_crate(false, true);
assert !building_library(bin_crate, crate);
}
#[test]
fn lib_option_overrides_bin_crate_type() {
let crate = make_crate(true, false);
assert building_library(lib_crate, crate);
}
#[test]
fn bin_crate_type_is_default() {
let crate = make_crate(false, false);
assert !building_library(unknown_crate, crate);
}
}
// Local Variables:
// fill-column: 78;
// indent-tabs-mode: nil
// c-basic-offset: 4
// buffer-file-coding-system: utf-8-unix
// End: