integer parser: removing some signed/unsigned function duplication
| | |
| | | |
| | | size_t SCPI_ResultCharacters(scpi_t * context, const char * data, size_t len); |
| | | #define SCPI_ResultMnemonic(context, data) SCPI_ResultCharacters((context), (data), strlen(data)) |
| | | size_t SCPI_ResultInt32Base(scpi_t * context, int32_t val, int8_t base, scpi_bool_t sign); |
| | | #define SCPI_ResultIntBase(context, val, base) SCPI_ResultInt32Base ((context), (val), (base), TRUE) |
| | | size_t SCPI_ResultInt32(scpi_t * context, int32_t val); |
| | | #define SCPI_ResultInt(context, val) SCPI_ResultInt32 ((context), (val)) |
| | | size_t SCPI_ResultInt32Base(scpi_t * context, int32_t val, int8_t base); |
| | | #define SCPI_ResultIntBase(context, val, base) SCPI_ResultInt32Base ((context), (val), (base)) |
| | | size_t SCPI_ResultUInt32(scpi_t * context, uint32_t val); |
| | | size_t SCPI_ResultUInt32Base(scpi_t * context, uint32_t val, int8_t base); |
| | | size_t SCPI_ResultInt64Base(scpi_t * context, int64_t val, int8_t base, scpi_bool_t sign); |
| | | size_t SCPI_ResultInt64(scpi_t * context, int64_t val); |
| | | size_t SCPI_ResultInt64Base(scpi_t * context, int64_t val, int8_t base); |
| | | size_t SCPI_ResultUInt64(scpi_t * context, uint64_t val); |
| | | size_t SCPI_ResultUInt64Base(scpi_t * context, uint64_t val, int8_t base); |
| | | size_t SCPI_ResultDouble(scpi_t * context, double val); |
| | | size_t SCPI_ResultText(scpi_t * context, const char * data); |
| | | size_t SCPI_ResultArbitraryBlock(scpi_t * context, const char * data, size_t len); |
| | |
| | | extern "C" { |
| | | #endif |
| | | |
| | | size_t SCPI_Int32ToStr(int32_t val, char * str, size_t len, int8_t base); |
| | | #define SCPI_LongToStr(val, str, len, base) SCPI_Int32ToStr((val), (str), (len), (base)) |
| | | size_t SCPI_UInt32ToStr(uint32_t val, char * str, size_t len, int8_t base); |
| | | size_t SCPI_Int64ToStr(int64_t val, char * str, size_t len, int8_t base); |
| | | size_t SCPI_UInt64ToStr(uint64_t val, char * str, size_t len, int8_t base); |
| | | size_t SCPI_Int32ToStr(int32_t val, char * str, size_t len, int8_t base, scpi_bool_t sign); |
| | | #define SCPI_LongToStr(val, str, len, base) SCPI_Int32ToStr((val), (str), (len), (base), TRUE) |
| | | size_t SCPI_Int64ToStr(int64_t val, char * str, size_t len, int8_t base, scpi_bool_t sign); |
| | | size_t SCPI_DoubleToStr(double val, char * str, size_t len); |
| | | |
| | | #ifdef __cplusplus |
| | |
| | | * @return |
| | | */ |
| | | size_t SCPI_ResultInt32(scpi_t * context, int32_t val) { |
| | | return SCPI_ResultInt32Base(context, val, 10); |
| | | return SCPI_ResultInt32Base(context, val, 10, TRUE); |
| | | } |
| | | |
| | | /** |
| | |
| | | * @return |
| | | */ |
| | | size_t SCPI_ResultUInt32(scpi_t * context, uint32_t val) { |
| | | return SCPI_ResultUInt32Base(context, val, 10); |
| | | return SCPI_ResultInt32Base(context, val, 10, FALSE); |
| | | } |
| | | |
| | | /** |
| | |
| | | * @return |
| | | */ |
| | | size_t SCPI_ResultInt64(scpi_t * context, int64_t val) { |
| | | return SCPI_ResultInt64Base(context, val, 10); |
| | | return SCPI_ResultInt64Base(context, val, 10, TRUE); |
| | | } |
| | | |
| | | /** |
| | |
| | | * @return |
| | | */ |
| | | size_t SCPI_ResultUInt64(scpi_t * context, uint64_t val) { |
| | | return SCPI_ResultUInt64Base(context, val, 10); |
| | | return SCPI_ResultInt64Base(context, val, 10, FALSE); |
| | | } |
| | | |
| | | /** |
| | |
| | | } |
| | | |
| | | /** |
| | | * Write signed 32 bit integer value in specific base to the result |
| | | * Write signed/unsigned 32 bit integer value in specific base to the result |
| | | * @param context |
| | | * @param val |
| | | * @param base |
| | | * @param sign |
| | | * @return |
| | | */ |
| | | size_t SCPI_ResultInt32Base(scpi_t * context, int32_t val, int8_t base) { |
| | | size_t SCPI_ResultInt32Base(scpi_t * context, int32_t val, int8_t base, scpi_bool_t sign) { |
| | | char buffer[32+1]; |
| | | const char * basePrefix; |
| | | size_t result = 0; |
| | | size_t len; |
| | | |
| | | len = SCPI_Int32ToStr(val, buffer, sizeof (buffer), base); |
| | | len = SCPI_Int32ToStr(val, buffer, sizeof (buffer), base, sign); |
| | | basePrefix = getBasePrefix(base); |
| | | |
| | | result += writeDelimiter(context); |
| | |
| | | } |
| | | |
| | | /** |
| | | * Write unsigned 32 bit integer value in specific base to the result |
| | | * Write signed/unsigned 64 bit integer value in specific base to the result |
| | | * @param context |
| | | * @param val |
| | | * @param base |
| | | * @param sign |
| | | * @return |
| | | */ |
| | | size_t SCPI_ResultUInt32Base(scpi_t * context, uint32_t val, int8_t base) { |
| | | char buffer[32+1]; |
| | | const char * basePrefix; |
| | | size_t result = 0; |
| | | size_t len; |
| | | |
| | | len = SCPI_UInt32ToStr(val, buffer, sizeof (buffer), base); |
| | | basePrefix = getBasePrefix(base); |
| | | |
| | | result += writeDelimiter(context); |
| | | if (basePrefix != NULL) { |
| | | result += writeData(context, basePrefix, 2); |
| | | } |
| | | result += writeData(context, buffer, len); |
| | | context->output_count++; |
| | | return result; |
| | | } |
| | | |
| | | /** |
| | | * Write signed 64 bit integer value in specific base to the result |
| | | * @param context |
| | | * @param val |
| | | * @param base |
| | | * @return |
| | | */ |
| | | size_t SCPI_ResultInt64Base(scpi_t * context, int64_t val, int8_t base) { |
| | | size_t SCPI_ResultInt64Base(scpi_t * context, int64_t val, int8_t base, scpi_bool_t sign) { |
| | | char buffer[64+1]; |
| | | const char * basePrefix; |
| | | size_t result = 0; |
| | | size_t len; |
| | | |
| | | len = SCPI_Int64ToStr(val, buffer, sizeof (buffer), base); |
| | | basePrefix = getBasePrefix(base); |
| | | |
| | | result += writeDelimiter(context); |
| | | if (basePrefix != NULL) { |
| | | result += writeData(context, basePrefix, 2); |
| | | } |
| | | result += writeData(context, buffer, len); |
| | | context->output_count++; |
| | | return result; |
| | | } |
| | | |
| | | /** |
| | | * Write unsigned 64 bit integer value in specific base to the result |
| | | * @param context |
| | | * @param val |
| | | * @param base |
| | | * @return |
| | | */ |
| | | size_t SCPI_ResultUInt64Base(scpi_t * context, uint64_t val, int8_t base) { |
| | | char buffer[64+1]; |
| | | const char * basePrefix; |
| | | size_t result = 0; |
| | | size_t len; |
| | | |
| | | len = SCPI_UInt64ToStr(val, buffer, sizeof (buffer), base); |
| | | len = SCPI_Int64ToStr(val, buffer, sizeof (buffer), base, sign); |
| | | basePrefix = getBasePrefix(base); |
| | | |
| | | result += writeDelimiter(context); |
| | |
| | | char block_header[12]; |
| | | size_t header_len; |
| | | block_header[0] = '#'; |
| | | SCPI_Int32ToStr(len, block_header + 2, 10, 10); |
| | | SCPI_Int32ToStr(len, block_header + 2, 10, 10, FALSE); |
| | | |
| | | header_len = strlen(block_header + 2); |
| | | block_header[1] = (char)(header_len + '0'); |
| | |
| | | * @return |
| | | */ |
| | | size_t SCPI_ResultBool(scpi_t * context, scpi_bool_t val) { |
| | | return SCPI_ResultInt32Base(context, val ? 1 : 0, 10); |
| | | return SCPI_ResultInt32Base(context, val ? 1 : 0, 10, FALSE); |
| | | } |
| | | |
| | | /* parsing parameters */ |
| | |
| | | * @param context |
| | | * @param parameter |
| | | * @param value result |
| | | * @param sign |
| | | * @return TRUE if succesful |
| | | */ |
| | | static scpi_bool_t ParamToInt32(scpi_t * context, scpi_parameter_t * parameter, int32_t * value, scpi_bool_t sign) { |
| | |
| | | * @param context |
| | | * @param value |
| | | * @param mandatory |
| | | * @param sign |
| | | * @return |
| | | */ |
| | | static scpi_bool_t ParamInt32(scpi_t * context, int32_t * value, scpi_bool_t mandatory, scpi_bool_t sign) { |
| | |
| | | } |
| | | |
| | | /** |
| | | * Converts signed 32b integer value to string |
| | | * Converts signed/unsigned 32 bit integer value to string |
| | | * @param val integer value |
| | | * @param str converted textual representation |
| | | * @param len string buffer length |
| | | * @param base output base |
| | | * @param sign |
| | | * @return number of bytes written to str (without '\0') |
| | | */ |
| | | size_t SCPI_Int32ToStr(int32_t val, char * str, size_t len, int8_t base) { |
| | | size_t SCPI_Int32ToStr(int32_t val, char * str, size_t len, int8_t base, scpi_bool_t sign) { |
| | | const char digits[] = "0123456789ABCDEF"; |
| | | |
| | | #define ADD_CHAR(c) if (pos < len) str[pos++] = (c) |
| | |
| | | case 10: |
| | | x = 1000000000L; |
| | | break; |
| | | case 0x10: |
| | | case 16: |
| | | x = 0x10000000L; |
| | | break; |
| | | default: |
| | |
| | | } |
| | | |
| | | // add sign for numbers in base 10 |
| | | if ((val < 0) && (base == 10)) { |
| | | if (sign && (val < 0) && (base == 10)) { |
| | | uval = -val; |
| | | ADD_CHAR('-'); |
| | | } |
| | |
| | | } |
| | | |
| | | /** |
| | | * Converts unsigned 32b integer value to string |
| | | * Converts signed/unsigned 64 bit integer value to string |
| | | * @param val integer value |
| | | * @param str converted textual representation |
| | | * @param len string buffer length |
| | | * @param base output base |
| | | * @param sign |
| | | * @return number of bytes written to str (without '\0') |
| | | */ |
| | | size_t SCPI_UInt32ToStr(uint32_t val, char * str, size_t len, int8_t base) { |
| | | const char digits[] = "0123456789ABCDEF"; |
| | | |
| | | #define ADD_CHAR(c) if (pos < len) str[pos++] = (c) |
| | | uint32_t x = 0; |
| | | int_fast8_t digit; |
| | | size_t pos = 0; |
| | | |
| | | if (val == 0) { |
| | | ADD_CHAR('0'); |
| | | } else { |
| | | |
| | | switch (base) { |
| | | case 2: |
| | | x = 0x80000000L; |
| | | break; |
| | | case 8: |
| | | x = 0x40000000L; |
| | | break; |
| | | case 10: |
| | | x = 1000000000L; |
| | | break; |
| | | case 0x10: |
| | | x = 0x10000000L; |
| | | break; |
| | | default: |
| | | x = 1000000000L; |
| | | base = 10; |
| | | break; |
| | | } |
| | | |
| | | // remove leading zeros |
| | | while ((val / x) == 0) { |
| | | x /= base; |
| | | } |
| | | |
| | | do { |
| | | digit = (uint8_t) (val / x); |
| | | ADD_CHAR(digits[digit]); |
| | | val -= digit * x; |
| | | x /= base; |
| | | } while (x && (pos < len)); |
| | | } |
| | | |
| | | if (pos < len) str[pos] = 0; |
| | | return pos; |
| | | #undef ADD_CHAR |
| | | } |
| | | |
| | | /** |
| | | * Converts signed 64b integer value to string |
| | | * @param val integer value |
| | | * @param str converted textual representation |
| | | * @param len string buffer length |
| | | * @param base output base |
| | | * @return number of bytes written to str (without '\0') |
| | | */ |
| | | size_t SCPI_Int64ToStr(int64_t val, char * str, size_t len, int8_t base) { |
| | | size_t SCPI_Int64ToStr(int64_t val, char * str, size_t len, int8_t base, scpi_bool_t sign) { |
| | | const char digits[] = "0123456789ABCDEF"; |
| | | |
| | | #define ADD_CHAR(c) if (pos < len) str[pos++] = (c) |
| | |
| | | |
| | | switch (base) { |
| | | case 2: |
| | | x = 0x8000000000000000LL; |
| | | x = 0x8000000000000000ULL; |
| | | break; |
| | | case 8: |
| | | x = 0x8000000000000000LL; |
| | | x = 0x8000000000000000ULL; |
| | | break; |
| | | case 10: |
| | | x = 1000000000000000000LL; |
| | | x = 10000000000000000000ULL; |
| | | break; |
| | | case 0x10: |
| | | x = 0x1000000000000000LL; |
| | | case 16: |
| | | x = 0x1000000000000000ULL; |
| | | break; |
| | | default: |
| | | x = 1000000000000000000LL; |
| | | x = 10000000000000000000ULL; |
| | | base = 10; |
| | | break; |
| | | } |
| | | |
| | | // add sign for numbers in base 10 |
| | | if ((val < 0) && (base == 10)) { |
| | | if (sign && (val < 0) && (base == 10)) { |
| | | uval = -val; |
| | | ADD_CHAR('-'); |
| | | } |
| | |
| | | digit = (uint8_t) (uval / x); |
| | | ADD_CHAR(digits[digit]); |
| | | uval -= digit * x; |
| | | x /= base; |
| | | } while (x && (pos < len)); |
| | | } |
| | | |
| | | if (pos < len) str[pos] = 0; |
| | | return pos; |
| | | #undef ADD_CHAR |
| | | } |
| | | |
| | | /** |
| | | * Converts unsigned 64b integer value to string |
| | | * @param val integer value |
| | | * @param str converted textual representation |
| | | * @param len string buffer length |
| | | * @param base output base |
| | | * @return number of bytes written to str (without '\0') |
| | | */ |
| | | size_t SCPI_UInt64ToStr(uint64_t val, char * str, size_t len, int8_t base) { |
| | | const char digits[] = "0123456789ABCDEF"; |
| | | |
| | | #define ADD_CHAR(c) if (pos < len) str[pos++] = (c) |
| | | uint64_t x = 0; |
| | | int_fast8_t digit; |
| | | size_t pos = 0; |
| | | |
| | | if (val == 0) { |
| | | ADD_CHAR('0'); |
| | | } else { |
| | | |
| | | switch (base) { |
| | | case 2: |
| | | x = 0x8000000000000000ULL; |
| | | break; |
| | | case 8: |
| | | x = 0x8000000000000000ULL; |
| | | break; |
| | | case 10: |
| | | x = 10000000000000000000ULL; |
| | | break; |
| | | case 0x10: |
| | | x = 0x1000000000000000ULL; |
| | | break; |
| | | default: |
| | | x = 10000000000000000000ULL; |
| | | base = 10; |
| | | break; |
| | | } |
| | | |
| | | // remove leading zeros |
| | | while ((val / x) == 0) { |
| | | x /= base; |
| | | } |
| | | |
| | | do { |
| | | digit = (uint8_t) (val / x); |
| | | ADD_CHAR(digits[digit]); |
| | | val -= digit * x; |
| | | x /= base; |
| | | } while (x && (pos < len)); |
| | | } |
| | |
| | | |
| | | // test conversion to decimal numbers |
| | | for (uintptr_t i=0; i<7; i++) { |
| | | len = SCPI_Int32ToStr(val[i], str, max, 10); |
| | | len = SCPI_Int32ToStr(val[i], str, max, 10, TRUE); |
| | | snprintf(ref, max, "%"PRIi32, val[i]); |
| | | CU_ASSERT(len == strlen(ref)); |
| | | CU_ASSERT_STRING_EQUAL(str, ref); |
| | |
| | | |
| | | // test conversion to hexadecimal numbers |
| | | for (uintptr_t i=0; i<7; i++) { |
| | | len = SCPI_Int32ToStr(val[i], str, max, 16); |
| | | len = SCPI_Int32ToStr(val[i], str, max, 16, TRUE); |
| | | snprintf(ref, max, "%"PRIX32, val[i]); |
| | | CU_ASSERT(len == strlen(ref)); |
| | | CU_ASSERT_STRING_EQUAL(str, ref); |
| | |
| | | |
| | | // test conversion to octal numbers |
| | | for (uintptr_t i=0; i<7; i++) { |
| | | len = SCPI_Int32ToStr(val[i], str, max, 8); |
| | | len = SCPI_Int32ToStr(val[i], str, max, 8, TRUE); |
| | | snprintf(ref, max, "%"PRIo32, val[i]); |
| | | CU_ASSERT(len == strlen(ref)); |
| | | CU_ASSERT_STRING_EQUAL(str, ref); |
| | | } |
| | | |
| | | // test conversion to binary numbers |
| | | len = SCPI_Int32ToStr(0, str, max, 2); |
| | | len = SCPI_Int32ToStr(0, str, max, 2, TRUE); |
| | | CU_ASSERT(len == 1); |
| | | CU_ASSERT_STRING_EQUAL(str, "0"); |
| | | |
| | | len = SCPI_Int32ToStr(1, str, max, 2); |
| | | len = SCPI_Int32ToStr(1, str, max, 2, TRUE); |
| | | CU_ASSERT(len == 1); |
| | | CU_ASSERT_STRING_EQUAL(str, "1"); |
| | | |
| | | len = SCPI_Int32ToStr(-1, str, max, 2); |
| | | len = SCPI_Int32ToStr(-1, str, max, 2, TRUE); |
| | | CU_ASSERT(len == 32); |
| | | CU_ASSERT_STRING_EQUAL(str, "11111111111111111111111111111111"); |
| | | |
| | | len = SCPI_Int32ToStr(0x01234567, str, max, 2); |
| | | len = SCPI_Int32ToStr(0x01234567, str, max, 2, TRUE); |
| | | CU_ASSERT(len == 25); |
| | | CU_ASSERT_STRING_EQUAL(str, "1001000110100010101100111"); |
| | | |
| | | len = SCPI_Int32ToStr(0x89abcdef, str, max, 2); |
| | | len = SCPI_Int32ToStr(0x89abcdef, str, max, 2, TRUE); |
| | | CU_ASSERT(len == 32); |
| | | CU_ASSERT_STRING_EQUAL(str, "10001001101010111100110111101111"); |
| | | } |
| | |
| | | |
| | | // test conversion to decimal numbers |
| | | for (uintptr_t i=0; i<7; i++) { |
| | | len = SCPI_UInt32ToStr(val[i], str, max, 10); |
| | | len = SCPI_Int32ToStr(val[i], str, max, 10, FALSE); |
| | | snprintf(ref, max, "%"PRIu32, val[i]); |
| | | CU_ASSERT(len == strlen(ref)); |
| | | CU_ASSERT_STRING_EQUAL(str, ref); |
| | |
| | | |
| | | // test conversion to hexadecimal numbers |
| | | for (uintptr_t i=0; i<7; i++) { |
| | | len = SCPI_UInt32ToStr(val[i], str, max, 16); |
| | | len = SCPI_Int32ToStr(val[i], str, max, 16, FALSE); |
| | | snprintf(ref, max, "%"PRIX32, val[i]); |
| | | CU_ASSERT(len == strlen(ref)); |
| | | CU_ASSERT_STRING_EQUAL(str, ref); |
| | |
| | | |
| | | // test conversion to octal numbers |
| | | for (uintptr_t i=0; i<7; i++) { |
| | | len = SCPI_UInt32ToStr(val[i], str, max, 8); |
| | | len = SCPI_Int32ToStr(val[i], str, max, 8, FALSE); |
| | | snprintf(ref, max, "%"PRIo32, val[i]); |
| | | CU_ASSERT(len == strlen(ref)); |
| | | CU_ASSERT_STRING_EQUAL(str, ref); |
| | |
| | | |
| | | // test conversion to decimal numbers |
| | | for (uintptr_t i=0; i<7; i++) { |
| | | len = SCPI_Int64ToStr(val[i], str, max, 10); |
| | | len = SCPI_Int64ToStr(val[i], str, max, 10, TRUE); |
| | | snprintf(ref, max, "%"PRIi64, val[i]); |
| | | CU_ASSERT(len == strlen(ref)); |
| | | CU_ASSERT_STRING_EQUAL(str, ref); |
| | |
| | | |
| | | // test conversion to hexadecimal numbers |
| | | for (uintptr_t i=0; i<7; i++) { |
| | | len = SCPI_Int64ToStr(val[i], str, max, 16); |
| | | len = SCPI_Int64ToStr(val[i], str, max, 16, TRUE); |
| | | snprintf(ref, max, "%"PRIX64, val[i]); |
| | | CU_ASSERT(len == strlen(ref)); |
| | | CU_ASSERT_STRING_EQUAL(str, ref); |
| | |
| | | |
| | | // test conversion to octal numbers |
| | | for (uintptr_t i=0; i<7; i++) { |
| | | len = SCPI_Int64ToStr(val[i], str, max, 8); |
| | | len = SCPI_Int64ToStr(val[i], str, max, 8, TRUE); |
| | | snprintf(ref, max, "%"PRIo64, val[i]); |
| | | CU_ASSERT(len == strlen(ref)); |
| | | CU_ASSERT_STRING_EQUAL(str, ref); |
| | | } |
| | | |
| | | // test conversion to binary numbers |
| | | len = SCPI_Int64ToStr(0, str, max, 2); |
| | | len = SCPI_Int64ToStr(0, str, max, 2, TRUE); |
| | | CU_ASSERT(len == 1); |
| | | CU_ASSERT_STRING_EQUAL(str, "0"); |
| | | |
| | | len = SCPI_Int64ToStr(1, str, max, 2); |
| | | len = SCPI_Int64ToStr(1, str, max, 2, TRUE); |
| | | CU_ASSERT(len == 1); |
| | | CU_ASSERT_STRING_EQUAL(str, "1"); |
| | | |
| | | len = SCPI_Int64ToStr(-1, str, max, 2); |
| | | len = SCPI_Int64ToStr(-1, str, max, 2, TRUE); |
| | | CU_ASSERT(len == 64); |
| | | CU_ASSERT_STRING_EQUAL(str, "1111111111111111111111111111111111111111111111111111111111111111"); |
| | | |
| | | len = SCPI_Int64ToStr(0x0123456789abcdef, str, max, 2); |
| | | len = SCPI_Int64ToStr(0x0123456789abcdef, str, max, 2, TRUE); |
| | | CU_ASSERT(len == 57); |
| | | CU_ASSERT_STRING_EQUAL(str, "100100011010001010110011110001001101010111100110111101111"); |
| | | |
| | | len = SCPI_Int64ToStr(0xfedcba9876543210, str, max, 2); |
| | | len = SCPI_Int64ToStr(0xfedcba9876543210, str, max, 2, TRUE); |
| | | CU_ASSERT(len == 64); |
| | | CU_ASSERT_STRING_EQUAL(str, "1111111011011100101110101001100001110110010101000011001000010000"); |
| | | } |
| | |
| | | |
| | | // test conversion to decimal numbers |
| | | for (uintptr_t i=0; i<7; i++) { |
| | | len = SCPI_UInt64ToStr(val[i], str, max, 10); |
| | | len = SCPI_Int64ToStr(val[i], str, max, 10, FALSE); |
| | | snprintf(ref, max, "%"PRIu64, val[i]); |
| | | CU_ASSERT(len == strlen(ref)); |
| | | CU_ASSERT_STRING_EQUAL(str, ref); |
| | |
| | | |
| | | // test conversion to hexadecimal numbers |
| | | for (uintptr_t i=0; i<7; i++) { |
| | | len = SCPI_UInt64ToStr(val[i], str, max, 16); |
| | | len = SCPI_Int64ToStr(val[i], str, max, 16, FALSE); |
| | | snprintf(ref, max, "%"PRIX64, val[i]); |
| | | CU_ASSERT(len == strlen(ref)); |
| | | CU_ASSERT_STRING_EQUAL(str, ref); |
| | |
| | | |
| | | // test conversion to octal numbers |
| | | for (uintptr_t i=0; i<7; i++) { |
| | | len = SCPI_UInt64ToStr(val[i], str, max, 8); |
| | | len = SCPI_Int64ToStr(val[i], str, max, 8, FALSE); |
| | | snprintf(ref, max, "%"PRIo64, val[i]); |
| | | CU_ASSERT(len == strlen(ref)); |
| | | CU_ASSERT_STRING_EQUAL(str, ref); |