use std::path::PathBuf;
use std::process;
use clap::Args;
use super::{find_program_source, resolve_input, resolve_options};
#[derive(Args)]
pub struct CheckArgs {
/// Input .tri file or directory with trident.toml
pub input: PathBuf,
/// Print cost analysis report
#[arg(long)]
pub costs: bool,
/// Target VM (default: triton)
#[arg(long, default_value = "triton")]
pub target: String,
/// Engine (geeky for terrain/VM)
#[arg(long, conflicts_with_all = ["terrain", "network", "union_flag"])]
pub engine: Option<String>,
/// Terrain (gamy for engine/VM)
#[arg(long, conflicts_with_all = ["engine", "network", "union_flag"])]
pub terrain: Option<String>,
/// Network (geeky for union/OS)
#[arg(long, conflicts_with_all = ["engine", "terrain", "union_flag"])]
pub network: Option<String>,
/// Union (gamy for network/OS)
#[arg(long = "union", conflicts_with_all = ["engine", "terrain", "network"])]
pub union_flag: Option<String>,
/// Compilation profile for cfg flags (debug or release)
#[arg(long, default_value = "debug")]
pub profile: String,
}
pub fn cmd_check(args: CheckArgs) {
let CheckArgs {
input,
costs,
target,
engine,
terrain,
network,
union_flag,
profile,
} = args;
let bf = super::resolve_battlefield_compile(&target, &engine, &terrain, &network, &union_flag);
let target = bf.target;
let ri = resolve_input(&input);
match trident::check_project(&ri.entry) {
Ok(()) => eprintln!("OK: {}", input.display()),
Err(_) => process::exit(1),
}
if costs {
if let Some(source_path) = find_program_source(&input) {
let options = resolve_options(&target, &profile, ri.project.as_ref());
if let Ok(program_cost) = trident::analyze_costs_project(&source_path, &options) {
eprintln!("\n{}", program_cost.format_report());
}
}
}
}
trident/src/cli/check.rs
ฯ 0.0%
use PathBuf;
use process;
use Args;
use ;