From 78e1c2908d3f387cfcfd28c08105b5ba588bd7d0 Mon Sep 17 00:00:00 2001 From: nancy.liao <huihui.liao@greentest.com.cn> Date: 周二, 06 5月 2025 09:29:46 +0800 Subject: [PATCH] 修改了全局变量的单例化 --- libscpi/src/parser.c | 19 ++++++------------- 1 files changed, 6 insertions(+), 13 deletions(-) diff --git a/libscpi/src/parser.c b/libscpi/src/parser.c index e51eb7a..a6376cf 100644 --- a/libscpi/src/parser.c +++ b/libscpi/src/parser.c @@ -37,6 +37,7 @@ #include <ctype.h> #include <string.h> +#include "scpi/externinterface.h" #include "scpi/config.h" #include "scpi/parser.h" @@ -45,7 +46,7 @@ #include "scpi/error.h" #include "scpi/constants.h" #include "scpi/utils.h" - +#include "scpi/externinterface.h" /** * Write data to SCPI output * @param context @@ -183,21 +184,13 @@ scpi_bool_t findCommandHeader(scpi_t * context, const char * header, int len) { - int32_t i; - const scpi_command_t * cmd = NULL; - for (i = 0; i<context->cmdlistSize; i++) { - cmd = &context->cmdlist[i]; - - bool result =test_match(cmd->pattern, header); - if(result) + for(int i=0;i<get_pattern_count();i++) + { + if( match_segments_global(header,i) ) { - context->param_list.cmd = &context->cmdlist[i]; + context->param_list.cmd = &context->cmdlist[i]; return TRUE; } - // if (matchCommand(cmd->pattern, header, len, NULL, 0, 0)) { - // context->param_list.cmd = cmd; - // return TRUE; - // } } context->SCPIerror = RETURN_NotFind; return FALSE; -- Gitblit v1.9.1