From 9b9bc8a81ad303ffb1e5eef12f34702b2aceef60 Mon Sep 17 00:00:00 2001 From: Jan Breuer <jan.breuer@jaybee.cz> Date: 周三, 22 4月 2015 03:52:29 +0800 Subject: [PATCH] Support RESPONSE MESSAGE UNIT SEPARATOR, issue #21 --- libscpi/src/parser.c | 26 +++++++++++++++++++++++--- 1 files changed, 23 insertions(+), 3 deletions(-) diff --git a/libscpi/src/parser.c b/libscpi/src/parser.c index 49080ff..f437018 100644 --- a/libscpi/src/parser.c +++ b/libscpi/src/parser.c @@ -192,6 +192,19 @@ } /** + * Conditionaly write ";" + * @param context + * @return number of characters written + */ +static size_t writeSemicolon(scpi_t * context) { + if (context->output_count > 0) { + return writeData(context, ";", 1); + } else { + return 0; + } +} + +/** * Process command * @param context */ @@ -199,6 +212,10 @@ const scpi_command_t * cmd = context->paramlist.cmd; context->cmd_error = FALSE; + + /* conditionaly write ; */ + writeSemicolon(context); + context->output_count = 0; context->input_count = 0; @@ -209,9 +226,6 @@ SCPI_ErrorPush(context, SCPI_ERROR_EXECUTION_ERROR); } } - - /* conditionaly write new line */ - writeNewLine(context); /* skip all whitespaces */ paramSkipWhitespace(context); @@ -266,6 +280,8 @@ return -1; } + context->output_count = 0; + while (cmdline_ptr < cmdline_end) { result = 0; cmd_len = cmdTerminatorPos(cmdline_ptr, cmdline_end - cmdline_ptr); @@ -285,6 +301,10 @@ cmdline_ptr += skipCmdLine(cmdline_ptr, cmdline_end - cmdline_ptr); cmdline_ptr += skipWhitespace(cmdline_ptr, cmdline_end - cmdline_ptr); } + + /* conditionaly write new line */ + writeNewLine(context); + return result; } -- Gitblit v1.9.1