Cómo escribir un predicado a medida para multi_index_containder con composite_key?
-
26-09-2019 - |
Pregunta
Busqué en Google y busqué en el hombre del impulso, pero no encontró ningún ejemplo. Puede ser que es una pregunta estúpida ... de todos modos.
Así que tenemos la famosa agenda del hombre:
typedef multi_index_container<
phonebook_entry,
indexed_by<
ordered_non_unique<
composite_key<
phonebook_entry,
member<phonebook_entry,std::string,&phonebook_entry::family_name>,
member<phonebook_entry,std::string,&phonebook_entry::given_name>
>,
composite_key_compare<
std::less<std::string>, // family names sorted as by default
std::greater<std::string> // given names reversed
>
>,
ordered_unique<
member<phonebook_entry,std::string,&phonebook_entry::phone_number>
>
>
> phonebook;
phonebook pb;
...
// look for all Whites
std::pair<phonebook::iterator,phonebook::iterator> p=
pb.equal_range(boost::make_tuple("White"), my_custom_comp());
¿Cómo debe my_custom_comp mirada () como? Quiero decir que es claro para mí, entonces se necesita boost::multi_index::composite_key_result<CompositeKey>
como un argumen (debido a errores de compilación :)), pero lo que es CompositeKey en ese caso particular?
struct my_custom_comp
{
bool operator()( ?? boost::multi_index::composite_key_result<CompositeKey> ?? ) const
{
return blah_blah_blah;
}
};
Gracias de antemano.
Solución
Debe quedar como composite_key_compare
. Para su caso (versión sin plantilla):
typedef composite_key<
phonebook_entry,
member<phonebook_entry,std::string,&phonebook_entry::family_name>,
member<phonebook_entry,std::string,&phonebook_entry::given_name>
> my_comp_type_t;
struct my_custom_comp
{
bool operator()(
const boost::tuple<const char*>& x,
const boost::multi_index::composite_key_result<my_comp_type_t>& y ) const
{
return false; // should return something instead of false
}
bool operator()(
const boost::multi_index::composite_key_result<my_comp_type_t>& y,
const boost::tuple<const char*>& x ) const
{
return false; // should return something instead of false
}
};
Licenciado bajo: CC-BY-SA con atribución
No afiliado a StackOverflow