1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66
|
// Copyright (c) 2001-2012 Hartmut Kaiser
// Copyright (c) 2012 yyyy yyyy <typhoonking77@hotmail.com>
//
// Distributed under the Boost Software License, Version 1.0. (See accompanying
// file LICENSE_1_0.txt or copy at http://www.boost.org/LICENSE_1_0.txt)
#include <boost/config/warning_disable.hpp>
#include <boost/detail/lightweight_test.hpp>
#include <string>
#include <vector>
#include<boost/spirit/include/karma.hpp>
int main()
{
namespace karma = boost::spirit::karma;
int num[] = {0, 1, 2, 3, 4, 5};
std::vector<int> contents(num, num + sizeof(num) / sizeof(int));
{
std::string result;
BOOST_TEST(karma::generate(std::back_inserter(result),
*karma::center[karma::int_], contents));
BOOST_TEST(result == " 0 1 2 3 4 5 ");
}
{
std::string result;
BOOST_TEST(karma::generate(std::back_inserter(result),
*karma::center(5)[karma::int_], contents));
BOOST_TEST(result == " 0 1 2 3 4 5 ");
}
{
std::string result;
BOOST_TEST(karma::generate(std::back_inserter(result),
*karma::center("_")[karma::int_], contents));
BOOST_TEST(result == "_____0_________1_________2_________3_________4_________5____");
}
{
std::string result;
BOOST_TEST(karma::generate(std::back_inserter(result),
*karma::center(5, "_")[karma::int_], contents));
BOOST_TEST(result == "__0____1____2____3____4____5__");
}
{
std::string result;
BOOST_TEST(karma::generate(std::back_inserter(result),
*karma::center(karma::char_("_"))[karma::int_], contents));
BOOST_TEST(result == "_____0_________1_________2_________3_________4_________5____");
}
{
std::string result;
BOOST_TEST(karma::generate(std::back_inserter(result),
*karma::center(5, karma::char_("_"))[karma::int_], contents));
BOOST_TEST(result == "__0____1____2____3____4____5__");
}
return boost::report_errors();
}
|