diff --git a/src/uu/lsmem/src/lsmem.rs b/src/uu/lsmem/src/lsmem.rs index da309a1..6e36085 100644 --- a/src/uu/lsmem/src/lsmem.rs +++ b/src/uu/lsmem/src/lsmem.rs @@ -32,6 +32,7 @@ mod options { pub const NOHEADINGS: &str = "noheadings"; pub const JSON: &str = "json"; pub const PAIRS: &str = "pairs"; + pub const RAW: &str = "raw"; } // const BUFSIZ: usize = 1024; @@ -220,6 +221,12 @@ impl TableRow { self.range, self.size, self.state, self.removable, self.block ) } + fn to_raw_string(&self) -> String { + format!( + r#"{} {} {} {} {}"#, + self.range, self.size, self.state, self.removable, self.block + ) + } } #[derive(Serialize)] @@ -229,11 +236,10 @@ struct TableRowJson { struct Options { have_nodes: bool, - // raw: bool, + raw: bool, export: bool, json: bool, noheadings: bool, - // summary: bool, list_all: bool, bytes: bool, want_summary: bool, @@ -273,11 +279,10 @@ impl Options { fn new() -> Options { Options { have_nodes: false, - // raw: false, + raw: false, export: false, json: false, noheadings: false, - // summary: false, list_all: false, bytes: false, want_summary: true, // default true @@ -526,6 +531,18 @@ fn print_pairs(lsmem: &Lsmem, opts: &Options) { println!("{table_pairs_string}"); } +fn print_raw(lsmem: &Lsmem, opts: &Options) { + let table_rows = create_table_rows(lsmem, opts); + let mut table_raw_string = String::new(); + for row in table_rows { + table_raw_string += &row.to_raw_string(); + table_raw_string += "\n"; + } + // remove the last newline + table_raw_string.pop(); + println!("{table_raw_string}"); +} + fn print_summary(lsmem: &Lsmem, opts: &Options) { if opts.bytes { println!("{:<23} {:>15}", "Memory block size:", lsmem.block_size); @@ -571,8 +588,9 @@ pub fn uumain(args: impl uucore::Args) -> UResult<()> { opts.noheadings = matches.get_flag(options::NOHEADINGS); opts.json = matches.get_flag(options::JSON); opts.export = matches.get_flag(options::PAIRS); + opts.raw = matches.get_flag(options::RAW); - if opts.json || opts.export { + if opts.json || opts.export || opts.raw { opts.want_summary = false; } @@ -583,6 +601,8 @@ pub fn uumain(args: impl uucore::Args) -> UResult<()> { print_json(&lsmem, &opts); } else if opts.export { print_pairs(&lsmem, &opts); + } else if opts.raw { + print_raw(&lsmem, &opts); } else { print_table(&lsmem, &opts); } @@ -629,4 +649,11 @@ pub fn uu_app() -> Command { .help("use key=\"value\" output format") .action(ArgAction::SetTrue), ) + .arg( + Arg::new(options::RAW) + .short('r') + .long("raw") + .help("use raw output format") + .action(ArgAction::SetTrue), + ) }