1 // Copyright 2012-2013 The Rust Project Developers. See the COPYRIGHT
2 // file at the top-level directory of this distribution and at
3 // http://rust-lang.org/COPYRIGHT.
5 // Licensed under the Apache License, Version 2.0 <LICENSE-APACHE or
6 // http://www.apache.org/licenses/LICENSE-2.0> or the MIT license
7 // <LICENSE-MIT or http://opensource.org/licenses/MIT>, at your
8 // option. This file may not be copied, modified, or distributed
9 // except according to those terms.
11 //! The Rust compiler.
15 //! This API is completely unstable and subject to change.
17 // Do not remove on snapshot creation. Needed for bootstrap. (Issue #22364)
18 #![cfg_attr(stage0, feature(custom_attribute))]
19 #![crate_name = "rustc"]
20 #![unstable(feature = "rustc_private")]
22 #![crate_type = "dylib"]
23 #![crate_type = "rlib"]
24 #![doc(html_logo_url = "http://www.rust-lang.org/logos/rust-logo-128x128-blk-v2.png",
25 html_favicon_url = "http://www.rust-lang.org/favicon.ico",
26 html_root_url = "http://doc.rust-lang.org/nightly/")]
28 #![feature(box_patterns)]
29 #![feature(box_syntax)]
30 #![feature(collections)]
35 #![feature(rustc_diagnostic_macros)]
36 #![feature(rustc_private)]
37 #![feature(unsafe_destructor)]
38 #![feature(staged_api)]
43 #![feature(slice_patterns)]
44 #![cfg_attr(test, feature(test))]
46 #![allow(trivial_casts)]
50 extern crate fmt_macros;
52 extern crate graphviz;
54 extern crate rustc_llvm;
55 extern crate rustc_back;
56 extern crate rustc_data_structures;
57 extern crate serialize;
59 extern crate collections;
60 #[macro_use] extern crate log;
61 #[macro_use] extern crate syntax;
62 #[macro_use] #[no_link] extern crate rustc_bitflags;
64 extern crate serialize as rustc_serialize; // used by deriving
69 pub use rustc_llvm as llvm;
74 // NB: This module needs to be declared first so diagnostics are
75 // registered before they are used.
79 pub use rustc_back::abi;
80 pub use rustc_back::archive;
81 pub use rustc_back::arm;
82 pub use rustc_back::mips;
83 pub use rustc_back::mipsel;
84 pub use rustc_back::rpath;
85 pub use rustc_back::svh;
86 pub use rustc_back::target_strs;
87 pub use rustc_back::x86;
88 pub use rustc_back::x86_64;
96 pub mod check_static_recursion;
99 pub mod check_rvalues;
104 pub mod dependency_format;
107 pub mod expr_use_visitor;
113 pub mod mem_categorization;
118 pub mod recursion_limit;
119 pub mod resolve_lifetime;
128 pub mod weak_lang_items;
140 pub use rustc_back::fs;
141 pub use rustc_back::sha2;
146 pub mod lev_distance;
154 // A private module so that macro-expanded idents like
155 // `::rustc::lint::Lint` will also work in `rustc` itself.
157 // `libstd` uses the same trick.