From 47bf9b75f6dd8c2d3c3f1fb947a16e0e055f49cf Mon Sep 17 00:00:00 2001 From: 魏曹先生 <1992414357@qq.com> Date: Thu, 22 Jan 2026 14:24:50 +0800 Subject: Add renderer system and implement status command --- src/cmd/renderers/json_renderer.rs | 44 ++++++++++++++++++++++++++++++++++++++ 1 file changed, 44 insertions(+) create mode 100644 src/cmd/renderers/json_renderer.rs (limited to 'src/cmd/renderers') diff --git a/src/cmd/renderers/json_renderer.rs b/src/cmd/renderers/json_renderer.rs new file mode 100644 index 0000000..14c1f81 --- /dev/null +++ b/src/cmd/renderers/json_renderer.rs @@ -0,0 +1,44 @@ +use serde::Serialize; +use serde_json; + +use crate::{ + cmd::{ + errors::CmdRenderError, + renderer::{JVRenderResult, JVResultRenderer}, + }, + r_print, +}; + +pub struct JVResultJsonRenderer; + +impl JVResultRenderer for JVResultJsonRenderer +where + T: Serialize + Sync, +{ + async fn render(data: &T) -> Result { + let mut r = JVRenderResult::default(); + let json_string = serde_json::to_string(data) + .map_err(|e| CmdRenderError::SerializeFailed(e.to_string()))?; + + r_print!(r, "{}", json_string); + + Ok(r) + } +} + +pub struct JVResultPrettyJsonRenderer; + +impl JVResultRenderer for JVResultPrettyJsonRenderer +where + T: Serialize + Sync, +{ + async fn render(data: &T) -> Result { + let mut r = JVRenderResult::default(); + let json_string = serde_json::to_string_pretty(data) + .map_err(|e| CmdRenderError::SerializeFailed(e.to_string()))?; + + r_print!(r, "{}", json_string); + + Ok(r) + } +} -- cgit