mirror of
https://github.com/boostorg/spirit.git
synced 2026-01-19 04:42:11 +00:00
It is better to manage warnings on our side to know what warnings we need to fix or suppress, and the only thing that header does is disabling deprecation warnings on MSVC and ICC which we would prefer to not show to users.
121 lines
4.2 KiB
C++
121 lines
4.2 KiB
C++
/*=============================================================================
|
|
Copyright (c) 2002-2010 Hartmut Kaiser
|
|
Copyright (c) 2002-2010 Joel de Guzman
|
|
|
|
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)
|
|
=============================================================================*/
|
|
///////////////////////////////////////////////////////////////////////////////
|
|
//
|
|
// This sample demonstrates a generator for a comma separated list of numbers.
|
|
// No actions. It is based on the example qi/num_lists.cpp for reading in
|
|
// some numbers to generate.
|
|
//
|
|
///////////////////////////////////////////////////////////////////////////////
|
|
|
|
#include <boost/spirit/include/qi.hpp>
|
|
#include <boost/spirit/include/karma.hpp>
|
|
|
|
#include <iostream>
|
|
#include <string>
|
|
#include <list>
|
|
|
|
namespace client
|
|
{
|
|
namespace qi = boost::spirit::qi;
|
|
namespace karma = boost::spirit::karma;
|
|
namespace ascii = boost::spirit::ascii;
|
|
|
|
///////////////////////////////////////////////////////////////////////////
|
|
// Our number list parser, please see the example qi/numlist1.cpp for
|
|
// more information
|
|
///////////////////////////////////////////////////////////////////////////
|
|
template <typename Iterator>
|
|
bool parse_numbers(Iterator first, Iterator last, std::list<double>& v)
|
|
{
|
|
using qi::double_;
|
|
using qi::phrase_parse;
|
|
using ascii::space;
|
|
|
|
bool r = phrase_parse(first, last, double_ >> *(',' >> double_), space, v);
|
|
if (first != last)
|
|
return false;
|
|
return r;
|
|
}
|
|
|
|
///////////////////////////////////////////////////////////////////////////
|
|
// Our number list generator
|
|
///////////////////////////////////////////////////////////////////////////
|
|
//[tutorial_karma_numlist1
|
|
template <typename OutputIterator>
|
|
bool generate_numbers(OutputIterator& sink, std::list<double> const& v)
|
|
{
|
|
using karma::double_;
|
|
using karma::generate_delimited;
|
|
using ascii::space;
|
|
|
|
bool r = generate_delimited(
|
|
sink, // destination: output iterator
|
|
double_ << *(',' << double_), // the generator
|
|
space, // the delimiter-generator
|
|
v // the data to output
|
|
);
|
|
return r;
|
|
}
|
|
//]
|
|
}
|
|
|
|
////////////////////////////////////////////////////////////////////////////
|
|
// Main program
|
|
////////////////////////////////////////////////////////////////////////////
|
|
int
|
|
main()
|
|
{
|
|
std::cout << "/////////////////////////////////////////////////////////\n\n";
|
|
std::cout << "\t\tA comma separated list generator for Spirit...\n\n";
|
|
std::cout << "/////////////////////////////////////////////////////////\n\n";
|
|
|
|
std::cout << "Give me a comma separated list of numbers.\n";
|
|
std::cout << "Type [q or Q] to quit\n\n";
|
|
|
|
std::string str;
|
|
while (getline(std::cin, str))
|
|
{
|
|
if (str.empty() || str[0] == 'q' || str[0] == 'Q')
|
|
break;
|
|
|
|
std::list<double> v; // here we put the data to generate
|
|
if (client::parse_numbers(str.begin(), str.end(), v))
|
|
{
|
|
// ok, we got some numbers, now print them back out
|
|
std::cout << "-------------------------\n";
|
|
|
|
std::string generated;
|
|
std::back_insert_iterator<std::string> sink(generated);
|
|
if (!client::generate_numbers(sink, v))
|
|
{
|
|
std::cout << "-------------------------\n";
|
|
std::cout << "Generating failed\n";
|
|
std::cout << "-------------------------\n";
|
|
}
|
|
else
|
|
{
|
|
std::cout << "-------------------------\n";
|
|
std::cout << "Generated: " << generated << "\n";
|
|
std::cout << "-------------------------\n";
|
|
}
|
|
}
|
|
else
|
|
{
|
|
std::cout << "-------------------------\n";
|
|
std::cout << "Parsing failed\n";
|
|
std::cout << "-------------------------\n";
|
|
}
|
|
}
|
|
|
|
std::cout << "Bye... :-) \n\n";
|
|
return 0;
|
|
}
|
|
|
|
|