From d19e5d84ee21502fd3440511d4ffb1ee1f49d3b2 Mon Sep 17 00:00:00 2001 From: 魏曹先生 <1992414357@qq.com> Date: Wed, 4 Feb 2026 00:27:16 +0800 Subject: Refactor build system and implement complete renderer system - Split monolithic build.rs into modular async generators - Add renderer override system with type-safe dispatch - Implement command template macro for consistent command definitions - Add proc-macro crates for command and renderer systems - Reorganize directory structure for better separation of concerns - Update documentation to reflect new architecture --- src/cmds/renderer/status.rs | 32 ++++++++++++++------------------ 1 file changed, 14 insertions(+), 18 deletions(-) (limited to 'src/cmds/renderer/status.rs') diff --git a/src/cmds/renderer/status.rs b/src/cmds/renderer/status.rs index 965ff87..573e74e 100644 --- a/src/cmds/renderer/status.rs +++ b/src/cmds/renderer/status.rs @@ -2,40 +2,36 @@ use cli_utils::{ display::{SimpleTable, md}, env::auto_update_outdate, }; +use render_system_macros::result_renderer; use rust_i18n::t; +use crate::cmds::out::status::JVStatusWrongModifyReason; use crate::{ - cmds::out::status::{JVStatusOutput, JVStatusWrongModifyReason}, + cmds::out::status::JVStatusOutput, r_println, - systems::cmd::{ - errors::CmdRenderError, - renderer::{JVRenderResult, JVResultRenderer}, - }, + systems::{cmd::errors::CmdRenderError, render::renderer::JVRenderResult}, }; -pub struct JVStatusRenderer; - enum Mode { StructuralChangesMode, ContentChangesMode, Clean, } -impl JVResultRenderer for JVStatusRenderer { - async fn render(data: &JVStatusOutput) -> Result { - let mut r = JVRenderResult::default(); +#[result_renderer(JVStatusRenderer)] +pub async fn render(data: &JVStatusOutput) -> Result { + let mut r = JVRenderResult::default(); - // Render Header - render_header(&mut r, data); + // Render Header + render_header(&mut r, data); - // Render Info and Mode - render_info_and_mode(&mut r, data); + // Render Info and Mode + render_info_and_mode(&mut r, data); - // Render Hint - render_hint(&mut r, data); + // Render Hint + render_hint(&mut r, data); - Ok(r) - } + Ok(r) } fn render_header(r: &mut JVRenderResult, data: &JVStatusOutput) { -- cgit