2014-04-27 17:18:53 +00:00
|
|
|
#ifndef slic3r_perlglue_hpp_
|
|
|
|
#define slic3r_perlglue_hpp_
|
|
|
|
|
|
|
|
namespace Slic3r {
|
|
|
|
|
|
|
|
template<class T>
|
|
|
|
struct ClassTraits {
|
|
|
|
static const char* name;
|
|
|
|
static const char* name_ref;
|
|
|
|
};
|
2014-04-29 23:04:49 +00:00
|
|
|
|
|
|
|
// use this for typedefs for which the forward prototype
|
|
|
|
// in REGISTER_CLASS won't work
|
|
|
|
#define __REGISTER_CLASS(cname, perlname) \
|
2014-04-27 17:18:53 +00:00
|
|
|
template <>const char* ClassTraits<cname>::name = "Slic3r::" perlname; \
|
|
|
|
template <>const char* ClassTraits<cname>::name_ref = "Slic3r::" perlname "::Ref";
|
2014-04-29 23:04:49 +00:00
|
|
|
|
|
|
|
#define REGISTER_CLASS(cname,perlname) \
|
|
|
|
class cname; \
|
|
|
|
__REGISTER_CLASS(cname, perlname);
|
|
|
|
|
2014-04-27 17:18:53 +00:00
|
|
|
template<class T>
|
|
|
|
const char* perl_class_name(const T*) { return ClassTraits<T>::name; }
|
|
|
|
template<class T>
|
|
|
|
const char* perl_class_name_ref(const T*) { return ClassTraits<T>::name_ref; }
|
|
|
|
|
|
|
|
template <class T>
|
|
|
|
class Ref {
|
|
|
|
T* val;
|
|
|
|
public:
|
|
|
|
Ref() {}
|
|
|
|
Ref(T* t) : val(t) {}
|
|
|
|
operator T*() const {return val; }
|
|
|
|
static const char* CLASS() { return ClassTraits<T>::name_ref; }
|
|
|
|
};
|
|
|
|
|
|
|
|
template <class T>
|
|
|
|
class Clone {
|
|
|
|
T* val;
|
|
|
|
public:
|
2014-05-07 10:02:09 +00:00
|
|
|
Clone() : val() {}
|
2014-04-27 17:18:53 +00:00
|
|
|
Clone(T* t) : val(new T(*t)) {}
|
|
|
|
Clone(const T& t) : val(new T(t)) {}
|
|
|
|
operator T*() const {return val; }
|
|
|
|
static const char* CLASS() { return ClassTraits<T>::name; }
|
|
|
|
};
|
|
|
|
};
|
|
|
|
|
|
|
|
#endif
|