Désolé, je ne peux pas être plus précis dans le titre.Boost Multi_Index Question
Disons que j'ai une classe Foo
class Foo {
public:
Foo() { m_bitset.reset(); }
void set_i(int i) {
m_bitset.set(1);
m_i = i;
}
void set_j(int j) {
m_bitset.set(2);
m_j = j;
}
bool i_set() { return m_bitset(1); }
bool j_set() { return m_bitset(2); }
void clear_i() { m_bitset.reset(1); }
void clear_j() { m_bitset.reset(2); }
int get_i() {
assert(i_set());
return m_i;
}
int get_j() {
assert(j_set());
return m_j;
}
private:
int m_i, m_j;
bitset<2> m_bitset;
};
Et maintenant, je veux mettre Foo dans un multi_index.
typedef multi_index_container <
Foo,
indexed_by<
ordered_non_unique<BOOST_MULTI_INDEX_CONST_MEM_FUN(Foo, int, get_i)
>,
ordered_non_unique<BOOST_MULTI_INDEX_CONST_MEM_FUN(Foo, int, get_j)
>
>
> Foo_set;
Ce que je suis en train de comprendre est un moyen d'avoir mon genre multi_index de Foo qui ont des valeurs valides de i ou j (ou les deux dans le cas d'un composite_key et passer au-dessus du reste. donc Je ne veux pas le code ci-dessous pour sauter, je veux juste revenir seulement foos qui ont des valeurs valides pour i.
for (Foo_set::nth_index<1>::type::iterator it = foos.get<1>().begin(); it != foos.get<1>().end(); ++it)
cout << *it;
Oui, il devrait être possible d'indexer avec 'boost :: optional'. – alfC