2004-12-09 13:28:20 +08:00
|
|
|
#ifndef OSGINTROSPECTION_REFLECTION_
|
|
|
|
#define OSGINTROSPECTION_REFLECTION_
|
|
|
|
|
|
|
|
#include <osgIntrospection/Export>
|
|
|
|
|
|
|
|
#include <typeinfo>
|
|
|
|
#include <map>
|
2005-04-08 04:00:17 +08:00
|
|
|
#include <vector>
|
2004-12-09 13:28:20 +08:00
|
|
|
|
|
|
|
/// This macro emulates the behavior of the standard typeid operator,
|
|
|
|
/// returning the Type object associated to the type of the given
|
|
|
|
/// expression.
|
|
|
|
#define typeof(expr) osgIntrospection::Reflection::getType(typeid(expr))
|
|
|
|
|
|
|
|
namespace osgIntrospection
|
|
|
|
{
|
|
|
|
|
2005-03-14 17:28:31 +08:00
|
|
|
class Type;
|
2005-04-08 04:00:17 +08:00
|
|
|
struct Converter;
|
|
|
|
|
|
|
|
typedef std::vector<const Converter *> ConverterList;
|
2005-03-14 17:28:31 +08:00
|
|
|
|
|
|
|
/// This predicate compares two instances of std::type_info for equality.
|
|
|
|
/// Note that we can't rely on default pointer comparison because it is
|
|
|
|
/// not guaranteed that &typeid(T) always returns the same pointer for a
|
|
|
|
/// given T (thanks Andrew Koenig).
|
|
|
|
struct TypeInfoCmp
|
|
|
|
{
|
|
|
|
bool operator()(const std::type_info *t1, const std::type_info *t2) const
|
|
|
|
{
|
|
|
|
return t1->before(*t2) != 0;
|
|
|
|
}
|
|
|
|
};
|
|
|
|
|
|
|
|
/// A map of types, indexed by their associated type_info structure.
|
|
|
|
typedef std::map<const std::type_info *, Type *, TypeInfoCmp> TypeMap;
|
|
|
|
|
|
|
|
|
|
|
|
/// This class provides basic reflection services such as registration
|
|
|
|
/// of new types and queries on the global type map.
|
|
|
|
class OSGINTROSPECTION_EXPORT Reflection
|
|
|
|
{
|
|
|
|
public:
|
|
|
|
/// Returns the Type object associated to the given type_info
|
|
|
|
/// structure. If the type hasn't been created yet it is
|
|
|
|
/// automatically created and added to the global type map.
|
|
|
|
/// Please note that such type will have the status of
|
|
|
|
/// "declared", you still need to give details about it through
|
|
|
|
/// a Reflector class before you can query it.
|
|
|
|
static const Type &getType(const std::type_info &ti);
|
|
|
|
|
|
|
|
/// Finds a Type object given its qualified name, which must
|
|
|
|
/// be identical to the qualified name returned by that Type's
|
|
|
|
/// getQualifiedName() method. If the type hasn't been created
|
|
|
|
/// yet, an exception is thrown.
|
|
|
|
static const Type &getType(const std::string &qname);
|
|
|
|
|
|
|
|
/// Returns the global map of types.
|
|
|
|
static const TypeMap &getTypes();
|
|
|
|
|
|
|
|
/// Return the Type object associated to the C++ type 'void'.
|
|
|
|
/// This is a shortcut for typeof(void), which may be slow if
|
|
|
|
/// the type map is large.
|
|
|
|
static const Type &type_void();
|
2005-04-08 04:00:17 +08:00
|
|
|
|
|
|
|
static const Converter *getConverter(const Type &source, const Type &dest);
|
|
|
|
static bool getConversionPath(const Type &source, const Type &dest, ConverterList &conv);
|
2005-03-14 17:28:31 +08:00
|
|
|
|
|
|
|
private:
|
|
|
|
template<typename C> friend class Reflector;
|
2005-04-04 21:50:07 +08:00
|
|
|
template<typename C> friend struct TypeNameAliasProxy;
|
2005-04-08 04:00:17 +08:00
|
|
|
friend struct ConverterProxy;
|
2005-03-14 17:28:31 +08:00
|
|
|
|
|
|
|
struct StaticData
|
|
|
|
{
|
|
|
|
TypeMap typemap;
|
|
|
|
const Type *type_void;
|
2005-04-08 04:00:17 +08:00
|
|
|
|
|
|
|
typedef std::map<const Type *, const Converter *> ConverterMap;
|
|
|
|
typedef std::map<const Type *, ConverterMap> ConverterMapMap;
|
|
|
|
ConverterMapMap convmap;
|
|
|
|
|
|
|
|
~StaticData();
|
2005-03-14 17:28:31 +08:00
|
|
|
};
|
|
|
|
|
|
|
|
static StaticData &getOrCreateStaticData();
|
|
|
|
static Type *registerType(const std::type_info &ti);
|
2005-04-04 21:50:07 +08:00
|
|
|
static Type *getOrRegisterType(const std::type_info &ti, bool replace_if_defined = false);
|
2005-04-08 04:00:17 +08:00
|
|
|
static void registerConverter(const Type &source, const Type &dest, const Converter *cvt);
|
2005-03-14 17:28:31 +08:00
|
|
|
|
|
|
|
private:
|
2005-04-08 04:00:17 +08:00
|
|
|
static bool accum_conv_path(const Type &source, const Type &dest, ConverterList &conv, std::vector<const Type *> &chain);
|
2005-03-14 17:28:31 +08:00
|
|
|
static StaticData *staticdata__;
|
|
|
|
};
|
2004-12-09 13:28:20 +08:00
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
#endif
|