diff options
| author | 魏曹先生 <1992414357@qq.com> | 2026-02-25 14:42:25 +0800 |
|---|---|---|
| committer | 魏曹先生 <1992414357@qq.com> | 2026-02-25 14:42:25 +0800 |
| commit | 1fc71c37623fb7d8c42930b1cc1e350bf4bf53b9 (patch) | |
| tree | 1cb312bd411d0dac223ba046f2f8db963cf3a6f9 /src/cmds/override | |
| parent | d1b99a4d72b60ca6a1ed9ab5f8f6d38c23e038ac (diff) | |
Add RON, TOML, and YAML renderers for override command
Diffstat (limited to 'src/cmds/override')
| -rw-r--r-- | src/cmds/override/renderer/ron.rs | 17 | ||||
| -rw-r--r-- | src/cmds/override/renderer/ron_pretty.rs | 20 | ||||
| -rw-r--r-- | src/cmds/override/renderer/toml.rs | 16 | ||||
| -rw-r--r-- | src/cmds/override/renderer/yaml.rs | 16 |
4 files changed, 69 insertions, 0 deletions
diff --git a/src/cmds/override/renderer/ron.rs b/src/cmds/override/renderer/ron.rs new file mode 100644 index 0000000..8cd0bbd --- /dev/null +++ b/src/cmds/override/renderer/ron.rs @@ -0,0 +1,17 @@ +use serde::Serialize; + +use crate::{ + r_print, + systems::{cmd::errors::CmdRenderError, render::renderer::JVRenderResult}, +}; + +pub async fn render<T: Serialize + Send>(data: &T) -> Result<JVRenderResult, CmdRenderError> { + let mut r = JVRenderResult::default(); + + let ron_string = + ron::ser::to_string(data).map_err(|e| CmdRenderError::SerializeFailed(e.to_string()))?; + + r_print!(r, "{}", ron_string); + + Ok(r) +} diff --git a/src/cmds/override/renderer/ron_pretty.rs b/src/cmds/override/renderer/ron_pretty.rs new file mode 100644 index 0000000..cd6b7d5 --- /dev/null +++ b/src/cmds/override/renderer/ron_pretty.rs @@ -0,0 +1,20 @@ +use serde::Serialize; + +use crate::{ + r_print, + systems::{cmd::errors::CmdRenderError, render::renderer::JVRenderResult}, +}; + +pub async fn render<T: Serialize + Send>(data: &T) -> Result<JVRenderResult, CmdRenderError> { + let mut r = JVRenderResult::default(); + let mut pretty_config = ron::ser::PrettyConfig::new(); + pretty_config.new_line = std::borrow::Cow::from("\n"); + pretty_config.indentor = std::borrow::Cow::from(" "); + + let ron_string = ron::ser::to_string_pretty(data, pretty_config) + .map_err(|e| CmdRenderError::SerializeFailed(e.to_string()))?; + + r_print!(r, "{}", ron_string); + + Ok(r) +} diff --git a/src/cmds/override/renderer/toml.rs b/src/cmds/override/renderer/toml.rs new file mode 100644 index 0000000..83de042 --- /dev/null +++ b/src/cmds/override/renderer/toml.rs @@ -0,0 +1,16 @@ +use serde::Serialize; + +use crate::{ + r_print, + systems::{cmd::errors::CmdRenderError, render::renderer::JVRenderResult}, +}; + +pub async fn render<T: Serialize + Send>(data: &T) -> Result<JVRenderResult, CmdRenderError> { + let mut r = JVRenderResult::default(); + let toml_string = + toml::to_string(data).map_err(|e| CmdRenderError::SerializeFailed(e.to_string()))?; + + r_print!(r, "{}", toml_string); + + Ok(r) +} diff --git a/src/cmds/override/renderer/yaml.rs b/src/cmds/override/renderer/yaml.rs new file mode 100644 index 0000000..a496fe7 --- /dev/null +++ b/src/cmds/override/renderer/yaml.rs @@ -0,0 +1,16 @@ +use serde::Serialize; + +use crate::{ + r_print, + systems::{cmd::errors::CmdRenderError, render::renderer::JVRenderResult}, +}; + +pub async fn render<T: Serialize + Send>(data: &T) -> Result<JVRenderResult, CmdRenderError> { + let mut r = JVRenderResult::default(); + let yaml_string = + serde_yaml::to_string(data).map_err(|e| CmdRenderError::SerializeFailed(e.to_string()))?; + + r_print!(r, "{}", yaml_string); + + Ok(r) +} |
