From a6ce8b2d4fb37cc9b7655d636cb0c3b46628818b Mon Sep 17 00:00:00 2001 From: Slobodan Kletnikov Date: Sun, 31 Mar 2024 00:19:54 +0400 Subject: [PATCH] Fix values with number and dash data type are parsed as integer instead of string (#206) * Fix parsing numbers with dash to string * Fix single include libs * Renamed neg_allowed to is_negative It is unnecessary to determine if the minus sign is allowed separately from whitespace. --------- Co-authored-by: Slobodan Klentikov Co-authored-by: Vincent La --- include/internal/data_type.h | 10 +++++----- single_include/csv.hpp | 2 +- single_include_test/csv.hpp | 2 +- tests/test_data_type.cpp | 8 +++++++- 4 files changed, 14 insertions(+), 8 deletions(-) diff --git a/include/internal/data_type.h b/include/internal/data_type.h index b10d8690..f4789711 100644 --- a/include/internal/data_type.h +++ b/include/internal/data_type.h @@ -241,9 +241,9 @@ namespace csv { return DataType::CSV_NULL; bool ws_allowed = true, - neg_allowed = true, dot_allowed = true, digit_allowed = true, + is_negative = false, has_digit = false, prob_float = false; @@ -268,12 +268,12 @@ namespace csv { } break; case '-': - if (!neg_allowed) { + if (!ws_allowed) { // Ex: '510-123-4567' return DataType::CSV_STRING; } - neg_allowed = false; + is_negative = true; break; case '.': if (!dot_allowed) { @@ -297,7 +297,7 @@ namespace csv { return _process_potential_exponential( in.substr(exponent_start_idx), - neg_allowed ? integral_part + decimal_part : -(integral_part + decimal_part), + is_negative ? -(integral_part + decimal_part) : integral_part + decimal_part, out ); } @@ -331,7 +331,7 @@ namespace csv { if (has_digit) { long double number = integral_part + decimal_part; if (out) { - *out = neg_allowed ? number : -number; + *out = is_negative ? -number : number; } return prob_float ? DataType::CSV_DOUBLE : _determine_integral_type(number); diff --git a/single_include/csv.hpp b/single_include/csv.hpp index 9cebfc2b..da165928 100644 --- a/single_include/csv.hpp +++ b/single_include/csv.hpp @@ -5328,7 +5328,7 @@ namespace csv { } break; case '-': - if (!neg_allowed) { + if (!ws_allowed) { // Ex: '510-123-4567' return DataType::CSV_STRING; } diff --git a/single_include_test/csv.hpp b/single_include_test/csv.hpp index 9cebfc2b..da165928 100644 --- a/single_include_test/csv.hpp +++ b/single_include_test/csv.hpp @@ -5328,7 +5328,7 @@ namespace csv { } break; case '-': - if (!neg_allowed) { + if (!ws_allowed) { // Ex: '510-123-4567' return DataType::CSV_STRING; } diff --git a/tests/test_data_type.cpp b/tests/test_data_type.cpp index ff82369c..030e82d4 100644 --- a/tests/test_data_type.cpp +++ b/tests/test_data_type.cpp @@ -163,4 +163,10 @@ TEST_CASE("Parse Scientific Notation Malformed", "[sci_notation]") { SECTION("Butchered Parsing Attempt") { REQUIRE(data_type(butchered) == DataType::CSV_STRING); } -} \ No newline at end of file +} + +TEST_CASE( "Parse numbers with dash as string", "[regression_double]" ) { + std::string s("510-123-4567"); + long double out; + REQUIRE(data_type(s, &out) == DataType::CSV_STRING); +}