49 lines
1.2 KiB
Rust
49 lines
1.2 KiB
Rust
//! The `cat` sub-command.
|
|
//!
|
|
//! Read a sequence of Cranelift IR files and print them again to stdout. This has the effect of
|
|
//! normalizing formatting and removing comments.
|
|
|
|
use crate::utils::read_to_string;
|
|
use anyhow::{Context, Result};
|
|
use cranelift_reader::parse_functions;
|
|
use std::path::{Path, PathBuf};
|
|
use structopt::StructOpt;
|
|
|
|
/// Outputs .clif file
|
|
#[derive(StructOpt)]
|
|
pub struct Options {
|
|
/// Specify input file(s) to be used. Use '-' for stdin.
|
|
#[structopt(required(true), parse(from_os_str))]
|
|
files: Vec<PathBuf>,
|
|
|
|
/// Enable debug output on stderr/stdout
|
|
#[structopt(short = "d")]
|
|
debug: bool,
|
|
}
|
|
|
|
pub fn run(options: &Options) -> Result<()> {
|
|
crate::handle_debug_flag(options.debug);
|
|
for (i, f) in options.files.iter().enumerate() {
|
|
if i != 0 {
|
|
println!();
|
|
}
|
|
cat_one(f)?
|
|
}
|
|
Ok(())
|
|
}
|
|
|
|
fn cat_one(path: &Path) -> Result<()> {
|
|
let buffer = read_to_string(path)?;
|
|
let items =
|
|
parse_functions(&buffer).with_context(|| format!("failed to parse {}", path.display()))?;
|
|
|
|
for (idx, func) in items.into_iter().enumerate() {
|
|
if idx != 0 {
|
|
println!();
|
|
}
|
|
print!("{}", func);
|
|
}
|
|
|
|
Ok(())
|
|
}
|