From e8a27bb203fe2aff70390a5eca002d7438da9b0f Mon Sep 17 00:00:00 2001
From: mrDarker <mr.darker@163.com>
Date: 星期三, 22 十月 2025 14:24:34 +0800
Subject: [PATCH] Merge branch 'clh' into liuyang

---
 SourceCode/Bond/BondEq/RegexEdit.cpp |   28 ++++++++++++++++++++++++++++
 1 files changed, 28 insertions(+), 0 deletions(-)

diff --git a/SourceCode/Bond/BondEq/RegexEdit.cpp b/SourceCode/Bond/BondEq/RegexEdit.cpp
index f3943e1..eaf8879 100644
--- a/SourceCode/Bond/BondEq/RegexEdit.cpp
+++ b/SourceCode/Bond/BondEq/RegexEdit.cpp
@@ -41,6 +41,34 @@
     m_invalidInputCallback = callback;
 }
 
+bool CRegexEdit::FindMatch(const std::string& pattern, std::string& foundText)
+{
+    CString currentText;
+    GetWindowText(currentText);
+
+    std::string text(CT2A(currentText.GetString()));
+    std::regex regexPattern(pattern);
+    std::smatch match;
+
+    if (std::regex_search(text, match, regexPattern)) {
+        foundText = match.str();
+        return true;
+    }
+    return false;
+}
+
+void CRegexEdit::ReplaceMatch(const std::string& pattern, const std::string& replacement)
+{
+    CString currentText;
+    GetWindowText(currentText);
+
+    std::string text(CT2A(currentText.GetString()));
+    std::regex regexPattern(pattern);
+    std::string result = std::regex_replace(text, regexPattern, replacement);
+
+    SetWindowText(CString(result.c_str()));
+}
+
 std::regex CRegexEdit::GetCurrentRegex() const
 {
     switch (m_enRegexType)

--
Gitblit v1.9.3