From 483eb2f56657e8e7f419ab1a4fab8dce9ade8609 Mon Sep 17 00:00:00 2001 From: Daniel Baumann Date: Sat, 27 Apr 2024 20:24:20 +0200 Subject: Adding upstream version 14.2.21. Signed-off-by: Daniel Baumann --- src/boost/libs/tokenizer/test/Jamfile.v2 | 15 +++ src/boost/libs/tokenizer/test/examples.cpp | 150 +++++++++++++++++++++ src/boost/libs/tokenizer/test/simple_example_1.cpp | 25 ++++ src/boost/libs/tokenizer/test/simple_example_2.cpp | 24 ++++ src/boost/libs/tokenizer/test/simple_example_3.cpp | 25 ++++ src/boost/libs/tokenizer/test/simple_example_4.cpp | 24 ++++ src/boost/libs/tokenizer/test/simple_example_5.cpp | 34 +++++ 7 files changed, 297 insertions(+) create mode 100644 src/boost/libs/tokenizer/test/Jamfile.v2 create mode 100644 src/boost/libs/tokenizer/test/examples.cpp create mode 100644 src/boost/libs/tokenizer/test/simple_example_1.cpp create mode 100644 src/boost/libs/tokenizer/test/simple_example_2.cpp create mode 100644 src/boost/libs/tokenizer/test/simple_example_3.cpp create mode 100644 src/boost/libs/tokenizer/test/simple_example_4.cpp create mode 100644 src/boost/libs/tokenizer/test/simple_example_5.cpp (limited to 'src/boost/libs/tokenizer/test') diff --git a/src/boost/libs/tokenizer/test/Jamfile.v2 b/src/boost/libs/tokenizer/test/Jamfile.v2 new file mode 100644 index 00000000..58bc06fb --- /dev/null +++ b/src/boost/libs/tokenizer/test/Jamfile.v2 @@ -0,0 +1,15 @@ +#~ Copyright Rene Rivera 2008 +#~ 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) + +import testing ; + +test-suite tokenizer +: [ run examples.cpp + /boost/test//boost_test_exec_monitor/static ] + [ run simple_example_1.cpp ] + [ run simple_example_2.cpp ] + [ run simple_example_3.cpp ] + [ run simple_example_4.cpp ] + [ run simple_example_5.cpp ] + ; diff --git a/src/boost/libs/tokenizer/test/examples.cpp b/src/boost/libs/tokenizer/test/examples.cpp new file mode 100644 index 00000000..1e0b69b8 --- /dev/null +++ b/src/boost/libs/tokenizer/test/examples.cpp @@ -0,0 +1,150 @@ +// Boost tokenizer examples -------------------------------------------------// + +// (c) Copyright John R. Bandela 2001. + +// 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) + +// See http://www.boost.org for updates, documentation, and revision history. + +#include +#include +#include +#include +#include +#include + +#include + +int test_main( int /*argc*/, char* /*argv*/[] ) +{ + using namespace boost; + + // Use tokenizer + { + const std::string test_string = ";;Hello|world||-foo--bar;yow;baz|"; + std::string answer[] = { "Hello", "world", "foo", "bar", "yow", "baz" }; + typedef tokenizer > Tok; + char_separator sep("-;|"); + Tok t(test_string, sep); + BOOST_REQUIRE(std::equal(t.begin(),t.end(),answer)); + } + { + const std::string test_string = ";;Hello|world||-foo--bar;yow;baz|"; + std::string answer[] = { "", "", "Hello", "|", "world", "|", "", "|", "", + "foo", "", "bar", "yow", "baz", "|", "" }; + typedef tokenizer > Tok; + char_separator sep("-;", "|", boost::keep_empty_tokens); + Tok t(test_string, sep); + BOOST_REQUIRE(std::equal(t.begin(), t.end(), answer)); + } + { + const std::string test_string = "This,,is, a.test.."; + std::string answer[] = {"This","is","a","test"}; + typedef tokenizer<> Tok; + Tok t(test_string); + BOOST_REQUIRE(std::equal(t.begin(),t.end(),answer)); + } + + { + const std::string test_string = "Field 1,\"embedded,comma\",quote \\\", escape \\\\"; + std::string answer[] = {"Field 1","embedded,comma","quote \""," escape \\"}; + typedef tokenizer > Tok; + Tok t(test_string); + BOOST_REQUIRE(std::equal(t.begin(),t.end(),answer)); + } + + { + const std::string test_string = ",1,;2\\\";3\\;,4,5^\\,\'6,7\';"; + std::string answer[] = {"","1","","2\"","3;","4","5\\","6,7",""}; + typedef tokenizer > Tok; + escaped_list_separator sep("\\^",",;","\"\'"); + Tok t(test_string,sep); + BOOST_REQUIRE(std::equal(t.begin(),t.end(),answer)); + } + + { + const std::string test_string = "12252001"; + std::string answer[] = {"12","25","2001"}; + typedef tokenizer Tok; + boost::array offsets = {{2,2,4}}; + offset_separator func(offsets.begin(),offsets.end()); + Tok t(test_string,func); + BOOST_REQUIRE(std::equal(t.begin(),t.end(),answer)); + } + + // Use token_iterator_generator + { + const std::string test_string = "This,,is, a.test.."; + std::string answer[] = {"This","is","a","test"}; + typedef token_iterator_generator >::type Iter; + Iter begin = make_token_iterator(test_string.begin(), + test_string.end(),char_delimiters_separator()); + Iter end; + BOOST_REQUIRE(std::equal(begin,end,answer)); + } + + { + const std::string test_string = "Field 1,\"embedded,comma\",quote \\\", escape \\\\"; + std::string answer[] = {"Field 1","embedded,comma","quote \""," escape \\"}; + typedef token_iterator_generator >::type Iter; + Iter begin = make_token_iterator(test_string.begin(), + test_string.end(),escaped_list_separator()); + Iter begin_c(begin); + Iter end; + BOOST_REQUIRE(std::equal(begin,end,answer)); + + while(begin_c != end) + { + BOOST_REQUIRE(begin_c.at_end() == 0); + ++begin_c; + } + BOOST_REQUIRE(begin_c.at_end()); + } + + { + const std::string test_string = "12252001"; + std::string answer[] = {"12","25","2001"}; + typedef token_iterator_generator::type Iter; + boost::array offsets = {{2,2,4}}; + offset_separator func(offsets.begin(),offsets.end()); + Iter begin = make_token_iterator(test_string.begin(), + test_string.end(),func); + Iter end= make_token_iterator(test_string.end(), + test_string.end(),func); + BOOST_REQUIRE(std::equal(begin,end,answer)); + } + + // Test copying + { + const std::string test_string = "abcdef"; + token_iterator_generator::type beg, end, other; + boost::array ar = {{1,2,3}}; + offset_separator f(ar.begin(),ar.end()); + beg = make_token_iterator(test_string.begin(),test_string.end(),f); + + ++beg; + other = beg; + ++other; + + BOOST_REQUIRE(*beg=="bc"); + BOOST_REQUIRE(*other=="def"); + + other = make_token_iterator(test_string.begin(), + test_string.end(),f); + + BOOST_REQUIRE(*other=="a"); + } + + // Test non-default constructed char_delimiters_separator + { + const std::string test_string = "how,are you, doing"; + std::string answer[] = {"how",",","are you",","," doing"}; + tokenizer<> t(test_string,char_delimiters_separator(true,",","")); + BOOST_REQUIRE(std::equal(t.begin(),t.end(),answer)); + } + + return 0; +} + diff --git a/src/boost/libs/tokenizer/test/simple_example_1.cpp b/src/boost/libs/tokenizer/test/simple_example_1.cpp new file mode 100644 index 00000000..950f7328 --- /dev/null +++ b/src/boost/libs/tokenizer/test/simple_example_1.cpp @@ -0,0 +1,25 @@ +// (c) Copyright John R. Bandela 2001. + +// 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) + +// See http://www.boost.org/libs/tokenizer for documenation + + +// simple_example_1.cpp +#include +#include +#include + +int main(){ + using namespace std; + using namespace boost; + string s = "This is, a test"; + tokenizer<> tok(s); + for(tokenizer<>::iterator beg=tok.begin(); beg!=tok.end();++beg){ + cout << *beg << "\n"; + } + return 0; +} + diff --git a/src/boost/libs/tokenizer/test/simple_example_2.cpp b/src/boost/libs/tokenizer/test/simple_example_2.cpp new file mode 100644 index 00000000..1bac2d9b --- /dev/null +++ b/src/boost/libs/tokenizer/test/simple_example_2.cpp @@ -0,0 +1,24 @@ +// (c) Copyright John R. Bandela 2001. + +// 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) + +// See http://www.boost.org/libs/tokenizer for documenation + +// simple_example_2.cpp +#include +#include +#include + +int main(){ + using namespace std; + using namespace boost; + string s = "Field 1,\"putting quotes around fields, allows commas\",Field 3"; + tokenizer > tok(s); + for(tokenizer >::iterator beg=tok.begin(); beg!=tok.end();++beg){ + cout << *beg << "\n"; + } + return 0; +} + diff --git a/src/boost/libs/tokenizer/test/simple_example_3.cpp b/src/boost/libs/tokenizer/test/simple_example_3.cpp new file mode 100644 index 00000000..6f47d353 --- /dev/null +++ b/src/boost/libs/tokenizer/test/simple_example_3.cpp @@ -0,0 +1,25 @@ +// (c) Copyright John R. Bandela 2001. + +// 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) + +// See http://www.boost.org/libs/tokenizer for documenation + +// simple_example_3.cpp +#include +#include +#include + +int main(){ + using namespace std; + using namespace boost; + string s = "12252001"; + int offsets[] = {2,2,4}; + offset_separator f(offsets, offsets+3); + tokenizer tok(s,f); + for(tokenizer::iterator beg=tok.begin(); beg!=tok.end();++beg){ + cout << *beg << "\n"; + } + return 0; +} diff --git a/src/boost/libs/tokenizer/test/simple_example_4.cpp b/src/boost/libs/tokenizer/test/simple_example_4.cpp new file mode 100644 index 00000000..cf7ead39 --- /dev/null +++ b/src/boost/libs/tokenizer/test/simple_example_4.cpp @@ -0,0 +1,24 @@ +// (c) Copyright John R. Bandela 2001. + +// 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) + +// See http://www.boost.org/libs/tokenizer for documenation + +// simple_example_4.cpp +#include +#include +#include + +int main(){ + using namespace std; + using namespace boost; + string s = "This is, a test"; + tokenizer > tok(s); + for(tokenizer >::iterator beg=tok.begin(); beg!=tok.end();++beg){ + cout << *beg << "\n"; + } + return 0; +} + diff --git a/src/boost/libs/tokenizer/test/simple_example_5.cpp b/src/boost/libs/tokenizer/test/simple_example_5.cpp new file mode 100644 index 00000000..8259533c --- /dev/null +++ b/src/boost/libs/tokenizer/test/simple_example_5.cpp @@ -0,0 +1,34 @@ +// (c) Copyright John R. Bandela 2001. + +// 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) + +// See http://www.boost.org/libs/tokenizer for documenation + +/// simple_example_5.cpp +#include +#include +#include + +#ifdef __BORLANDC__ +// compiler bug fix: +template class boost::token_iterator_generator::type; +#endif + +int main(){ + using namespace std; + using namespace boost; + string s = "12252001"; + int offsets[] = {2,2,4}; + offset_separator f(offsets, offsets+3); + typedef token_iterator_generator::type Iter; + Iter beg = make_token_iterator(s.begin(),s.end(),f); + Iter end = make_token_iterator(s.end(),s.end(),f); + // The above statement could also have been what is below + // Iter end; + for(;beg!=end;++beg){ + cout << *beg << "\n"; + } + return 0; +} -- cgit v1.2.3