From fc02ccdf50754990420b4a5d327088ecaad5b608 Mon Sep 17 00:00:00 2001 From: benluiwj Date: Sun, 1 Dec 2024 17:03:27 +0800 Subject: [PATCH] add diff wrapper --- check_diff/src/lib.rs | 35 ++++++++++++++++++++++++++--------- 1 file changed, 26 insertions(+), 9 deletions(-) diff --git a/check_diff/src/lib.rs b/check_diff/src/lib.rs index d3f1dfa7278..812f40ff2ba 100644 --- a/check_diff/src/lib.rs +++ b/check_diff/src/lib.rs @@ -1,6 +1,6 @@ -use diffy; +use diffy::{self}; use std::env; -use std::fmt::Debug; +use std::fmt::{Debug, Display}; use std::io::{self, Write}; use std::path::{Path, PathBuf}; use std::process::{Command, Stdio}; @@ -61,6 +61,25 @@ impl From for GitError { } } +pub struct Diff { + src_format: String, + feature_format: String, +} + +impl Display for Diff { + fn fmt(&self, f: &mut std::fmt::Formatter<'_>) -> std::fmt::Result { + let patch = diffy::create_patch(self.src_format.as_str(), self.feature_format.as_str()); + write!(f, "{}", patch) + } +} + +impl Diff { + pub fn is_empty(&self) -> bool { + let patch = diffy::create_patch(self.src_format.as_str(), self.feature_format.as_str()); + patch.hunks().is_empty() + } +} + // will be used in future PRs, just added to make the compiler happy pub struct CheckDiffRunners { pub feature_runner: RustfmtRunner, @@ -78,16 +97,14 @@ impl CheckDiffRunners { &self, path: &Path, additional_configs: &Option>, - ) -> Result { + ) -> Result { let code = std::fs::read_to_string(path)?; let src_format = self.src_runner.format_code(&code, additional_configs)?; let feature_format = self.feature_runner.format_code(&code, additional_configs)?; - let diff = diffy::create_patch(src_format.as_str(), feature_format.as_str()); - if diff.hunks().is_empty() { - Ok(String::new()) - } else { - Ok(format!("{diff}")) - } + Ok(Diff { + src_format, + feature_format, + }) } }