use clap::Parser;
use parquet::{
file::reader::{FileReader, SerializedFileReader},
schema::printer::{print_file_metadata, print_parquet_metadata},
};
use std::{fs::File, path::Path};
#[derive(Debug, Parser)]
#[clap(author, version, about("Binary file to print the schema and metadata of a Parquet file"), long_about = None)]
struct Args {
#[clap(help("Path to the parquet file"))]
file_path: String,
#[clap(short, long, help("Enable printing full file metadata"))]
verbose: bool,
}
fn main() {
let args = Args::parse();
let filename = args.file_path;
let path = Path::new(&filename);
let file = File::open(path).expect("Unable to open file");
let verbose = args.verbose;
match SerializedFileReader::new(file) {
Err(e) => panic!("Error when parsing Parquet file: {e}"),
Ok(parquet_reader) => {
let metadata = parquet_reader.metadata();
println!("Metadata for file: {}", &filename);
println!();
if verbose {
print_parquet_metadata(&mut std::io::stdout(), metadata);
} else {
print_file_metadata(&mut std::io::stdout(), metadata.file_metadata());
}
}
}
}