aboutsummaryrefslogtreecommitdiff
path: root/src/main.rs
blob: 40303d3f8bfce0f7c146495f6f65308e61fe20da (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
#![warn(
    missing_docs,
    unreachable_pub,
    unsafe_code,
    unused_crate_dependencies,
    variant_size_differences,
    clippy::pedantic,
    clippy::cargo,
    clippy::nursery
)]

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);
    }
}