diff --git a/utilities/xmlrpcpp/include/xmlrpcpp/XmlRpcValue.h b/utilities/xmlrpcpp/include/xmlrpcpp/XmlRpcValue.h index 703cceea6e..4aa560849a 100644 --- a/utilities/xmlrpcpp/include/xmlrpcpp/XmlRpcValue.h +++ b/utilities/xmlrpcpp/include/xmlrpcpp/XmlRpcValue.h @@ -95,6 +95,13 @@ namespace XmlRpc { operator BinaryData&() { assertTypeOrInvalid(TypeBase64); return *_value.asBinary; } operator struct tm&() { assertTypeOrInvalid(TypeDateTime); return *_value.asTime; } + operator const bool&() const { assertTypeOrInvalid(TypeBoolean); return _value.asBool; } + operator const int&() const { assertTypeOrInvalid(TypeInt); return _value.asInt; } + operator const double&() const { assertTypeOrInvalid(TypeDouble); return _value.asDouble; } + operator const std::string&() const { assertTypeOrInvalid(TypeString); return *_value.asString; } + operator const BinaryData&() const { assertTypeOrInvalid(TypeBase64); return *_value.asBinary; } + operator const struct tm&() const { assertTypeOrInvalid(TypeDateTime); return *_value.asTime; } + XmlRpcValue const& operator[](int i) const { assertArray(i+1); return _value.asArray->at(i); } XmlRpcValue& operator[](int i) { assertArray(i+1); return _value.asArray->at(i); } @@ -147,6 +154,7 @@ namespace XmlRpc { void invalidate(); // Type checking + void assertTypeOrInvalid(Type t) const; void assertTypeOrInvalid(Type t); void assertArray(int size) const; void assertArray(int size); diff --git a/utilities/xmlrpcpp/src/XmlRpcValue.cpp b/utilities/xmlrpcpp/src/XmlRpcValue.cpp index 361a8e8073..1928784311 100644 --- a/utilities/xmlrpcpp/src/XmlRpcValue.cpp +++ b/utilities/xmlrpcpp/src/XmlRpcValue.cpp @@ -70,6 +70,12 @@ namespace XmlRpc { // Type checking + void XmlRpcValue::assertTypeOrInvalid(Type t) const + { + if (_type != t) + throw XmlRpcException("type error"); + } + void XmlRpcValue::assertTypeOrInvalid(Type t) { if (_type == TypeInvalid) diff --git a/utilities/xmlrpcpp/test/TestValues.cpp b/utilities/xmlrpcpp/test/TestValues.cpp index 842e78e9fe..60dae29a5e 100644 --- a/utilities/xmlrpcpp/test/TestValues.cpp +++ b/utilities/xmlrpcpp/test/TestValues.cpp @@ -49,7 +49,7 @@ TEST(XmlRpc, Bool) { } TEST(XmlRpc, testBoolean) { - XmlRpcValue booleanFalse(false); + const XmlRpcValue booleanFalse(false); XmlRpcValue booleanTrue(true); int offset = 0; XmlRpcValue booleanFalseXml("0", &offset); @@ -75,7 +75,7 @@ TEST(XmlRpc, testBoolean) { // Int TEST(XmlRpc, testInt) { - XmlRpcValue int0(0); + const XmlRpcValue int0(0); ASSERT_EQ(XmlRpcValue::TypeInt, int0.getType()); XmlRpcValue int1(1); @@ -110,7 +110,7 @@ TEST(XmlRpc, testInt) { TEST(XmlRpc, testDouble) { // Double - XmlRpcValue d(43.7); + const XmlRpcValue d(43.7); ASSERT_EQ(XmlRpcValue::TypeDouble, d.getType()); EXPECT_EQ("43.700000000000003", d.toXml()); EXPECT_DOUBLE_EQ(43.7, double(d)); @@ -130,7 +130,7 @@ TEST(XmlRpc, testDouble) { TEST(XmlRpc, testString) { // String - XmlRpcValue s("Now is the time <&"); + const XmlRpcValue s("Now is the time <&"); ASSERT_EQ(XmlRpcValue::TypeString, s.getType()); EXPECT_EQ(18, s.size()); EXPECT_EQ("Now is the time <&", s.toXml()); @@ -178,7 +178,7 @@ TEST(XmlRpc, testDateTime) { // DateTime int offset = 0; // Construct from XML - XmlRpcValue dateTime( + const XmlRpcValue dateTime( "19040503T03:12:35", &offset); ASSERT_EQ(XmlRpcValue::TypeDateTime, dateTime.getType()); @@ -286,7 +286,7 @@ TEST(XmlRpc, testArray) { EXPECT_EQ(a, aXml); // Array copy works - XmlRpcValue copy(a); + const XmlRpcValue copy(a); ASSERT_EQ(a.getType(), copy.getType()); ASSERT_EQ(a.size(), copy.size()); for (int i = 0; i < 3; i++) { @@ -345,7 +345,7 @@ TEST(XmlRpc, testStruct) { ""; int offset = 0; - XmlRpcValue structXml(csStructXml, &offset); + const XmlRpcValue structXml(csStructXml, &offset); EXPECT_EQ(struct1, structXml); for (XmlRpcValue::iterator itr = struct1.begin(); itr != struct1.end(); @@ -399,7 +399,7 @@ TEST(XmlRpc, testStruct) { TEST(XmlRpc, base64) { char data[] = {1, 2}; - XmlRpcValue bin(data, 2); + const XmlRpcValue bin(data, 2); EXPECT_EQ(XmlRpcValue::TypeBase64, bin.getType()); EXPECT_EQ(2, bin.size());