5 Commits

3 changed files with 61 additions and 40 deletions

2
Cargo.lock generated
View File

@@ -4,4 +4,4 @@ version = 4
[[package]] [[package]]
name = "dbus-prettifier" name = "dbus-prettifier"
version = "1.1.0" version = "1.2.0"

View File

@@ -1,6 +1,6 @@
[package] [package]
name = "dbus-prettifier" name = "dbus-prettifier"
version = "1.1.0" version = "1.2.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."

View File

@@ -1,13 +1,34 @@
/*
* Copyright (C) 2025 Nicolás Ortega Froysa <nicolas@ortegas.org> All rights reserved.
* Author: Nicolás Ortega Froysa <nicolas@ortegas.org>
*
* This software is provided 'as-is', without any express or implied
* warranty. In no event will the authors be held liable for any damages
* arising from the use of this software.
*
* Permission is granted to anyone to use this software for any purpose,
* including commercial applications, and to alter it and redistribute it
* freely, subject to the following restrictions:
*
* 1. The origin of this software must not be misrepresented; you must not
* claim that you wrote the original software. If you use this software
* in a product, an acknowledgment in the product documentation would be
* appreciated but is not required.
*
* 2. Altered source versions must be plainly marked as such, and must not be
* misrepresented as being the original software.
*
* 3. This notice may not be removed or altered from any source
* distribution.
*/
use std::io; use std::io;
use std::fs; use std::fs;
use std::io::Read; use std::io::Read;
use std::boxed::Box; use std::boxed::Box;
// Read 1KiB of the file at a time.
static BLOCK_SIZE:usize = 1024;
pub fn work(in_path:Option<&str>, out_path:Option<&str>) -> Result<(), String> { 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 in_reader:Box<dyn io::Read> = match in_path {
Some(path) => { Some(path) => {
let in_file = fs::File::open(path); let in_file = fs::File::open(path);
if let Err(e) = in_file { if let Err(e) = in_file {
@@ -33,17 +54,15 @@ pub fn work(in_path:Option<&str>, out_path:Option<&str>) -> Result<(), String>
}, },
}; };
let mut read_buf:[u8; BLOCK_SIZE] = [0; BLOCK_SIZE]; let mut last_ch = '\0';
let mut last_ch:char = '\0';
let mut tab_num = 0; let mut tab_num = 0;
while in_reader.read(&mut read_buf).unwrap() > 0 { for i in in_reader.bytes() {
for i in read_buf { let ch = i.unwrap() 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()).unwrap(); out_writer.write(format!("{ch}\n").as_bytes()).unwrap();
for _ in 0..tab_num { for _ in 0..tab_num {
out_writer.write(b" ").unwrap(); out_writer.write(b" ").unwrap();
} }
@@ -55,27 +74,29 @@ pub fn work(in_path:Option<&str>, out_path:Option<&str>) -> Result<(), String>
for _ in 0..tab_num { for _ in 0..tab_num {
out_writer.write(b" ").unwrap(); out_writer.write(b" ").unwrap();
} }
out_writer.write(format!("{}", ch).as_bytes()).unwrap(); out_writer.write(format!("{ch}").as_bytes()).unwrap();
last_ch = ch; last_ch = ch;
}, },
',' => { ',' => {
out_writer.write(format!("{}\n", ch).as_bytes()).unwrap(); out_writer.write(format!("{ch}").as_bytes()).unwrap();
if last_ch == '}' || last_ch == ']' {
out_writer.write(b"\n").unwrap();
for _ in 0..tab_num { for _ in 0..tab_num {
out_writer.write(b" ").unwrap(); out_writer.write(b" ").unwrap();
} }
last_ch = ' '; last_ch = ' ';
} else {
last_ch = ch;
}
}, },
_ => { _ => {
if ch != ' ' || last_ch != ' ' { if ch != ' ' || last_ch != ' ' {
out_writer.write(format!("{}", ch).as_bytes()).unwrap(); out_writer.write(format!("{ch}").as_bytes()).unwrap();
last_ch = ch; last_ch = ch;
} }
}, },
} }
} }
}
out_writer.flush().unwrap();
Ok(()) Ok(())
} }