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; 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 = {os: os, arch: arch, target_strs: target_strs::t, int_type: int_ty, uint_type: uint_ty, float_type: float_ty}; type options = // The crate config requested for the session, which may be combined // with additional crate configurations during the compile process {crate_type: crate_type, static: bool, libcore: bool, optimize: uint, debuginfo: bool, extra_debuginfo: bool, 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, target_triple: str, cfg: ast::crate_cfg, test: bool, parse_only: bool, no_trans: bool, do_gc: bool, no_asm_comments: bool, warn_unused_imports: bool}; type crate_metadata = {name: str, data: [u8]}; 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, mutable err_count: uint, filesearch: filesearch::filesearch, mutable building_library: bool, working_dir: str}; impl session for session { fn span_fatal(sp: span, msg: str) -> ! { diagnostic::emit_error(some((self.parse_sess.cm, sp)), msg); fail; } fn fatal(msg: str) -> ! { diagnostic::emit_error(none, msg); fail; } fn span_err(sp: span, msg: str) { diagnostic::emit_error(some((self.parse_sess.cm, sp)), msg); self.err_count += 1u; } fn err(msg: str) { diagnostic::emit_error(none, msg); 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) { diagnostic::emit_warning(some((self.parse_sess.cm, sp)), msg); } fn warn(msg: str) { diagnostic::emit_warning(none, msg); } fn span_note(sp: span, msg: str) { diagnostic::emit_note(some((self.parse_sess.cm, sp)), msg); } fn note(msg: str) { diagnostic::emit_note(none, msg); } fn span_bug(sp: span, msg: str) -> ! { self.span_fatal(sp, #fmt["internal compiler error %s", msg]); } fn bug(msg: str) -> ! { self.fatal(#fmt["internal compiler error %s", msg]); } fn span_unimpl(sp: span, msg: str) -> ! { 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: