В документации Boost MPL указано, что boost::map::equal
"Возвращает интегральную константу с истинным значением, если две последовательности Seq1 и Seq2 идентичны при сравнении _element_ по _element_ .
но похоже, что карта ассоциативной последовательности не проверяется на равенство element _wise_:
Следующая демонстрация продемонстрирует это: Map2 должен равняться Map3, которые оба увеличивают значение 'int_‹1>' value_type в 'key'. Посмотрите на typedef, определяющий Map3. Размер и единственный элемент сбрасываются в демо:
#include<iostream>
#include<boost/mpl/map.hpp>
#include<boost/mpl/at.hpp>
#include<boost/mpl/insert.hpp>
#include<boost/mpl/erase_key.hpp>
#include<boost/mpl/pair.hpp>
#include<boost/mpl/int.hpp>
#include<boost/mpl/plus.hpp>
#include<boost/mpl/equal.hpp>
#include<boost/mpl/size.hpp>
#include<boost/mpl/front.hpp>
namespace mpl = boost::mpl;
using mpl::int_;
using std::cout;
using std::endl;
using std::is_same;
int main(int argc, char *argv[])
{
typedef int key;
typedef typename mpl::map<mpl::pair<key, int_<1>>> Map;
typedef typename mpl::map<mpl::pair<key, int_<2>>> Map2;
typedef typename mpl::insert<
typename mpl::erase_key<Map,
key>::type,
mpl::pair<key,
typename mpl::plus<int_<1>,
typename mpl::at<Map, key>::type>::type
>::type
>::type Map3;
cout << "equal? " << mpl::equal<Map2,Map3>::type::value << endl;
cout << "size? " << mpl::size<Map3>::value << endl;
cout << "key type at front? " << typeid(mpl::front<Map3>::type::first).name() << endl;
cout << "value type at front? " << mpl::front<Map3>::type::second::value << endl;
cout << "expected size? " << mpl::size<Map2>::value << endl;
cout << "expected key type at front? " << typeid(mpl::front<Map2>::type::first).name() << endl;
cout << "expected value type at front? " << mpl::front<Map2>::type::second::value << endl;
return 0;
}
Я использую gcc 4.8.1 с Boost 1.51.