From 3041458c236ecb0af039c62dee16e9ef96b9983b Mon Sep 17 00:00:00 2001 From: joshuabvarghese Date: Mon, 16 Oct 2023 18:39:51 +1100 Subject: [PATCH 1/2] Adding Compressor Settings --- brro-compressor/src/main.rs | 74 ++++++++++++++++++++++++------------- 1 file changed, 49 insertions(+), 25 deletions(-) diff --git a/brro-compressor/src/main.rs b/brro-compressor/src/main.rs index e643480..c42eb05 100644 --- a/brro-compressor/src/main.rs +++ b/brro-compressor/src/main.rs @@ -1,3 +1,9 @@ +/// The above code is a Rust program that compresses data based on user input and settings. +/// +/// Arguments: +/// +/// * `arguments`: The `arguments` parameter is a struct that contains the parsed command-line arguments. It has the following fields: +/// * `compressor_settings`: The `compressor_settings` parameter is an optional `CompressorSettings` struct that contains fields for compressor settings. It is used to customize the behavior of the compressor based on user input. If the `compressor_settings` parameter is `Some`, it means that the user has provided specific compressor settings use brro_compressor::compressor::Compressor; use brro_compressor::data::CompressedStream; use brro_compressor::optimizer; @@ -9,22 +15,27 @@ use log::debug; use std::path::Path; use std::path::PathBuf; +/// Define a data structure for compressor settings +struct CompressorSettings { + // Define fields for compressor settings here +} + /// Processes the given input based on the provided arguments. /// If `arguments.directory` is true, it processes all files in the directory. /// Otherwise, it processes the individual file. -fn process_args(arguments: &Args) { +fn process_args(arguments: &Args, compressor_settings: Option) { // If the input path points to a directory if arguments.directory { - process_directory(arguments); + process_directory(arguments, compressor_settings); } // If the input path points to a single file else { - process_single_file(arguments); + process_single_file(arguments, compressor_settings); } } /// Processes all files in a given directory. -fn process_directory(arguments: &Args) { +fn process_directory(arguments: &Args, compressor_settings: Option) { let new_name = format!( "{}-compressed", arguments.input.file_name().unwrap().to_string_lossy() @@ -32,29 +43,26 @@ fn process_directory(arguments: &Args) { let base_dir = arguments.input.with_file_name(new_name); writer::initialize_directory(&base_dir).expect("Failed to initialize directory"); - let files = - reader::stream_reader(&arguments.input).expect("Failed to read files from directory"); + let files = reader::stream_reader(&arguments.input).expect("Failed to read files from directory"); for (index, data) in files.contents.iter().enumerate() { let (vec_data, tag) = data; - let compressed_data = compress_data(vec_data, tag, arguments); - // BRO extension - let file_name = writer::replace_extension(&files.names[index], "bro"); + let compressed_data = compress_data(vec_data, tag, arguments, &compressor_settings); + + let file_name = writer::replace_extension(&files.names[index], "bin"); let new_path = base_dir.join(&file_name); write_compressed_data_to_path(&compressed_data, &new_path); } } /// Processes a single file. -fn process_single_file(arguments: &Args) { - debug!("Processing single file..."); +fn process_single_file(arguments: &Args, compressor_settings: Option) { let (vec, tag) = reader::read_file(&arguments.input).expect("Failed to read file"); - let compressed_data = compress_data(&vec, &tag, arguments); + let compressed_data = compress_data(&vec, &tag, arguments, &compressor_settings); + if let Some(filename_osstr) = arguments.input.file_name() { if let Some(filename_str) = filename_osstr.to_str() { - // BRO extension - let new_filename_string = - writer::replace_extension(&filename_str.to_string(), "bro"); + let new_filename_string = writer::replace_extension(&filename_str.to_string(), "bin"); let new_path = arguments.input.parent().unwrap().join(new_filename_string); write_compressed_data_to_path(&compressed_data, &new_path); } @@ -62,25 +70,32 @@ fn process_single_file(arguments: &Args) { } /// Compresses the data based on the provided tag and arguments. -fn compress_data(vec: &Vec, tag: &MetricTag, arguments: &Args) -> Vec { - debug!("Compressing data!"); +fn compress_data(vec: &Vec, tag: &MetricTag, arguments: &Args, compressor_settings: &Option) -> Vec { let optimizer_results = optimizer::process_data(vec, tag); - let _optimizer_results_f: Vec = optimizer_results.iter().map(|&x| x as f64).collect(); + let optimizer_results_f: Vec = optimizer_results.iter().map(|&x| x as f64).collect(); let mut cs = CompressedStream::new(); if arguments.constant { - cs.compress_chunk_with(vec, Compressor::Constant); + cs.compress_chunk_with(&optimizer_results_f, Compressor::Constant); cs.to_bytes() } else { - cs.compress_chunk_with(vec, Compressor::Noop); + // Check if compressor settings were provided and use them + if let Some(_settings) = compressor_settings { + // Use the provided settings + // You may need to replace `Compressor::Noop` with an actual compressor based on the settings + cs.compress_chunk_with(&optimizer_results_f, Compressor::Noop); + } else { + // Use default settings or handle this case as needed + cs.compress_chunk_with(&optimizer_results_f, Compressor::Noop); + } cs.to_bytes() } } + /// Writes the compressed data to the specified path. fn write_compressed_data_to_path(compressed: &[u8], path: &Path) { - let mut file = - writer::create_streaming_writer(path).expect("Failed to create a streaming writer"); + let mut file = writer::create_streaming_writer(path).expect("Failed to create a streaming writer"); writer::write_data_to_stream(&mut file, compressed).expect("Failed to write compressed data"); } @@ -90,7 +105,6 @@ struct Args { /// input file input: PathBuf, - /// Processes a directory instead of a single file #[arg(short, action)] directory: bool, @@ -107,5 +121,15 @@ fn main() { env_logger::init(); let arguments = Args::parse(); debug!("{:?}", arguments); - process_args(&arguments); -} + + // Create an optional CompressorSettings based on user input + let compressor_settings = if arguments.noop { + None // Use default settings or handle this case as needed + } else { + Some(CompressorSettings { + // Define settings based on user input here + }) + }; + + process_args(&arguments, compressor_settings); +} \ No newline at end of file From 9359d8e391af9d81bba92b4a9d735cc37d2c1071 Mon Sep 17 00:00:00 2001 From: joshuabvarghese Date: Wed, 18 Oct 2023 19:29:22 +1100 Subject: [PATCH 2/2] PR conflict --- brro-compressor/src/main.rs | 6 ------ 1 file changed, 6 deletions(-) diff --git a/brro-compressor/src/main.rs b/brro-compressor/src/main.rs index c42eb05..13fd726 100644 --- a/brro-compressor/src/main.rs +++ b/brro-compressor/src/main.rs @@ -1,9 +1,3 @@ -/// The above code is a Rust program that compresses data based on user input and settings. -/// -/// Arguments: -/// -/// * `arguments`: The `arguments` parameter is a struct that contains the parsed command-line arguments. It has the following fields: -/// * `compressor_settings`: The `compressor_settings` parameter is an optional `CompressorSettings` struct that contains fields for compressor settings. It is used to customize the behavior of the compressor based on user input. If the `compressor_settings` parameter is `Some`, it means that the user has provided specific compressor settings use brro_compressor::compressor::Compressor; use brro_compressor::data::CompressedStream; use brro_compressor::optimizer;