From 1e139e410744eb791486dcee0ed4b1eebdf9a515 Mon Sep 17 00:00:00 2001
From: nancy.liao <huihui.liao@greentest.com.cn>
Date: 周四, 24 4月 2025 09:32:54 +0800
Subject: [PATCH] 提交修改

---
 libscpi/src/utils.c |  195 +++++++++++++++++++-----------------------------
 1 files changed, 77 insertions(+), 118 deletions(-)

diff --git a/libscpi/src/utils.c b/libscpi/src/utils.c
index afb6664..8758917 100644
--- a/libscpi/src/utils.c
+++ b/libscpi/src/utils.c
@@ -1146,139 +1146,98 @@
 }
 
 
-// 瑙f瀽妯″紡锛屽皢姣忎釜閮ㄥ垎淇濆瓨鍒� segments 涓�
-int parse_pattern(const char* pattern, Segment segments[], int max_segments) {
-    int seg_count = 0;
-    const char* p = pattern;
+// 鐢ㄤ簬鎻愬彇骞跺鐞嗛�夐」鐨勫嚱鏁�
+int extract_required_options(const char* pattern, char options[MAX_TAGS][MAX_OPTION_LEN][MAX_OPTION_LEN], int max_tags) {
+    const char* start = strchr(pattern, '<');  // 鏌ユ壘绗竴涓� '<'
+    const char* end = NULL;
+    int tag_count = 0;
 
-    while (*p && seg_count < max_segments) {
-        if (*p == '[') {
-            // 澶勭悊鍙彉娈碉紙[]锛�
-            segments[seg_count].is_variable = TRUE;
-            segments[seg_count].is_required = FALSE;  // []鏄彲閫夌殑
-            segments[seg_count].is_option = FALSE;
-            p++;  // 璺宠繃'['
+    // 澶勭悊 <...> 鍐呯殑閫夐」
+    while (start != NULL && tag_count < max_tags)
+    {
+        end = strchr(start, '>');  // 鏌ユ壘瀵瑰簲鐨� '>'
 
-            int i = 0;
-            while (*p && *p != ']' && i < sizeof(segments[seg_count].text) - 1) {
-                segments[seg_count].text[i++] = toupper(*p++);
-            }
-            segments[seg_count].text[i] = '\0';  // 缁撴潫绗�
-
-            if (*p == ']') {
-                p++;  // 璺宠繃']'
-            }
-        }
-        else if (*p == '<') {
-            // 澶勭悊蹇呴�夋锛�<>锛�
-            segments[seg_count].is_variable = TRUE;
-            segments[seg_count].is_required = TRUE;  // <>鏄繀閫夌殑
-            segments[seg_count].is_option = FALSE;
-            p++;  // 璺宠繃'<'
-
-            int i = 0;
-            while (*p && *p != '>' && i < sizeof(segments[seg_count].text) - 1) {
-                segments[seg_count].text[i++] = toupper(*p++);
-            }
-            segments[seg_count].text[i] = '\0';  // 缁撴潫绗�
-
-            if (*p == '>') {
-                p++;  // 璺宠繃'>'
-            }
-        }
-        else if (*p == '|') {
-            // 澶勭悊绔栫嚎鍒嗛殧鐨勫閫夐儴鍒嗭紙|锛�
-            segments[seg_count].is_variable = TRUE;
-            segments[seg_count].is_required = TRUE;  // 閫夐」鏄繀閫夌殑
-            segments[seg_count].is_option = TRUE;   // 杩欒〃绀洪�夐」缁�
-            p++;  // 璺宠繃'|'
-
-            int i = 0;
-            while (*p && *p != '|' && *p != '>' && *p != '[' && *p != ']' && i < sizeof(segments[seg_count].text) - 1) {
-                segments[seg_count].text[i++] = toupper(*p++);
-            }
-            segments[seg_count].text[i] = '\0';  // 缁撴潫绗�
-
-            // 璺宠繃'|'缁х画澶勭悊涓嬩竴涓�夐」
-            if (*p == '|') {
-                p++;  // 璺宠繃'|'
-            }
-        }
-        else {
-            // 澶勭悊鍥哄畾娈�
-            segments[seg_count].is_variable = FALSE;
-            segments[seg_count].is_required = TRUE;  // 鍥哄畾娈靛繀閫�
-            segments[seg_count].is_option = FALSE;
-            int i = 0;
-            while (*p && *p != '[' && *p != '<' && *p != '|' && *p != ':' && i < sizeof(segments[seg_count].text) - 1) {
-                segments[seg_count].text[i++] = toupper(*p++);
-            }
-            segments[seg_count].text[i] = '\0';  // 缁撴潫绗�
+        if (end == NULL) {
+            break;  // 濡傛灉娌℃湁鎵惧埌 '>'锛屽垯閫�鍑�
         }
 
-        seg_count++;
-    }
+        // 鎻愬彇 <...> 涓殑鍐呭
+        int len = end - start - 1;
+        if (len > 0 && len < MAX_OPTION_LEN) {
+            char buffer[MAX_OPTION_LEN];
+            strncpy(buffer, start + 1, len);  // 澶嶅埗 '<' 鍜� '>' 涔嬮棿鐨勫唴瀹�
+            buffer[len] = '\0';  // 缁撴潫绗�
 
-    return seg_count;
-}
+            // 澶勭悊 | 鍒嗛殧绗︼紝鎻愬彇澶氫釜閫夐」
+            char* token = strtok(buffer, "|");
+            int option_count = 0;
+            while (token && option_count < MAX_OPTION_LEN) {
+                // 鍘婚櫎 token 涓殑 "[:", "]" 鍜岀┖鏍�
+                char* p = token;
+                while (*p == ' ' || *p == '[' || *p == ':') p++;  // 鍘婚櫎鍓嶅绌烘牸鍜� [:
+                char* q = p + strlen(p) - 1;
+                while (q > p && (*q == ' ' || *q == ']')) q--;  // 鍘婚櫎灏鹃殢绌烘牸鍜� ]
+                *(q + 1) = '\0';  // 纭繚缁撳熬鏄�'\0'
 
-// 鍖归厤鍛戒护瀛楃涓叉槸鍚︾鍚堟ā寮�
-bool match_command(const char* command, Segment segments[], int seg_count) {
-    const char* cmd = command;
-    int current_seg = 0;
-
-    while (*cmd && current_seg < seg_count) {
-        // 鎸夊啋鍙峰垎闅斿懡浠�
-        if (*cmd == ':') {
-            cmd++;  // 璺宠繃鍒嗛殧绗�
-            continue;
-        }
-
-        size_t seg_len = strlen(segments[current_seg].text);
-
-        if (segments[current_seg].is_variable) {
-            // 鍙彉娈� - 璺宠繃瀵瑰簲闀垮害鐨勫瓧绗�
-            int i = 0;
-            while (*cmd && *cmd != ':' && i < seg_len) {
-                cmd++;
-                i++;
-            }
-        }
-        else if (segments[current_seg].is_option) {
-            // 閫夐」缁� - 蹇呴』鍖归厤鍏朵腑涓�涓�夐」
-            bool matched = FALSE;
-            const char* options[] = { segments[current_seg].text, NULL };
-            for (int i = 0; options[i]; i++) {
-                if (strncasecmp(cmd, options[i], strlen(options[i])) == 0) {
-                    matched = TRUE;
-                    break;
+                // 鎷疯礉閫夐」鍒� options 鏁扮粍
+                if (option_count < MAX_OPTION_LEN) {  // 纭繚涓嶄細瓒婄晫
+                    strncpy(options[tag_count][option_count], p, MAX_OPTION_LEN - 1);
+                    options[tag_count][option_count][MAX_OPTION_LEN - 1] = '\0';  // 纭繚缁撴潫绗�
+                    option_count++;
                 }
+                token = strtok(NULL, "|");
             }
-            if (!matched) {
-                return FALSE;
-            }
-            cmd += strlen(options[0]);
-        }
-        else {
-            // 鍥哄畾娈� - 蹇呴』绮剧‘鍖归厤
-            if (strncasecmp(cmd, segments[current_seg].text, seg_len) != 0) {
-                return FALSE;
-            }
-            cmd += seg_len;  // 璺宠繃鍖归厤鐨勯儴鍒�
         }
 
-        current_seg++;
+        // 绉诲姩鍒颁笅涓�涓� '<' 浣嶇疆锛岀户缁煡鎵�
+        start = strchr(end + 1, '<');
+        tag_count++;
     }
 
-    // 妫�鏌ユ槸鍚﹀鐞嗗畬鎵�鏈夊懡浠ゅ拰鎵�鏈夋
-    return (*cmd == '\0') && (current_seg == seg_count);
+    return tag_count;
 }
+
+// 鐢ㄤ簬妫�鏌ヨ緭鍏ユ槸鍚﹁兘鍖归厤姣忎竴缁勯�夐」
+int match_input_to_options(const char* input, char options[MAX_TAGS][MAX_OPTION_LEN][MAX_OPTION_LEN], int num_tags) {
+    char input_copy[MAX_INPUT_LEN];
+    strncpy(input_copy, input, MAX_INPUT_LEN - 1);
+    input_copy[MAX_INPUT_LEN - 1] = '\0';  // 纭繚缁撳熬鏄�'\0'
+
+    // 鎷嗗垎杈撳叆瀛楃涓诧紝鎸� ":" 鍒嗗壊
+    char* token = strtok(input_copy, ":");
+    int group_idx = 0;
+
+    // 瀵规瘡涓�缁勮繘琛屽尮閰�
+    while (token != NULL && group_idx < num_tags) {
+        int match_found = 0;
+        // 妫�鏌ュ綋鍓嶇粍鐨勬瘡涓�夐」鏄惁涓庤緭鍏ョ殑 token 鍖归厤
+        printf("Checking input token: '%s' against group %d options\n", token, group_idx + 1); // Debug info
+        for (int i = 0; i < MAX_OPTION_LEN && options[group_idx][i][0] != '\0'; i++) {
+            printf("  Comparing with option: '%s'\n", options[group_idx][i]); // Debug info
+            if (strcmp(options[group_idx][i], token) == 0) {
+                match_found = 1;
+                break;
+            }
+        }
+
+        // 濡傛灉褰撳墠缁勭殑鏌愪釜閫夐」娌℃湁鍖归厤涓婏紝杩斿洖 false
+        if (!match_found) {
+            return 0;  // 涓嶅尮閰�
+        }
+
+        // 澶勭悊涓嬩竴涓緭鍏ラ儴鍒�
+        token = strtok(NULL, ":");
+        group_idx++;
+    }
+
+    return (group_idx == num_tags);
+}
+
 
 // 娴嬭瘯鍖归厤鍑芥暟
 bool test_match(const char* pattern, const char* command)
 {
-
-    Segment segments[MAX_SEGMENTS];
-    int seg_count = parse_pattern(pattern, segments, MAX_SEGMENTS);
-    return match_command(command, segments, seg_count);
+    char options[MAX_TAGS][MAX_OPTION_LEN][MAX_OPTION_LEN] = { {{0}} };
+    int num_tags = extract_required_options(pattern, options, MAX_TAGS);
+    return match_input_to_options(command, options, num_tags);
 }

--
Gitblit v1.9.1