1 #ifndef DataFormats_Common_AssociationVector_h
2 #define DataFormats_Common_AssociationVector_h
26 #include <type_traits>
30 template<
class T>
class Ptr;
44 template<
typename REFPROD>
58 template<
typename KeyRefProd,
typename CVal,
60 typename SizeType =
unsigned int,
68 typedef typename KeyRefProd::product_type
CKey;
71 typedef typename std::pair<KeyRef, typename CVal::value_type>
value_type;
82 typename CVal::const_reference
operator[](KeyRef
const&
k)
const;
93 void swap(
self& other);
99 std::vector<void const*>& pointers,
120 template<
typename KeyRefProd,
typename CVal,
typename KeyRef,
typename SizeType,
typename KeyReferenceHelper>
124 return *(transientVector_.load(std::memory_order_acquire)); }
126 template<
typename KeyRefProd,
typename CVal,
typename KeyRef,
typename SizeType,
typename KeyReferenceHelper>
128 data_(), ref_(), transientVector_(
nullptr) { }
130 template<
typename KeyRefProd,
typename CVal,
typename KeyRef,
typename SizeType,
typename KeyReferenceHelper>
133 data_(coll == 0 ? ref->
size() : coll->
size()), ref_(ref),
136 template<
typename KeyRefProd,
typename CVal,
typename KeyRef,
typename SizeType,
typename KeyReferenceHelper>
139 data_(o.data_), ref_(o.ref_), transientVector_() {
146 template<
typename KeyRefProd,
typename CVal,
typename KeyRef,
typename SizeType,
typename KeyReferenceHelper>
148 delete transientVector_.load(std::memory_order_acquire);
151 template<
typename KeyRefProd,
typename CVal,
typename KeyRef,
typename SizeType,
typename KeyReferenceHelper>
154 return transientVector()[
n ];
157 template<
typename KeyRefProd,
typename CVal,
typename KeyRef,
typename SizeType,
typename KeyReferenceHelper>
158 inline typename CVal::const_reference
162 return data_[ keyRef.key() ];
165 template<
typename KeyRefProd,
typename CVal,
typename KeyRef,
typename SizeType,
typename KeyReferenceHelper>
166 template<
typename K>
167 inline typename CVal::const_reference
171 return data_[ k.
key() ];
174 template<
typename KeyRefProd,
typename CVal,
typename KeyRef,
typename SizeType,
typename KeyReferenceHelper>
175 template<
typename K>
176 typename CVal::const_reference
180 return data_[ k.
key() ];
183 template<
typename KeyRefProd,
typename CVal,
typename KeyRef,
typename SizeType,
typename KeyReferenceHelper>
187 auto t = transientVector_.exchange(
nullptr,std::memory_order_acq_rel);
190 return data_[ keyRef.key() ];
193 template<
typename KeyRefProd,
typename CVal,
typename KeyRef,
typename SizeType,
typename KeyReferenceHelper>
201 auto t =transientVector_.exchange(
nullptr, std::memory_order_acq_rel);
206 template<
typename KeyRefProd,
typename CVal,
typename KeyRef,
typename SizeType,
typename KeyReferenceHelper>
210 auto t = transientVector_.load(std::memory_order_acquire);
211 (*t)[
i ].first = ref;
212 (*t)[
i ].second = data_[
i ];
215 template<
typename KeyRefProd,
typename CVal,
typename KeyRef,
typename SizeType,
typename KeyReferenceHelper>
221 template<
typename KeyRefProd,
typename CVal,
typename KeyRef,
typename SizeType,
typename KeyReferenceHelper>
223 return data_.empty();
226 template<
typename KeyRefProd,
typename CVal,
typename KeyRef,
typename SizeType,
typename KeyReferenceHelper>
229 auto t = transientVector_.load(std::memory_order_acquire);
234 template<
typename KeyRefProd,
typename CVal,
typename KeyRef,
typename SizeType,
typename KeyReferenceHelper>
236 data_.swap(other.data_);
237 other.transientVector_.store(transientVector_.exchange(other.transientVector_.load(std::memory_order_acquire),std::memory_order_acq_rel),std::memory_order_release);
238 ref_.swap(other.ref_);
241 template<
typename KeyRefProd,
typename CVal,
typename KeyRef,
typename SizeType,
typename KeyReferenceHelper>
243 if (
nullptr == transientVector_.load(std::memory_order_acquire)) {
246 (*newT)[
i ] = std::make_pair(KeyRef(ref_,
i), data_[
i ]);
249 if(transientVector_.compare_exchange_strong(expected, newT.get()) ) {
255 template<
typename KeyRefProd,
typename CVal,
typename KeyRef,
typename SizeType,
typename KeyReferenceHelper>
257 std::vector<void const*>& pointers,
268 template<
typename KeyRefProd,
typename CVal,
typename KeyRef,
typename SizeType,
typename KeyReferenceHelper>
278 template <
typename KeyRefProd,
typename CVal,
typename KeyRef,
typename SizeType,
typename KeyReferenceHelper>
283 std::vector<void const*>& pointers,
285 obj.
fillView(
id, pointers, helpers);
288 template <
typename KeyRefProd,
typename CVal,
typename KeyRef,
typename SizeType,
typename KeyReferenceHelper>
void checkForWrongProduct(ProductID const &keyID, ProductID const &refID)
void fillView(ProductID const &id, std::vector< void const * > &pointers, FillViewHelperVector &helpers) const
transient_vector_type::const_iterator const_iterator
void reallyFillView(COLLECTION const &coll, ProductID const &id, std::vector< void const * > &ptrs, FillViewHelperVector &helpers)
Ref< typename RefProd< C >::product_type > ref_type
self & operator=(self const &)
const_iterator end() const
std::vector< value_type > transient_vector_type
#define CMS_CLASS_VERSION(_version_)
void swap(Association< C > &lhs, Association< C > &rhs)
AssociationIdenticalKeyReference type
Container::value_type value_type
value_type const & const_reference
const_reference operator[](size_type n) const
std::pair< KeyRef, typename CVal::value_type > value_type
BOOST_STATIC_ASSERT((boost::is_convertible< SizeType, typename CVal::size_type >::value))
void fillView(AssociationVector< KeyRefProd, CVal, KeyRef, SizeType, KeyReferenceHelper > const &obj, ProductID const &id, std::vector< void const * > &pointers, FillViewHelperVector &helpers)
CVal::value_type const value(size_type i) const
KeyRefProd::product_type CKey
Container::transient_vector_type transient_vector_type
KeyRef key(size_type i) const
KeyRef::value_type key_type
ProductID id() const
Accessor for product ID.
std::atomic< transient_vector_type * > transientVector_
KeyRefProd const & keyProduct() const
transient_vector_type const & transientVector() const
void setValue(size_type i, typename CVal::value_type const &val)
const_iterator begin() const
std::vector< std::pair< edm::ProductID, unsigned long > > FillViewHelperVector
tuple size
Write out results.
T get(const Candidate &c)