From 4cd8a68a0ed6a5714fb05c51dde8c9da814a5731 Mon Sep 17 00:00:00 2001 From: Jan Breuer <jan.breuer@jaybee.cz> Date: 周二, 18 6月 2013 22:44:55 +0800 Subject: [PATCH] Update to master --- libscpi/src/parser.c | 104 +-------------------------------------------------- 1 files changed, 3 insertions(+), 101 deletions(-) diff --git a/libscpi/src/parser.c b/libscpi/src/parser.c index df73700..d10cfe1 100644 --- a/libscpi/src/parser.c +++ b/libscpi/src/parser.c @@ -44,14 +44,11 @@ #include "scpi/error.h" -static size_t patternSeparatorPos(const char * pattern, size_t len); -static size_t cmdSeparatorPos(const char * cmd, size_t len); static size_t cmdTerminatorPos(const char * cmd, size_t len); static size_t cmdlineSeparatorPos(const char * cmd, size_t len); static const char * cmdlineSeparator(const char * cmd, size_t len); static const char * cmdlineTerminator(const char * cmd, size_t len); static const char * cmdlineNext(const char * cmd, size_t len); -static bool_t cmdMatch(const char * pattern, const char * cmd, size_t len); static void paramSkipBytes(scpi_t * context, size_t num); static void paramSkipWhitespace(scpi_t * context); @@ -74,40 +71,6 @@ return result; } */ - -/** - * Find pattern separator position - * @param pattern - * @param len - max search length - * @return position of separator or len - */ -size_t patternSeparatorPos(const char * pattern, size_t len) { - - char * separator = strnpbrk(pattern, len, "?:[]"); - if (separator == NULL) { - return len; - } else { - return separator - pattern; - } -} - -/** - * Find command separator position - * @param cmd - input command - * @param len - max search length - * @return position of separator or len - */ -size_t cmdSeparatorPos(const char * cmd, size_t len) { - char * separator = strnpbrk(cmd, len, ":?"); - size_t result; - if (separator == NULL) { - result = len; - } else { - result = separator - cmd; - } - - return result; -} /** * Find command termination character @@ -175,67 +138,6 @@ } /** - * Compare pattern and command - * @param pattern - * @param cmd - command - * @param len - max search length - * @return TRUE if pattern matches, FALSE otherwise - */ -bool_t cmdMatch(const char * pattern, const char * cmd, size_t len) { - int result = FALSE; - - const char * pattern_ptr = pattern; - int pattern_len = SCPI_strnlen(pattern, len); - const char * pattern_end = pattern + pattern_len; - - const char * cmd_ptr = cmd; - size_t cmd_len = SCPI_strnlen(cmd, len); - const char * cmd_end = cmd + cmd_len; - - while (1) { - int pattern_sep_pos = patternSeparatorPos(pattern_ptr, pattern_end - pattern_ptr); - int cmd_sep_pos = cmdSeparatorPos(cmd_ptr, cmd_end - cmd_ptr); - - if (matchPattern(pattern_ptr, pattern_sep_pos, cmd_ptr, cmd_sep_pos)) { - pattern_ptr = pattern_ptr + pattern_sep_pos; - cmd_ptr = cmd_ptr + cmd_sep_pos; - result = TRUE; - - /* command is complete */ - if ((pattern_ptr == pattern_end) && (cmd_ptr >= cmd_end)) { - break; - } - - /* pattern complete, but command not */ - if ((pattern_ptr == pattern_end) && (cmd_ptr < cmd_end)) { - result = FALSE; - break; - } - - /* command complete, but pattern not */ - if (cmd_ptr >= cmd_end) { - result = FALSE; - break; - } - - /* both command and patter contains command separator at this position */ - if ((pattern_ptr[0] == cmd_ptr[0]) && ((pattern_ptr[0] == ':') || (pattern_ptr[0] == '?'))) { - pattern_ptr = pattern_ptr + 1; - cmd_ptr = cmd_ptr + 1; - } else { - result = FALSE; - break; - } - } else { - result = FALSE; - break; - } - } - - return result; -} - -/** * Write data to SCPI output * @param context * @param data @@ -273,9 +175,9 @@ } /** - * Zapis nove radky na SCPI vystup + * Conditionaly write "New Line" * @param context - * @return pocet zapsanych znaku + * @return number of characters written */ static size_t writeNewLine(scpi_t * context) { if (context->output_count > 0) { @@ -330,7 +232,7 @@ for (i = 0; context->cmdlist[i].pattern != NULL; i++) { cmd = &context->cmdlist[i]; - if (cmdMatch(cmd->pattern, cmdline_ptr, cmd_len)) { + if (matchCommand(cmd->pattern, cmdline_ptr, cmd_len)) { context->paramlist.cmd = cmd; context->paramlist.parameters = cmdline_ptr + cmd_len; context->paramlist.length = cmdline_len - cmd_len; -- Gitblit v1.9.1