1 #ifndef DataFormats_Common_OneToManyWithQualityGeneric_h
2 #define DataFormats_Common_OneToManyWithQualityGeneric_h
9 #include <boost/bind.hpp>
14 template<
typename CKey,
typename CVal,
typename Q,
typename index =
unsigned int,
15 typename KeyRefProd =
typename helper::MapRefViewTrait<CKey>::refprod_type,
16 typename ValRefProd =
typename helper::MapRefViewTrait<CVal>::refprod_type,
17 typename KeyRef =
typename helper::MapRefViewTrait<CKey>::ref_type,
18 typename ValRef =
typename helper::MapRefViewTrait<CVal>::ref_type >
25 typedef std::vector<std::pair<index, Q> >
map_assoc;
29 typedef std::vector<std::pair<ValRef, Q> >
val_type;
37 typedef std::map<index_type, map_assoc>
map_type;
42 std::vector<std::pair<const typename CVal::value_type *, Q > >
47 typedef std::vector<std::vector<std::pair<const typename CVal::value_type *, Q > >
52 const ValRef & vref = v.first;
53 if (k.isNull() || vref.isNull())
55 "can't insert null references in AssociationMap");
56 if (ref.
key.isNull()) {
62 m[ik].push_back(std::make_pair(iv, v.second));
65 for(
typename val_type::const_iterator
i = v.begin(), iEnd = v.end();
i != iEnd; ++
i)
71 for(
typename map_assoc::const_iterator idx = iv.begin(), idxEnd = iv.end(); idx != idxEnd; ++idx)
72 v.push_back(std::make_pair(ValRef(ref.
val, idx->first), idx->second));
80 for(
typename map_type::iterator
i = m.begin(), iEnd = m.end();
i != iEnd; ++
i) {
86 boost::bind(std::less<Q>(),
96 const CKey & ckey = * ref.
key;
97 const CVal & cval = * ref.
val;
98 for(
typename map_type::const_iterator
i = map.begin();
i != map.end(); ++
i) {
101 std::vector<std::pair<const typename CVal::value_type *, Q> >
v;
102 for(
typename map_assoc::const_iterator
j = a.begin();
j != a.end(); ++
j) {
104 v.push_back(std::make_pair(val,
j->second));
106 m.insert(std::make_pair(k, v));
113 const CKey & ckey = * ref.
key;
114 for(
typename map_type::const_iterator
i = map.begin();
i != map.end(); ++
i)
115 m.push_back(& ckey[
i->first]);
121 const CVal & cval = * ref.
val;
122 for(
typename map_type::const_iterator
i = map.begin();
i != map.end(); ++
i) {
124 std::vector<std::pair<const typename CVal::value_type *, Q> >
v;
126 for(
typename map_assoc::const_iterator
j = a.begin();
j != a.end(); ++
j)
127 m.back().push_back(std::make_pair(& cval[
j->first ],
j->second));
static map_type::size_type size(const map_assoc &v)
size of data_type
KeyRefProd keyrefprod_type
reference to "key" collection
static void sort(map_type &m)
sort
static transient_val_vector transientValVector(const ref_type &ref, const map_type &map)
fill transient val vector
static val_type val(const ref_type &ref, const map_assoc &iv)
return values collection
static void throwThis(Code category, char const *message0="", char const *message1="", char const *message2="", char const *message3="", char const *message4="")
std::vector< std::pair< ValRef, Q > > val_type
values reference collection type
U second(std::pair< T, U > const &p)
KeyRef key_type
insert key type
static transient_key_vector transientKeyVector(const ref_type &ref, const map_type &map)
fill transient key vector
static void insert(ref_type &ref, map_type &m, const key_type &k, const val_type &v)
Container::value_type value_type
helpers::KeyVal< keyrefprod_type, valrefprod_type > ref_type
reference set type
index index_type
index type
std::vector< std::pair< index, Q > > map_assoc
internal map associated data
static transient_map_type transientMap(const ref_type &ref, const map_type &map)
fill transient map
std::pair< ValRef, Q > data_type
insert val type
std::vector< std::vector< std::pair< const typename CVal::value_type *, Q > > > transient_val_vector
transient val vector
std::vector< const typename CKey::value_type * > transient_key_vector
transient key vector
void checkRef(const RP &rp, const R &r)
throw if r hasn't the same id as rp
static void insert(ref_type &ref, map_type &m, const key_type &k, const data_type &v)
insert in the map
std::map< index_type, map_assoc > map_type
map type
ValRefProd valrefprod_type
reference to "value" collection
std::map< const typename CKey::value_type *, std::vector< std::pair< const typename CVal::value_type *, Q > > > transient_map_type
transient map type