From cf23c1aa245391e1c531b86386bb216cac72a171 Mon Sep 17 00:00:00 2001 From: Jan Breuer <jan.breuer@jaybee.cz> Date: ćšć, 07 11æ 2013 22:30:36 +0800 Subject: [PATCH] Resolve bug #10 Multiple commands per package --- examples/common/scpi-def.c | 53 ++++++++++++++++++++++++++++++++++++++++++++++------- 1 files changed, 46 insertions(+), 7 deletions(-) diff --git a/examples/common/scpi-def.c b/examples/common/scpi-def.c index c49eb44..6a53644 100644 --- a/examples/common/scpi-def.c +++ b/examples/common/scpi-def.c @@ -89,6 +89,43 @@ return SCPI_RES_OK; } +scpi_result_t TEST_Bool(scpi_t * context) { + bool_t param1; + fprintf(stderr, "TEST:BOOL\r\n"); // debug command name + + // read first parameter if present + if (!SCPI_ParamBool(context, ¶m1, true)) { + return SCPI_RES_ERR; + } + + fprintf(stderr, "\tP1=%d\r\n", param1); + + return SCPI_RES_OK; +} + +const char * trigger_source[] = { + "BUS", + "IMMediate", + "EXTernal", + NULL /* termination of option list */ +}; + + +scpi_result_t TEST_ChoiceQ(scpi_t * context) { + + int32_t param; + + if (!SCPI_ParamChoice(context, trigger_source, ¶m, true)) { + return SCPI_RES_ERR; + } + + fprintf(stderr, "\tP1=%s (%d)\r\n", trigger_source[param], param); + + SCPI_ResultInt(context, param); + + return SCPI_RES_OK; +} + static const scpi_command_t scpi_commands[] = { /* IEEE Mandated Commands (SCPI std V1999.0 4.1.1) */ { .pattern = "*CLS", .callback = SCPI_CoreCls,}, @@ -106,8 +143,7 @@ { .pattern = "*WAI", .callback = SCPI_CoreWai,}, /* Required SCPI commands (SCPI std V1999.0 4.2.1) */ - {.pattern = "SYSTem:ERRor?", .callback = SCPI_SystemErrorNextQ,}, - {.pattern = "SYSTem:ERRor:NEXT?", .callback = SCPI_SystemErrorNextQ,}, + {.pattern = "SYSTem:ERRor[:NEXT]?", .callback = SCPI_SystemErrorNextQ,}, {.pattern = "SYSTem:ERRor:COUNt?", .callback = SCPI_SystemErrorCountQ,}, {.pattern = "SYSTem:VERSion?", .callback = SCPI_SystemVersionQ,}, @@ -117,8 +153,7 @@ //{.pattern = "STATus:OPERation:ENABle", .callback = scpi_stub_callback,}, //{.pattern = "STATus:OPERation:ENABle?", .callback = scpi_stub_callback,}, - {.pattern = "STATus:QUEStionable?", .callback = SCPI_StatusQuestionableEventQ,}, - {.pattern = "STATus:QUEStionable:EVENt?", .callback = SCPI_StatusQuestionableEventQ,}, + {.pattern = "STATus:QUEStionable[:EVENt]?", .callback = SCPI_StatusQuestionableEventQ,}, //{.pattern = "STATus:QUEStionable:CONDition?", .callback = scpi_stub_callback,}, {.pattern = "STATus:QUEStionable:ENABle", .callback = SCPI_StatusQuestionableEnable,}, {.pattern = "STATus:QUEStionable:ENABle?", .callback = SCPI_StatusQuestionableEnableQ,}, @@ -139,16 +174,19 @@ {.pattern = "SYSTem:COMMunication:TCPIP:CONTROL?", .callback = SCPI_SystemCommTcpipControlQ,}, + {.pattern = "TEST:BOOL", .callback = TEST_Bool,}, + {.pattern = "TEST:CHOice?", .callback = TEST_ChoiceQ,}, + SCPI_CMD_LIST_END }; static scpi_interface_t scpi_interface = { - .write = SCPI_Write, .error = SCPI_Error, - .reset = SCPI_Reset, - .test = SCPI_Test, + .write = SCPI_Write, .control = SCPI_Control, .flush = SCPI_Flush, + .reset = SCPI_Reset, + .test = SCPI_Test, }; #define SCPI_INPUT_BUFFER_LENGTH 256 @@ -167,4 +205,5 @@ .registers = scpi_regs, .units = scpi_units_def, .special_numbers = scpi_special_numbers_def, + .idn = {"MANUFACTURE", "INSTR2013", NULL, "01-02"}, }; -- Gitblit v1.9.1