Compare commits
4 Commits
Author | SHA1 | Date | |
---|---|---|---|
b90c5f5f54 | |||
2ede3db3b8 | |||
54e4c065ca | |||
2a1adb048e |
2
Cargo.lock
generated
2
Cargo.lock
generated
@@ -4,4 +4,4 @@ version = 4
|
|||||||
|
|
||||||
[[package]]
|
[[package]]
|
||||||
name = "dbus-prettifier"
|
name = "dbus-prettifier"
|
||||||
version = "1.0.0"
|
version = "1.1.0"
|
||||||
|
@@ -1,6 +1,6 @@
|
|||||||
[package]
|
[package]
|
||||||
name = "dbus-prettifier"
|
name = "dbus-prettifier"
|
||||||
version = "1.0.0"
|
version = "1.1.0"
|
||||||
edition = "2024"
|
edition = "2024"
|
||||||
authors = [ "Nicolás A. Ortega Froysa <nicolas@ortegas.org>" ]
|
authors = [ "Nicolás A. Ortega Froysa <nicolas@ortegas.org>" ]
|
||||||
description = "A tool to prettify the output of qdbus."
|
description = "A tool to prettify the output of qdbus."
|
||||||
|
15
src/main.rs
15
src/main.rs
@@ -23,7 +23,6 @@
|
|||||||
*/
|
*/
|
||||||
|
|
||||||
use std::env;
|
use std::env;
|
||||||
use std::io;
|
|
||||||
use std::process;
|
use std::process;
|
||||||
|
|
||||||
use crate::worker::work;
|
use crate::worker::work;
|
||||||
@@ -52,7 +51,7 @@ fn print_help() {
|
|||||||
env!("CARGO_PKG_NAME"), env!("CARGO_PKG_NAME"));
|
env!("CARGO_PKG_NAME"), env!("CARGO_PKG_NAME"));
|
||||||
}
|
}
|
||||||
|
|
||||||
fn main() -> io::Result<()> {
|
fn main() {
|
||||||
let args:Vec<String> = env::args().collect();
|
let args:Vec<String> = env::args().collect();
|
||||||
let mut in_path:Option<&str> = None;
|
let mut in_path:Option<&str> = None;
|
||||||
let mut out_path:Option<&str> = None;
|
let mut out_path:Option<&str> = None;
|
||||||
@@ -63,13 +62,13 @@ fn main() -> io::Result<()> {
|
|||||||
process::exit(1);
|
process::exit(1);
|
||||||
}
|
}
|
||||||
|
|
||||||
for i in &args {
|
for i in &args[1..args.len()] {
|
||||||
if i == "-h" {
|
if i == "-h" {
|
||||||
print_help();
|
print_help();
|
||||||
return Ok(());
|
return;
|
||||||
} else if i == "-v" {
|
} else if i == "-v" {
|
||||||
print_version();
|
print_version();
|
||||||
return Ok(());
|
return;
|
||||||
} else if i.starts_with("-") && i != "-" {
|
} else if i.starts_with("-") && i != "-" {
|
||||||
eprintln!("Invalid argument '{}'. Use -h for help information.", i);
|
eprintln!("Invalid argument '{}'. Use -h for help information.", i);
|
||||||
process::exit(1);
|
process::exit(1);
|
||||||
@@ -83,5 +82,9 @@ fn main() -> io::Result<()> {
|
|||||||
out_path = Some(args[2].as_str());
|
out_path = Some(args[2].as_str());
|
||||||
}
|
}
|
||||||
|
|
||||||
work(in_path, out_path)
|
let res = work(in_path, out_path);
|
||||||
|
if let Err(err) = res {
|
||||||
|
eprintln!("{}", err);
|
||||||
|
process::exit(1);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
@@ -6,11 +6,14 @@ use std::boxed::Box;
|
|||||||
// Read 1KiB of the file at a time.
|
// Read 1KiB of the file at a time.
|
||||||
static BLOCK_SIZE:usize = 1024;
|
static BLOCK_SIZE:usize = 1024;
|
||||||
|
|
||||||
pub fn work(in_path:Option<&str>, out_path:Option<&str>) -> io::Result<()> {
|
pub fn work(in_path:Option<&str>, out_path:Option<&str>) -> Result<(), String> {
|
||||||
let mut in_reader:Box<dyn io::Read> = match in_path {
|
let mut in_reader:Box<dyn io::Read> = match in_path {
|
||||||
Some(x) => {
|
Some(path) => {
|
||||||
let in_file = fs::File::open(x)?;
|
let in_file = fs::File::open(path);
|
||||||
Box::new(io::BufReader::new(in_file))
|
if let Err(e) = in_file {
|
||||||
|
return Err(format!("{path}: {e}"));
|
||||||
|
}
|
||||||
|
Box::new(io::BufReader::new(in_file.unwrap()))
|
||||||
},
|
},
|
||||||
None => {
|
None => {
|
||||||
Box::new(io::stdin())
|
Box::new(io::stdin())
|
||||||
@@ -18,9 +21,12 @@ pub fn work(in_path:Option<&str>, out_path:Option<&str>) -> io::Result<()> {
|
|||||||
};
|
};
|
||||||
|
|
||||||
let mut out_writer:Box<dyn io::Write> = match out_path {
|
let mut out_writer:Box<dyn io::Write> = match out_path {
|
||||||
Some(x) => {
|
Some(path) => {
|
||||||
let out_file = fs::File::create(x)?;
|
let out_file = fs::File::create(path);
|
||||||
Box::new(io::BufWriter::new(out_file))
|
if let Err(e) = out_file {
|
||||||
|
return Err(format!("{path}: {e}"));
|
||||||
|
}
|
||||||
|
Box::new(io::BufWriter::new(out_file.unwrap()))
|
||||||
},
|
},
|
||||||
None => {
|
None => {
|
||||||
Box::new(io::stdout())
|
Box::new(io::stdout())
|
||||||
@@ -31,38 +37,37 @@ pub fn work(in_path:Option<&str>, out_path:Option<&str>) -> io::Result<()> {
|
|||||||
let mut last_ch:char = '\0';
|
let mut last_ch:char = '\0';
|
||||||
let mut tab_num = 0;
|
let mut tab_num = 0;
|
||||||
|
|
||||||
while in_reader.read(&mut read_buf)? > 0 {
|
while in_reader.read(&mut read_buf).unwrap() > 0 {
|
||||||
for i in read_buf {
|
for i in read_buf {
|
||||||
let ch = i as char;
|
let ch = i as char;
|
||||||
match ch {
|
match ch {
|
||||||
'[' | '{' => {
|
'[' | '{' => {
|
||||||
tab_num += 1;
|
tab_num += 1;
|
||||||
out_writer.write(format!("{}\n", ch).as_bytes())?;
|
out_writer.write(format!("{}\n", ch).as_bytes()).unwrap();
|
||||||
for _ in 0..tab_num {
|
for _ in 0..tab_num {
|
||||||
out_writer.write(b" ")?;
|
out_writer.write(b" ").unwrap();
|
||||||
}
|
}
|
||||||
last_ch = ' ';
|
last_ch = ' ';
|
||||||
},
|
},
|
||||||
']' | '}' => {
|
']' | '}' => {
|
||||||
tab_num -= 1;
|
tab_num -= 1;
|
||||||
out_writer.write(b"\n")?;
|
out_writer.write(b"\n").unwrap();
|
||||||
for _ in 0..tab_num {
|
for _ in 0..tab_num {
|
||||||
out_writer.write(b" ")?;
|
out_writer.write(b" ").unwrap();
|
||||||
}
|
}
|
||||||
out_writer.write(format!("{}", ch).as_bytes())?;
|
out_writer.write(format!("{}", ch).as_bytes()).unwrap();
|
||||||
last_ch = ch;
|
last_ch = ch;
|
||||||
},
|
},
|
||||||
',' => {
|
',' => {
|
||||||
out_writer.write(format!("{}\n", ch).as_bytes())?;
|
out_writer.write(format!("{}\n", ch).as_bytes()).unwrap();
|
||||||
for _ in 0..tab_num {
|
for _ in 0..tab_num {
|
||||||
out_writer.write(b" ")?;
|
out_writer.write(b" ").unwrap();
|
||||||
}
|
}
|
||||||
last_ch = ' ';
|
last_ch = ' ';
|
||||||
},
|
},
|
||||||
_ => {
|
_ => {
|
||||||
let ch = ch;
|
|
||||||
if ch != ' ' || last_ch != ' ' {
|
if ch != ' ' || last_ch != ' ' {
|
||||||
out_writer.write(format!("{}", ch).as_bytes())?;
|
out_writer.write(format!("{}", ch).as_bytes()).unwrap();
|
||||||
last_ch = ch;
|
last_ch = ch;
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
@@ -70,8 +75,7 @@ pub fn work(in_path:Option<&str>, out_path:Option<&str>) -> io::Result<()> {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
out_writer.flush()?;
|
out_writer.flush().unwrap();
|
||||||
|
|
||||||
Ok(())
|
Ok(())
|
||||||
|
|
||||||
}
|
}
|
||||||
|
Reference in New Issue
Block a user