diff options
| author | 魏曹先生 <1992414357@qq.com> | 2026-01-23 04:49:34 +0800 |
|---|---|---|
| committer | 魏曹先生 <1992414357@qq.com> | 2026-01-23 04:49:34 +0800 |
| commit | 626536ce51975b051fea087620bc1eb7f6bc69d3 (patch) | |
| tree | b24916b22012d9b8b3b09366bca9911781e6d596 /src/renderers/json_pretty.rs | |
| parent | f607f6ac3b98d00370f613e674da7beb4c61ce58 (diff) | |
Reorganize project structure into systems and assets
Diffstat (limited to 'src/renderers/json_pretty.rs')
| -rw-r--r-- | src/renderers/json_pretty.rs | 26 |
1 files changed, 26 insertions, 0 deletions
diff --git a/src/renderers/json_pretty.rs b/src/renderers/json_pretty.rs new file mode 100644 index 0000000..a4a3ba5 --- /dev/null +++ b/src/renderers/json_pretty.rs @@ -0,0 +1,26 @@ +use serde::Serialize; + +use crate::{ + r_print, + systems::cmd::{ + errors::CmdRenderError, + renderer::{JVRenderResult, JVResultRenderer}, + }, +}; + +pub struct JVResultPrettyJsonRenderer; + +impl<T> JVResultRenderer<T> for JVResultPrettyJsonRenderer +where + T: Serialize + Sync, +{ + async fn render(data: &T) -> Result<JVRenderResult, CmdRenderError> { + 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) + } +} |
