From 1f77a03fa02b0cdbaa878cd7015838638eedc4a8 Mon Sep 17 00:00:00 2001
From: Jan Breuer <jan.breuer@jaybee.cz>
Date: 周日, 24 4月 2016 22:11:15 +0800
Subject: [PATCH] Fix strndup of NULL, add auto length for SCPI_ErrorPushEx

---
 libscpi/inc/scpi/parser.h |   24 +++++++++++++++++-------
 1 files changed, 17 insertions(+), 7 deletions(-)

diff --git a/libscpi/inc/scpi/parser.h b/libscpi/inc/scpi/parser.h
index 4cc088d..2f00c82 100644
--- a/libscpi/inc/scpi/parser.h
+++ b/libscpi/inc/scpi/parser.h
@@ -43,19 +43,28 @@
 #ifdef	__cplusplus
 extern "C" {
 #endif
-    void SCPI_Init(scpi_t * context);
+    void SCPI_Init(scpi_t * context,
+            const scpi_command_t * commands,
+            scpi_interface_t * interface,
+            const scpi_unit_def_t * units,
+            const char * idn1, const char * idn2, const char * idn3, const char * idn4,
+            char * input_buffer, size_t input_buffer_length, 
+            scpi_error_t * error_queue_data, int16_t error_queue_size);
+#if USE_DEVICE_DEPENDENT_ERROR_INFORMATION && !USE_MEMORY_ALLOCATION_FREE
+    void SCPI_InitHeap(scpi_t * context, char * error_info_heap, size_t error_info_heap_length);
+#endif
 
     scpi_bool_t SCPI_Input(scpi_t * context, const char * data, int len);
     scpi_bool_t SCPI_Parse(scpi_t * context, char * data, int len);
 
     size_t SCPI_ResultCharacters(scpi_t * context, const char * data, size_t len);
 #define SCPI_ResultMnemonic(context, data) SCPI_ResultCharacters((context), (data), strlen(data))
-#define SCPI_ResultUInt8Base SCPI_ResultUInt32Base
-#define SCPI_ResultUInt8(c, v) SCPI_ResultUInt32Base((c), (v), 10)
-#define SCPI_ResultInt8 SCPI_ResultInt32
-#define SCPI_ResultUInt16Base SCPI_ResultUInt32Base
-#define SCPI_ResultUInt16(c, v) SCPI_ResultUInt32Base((c), (v), 10)
-#define SCPI_ResultInt16 SCPI_ResultInt32
+#define SCPI_ResultUInt8Base(c, v, b) SCPI_ResultUInt32Base((c), (v), (uint8_t)(b))
+#define SCPI_ResultUInt8(c, v) SCPI_ResultUInt32Base((c), (uint8_t)(v), 10)
+#define SCPI_ResultInt8(c, v) SCPI_ResultInt32((c), (int8_t)(v))
+#define SCPI_ResultUInt16Base(c, v, b) SCPI_ResultUInt32Base((c), (uint16_t)(v), (b))
+#define SCPI_ResultUInt16(c, v) SCPI_ResultUInt32Base((c), (uint16_t)(v), 10)
+#define SCPI_ResultInt16(c, v) SCPI_ResultInt32((c), (int16_t)(v))
     size_t SCPI_ResultUInt32Base(scpi_t * context, uint32_t val, int8_t base);
 #define SCPI_ResultUInt32(c, v) SCPI_ResultUInt32Base((c), (v), 10)
     size_t SCPI_ResultInt32(scpi_t * context, int32_t val);
@@ -65,6 +74,7 @@
     size_t SCPI_ResultFloat(scpi_t * context, float val);
     size_t SCPI_ResultDouble(scpi_t * context, double val);
     size_t SCPI_ResultText(scpi_t * context, const char * data);
+	size_t SCPI_ResultError(scpi_t * context, scpi_error_t * error);
     size_t SCPI_ResultArbitraryBlock(scpi_t * context, const void * data, size_t len);
     size_t SCPI_ResultArbitraryBlockHeader(scpi_t * context, size_t len);
     size_t SCPI_ResultArbitraryBlockData(scpi_t * context, const void * data, size_t len);

--
Gitblit v1.9.1