#ifndef ROOT_TCollectionProxy
#define ROOT_TCollectionProxy
#include <typeinfo>
class TBuffer;
class TClassStreamer;
class TMemberStreamer;
class TGenCollectionProxy;
class TGenCollectionStreamer;
class TVirtualCollectionProxy;
class TEmulatedCollectionProxy;
#if defined(_WIN32)
#if _MSC_VER<1300
#define TYPENAME
#define R__VCXX6
#else
#define TYPENAME typename
#endif
#else
#define TYPENAME typename
#endif
namespace ROOT {
#ifndef __CINT__
template <typename T> struct Environ {
typedef T Iter_t;
char buff[64];
size_t idx;
size_t size;
void* object;
void* start;
void* temp;
Bool_t delete_temp;
int refCount;
size_t space;
T& iter() { return *(T*)buff; }
};
#else
template <typename T> struct Environ;
#endif
#if defined(R__VCXX6)
template <class T> void Destruct(T* obj) { obj->~T(); }
#endif
}
class TCollectionProxy {
public:
typedef TVirtualCollectionProxy Proxy_t;
#ifdef R__HPUX
typedef const type_info& Info_t;
#else
typedef const std::type_info& Info_t;
#endif
template <class T, class Q> struct PairHolder {
T first;
Q second;
PairHolder() {}
PairHolder(const PairHolder& c) : first(c.first), second(c.second) {}
virtual ~PairHolder() {}
private:
PairHolder& operator=(const PairHolder&);
};
template <class T> struct Address {
virtual ~Address() {}
static void* address(T ref) {
return (void*)&ref;
}
};
template <class T> struct Type
#ifdef R__KCC
: public Address<TYPENAME T::value_type&>
#else
: public Address<TYPENAME T::const_reference>
#endif
{
typedef T Cont_t;
typedef typename T::iterator Iter_t;
typedef typename T::value_type Value_t;
typedef ROOT::Environ<Iter_t> Env_t;
typedef Env_t *PEnv_t;
typedef Cont_t *PCont_t;
typedef Value_t *PValue_t;
virtual ~Type() {}
static inline PCont_t object(void* ptr) {
return PCont_t(PEnv_t(ptr)->object);
}
static void* size(void* env) {
PEnv_t e = PEnv_t(env);
e->size = PCont_t(e->object)->size();
return &e->size;
}
static void* clear(void* env) {
object(env)->clear();
return 0;
}
static void* first(void* env) {
PEnv_t e = PEnv_t(env);
PCont_t c = PCont_t(e->object);
::new(e->buff) Iter_t(c->begin());
e->size = c->size();
if ( 0 == e->size ) return e->start = 0;
#ifdef R__KCC
TYPENAME T::value_type& ref = *(e->iter());
#else
TYPENAME T::const_reference ref = *(e->iter());
#endif
return e->start = address(ref);
}
static void* next(void* env) {
PEnv_t e = PEnv_t(env);
PCont_t c = PCont_t(e->object);
for (; e->idx > 0 && e->iter() != c->end(); ++(e->iter()), --e->idx );
if ( e->iter() == c->end() ) return 0;
#ifdef R__KCC
TYPENAME T::value_type& ref = *(e->iter());
#else
TYPENAME T::const_reference ref = *(e->iter());
#endif
return address(ref);
}
static void* construct(void* env) {
PEnv_t e = PEnv_t(env);
PValue_t m = PValue_t(e->start);
for (size_t i=0; i<e->size; ++i, ++m)
::new(m) Value_t();
return 0;
}
static void* collect(void* env) {
PEnv_t e = PEnv_t(env);
PCont_t c = PCont_t(e->object);
PValue_t m = PValue_t(e->start);
for (Iter_t i=c->begin(); i != c->end(); ++i, ++m )
::new(m) Value_t(*i);
return 0;
}
static void* destruct(void* env) {
PEnv_t e = PEnv_t(env);
PValue_t m = PValue_t(e->start);
#if defined(R__VCXX6)
PCont_t c = PCont_t(e->object);
for (size_t i=0; i < e->size; ++i, ++m )
ROOT::Destruct(m);
#else
for (size_t i=0; i < e->size; ++i, ++m )
m->~Value_t();
#endif
return 0;
}
};
template <class T> struct Pushback : public Type<T> {
typedef T Cont_t;
typedef typename T::iterator Iter_t;
typedef typename T::value_type Value_t;
typedef ROOT::Environ<Iter_t> Env_t;
typedef Env_t *PEnv_t;
typedef Cont_t *PCont_t;
typedef Value_t *PValue_t;
static void* resize(void* env) {
PEnv_t e = PEnv_t(env);
PCont_t c = PCont_t(e->object);
c->resize(e->size);
e->idx = 0;
return e->start = address(*c->begin());
}
static void* feed(void* env) {
PEnv_t e = PEnv_t(env);
PCont_t c = PCont_t(e->object);
PValue_t m = PValue_t(e->start);
for (size_t i=0; i<e->size; ++i, ++m)
c->push_back(*m);
return 0;
}
static int value_offset() {
return 0;
}
};
template <class T> struct Insert : public Type<T> {
typedef T Cont_t;
typedef typename T::iterator Iter_t;
typedef typename T::value_type Value_t;
typedef ROOT::Environ<Iter_t> Env_t;
typedef Env_t *PEnv_t;
typedef Cont_t *PCont_t;
typedef Value_t *PValue_t;
static void* feed(void* env) {
PEnv_t e = PEnv_t(env);
PCont_t c = PCont_t(e->object);
PValue_t m = PValue_t(e->start);
for (size_t i=0; i<e->size; ++i, ++m)
c->insert(*m);
return 0;
}
static void* resize(void* ) {
return 0;
}
static int value_offset() {
return 0;
}
};
template <class T> struct MapInsert : public Type<T> {
typedef T Cont_t;
typedef typename T::iterator Iter_t;
typedef typename T::value_type Value_t;
typedef ROOT::Environ<Iter_t> Env_t;
typedef Env_t *PEnv_t;
typedef Cont_t *PCont_t;
typedef Value_t *PValue_t;
static void* feed(void* env) {
PEnv_t e = PEnv_t(env);
PCont_t c = PCont_t(e->object);
PValue_t m = PValue_t(e->start);
for (size_t i=0; i<e->size; ++i, ++m)
c->insert(*m);
return 0;
}
static void* resize(void* ) {
return 0;
}
static int value_offset() {
return ((char*)&((PValue_t(0x1000))->second)) - ((char*)PValue_t(0x1000));
}
};
static TVirtualCollectionProxy* GenEmulatedProxy(const char* class_name);
static TClassStreamer* GenEmulatedClassStreamer(const char* class_name);
static TMemberStreamer* GenEmulatedMemberStreamer(const char* class_name);
static Proxy_t* GenExplicitProxy( Info_t info,
size_t iter_size,
size_t value_diff,
int value_offset,
void* (*size_func)(void*),
void* (*resize_func)(void*),
void* (*clear_func)(void*),
void* (*first_func)(void*),
void* (*next_func)(void*),
void* (*construct_func)(void*),
void* (*destruct_func)(void*),
void* (*feed_func)(void*),
void* (*collect_func)(void*)
);
template <class T> static Proxy_t* GenProxy(const T&) {
PairHolder<TYPENAME T::Value_t, TYPENAME T::Value_t>* p =
(PairHolder<TYPENAME T::Value_t, TYPENAME T::Value_t>*)0x1000;
return GenExplicitProxy(typeid(TYPENAME T::Cont_t),
sizeof(TYPENAME T::Iter_t),
(((char*)&p->second)-((char*)&p->first)),
T::value_offset(),
T::size,
T::resize,
T::clear,
T::first,
T::next,
T::construct,
T::destruct,
T::feed,
T::collect);
}
static TGenCollectionStreamer*
GenExplicitStreamer( Info_t info,
size_t iter_size,
size_t value_diff,
int value_offset,
void* (*size_func)(void*),
void* (*resize_func)(void*),
void* (*clear_func)(void*),
void* (*first_func)(void*),
void* (*next_func)(void*),
void* (*construct_func)(void*),
void* (*destruct_func)(void*),
void* (*feed_func)(void*),
void* (*collect_func)(void*)
);
static TClassStreamer*
GenExplicitClassStreamer( Info_t info,
size_t iter_size,
size_t value_diff,
int value_offset,
void* (*size_func)(void*),
void* (*resize_func)(void*),
void* (*clear_func)(void*),
void* (*first_func)(void*),
void* (*next_func)(void*),
void* (*construct_func)(void*),
void* (*destruct_func)(void*),
void* (*feed_func)(void*),
void* (*collect_func)(void*)
);
template <class T> static TClassStreamer* GenClassStreamer(const T&) {
PairHolder<TYPENAME T::Value_t, TYPENAME T::Value_t>* p =
(PairHolder<TYPENAME T::Value_t, TYPENAME T::Value_t>*)0x1000;
return GenExplicitClassStreamer(typeid(TYPENAME T::Cont_t),
sizeof(TYPENAME T::Iter_t),
(((char*)&p->second)-((char*)&p->first)),
T::value_offset(),
T::size,
T::resize,
T::clear,
T::first,
T::next,
T::construct,
T::destruct,
T::feed,
T::collect);
}
static TMemberStreamer*
GenExplicitMemberStreamer(Info_t info,
size_t iter_size,
size_t value_diff,
int value_offset,
void* (*size_func)(void*),
void* (*resize_func)(void*),
void* (*clear_func)(void*),
void* (*first_func)(void*),
void* (*next_func)(void*),
void* (*construct_func)(void*),
void* (*destruct_func)(void*),
void* (*feed_func)(void*),
void* (*collect_func)(void*)
);
template <class T> static TMemberStreamer* GenMemberStreamer(const T&) {
PairHolder<TYPENAME T::Value_t, TYPENAME T::Value_t>* p =
(PairHolder<TYPENAME T::Value_t, TYPENAME T::Value_t>*)0x1000;
return GenExplicitMemberStreamer( typeid(TYPENAME T::Cont_t),
sizeof(TYPENAME T::Iter_t),
(((char*)&p->second)-((char*)&p->first)),
T::value_offset(),
T::size,
T::resize,
T::clear,
T::first,
T::next,
T::construct,
T::destruct,
T::feed,
T::collect);
}
};
class TCollectionStreamer {
private:
TCollectionStreamer& operator=(const TCollectionStreamer&);
protected:
TGenCollectionProxy* fStreamer;
void InvalidProxyError();
public:
TCollectionStreamer();
TCollectionStreamer(const TCollectionStreamer& c);
virtual ~TCollectionStreamer();
void AdoptStreamer(TGenCollectionProxy* streamer);
void Streamer(TBuffer &refBuffer, void *pObject, int siz);
};
#include "TClassStreamer.h"
class TCollectionClassStreamer : public TClassStreamer, public TCollectionStreamer {
public:
TCollectionClassStreamer() : TClassStreamer(0) { }
TCollectionClassStreamer(const TCollectionClassStreamer& c)
: TClassStreamer(c), TCollectionStreamer(c) { }
virtual ~TCollectionClassStreamer() { }
virtual void operator()(TBuffer &buff, void *pObj) { Streamer(buff,pObj,0); }
virtual TClassStreamer *Generate() {
return new TCollectionClassStreamer(*this);
}
};
#include "TMemberStreamer.h"
class TCollectionMemberStreamer : public TMemberStreamer, public TCollectionStreamer {
public:
TCollectionMemberStreamer() : TMemberStreamer(0) { }
TCollectionMemberStreamer(const TCollectionMemberStreamer& c)
: TMemberStreamer(c), TCollectionStreamer(c) { }
virtual ~TCollectionMemberStreamer() { }
virtual void operator()(TBuffer &buff,void *pObj,Int_t siz=0)
{ Streamer(buff, pObj, siz); }
};
#ifndef __CINT__
template<> inline void* TCollectionProxy::Address<std::vector<bool>::const_reference>::address(std::vector<bool>::const_reference ) {
return 0;
}
#endif
#endif
ROOT page - Class index - Class Hierarchy - Top of the page
This page has been automatically generated. If you have any comments or suggestions about the page layout send a mail to ROOT support, or contact the developers with any questions or problems regarding ROOT.