Packets: Fix annotation unit-test on 64bit architectures
[senf.git] / senf / Utils / TypeIdValue.hh
index 85eebf0..c473565 100644 (file)
@@ -54,8 +54,7 @@ namespace senf {
         // no conversion constructors
 
         TypeIdValue();
-        TypeIdValue(TypeIdValue const & other);
-        TypeIdValue const & operator=(TypeIdValue const & other);
+        TypeIdValue(std::type_info const & v);
 
         ///@}
         ///////////////////////////////////////////////////////////////////////////
@@ -64,35 +63,36 @@ namespace senf {
         bool operator<(TypeIdValue const & other) const;
 
         std::string name() const;
+        std::string prettyName() const;
+
         std::type_info const & id() const;
 
     protected:
 
     private:
-        template <class Type> TypeIdValue(Type *);
-
-        struct Value {
-            virtual ~Value();
-            virtual std::type_info const & id() = 0;
-            virtual Value * clone() = 0;
-        };
-
-        template <class Type>
-        struct ValueImpl : public Value {
-            virtual std::type_info const & id();
-            virtual Value * clone();
-        };
-
-        boost::scoped_ptr<Value> value_;
-
-        template <class Type> friend TypeIdValue const typeIdValue();
+        std::type_info const * p_;
     };
 
+    /**
+        \related TypeIdValue
+     */
     TypeIdValue const typeIdValue();
 
+    /**
+        \related TypeIdValue
+     */
     template <class Type>
     TypeIdValue const typeIdValue();
 
+    /**
+        \related TypeIdValue
+     */
+    template <class Type>
+    TypeIdValue const typeIdValue(Type const & ob);
+
+    /**
+        \related TypeIdValue
+     */
     std::ostream & operator<<(std::ostream & os, TypeIdValue const & v);
 }