From 7f6b062e9f51c98e56713b1869c01573d7fe855f Mon Sep 17 00:00:00 2001 From: Arseny Kapoulkine Date: Wed, 15 Jan 2014 04:28:10 +0000 Subject: Implement automatic hexadecimal decoding for xml_attribute::as_int and xml_text::as_int. This is effectively a form of strtol with base 0, but without octal support. git-svn-id: http://pugixml.googlecode.com/svn/trunk@958 99668b35-9821-0410-8761-19e4c4f06640 --- tests/test_dom_text.cpp | 40 ++++++++++++++++++++++++++++++++++++++-- 1 file changed, 38 insertions(+), 2 deletions(-) (limited to 'tests/test_dom_text.cpp') diff --git a/tests/test_dom_text.cpp b/tests/test_dom_text.cpp index 153c372..2e38f29 100644 --- a/tests/test_dom_text.cpp +++ b/tests/test_dom_text.cpp @@ -57,7 +57,7 @@ TEST_XML_FLAGS(dom_text_as_string, "foo1-1-21474836482147483647") +TEST_XML(dom_text_as_int, "1-1-214748364821474836470") { xml_node node = doc.child(STR("node")); @@ -66,9 +66,22 @@ TEST_XML(dom_text_as_int, "1-1-214748 CHECK(node.child(STR("text2")).text().as_int() == -1); CHECK(node.child(STR("text3")).text().as_int() == -2147483647 - 1); CHECK(node.child(STR("text4")).text().as_int() == 2147483647); + CHECK(node.child(STR("text5")).text().as_int() == 0); } -TEST_XML(dom_text_as_uint, "0121474836474294967295") +TEST_XML(dom_text_as_int_hex, "07770x5ab0XFf-0x20-0x800000000x") +{ + xml_node node = doc.child(STR("node")); + + CHECK(node.child(STR("text1")).text().as_int() == 777); // no octal support! intentional + CHECK(node.child(STR("text2")).text().as_int() == 1451); + CHECK(node.child(STR("text3")).text().as_int() == 255); + CHECK(node.child(STR("text4")).text().as_int() == -32); + CHECK(node.child(STR("text5")).text().as_int() == -2147483647 - 1); + CHECK(node.child(STR("text6")).text().as_int() == 0); +} + +TEST_XML(dom_text_as_uint, "01214748364742949672950") { xml_node node = doc.child(STR("node")); @@ -77,6 +90,29 @@ TEST_XML(dom_text_as_uint, "012147483 CHECK(node.child(STR("text2")).text().as_uint() == 1); CHECK(node.child(STR("text3")).text().as_uint() == 2147483647); CHECK(node.child(STR("text4")).text().as_uint() == 4294967295u); + CHECK(node.child(STR("text5")).text().as_uint() == 0); +} + +TEST_XML(dom_text_as_uint_hex, "07770x5ab0XFf0x200xFFFFFFFF0x") +{ + xml_node node = doc.child(STR("node")); + + CHECK(node.child(STR("text1")).text().as_uint() == 777); // no octal support! intentional + CHECK(node.child(STR("text2")).text().as_uint() == 1451); + CHECK(node.child(STR("text3")).text().as_uint() == 255); + CHECK(node.child(STR("text4")).text().as_uint() == 32); + CHECK(node.child(STR("text5")).text().as_uint() == 4294967295u); + CHECK(node.child(STR("text6")).text().as_uint() == 0); +} + +TEST_XML(dom_text_as_integer_space, " \t\n1234\n\t 0x123- 16- 0x10") +{ + xml_node node = doc.child(STR("node")); + + CHECK(node.child(STR("text1")).text().as_int() == 1234); + CHECK(node.child(STR("text2")).text().as_int() == 291); + CHECK(node.child(STR("text3")).text().as_int() == 0); + CHECK(node.child(STR("text4")).text().as_int() == 0); } TEST_XML(dom_text_as_float, "010.12-5.13e-43.14159265358979323846") -- cgit v1.2.3