aboutsummaryrefslogtreecommitdiff
path: root/src/comp/driver
diff options
context:
space:
mode:
authorPatrick Walton <[email protected]>2011-05-05 10:48:02 -0700
committerPatrick Walton <[email protected]>2011-05-05 10:48:02 -0700
commitfea623211fafb2ce719eeb9ed47cdb9624e1fbe8 (patch)
tree6384aa2efacd0c81f293677e84d24516f568b536 /src/comp/driver
parentrustllvm: Add bindings to the LLVM linker (diff)
downloadrust-fea623211fafb2ce719eeb9ed47cdb9624e1fbe8.tar.xz
rust-fea623211fafb2ce719eeb9ed47cdb9624e1fbe8.zip
rustc: Add a Link module; move crate writing to it to slim down trans slightly
Diffstat (limited to 'src/comp/driver')
-rw-r--r--src/comp/driver/rustc.rs29
-rw-r--r--src/comp/driver/session.rs2
2 files changed, 16 insertions, 15 deletions
diff --git a/src/comp/driver/rustc.rs b/src/comp/driver/rustc.rs
index 4276b558..dd10eee5 100644
--- a/src/comp/driver/rustc.rs
+++ b/src/comp/driver/rustc.rs
@@ -11,6 +11,7 @@ import middle.capture;
import middle.ty;
import middle.typeck;
import middle.typestate_check;
+import back.Link;
import lib.llvm;
import util.common;
@@ -30,6 +31,8 @@ import std.GetOpts.optmulti;
import std.GetOpts.optflag;
import std.GetOpts.opt_present;
+import back.Link.output_type;
+
fn default_environment(session.session sess,
str argv0,
str input) -> eval.env {
@@ -86,7 +89,7 @@ fn compile_input(session.session sess,
auto p = parser.new_parser(sess, env, def, input, 0u);
auto crate = time[@ast.crate](time_passes, "parsing",
bind parse_input(sess, p, input));
- if (sess.get_opts().output_type == trans.output_type_none) {ret;}
+ if (sess.get_opts().output_type == Link.output_type_none) {ret;}
crate = time[@ast.crate](time_passes, "external crate reading",
bind creader.read_crates(sess, crate));
@@ -111,7 +114,7 @@ fn compile_input(session.session sess,
bind trans.trans_crate(sess, crate, ty_cx, type_cache, output));
time[()](time_passes, "LLVM passes",
- bind trans.run_passes(sess, llmod, output));
+ bind Link.Write.run_passes(sess, llmod, output));
}
fn pretty_print_input(session.session sess,
@@ -197,14 +200,16 @@ fn main(vec[str] args) {
auto shared = opt_present(match, "shared");
auto output_file = GetOpts.opt_maybe_str(match, "o");
auto library_search_paths = GetOpts.opt_strs(match, "L");
- auto output_type = trans.output_type_bitcode;
+
+ auto output_type = Link.output_type_bitcode;
if (opt_present(match, "parse-only")) {
- output_type = trans.output_type_none;
+ output_type = Link.output_type_none;
} else if (opt_present(match, "S")) {
- output_type = trans.output_type_assembly;
+ output_type = Link.output_type_assembly;
} else if (opt_present(match, "c")) {
- output_type = trans.output_type_object;
+ output_type = Link.output_type_object;
}
+
auto verify = !opt_present(match, "noverify");
auto save_temps = opt_present(match, "save-temps");
// FIXME: Maybe we should support -O0, -O1, -Os, etc
@@ -268,14 +273,10 @@ fn main(vec[str] args) {
let vec[str] parts = _str.split(ifile, '.' as u8);
_vec.pop[str](parts);
alt (output_type) {
- case (trans.output_type_none)
- { parts += vec("pp"); }
- case (trans.output_type_bitcode)
- { parts += vec("bc"); }
- case (trans.output_type_assembly)
- { parts += vec("s"); }
- case (trans.output_type_object)
- { parts += vec("o"); }
+ case (Link.output_type_none) { parts += vec("pp"); }
+ case (Link.output_type_bitcode) { parts += vec("bc"); }
+ case (Link.output_type_assembly) { parts += vec("s"); }
+ case (Link.output_type_object) { parts += vec("o"); }
}
auto ofile = _str.connect(parts, ".");
compile_input(sess, env, ifile, ofile);
diff --git a/src/comp/driver/session.rs b/src/comp/driver/session.rs
index 6b3b55f4..cf34bb7c 100644
--- a/src/comp/driver/session.rs
+++ b/src/comp/driver/session.rs
@@ -32,7 +32,7 @@ type options = rec(bool shared,
bool run_typestate,
bool save_temps,
bool time_passes,
- middle.trans.output_type output_type,
+ back.Link.output_type output_type,
vec[str] library_search_paths,
str sysroot);