rust/src/rustc/driver/session.rs

308 lines
9.4 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 syntax::parse::parse_sess;
import metadata::filesearch;
import back::target_strs;
import back::link;
import middle::lint;
2012-01-19 19:56:05 -06:00
enum os { os_win32, os_macos, os_linux, os_freebsd, }
2012-01-19 19:56:05 -06:00
enum arch { arch_x86, arch_x86_64, arch_arm, }
2012-01-19 19:56:05 -06:00
enum 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};
const ppregions: uint = 1u;
const time_passes: uint = 2u;
const count_llvm_insns: uint = 4u;
const time_llvm_passes: uint = 8u;
const trans_stats: uint = 16u;
const no_asm_comments: uint = 32u;
const no_verify: uint = 64u;
2012-05-18 21:02:39 -05:00
const trace: uint = 128u;
// FIXME (#2377): This exists to transition to a Rust crate runtime
// It should be removed
const no_rt: uint = 256u;
const coherence: uint = 512u;
const borrowck_stats: uint = 1024u;
fn debugging_opts_map() -> ~[(str, str, uint)] {
~[("ppregions", "prettyprint regions with \
internal repr details", ppregions),
("time-passes", "measure time of each rustc pass", time_passes),
("count-llvm-insns", "count where LLVM \
instrs originate", count_llvm_insns),
("time-llvm-passes", "measure time of each LLVM pass", time_llvm_passes),
("stats", "gather trans statistics", stats),
("no-asm-comments", "omit comments when using -S", no_asm_comments),
2012-05-18 21:02:39 -05:00
("no-verify", "skip LLVM verification", no_verify),
("trace", "emit trace logs", trace),
("no-rt", "do not link to the runtime", no_rt),
("coherence", "perform coherence checking", coherence),
("borrowck-stats", "gather borrowck statistics", borrowck_stats)
]
}
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,
optimize: uint,
debuginfo: bool,
extra_debuginfo: bool,
lint_opts: ~[(lint::lint, lint::level)],
2011-07-27 07:19:39 -05:00
save_temps: bool,
output_type: back::link::output_type,
addl_lib_search_paths: ~[str],
maybe_sysroot: option<str>,
target_triple: str,
2011-07-27 07:19:39 -05:00
cfg: ast::crate_cfg,
test: bool,
parse_only: bool,
no_trans: bool,
debugging_opts: uint,
};
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
2012-03-26 20:35:18 -05:00
mut main_fn: option<(node_id, codemap::span)>,
span_diagnostic: diagnostic::span_handler,
filesearch: filesearch::filesearch,
2012-03-26 20:35:18 -05:00
mut building_library: bool,
working_dir: str,
warning_settings: lint::warning_settings};
2011-03-25 12:42:57 -05:00
impl session for session {
fn span_fatal(sp: span, msg: str) -> ! {
self.span_diagnostic.span_fatal(sp, msg)
}
fn fatal(msg: str) -> ! {
self.span_diagnostic.handler().fatal(msg)
}
fn span_err(sp: span, msg: str) {
self.span_diagnostic.span_err(sp, msg)
}
fn err(msg: str) {
self.span_diagnostic.handler().err(msg)
}
fn has_errors() -> bool {
self.span_diagnostic.handler().has_errors()
}
fn abort_if_errors() {
self.span_diagnostic.handler().abort_if_errors()
}
fn span_warn(sp: span, msg: str) {
self.span_diagnostic.span_warn(sp, msg)
}
fn warn(msg: str) {
self.span_diagnostic.handler().warn(msg)
}
fn span_note(sp: span, msg: str) {
self.span_diagnostic.span_note(sp, msg)
}
fn note(msg: str) {
self.span_diagnostic.handler().note(msg)
}
fn span_bug(sp: span, msg: str) -> ! {
self.span_diagnostic.span_bug(sp, msg)
}
fn bug(msg: str) -> ! {
self.span_diagnostic.handler().bug(msg)
}
fn span_unimpl(sp: span, msg: str) -> ! {
self.span_diagnostic.span_unimpl(sp, msg)
}
fn unimpl(msg: str) -> ! {
self.span_diagnostic.handler().unimpl(msg)
}
fn span_lint_level(level: lint::level,
sp: span, msg: str) {
alt level {
lint::ignore { }
lint::warn { self.span_warn(sp, msg); }
lint::error { self.span_err(sp, msg); }
}
}
fn span_lint(lint_mode: lint::lint,
expr_id: ast::node_id, item_id: ast::node_id,
span: span, msg: str) {
let level = lint::get_warning_settings_level(
self.warning_settings, lint_mode, expr_id, item_id);
self.span_lint_level(level, span, msg);
}
fn next_node_id() -> ast::node_id {
ret syntax::parse::next_node_id(self.parse_sess);
}
fn diagnostic() -> diagnostic::span_handler {
self.span_diagnostic
}
fn debugging_opt(opt: uint) -> bool {
(self.opts.debugging_opts & opt) != 0u
}
fn ppregions() -> bool { self.debugging_opt(ppregions) }
fn time_passes() -> bool { self.debugging_opt(time_passes) }
fn count_llvm_insns() -> bool { self.debugging_opt(count_llvm_insns) }
fn time_llvm_passes() -> bool { self.debugging_opt(time_llvm_passes) }
fn trans_stats() -> bool { self.debugging_opt(trans_stats) }
fn no_asm_comments() -> bool { self.debugging_opt(no_asm_comments) }
fn no_verify() -> bool { self.debugging_opt(no_verify) }
2012-05-18 21:02:39 -05:00
fn trace() -> bool { self.debugging_opt(trace) }
fn coherence() -> bool { self.debugging_opt(coherence) }
fn borrowck_stats() -> bool { self.debugging_opt(borrowck_stats) }
}
/// Some reasonable defaults
fn basic_options() -> @options {
@{
crate_type: session::lib_crate,
static: false,
optimize: 0u,
debuginfo: false,
extra_debuginfo: false,
lint_opts: ~[],
save_temps: false,
output_type: link::output_type_exe,
addl_lib_search_paths: ~[],
maybe_sysroot: none,
target_triple: driver::host_triple(),
cfg: ~[],
test: false,
parse_only: false,
no_trans: false,
debugging_opts: 0u
}
}
// Seems out of place, but it uses session, so I'm putting it here
fn expect<T: copy>(sess: session, opt: option<T>, msg: fn() -> str) -> T {
2012-05-22 16:55:39 -05:00
diagnostic::expect(sess.diagnostic(), opt, msg)
}
fn building_library(req_crate_type: crate_type, crate: @ast::crate,
testing: bool) -> bool {
alt req_crate_type {
bin_crate { false }
lib_crate { true }
unknown_crate {
if testing {
false
} else {
alt syntax::attr::first_attr_value_str_by_name(
crate.node.attrs,
"crate_type") {
2012-06-10 02:49:59 -05:00
option::some(@"lib") { true }
_ { false }
}
}
}
}
}
fn sess_os_to_meta_os(os: os) -> metadata::loader::os {
import metadata::loader;
alt os {
os_win32 { loader::os_win32 }
os_linux { loader::os_linux }
os_macos { loader::os_macos }
os_freebsd { loader::os_freebsd }
}
}
#[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(
2012-06-10 02:49:59 -05:00
@"crate_type",
ast_util::respan(ast_util::dummy_sp(),
ast::lit_str(@t)))),
is_sugared_doc: false
})
}
fn make_crate(with_bin: bool, with_lib: bool) -> @ast::crate {
let mut 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, false);
}
#[test]
fn lib_crate_type_attr_results_in_lib_output() {
let crate = make_crate(false, true);
assert building_library(unknown_crate, crate, false);
}
#[test]
fn bin_option_overrides_lib_crate_type() {
let crate = make_crate(false, true);
assert !building_library(bin_crate, crate, false);
}
#[test]
fn lib_option_overrides_bin_crate_type() {
let crate = make_crate(true, false);
assert building_library(lib_crate, crate, false);
}
#[test]
fn bin_crate_type_is_default() {
let crate = make_crate(false, false);
assert !building_library(unknown_crate, crate, false);
}
#[test]
fn test_option_overrides_lib_crate_type() {
let crate = make_crate(false, true);
assert !building_library(unknown_crate, crate, true);
}
#[test]
fn test_option_does_not_override_requested_lib_type() {
let crate = make_crate(false, false);
assert building_library(lib_crate, crate, true);
}
}
// Local Variables:
// fill-column: 78;
// indent-tabs-mode: nil
// c-basic-offset: 4
// buffer-file-coding-system: utf-8-unix
// End: