querying.cpp

来自「Boost provides free peer-reviewed portab」· C++ 代码 · 共 271 行

CPP
271
字号
/*=============================================================================    Copyright (c) 2005 Dan Marsden    Copyright (c) 2005-2007 Joel de Guzman    Copyright (c) 2007 Hartmut Kaiser    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/spirit/home/phoenix/stl/algorithm/querying.hpp>#include <boost/spirit/include/phoenix_core.hpp>#include <boost/detail/lightweight_test.hpp>#include <set>#include <functional>namespace{    struct even    {        bool operator()(const int i) const        {            return i % 2 == 0;        }    };    struct mod_2_comparison    {        bool operator()(            const int lhs,            const int rhs)        {            return lhs % 2 == rhs % 2;        };    };    void find_test()    {        using namespace boost::phoenix;        using namespace boost::phoenix::arg_names;        int array[] = {1,2,3};        BOOST_TEST(find(arg1,2)(array) == array + 1);        std::set<int> s(array, array + 3);        BOOST_TEST(find(arg1, 2)(s) == s.find(2));        return;    }    void find_if_test()    {        using namespace boost::phoenix;        using namespace boost::phoenix::arg_names;        int array[] = {1,2,3};        BOOST_TEST(find_if(arg1, even())(array) == array + 1);        return;    }    void find_end_test()    {        using namespace boost::phoenix;        using namespace boost::phoenix::arg_names;        int array[] = {1,2,3,1,2,3,1};        int pattern[] = {1,2,3};        BOOST_TEST(find_end(arg1, arg2)(array, pattern) == array + 3);        int pattern2[] = {5,6,5};        BOOST_TEST(find_end(arg1, arg2, mod_2_comparison())(array, pattern2) == array + 3);        return;    }    void find_first_of_test()    {        using namespace boost::phoenix;        using namespace boost::phoenix::arg_names;        int array[] = {1,2,3};        int search_for[] = {2,3,4};        BOOST_TEST(find_first_of(arg1, arg2)(array, search_for) == array + 1);        int search_for2[] = {0};        BOOST_TEST(find_first_of(arg1, arg2, mod_2_comparison())(array, search_for2) == array + 1);        return;    }    void adjacent_find_test()    {        using namespace boost::phoenix;        using namespace boost::phoenix::arg_names;        int array[] = {0,1,3,4,4};        BOOST_TEST(adjacent_find(arg1)(array) == array + 3);        BOOST_TEST(adjacent_find(arg1, mod_2_comparison())(array) == array + 1);        return;    }    void count_test()    {        using namespace boost::phoenix;        using namespace boost::phoenix::arg_names;        int array[] = {1,1,0,1,1};        BOOST_TEST(count(arg1, 1)(array) == 4);        return;    }    void count_if_test()    {        using namespace boost::phoenix;        using namespace boost::phoenix::arg_names;        int array[] = {1,2,3,4,5};        BOOST_TEST(count_if(arg1, even())(array) == 2);        return;    }    void distance_test()    {        using namespace boost::phoenix;        using namespace boost::phoenix::arg_names;        int array[] = {1,1,0,1,1};        BOOST_TEST(distance(arg1)(array) == 5);        return;    }    void mismatch_test()    {        using namespace boost::phoenix;        using namespace boost::phoenix::arg_names;        int array[] = {1,2,3,4,5};        int search[] = {1,2,4};        BOOST_TEST(            mismatch(arg1, arg2)(array, search) ==             std::make_pair(array + 2, search + 2));        int search2[] = {1,2,1,1};        BOOST_TEST(            mismatch(arg1, arg2, mod_2_comparison())(array, search2)             == std::make_pair(array + 3, search2 + 3));        return;    }    void equal_test()    {        using namespace boost::phoenix;        using namespace boost::phoenix::arg_names;        int array[] = {1,2,3};        int array2[] = {1,2,3};        int array3[] = {1,2,4};        BOOST_TEST(            equal(arg1, arg2)(array, array2));        BOOST_TEST(            !equal(arg1, arg2)(array, array3));        BOOST_TEST(            equal(arg1, arg2, mod_2_comparison())(array, array2));        BOOST_TEST(            !equal(arg1, arg2, mod_2_comparison())(array, array3));        return;    }    void search_test()    {        using namespace boost::phoenix;        using namespace boost::phoenix::arg_names;        int array[] = {1,2,3,1,2,3};        int pattern[] = {2,3};        BOOST_TEST(            search(arg1, arg2)(array, pattern) == array + 1);        int pattern2[] = {1,1};        BOOST_TEST(            search(arg1, arg2, mod_2_comparison())(array, pattern2) == array + 2);        return;    }    void lower_bound_test()    {        using namespace boost::phoenix;        using namespace boost::phoenix::arg_names;        int array[] = {1,2,3};        const std::set<int> test_set(array, array + 3);        BOOST_TEST(lower_bound(arg1, 2)(array) == array + 1);        BOOST_TEST(lower_bound(arg1, 2)(test_set) == test_set.lower_bound(2));        int array2[] = {3,2,1};        const std::set<int, std::greater<int> > test_set2(array2, array2 + 3);        BOOST_TEST(boost::phoenix::lower_bound(arg1, 2, std::greater<int>())(array2) ==                   array2 + 1);        BOOST_TEST(boost::phoenix::lower_bound(arg1, 2, std::greater<int>())(test_set2) ==                   test_set2.lower_bound(2));        return;    }    void upper_bound_test()    {        using namespace boost::phoenix;        using namespace boost::phoenix::arg_names;        int array[] = {1,2,3};        const std::set<int> test_set(array, array + 3);        BOOST_TEST(upper_bound(arg1, 2)(array) == array + 2);        BOOST_TEST(upper_bound(arg1, 2)(test_set) == test_set.upper_bound(2));        int array2[] = {3,2,1};        const std::set<int, std::greater<int> > test_set2(array2, array2 + 3);        BOOST_TEST(boost::phoenix::upper_bound(arg1, 2, std::greater<int>())(array2) ==                   array2 + 2);        BOOST_TEST(boost::phoenix::upper_bound(arg1, 2, std::greater<int>())(test_set2) ==                   test_set2.upper_bound(2));        return;    }    void equal_range_test()    {        using namespace boost::phoenix;        using namespace boost::phoenix::arg_names;        int array[] = {1,2,2,3};        const std::set<int> test_set(array, array + 4);        BOOST_TEST(equal_range(arg1, 2)(array).first ==                    array + 1);        BOOST_TEST(equal_range(arg1, 2)(array).second ==                    array + 3);        BOOST_TEST(equal_range(arg1, 2)(test_set).first ==                    test_set.equal_range(2).first);        BOOST_TEST(equal_range(arg1, 2)(test_set).second ==                    test_set.equal_range(2).second);        int array2[] = {3,2,2,1};        const std::set<int, std::greater<int> > test_set2(array2, array2 + 4);        BOOST_TEST(boost::phoenix::equal_range(arg1, 2, std::greater<int>())(array2).first ==                    array2 + 1);        BOOST_TEST(boost::phoenix::equal_range(arg1, 2, std::greater<int>())(array2).second ==                    array2 + 3);        BOOST_TEST(boost::phoenix::equal_range(arg1, 2, std::greater<int>())(test_set2).first ==                    test_set2.equal_range(2).first);        BOOST_TEST(boost::phoenix::equal_range(arg1, 2, std::greater<int>())(test_set2).second ==                    test_set2.equal_range(2).second);        return;    }    void binary_search_test()    {        using namespace boost::phoenix;        using namespace boost::phoenix::arg_names;        int array[] = {1,2,3};        BOOST_TEST(binary_search(arg1, 2)(array));        BOOST_TEST(!binary_search(arg1, 4)(array));        return;    }}int main(){    find_test();    find_if_test();    find_end_test();    find_first_of_test();    adjacent_find_test();    count_test();    count_if_test();    distance_test();    mismatch_test();    equal_test();    search_test();    lower_bound_test();    upper_bound_test();    equal_range_test();    binary_search_test();    return boost::report_errors();}

⌨️ 快捷键说明

复制代码Ctrl + C
搜索代码Ctrl + F
全屏模式F11
增大字号Ctrl + =
减小字号Ctrl + -
显示快捷键?