diff options
author | Dennis Kobert <dennis@kobert.dev> | 2025-04-02 16:47:34 +0200 |
---|---|---|
committer | Dennis Kobert <dennis@kobert.dev> | 2025-04-02 16:49:43 +0200 |
commit | a56c2e8ab39d7247d2b4c8959c306ffa07520d01 (patch) | |
tree | 7564e8190174276e0ae78959e9512c0ee82055f3 /src/socket.rs | |
parent | eb32f2c998e1efc55edcb78899df7967bd531cc3 (diff) |
Implement etop
Diffstat (limited to 'src/socket.rs')
-rw-r--r-- | src/socket.rs | 39 |
1 files changed, 24 insertions, 15 deletions
diff --git a/src/socket.rs b/src/socket.rs index 316c662..e2ecdbf 100644 --- a/src/socket.rs +++ b/src/socket.rs @@ -35,21 +35,9 @@ impl LoggingSocketService { break; } if let Ok(pid) = line.trim().parse::<Pid>() { - if let Some(info) = self.process_info.read().unwrap().get(&pid).clone() { - socket - .write_all( - format!( - "pid: {pid} process: {}J process tree: {}J\n", - info.energy, info.tree_energy - ) - .as_bytes(), - ) - .unwrap(); - } else { - socket - .write_all(format!("Unknown pid: {pid}\n").as_bytes()) - .unwrap(); - } + socket + .write_all(self.handle_request(pid).as_bytes()) + .unwrap(); } else { socket .write_all( @@ -63,6 +51,27 @@ impl LoggingSocketService { } }); } + + fn handle_request(&self, pid: i32) -> String { + let mut output = String::new(); + use std::fmt::Write; + if pid == -1 { + for (pid, info) in self.process_info.read().unwrap().iter() { + writeln!(&mut output, "{pid},{},{}", info.energy, info.tree_energy).unwrap(); + } + writeln!(&mut output, "#",).unwrap(); + return output; + } + + if let Some(info) = self.process_info.read().unwrap().get(&pid) { + format!( + "pid: {pid} process: {}J process tree: {}J\n", + info.energy, info.tree_energy + ) + } else { + format!("Unknown pid: {pid}\n") + } + } } pub fn start_logging_socket_service( |