blob: 0720ada67c727222fe7ad09934d4dae6d89503a6 (
plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
|
#![warn(
missing_docs,
unreachable_pub,
unsafe_code,
unused_crate_dependencies,
variant_size_differences,
clippy::pedantic,
clippy::cargo,
clippy::nursery
)]
#![allow(clippy::redundant_pub_crate)]
use std::fs::metadata;
use std::io::stdin;
use std::path::PathBuf;
mod args;
mod makefile;
use args::Args;
use makefile::Makefile;
fn main() {
let mut args = Args::from_env_and_args();
// If no makefile is specified, try some options.
if args.makefile.is_empty() {
args.makefile = vec![if metadata("./makefile").is_ok() {
"./makefile".into()
} else if metadata("./Makefile").is_ok() {
"./Makefile".into()
} else {
// TODO handle error gracefully
panic!("no makefile found");
}];
}
// Read in the makefile(s) specified.
// TODO dump command-line args into MAKEFLAGS
// TODO dump command-line macros into environment
// TODO add SHELL macro
let mut makefile = Makefile::new(&args);
for filename in &args.makefile {
if filename == &PathBuf::from("-") {
makefile.and_read(stdin().lock());
} else {
makefile.and_read_file(filename);
};
}
if args.print_everything {
println!("{}", &makefile);
}
let targets = if args.targets().count() == 0 {
vec![makefile
.first_non_special_target
.clone()
.expect("couldn't find a target!")]
} else {
args.targets().cloned().collect()
};
for target in targets {
makefile.update_target(&target);
}
}
|