LUMIERA.clone/tests/library/format-helper-test.cpp

152 lines
4.2 KiB
C++
Raw Normal View History

/*
FormatHelper(Test) - validate formatting and diagnostics helpers
2010-12-17 23:28:49 +01:00
Copyright (C) Lumiera.org
2009, Hermann Vosseler <Ichthyostega@web.de>
2010-12-17 23:28:49 +01:00
This program is free software; you can redistribute it and/or
modify it under the terms of the GNU General Public License as
2010-12-17 23:28:49 +01:00
published by the Free Software Foundation; either version 2 of
the License, or (at your option) any later version.
This program is distributed in the hope that it will be useful,
but WITHOUT ANY WARRANTY; without even the implied warranty of
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
GNU General Public License for more details.
2010-12-17 23:28:49 +01:00
You should have received a copy of the GNU General Public License
along with this program; if not, write to the Free Software
Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA.
2010-12-17 23:28:49 +01:00
* *****************************************************/
#include "lib/test/run.hpp"
#include "lib/format-util.hpp"
#include "lib/format-string.hpp"
#include "lib/iter-adapter-stl.hpp"
#include "lib/error.hpp"
#include <iostream>
#include <vector>
#include <string>
using lib::transformIterator;
using lib::iter_stl::eachElm;
using util::_Fmt;
using std::vector;
using std::string;
using std::to_string;
using std::cout;
using std::endl;
namespace util {
namespace test {
class Reticent
{ };
class UnReticent
: public Reticent
{
public:
operator string() const { return "hey Joe!"; }
};
class AutoCounter
{
static uint cnt;
uint id_;
double d_;
public:
AutoCounter(double d)
: id_(++cnt)
, d_(d*2)
{ }
operator string() const
{
return _Fmt("Nr.%02d(%3.1f)") % id_ % d_;
}
};
uint AutoCounter::cnt = 0;
/***************************************************************************//**
* @test verifies the proper working of some string-formatting helper functions.
* - util::str() provides a failsafe to-String conversion, preferring
* an built-in conversion, falling back to just a mangled type string.
* @see format-util.hpp
*/
class FormatHelper_test
: public Test
{
void
run (Arg)
{
check2String();
checkStringJoin();
}
/** @test verify a failsafe to-string conversion. */
void
check2String ()
{
std::cout << "Displaying some types....\n";
Reticent closeLipped;
UnReticent chatterer;
cout << str (closeLipped) << endl;
cout << str (closeLipped, "he says: ", "<no comment>") << endl;
cout << str (chatterer) << endl;
cout << str (chatterer, "he says: ", "<no comment>") << endl;
cout << str (false, "the truth: ") << endl;
cout << str (12.34e55, "just a number: ") << endl;
cout << str (short(12)) << str (345L) << str ('X') << endl;
}
/** @test verify delimiter separated joining of arbitrary collections.
* - the first test uses a STL container, which means we need to wrap
* into a lib::RangeIter. Moreover, lexical_cast is used to convert
* the double numbers into strings.
* - the second test uses an inline transforming iterator to build a
* series of AutoCounter objects, which provide a custom string
* conversion function. Moreover, since the transforming iterator
* conforms to the Lumiera Forward Iterator concept, we can just
* move the rvalue into the formatting function without much ado
*/
void
checkStringJoin()
{
vector<double> dubious;
for (uint i=0; i<10; ++i)
dubious.push_back(1.1*i);
std::function<AutoCounter(double)> justCount = [](double d){ return AutoCounter(d); };
cout << join(dubious, "--+--") << endl;
cout << join(transformIterator(eachElm(dubious)
,justCount)) << endl;
}
};
LAUNCHER (FormatHelper_test, "unit common");
}} // namespace util::test