mirror of
https://github.com/pocoproject/poco.git
synced 2025-04-06 10:55:59 +02:00
format() bool support
This commit is contained in:
parent
9e8e627347
commit
ae607d40e5
@ -160,6 +160,8 @@ namespace
|
|||||||
str << AnyCast<Int64>(any);
|
str << AnyCast<Int64>(any);
|
||||||
else if (any.type() == typeid(UInt64))
|
else if (any.type() == typeid(UInt64))
|
||||||
str << AnyCast<UInt64>(any);
|
str << AnyCast<UInt64>(any);
|
||||||
|
else if (any.type() == typeid(bool))
|
||||||
|
str << AnyCast<bool>(any);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
@ -176,6 +178,9 @@ namespace
|
|||||||
prepareFormat(str, type);
|
prepareFormat(str, type);
|
||||||
switch (type)
|
switch (type)
|
||||||
{
|
{
|
||||||
|
case 'b':
|
||||||
|
str << AnyCast<bool>(*itVal++);
|
||||||
|
break;
|
||||||
case 'c':
|
case 'c':
|
||||||
str << AnyCast<char>(*itVal++);
|
str << AnyCast<char>(*itVal++);
|
||||||
break;
|
break;
|
||||||
|
@ -46,6 +46,7 @@
|
|||||||
#include "FormatTest.h"
|
#include "FormatTest.h"
|
||||||
#include "CppUnit/TestCaller.h"
|
#include "CppUnit/TestCaller.h"
|
||||||
#include "CppUnit/TestSuite.h"
|
#include "CppUnit/TestSuite.h"
|
||||||
|
#include "Poco/Any.h"
|
||||||
#include "Poco/Format.h"
|
#include "Poco/Format.h"
|
||||||
#include "Poco/Exception.h"
|
#include "Poco/Exception.h"
|
||||||
|
|
||||||
@ -211,12 +212,44 @@ void FormatTest::testInt()
|
|||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
void FormatTest::testBool()
|
||||||
|
{
|
||||||
|
bool b = true;
|
||||||
|
std::string s = format("%b", b);
|
||||||
|
assert (s == "1");
|
||||||
|
|
||||||
|
b = false;
|
||||||
|
s = format("%b", b);
|
||||||
|
assert (s == "0");
|
||||||
|
|
||||||
|
std::vector<Poco::Any> bv;
|
||||||
|
bv.push_back(false);
|
||||||
|
bv.push_back(true);
|
||||||
|
bv.push_back(false);
|
||||||
|
bv.push_back(true);
|
||||||
|
bv.push_back(false);
|
||||||
|
bv.push_back(true);
|
||||||
|
bv.push_back(false);
|
||||||
|
bv.push_back(true);
|
||||||
|
bv.push_back(false);
|
||||||
|
bv.push_back(true);
|
||||||
|
|
||||||
|
s.clear();
|
||||||
|
format(s, "%b%b%b%b%b%b%b%b%b%b", bv);
|
||||||
|
assert (s == "0101010101");
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
void FormatTest::testAnyInt()
|
void FormatTest::testAnyInt()
|
||||||
{
|
{
|
||||||
char c = 42;
|
char c = 42;
|
||||||
std::string s(format("%?i", c));
|
std::string s(format("%?i", c));
|
||||||
assert (s == "42");
|
assert (s == "42");
|
||||||
|
|
||||||
|
bool b = true;
|
||||||
|
s = format("%?i", b);
|
||||||
|
assert (s == "1");
|
||||||
|
|
||||||
signed char sc = -42;
|
signed char sc = -42;
|
||||||
s = format("%?i", sc);
|
s = format("%?i", sc);
|
||||||
assert (s == "-42");
|
assert (s == "-42");
|
||||||
@ -361,6 +394,7 @@ CppUnit::Test* FormatTest::suite()
|
|||||||
CppUnit::TestSuite* pSuite = new CppUnit::TestSuite("FormatTest");
|
CppUnit::TestSuite* pSuite = new CppUnit::TestSuite("FormatTest");
|
||||||
|
|
||||||
CppUnit_addTest(pSuite, FormatTest, testChar);
|
CppUnit_addTest(pSuite, FormatTest, testChar);
|
||||||
|
CppUnit_addTest(pSuite, FormatTest, testBool);
|
||||||
CppUnit_addTest(pSuite, FormatTest, testInt);
|
CppUnit_addTest(pSuite, FormatTest, testInt);
|
||||||
CppUnit_addTest(pSuite, FormatTest, testAnyInt);
|
CppUnit_addTest(pSuite, FormatTest, testAnyInt);
|
||||||
CppUnit_addTest(pSuite, FormatTest, testFloatFix);
|
CppUnit_addTest(pSuite, FormatTest, testFloatFix);
|
||||||
|
@ -61,6 +61,7 @@ public:
|
|||||||
|
|
||||||
void testChar();
|
void testChar();
|
||||||
void testInt();
|
void testInt();
|
||||||
|
void testBool();
|
||||||
void testAnyInt();
|
void testAnyInt();
|
||||||
void testFloatFix();
|
void testFloatFix();
|
||||||
void testFloatSci();
|
void testFloatSci();
|
||||||
|
Loading…
x
Reference in New Issue
Block a user