]> www.ginac.de Git - ginac.git/commitdiff
registered_class_info: use typeid() instead of tinfo_static.
authorAlexei Sheplyakov <varg@theor.jinr.ru>
Wed, 15 Oct 2008 11:32:11 +0000 (15:32 +0400)
committerAlexei Sheplyakov <varg@theor.jinr.ru>
Sun, 19 Oct 2008 17:29:11 +0000 (21:29 +0400)
(Custom RTTI considered harmful, part 5).

Since custom RTTI is going to be removed, registered_class_info needs to be
re-organazied. Now tinfo_key is a (const) pointer to std::type_info.

check/exam_archive.cpp
ginac/registrar.cpp
ginac/registrar.h
ginac/structure.h

index 97962d7a637bc8cd34b4ab7381f1b16b07a8e536..bdf6995542427b2cc2f0eed1c779e4bc8d53f073 100644 (file)
@@ -65,7 +65,8 @@ unsigned exam_archive()
        }
        f = ar.unarchive_ex(lst(x, y, mu, dim), "expr 1");
 
        }
        f = ar.unarchive_ex(lst(x, y, mu, dim), "expr 1");
 
-       if (!f.is_equal(e)) {
+       ex difference = (f - e).expand();
+       if (!difference.is_zero()) {
                clog << "archiving/unarchiving " << e << endl
                     << "erroneously returned " << f << endl;
                ++result;
                clog << "archiving/unarchiving " << e << endl
                     << "erroneously returned " << f << endl;
                ++result;
index 369b89420527a9d3773acbf0fefa090dee571ae1..5a4d8903660fd74a14e28682634790878e404188 100644 (file)
@@ -28,7 +28,7 @@
 
 namespace GiNaC {
 
 
 namespace GiNaC {
 
-tinfo_t find_tinfo_key(const std::string &class_name)
+std::type_info const* find_tinfo_key(const std::string &class_name)
 {
        return registered_class_info::find(class_name)->options.get_id();
 }
 {
        return registered_class_info::find(class_name)->options.get_id();
 }
index d8a64db241dff5d99b720ec501eb7782602ee1fe..f7790d9ef907d867419c7b9e734d2763b589367f 100644 (file)
@@ -26,6 +26,7 @@
 #include <string>
 #include <list>
 #include <vector>
 #include <string>
 #include <list>
 #include <vector>
+#include <typeinfo>
 
 #include "class_info.h"
 #include "print.h"
 
 #include "class_info.h"
 #include "print.h"
@@ -86,12 +87,14 @@ typedef ex (*unarch_func)(const archive_node &n, lst &sym_lst);
 /** This class stores information about a registered GiNaC class. */
 class registered_class_options {
 public:
 /** This class stores information about a registered GiNaC class. */
 class registered_class_options {
 public:
-       registered_class_options(const char *n, const char *p, tinfo_t ti, unarch_func f)
-        : name(n), parent_name(p), tinfo_key(ti), unarchive(f) {}
+       registered_class_options(const char *n, const char *p, 
+                                const std::type_info& ti,
+                                unarch_func f)
+        : name(n), parent_name(p), tinfo_key(&ti), unarchive(f) {}
 
        const char *get_name() const { return name; }
        const char *get_parent_name() const { return parent_name; }
 
        const char *get_name() const { return name; }
        const char *get_parent_name() const { return parent_name; }
-       tinfo_t get_id() const { return tinfo_key; }
+       std::type_info const* get_id() const { return tinfo_key; }
        unarch_func get_unarch_func() const { return unarchive; }
        const std::vector<print_functor> &get_print_dispatch_table() const { return print_dispatch_table; }
 
        unarch_func get_unarch_func() const { return unarchive; }
        const std::vector<print_functor> &get_print_dispatch_table() const { return print_dispatch_table; }
 
@@ -126,7 +129,7 @@ public:
 private:
        const char *name;         /**< Class name. */
        const char *parent_name;  /**< Name of superclass. */
 private:
        const char *name;         /**< Class name. */
        const char *parent_name;  /**< Name of superclass. */
-       tinfo_t tinfo_key;        /**< Type information key. */
+       std::type_info const* tinfo_key;        /**< Type information key. */
        unarch_func unarchive;    /**< Pointer to unarchiving function. */
        std::vector<print_functor> print_dispatch_table; /**< Method table for print() dispatch */
 };
        unarch_func unarchive;    /**< Pointer to unarchiving function. */
        std::vector<print_functor> print_dispatch_table; /**< Method table for print() dispatch */
 };
@@ -181,24 +184,24 @@ private:
 
 /** Macro for inclusion in the implementation of each registered class. */
 #define GINAC_IMPLEMENT_REGISTERED_CLASS(classname, supername) \
 
 /** Macro for inclusion in the implementation of each registered class. */
 #define GINAC_IMPLEMENT_REGISTERED_CLASS(classname, supername) \
-       GiNaC::registered_class_info classname::reg_info = GiNaC::registered_class_info(GiNaC::registered_class_options(#classname, #supername, &classname::tinfo_static, &classname::unarchive)); \
+       GiNaC::registered_class_info classname::reg_info = GiNaC::registered_class_info(GiNaC::registered_class_options(#classname, #supername, typeid(classname), &classname::unarchive)); \
        const GiNaC::tinfo_static_t classname::tinfo_static = {};
 
 /** Macro for inclusion in the implementation of each registered class.
  *  Additional options can be specified. */
 #define GINAC_IMPLEMENT_REGISTERED_CLASS_OPT(classname, supername, options) \
        const GiNaC::tinfo_static_t classname::tinfo_static = {};
 
 /** Macro for inclusion in the implementation of each registered class.
  *  Additional options can be specified. */
 #define GINAC_IMPLEMENT_REGISTERED_CLASS_OPT(classname, supername, options) \
-       GiNaC::registered_class_info classname::reg_info = GiNaC::registered_class_info(GiNaC::registered_class_options(#classname, #supername, &classname::tinfo_static, &classname::unarchive).options); \
+       GiNaC::registered_class_info classname::reg_info = GiNaC::registered_class_info(GiNaC::registered_class_options(#classname, #supername, typeid(classname), &classname::unarchive).options); \
        const GiNaC::tinfo_static_t classname::tinfo_static = {};
 
 /** Macro for inclusion in the implementation of each registered class.
  *  Additional options can be specified. */
 #define GINAC_IMPLEMENT_REGISTERED_CLASS_OPT_T(classname, supername, options) \
        const GiNaC::tinfo_static_t classname::tinfo_static = {};
 
 /** Macro for inclusion in the implementation of each registered class.
  *  Additional options can be specified. */
 #define GINAC_IMPLEMENT_REGISTERED_CLASS_OPT_T(classname, supername, options) \
-       GiNaC::registered_class_info classname::reg_info = GiNaC::registered_class_info(GiNaC::registered_class_options(#classname, #supername, &classname::tinfo_static, &classname::unarchive).options); \
+       GiNaC::registered_class_info classname::reg_info = GiNaC::registered_class_info(GiNaC::registered_class_options(#classname, #supername, typeid(classname), &classname::unarchive).options); \
        template<> const GiNaC::tinfo_static_t classname::tinfo_static = {};
 
 
 /** Find type information key by class name. */
        template<> const GiNaC::tinfo_static_t classname::tinfo_static = {};
 
 
 /** Find type information key by class name. */
-extern tinfo_t find_tinfo_key(const std::string &class_name);
+extern std::type_info const* find_tinfo_key(const std::string &class_name);
 
 /** Find unarchiving function by class name. */
 extern unarch_func find_unarch_func(const std::string &class_name);
 
 /** Find unarchiving function by class name. */
 extern unarch_func find_unarch_func(const std::string &class_name);
index cfd17c90cc41feed0973015a8fe4a07157f23c17..6c08618c7c4a7752e4033b0db2dbe65213ec3456 100644 (file)
@@ -119,7 +119,6 @@ class structure : public basic, public ComparisonPolicy<T> {
        // helpers
        static tinfo_t get_tinfo() { return reg_info.options.get_id(); }
        static const char *get_class_name() { return "structure"; }
        // helpers
        static tinfo_t get_tinfo() { return reg_info.options.get_id(); }
        static const char *get_class_name() { return "structure"; }
-       static tinfo_t next_structure_tinfo_key() { return new tinfo_static_t; }
 
        // constructors
 public:
 
        // constructors
 public:
@@ -263,7 +262,7 @@ int structure<T, CP>::compare_same_type(const basic & other) const
 }
 
 template <class T, template <class> class CP>
 }
 
 template <class T, template <class> class CP>
-registered_class_info structure<T, CP>::reg_info = registered_class_info(registered_class_options(structure::get_class_name(), "basic", structure::next_structure_tinfo_key(), &structure::unarchive));
+registered_class_info structure<T, CP>::reg_info = registered_class_info(registered_class_options(structure::get_class_name(), "basic", typeid(structure<T, CP>), &structure::unarchive));
 
 
 } // namespace GiNaC
 
 
 } // namespace GiNaC