/* Boost.MultiIndex test for comparison functions. * * Copyright 2003-2013 Joaquin M Lopez Munoz. * 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/multi_index for library home page. */ #include "test_comparison.hpp" #include /* keep it first to prevent nasty warns in MSVC */ #include "pre_multi_index.hpp" #include "employee.hpp" #include "pair_of_ints.hpp" #include using namespace boost::multi_index; template struct lookup_list{ typedef multi_index_container< Value, indexed_by< sequenced<>, ordered_non_unique > > > type; }; template struct lookup_vector{ typedef multi_index_container< Value, indexed_by< random_access<>, ordered_non_unique > > > type; }; void test_comparison() { employee_set es; employee_set_by_name& i1=get<1>(es); employee_set_by_age& i2=get<2>(es); employee_set_as_inserted& i3=get<3>(es); employee_set_by_ssn& i4=get<4>(es); employee_set_randomly& i5=get<5>(es); es.insert(employee(0,"Joe",31,1123)); es.insert(employee(1,"Robert",27,5601)); es.insert(employee(2,"John",40,7889)); es.insert(employee(3,"Albert",20,9012)); es.insert(employee(4,"John",57,1002)); employee_set es2; employee_set_by_name& i12=get(es2); employee_set_by_age& i22=get(es2); employee_set_as_inserted& i32=get<3>(es2); employee_set_by_ssn& i42=get<4>(es2); employee_set_randomly& i52=get<5>(es2); es2.insert(employee(0,"Joe",31,1123)); es2.insert(employee(1,"Robert",27,5601)); es2.insert(employee(2,"John",40,7889)); es2.insert(employee(3,"Albert",20,9012)); BOOST_TEST(es==es&&es<=es&&es>=es&& i12==i12&& i22==i22&&i22<=i22&&i22>=i22&& i32==i32&&i32<=i32&&i32>=i32&& i42==i42&& i52==i52&&i52<=i52&&i52>=i52); BOOST_TEST(es!=es2&&es2es2&&!(es<=es2)&&!(es2>=es)); BOOST_TEST(i1!=i12); BOOST_TEST(i2!=i22&&i22i22&&!(i2<=i22)&&!(i22>=i2)); BOOST_TEST(i3!=i32&&i32i32&&!(i3<=i32)&&!(i32>=i3)); BOOST_TEST(i4!=i42); BOOST_TEST(i5!=i52&&i52i52&&!(i5<=i52)&&!(i52>=i5)); multi_index_container< pair_of_ints, indexed_by< hashed_non_unique > > hc1,hc2; hc1.insert(pair_of_ints(0,0)); hc1.insert(pair_of_ints(0,1)); hc1.insert(pair_of_ints(0,2)); hc1.insert(pair_of_ints(0,3)); hc1.insert(pair_of_ints(1,0)); hc1.insert(pair_of_ints(1,1)); hc2.insert(pair_of_ints(0,2)); hc2.insert(pair_of_ints(0,1)); hc2.insert(pair_of_ints(1,1)); hc2.insert(pair_of_ints(1,0)); hc2.insert(pair_of_ints(0,3)); hc2.insert(pair_of_ints(0,0)); BOOST_TEST(hc1==hc2); hc1.insert(pair_of_ints(0,4)); hc2.insert(pair_of_ints(0,5)); BOOST_TEST(hc1!=hc2); lookup_list::type l1; lookup_list::type l2; lookup_vector::type l3; lookup_list::type l4; lookup_vector::type l5; l1.push_back(3); l1.push_back(4); l1.push_back(5); l1.push_back(1); l1.push_back(2); l2.push_back(char(3)); l2.push_back(char(4)); l2.push_back(char(5)); l2.push_back(char(1)); l2.push_back(char(2)); l3.push_back(char(3)); l3.push_back(char(4)); l3.push_back(char(5)); l3.push_back(char(1)); l3.push_back(char(2)); l4.push_back(long(3)); l4.push_back(long(4)); l4.push_back(long(5)); l4.push_back(long(1)); l5.push_back(long(3)); l5.push_back(long(4)); l5.push_back(long(5)); l5.push_back(long(1)); BOOST_TEST(l1==l2&&l1<=l2&&l1>=l2); BOOST_TEST( get<1>(l1)==get<1>(l2)&&get<1>(l1)<=get<1>(l2)&&get<1>(l1)>=get<1>(l2)); BOOST_TEST( get<1>(l1)==get<1>(l3)&&get<1>(l1)<=get<1>(l3)&&get<1>(l1)>=get<1>(l3)); BOOST_TEST(l1!=l4&&l4l4); BOOST_TEST( get<1>(l1)!=get<1>(l4)&&get<1>(l1)(l4)&&get<1>(l4)>get<1>(l1)); BOOST_TEST(l3!=l5&&l5l5); BOOST_TEST( get<1>(l3)!=get<1>(l5)&&get<1>(l3)(l5)&&get<1>(l5)>get<1>(l3)); }