Skip to content

Commit

Permalink
auto merge of #9204 : lkuper/rust/workcache, r=alexcrichton
Browse files Browse the repository at this point in the history
This just removes the stray "foo.c" that `workcache::test` leaves behind when, for example, `make check` runs.
  • Loading branch information
bors committed Sep 16, 2013
2 parents 6bc48b6 + a7515c8 commit 250c3d4
Showing 1 changed file with 16 additions and 7 deletions.
23 changes: 16 additions & 7 deletions src/libextra/workcache.rs
Expand Up @@ -496,16 +496,23 @@ fn test() {
use std::io::WriterUtil;
use std::{os, run};

let pth = Path("foo.c");
// Create a path to a new file 'filename' in the directory in which
// this test is running.
fn make_path(filename: ~str) -> Path {
let pth = os::self_exe_path().expect("workcache::test failed").pop().push(filename);
if os::path_exists(&pth) {
os::remove_file(&pth);
}
return pth;
}

let pth = make_path(~"foo.c");
{
let r = io::file_writer(&pth, [io::Create]);
r.unwrap().write_str("int main() { return 0; }");
}

let db_path = os::self_exe_path().expect("workcache::test failed").pop().push("db.json");
if os::path_exists(&db_path) {
os::remove_file(&db_path);
}
let db_path = make_path(~"db.json");

let cx = Context::new(RWArc::new(Database::new(db_path)),
RWArc::new(Logger::new()),
Expand All @@ -514,17 +521,19 @@ fn test() {
let s = do cx.with_prep("test1") |prep| {

let subcx = cx.clone();
let pth = pth.clone();

prep.declare_input("file", pth.to_str(), digest_file(&pth));
do prep.exec |_exe| {
let out = Path("foo.o");
run::process_status("gcc", [~"foo.c", ~"-o", out.to_str()]);
let out = make_path(~"foo.o");
run::process_status("gcc", [pth.to_str(), ~"-o", out.to_str()]);

let _proof_of_concept = subcx.prep("subfn");
// Could run sub-rules inside here.

out.to_str()
}
};

io::println(s);
}

0 comments on commit 250c3d4

Please sign in to comment.