]> git.donarmstrong.com Git - lilypond.git/blobdiff - flower/include/virtual-methods.hh
cleanup. Separate into internal
[lilypond.git] / flower / include / virtual-methods.hh
index b00e741330fdb768e85f7cf4d62adfa41bde56ff..6d4d84087941e3074c59775e00464d736d7de4c7 100644 (file)
@@ -3,7 +3,7 @@
 
   source file of the Flower Library
 
-  (c)  1997--1999 Han-Wen Nienhuys <hanwen@cs.uu.nl>
+  (c) 1997--2004 Han-Wen Nienhuys <hanwen@cs.uu.nl>
 */
 
 
 #define VIRTUAL_METHODS_HH
 
 #include <typeinfo>
-#include "stdlib.h"            // size_t
 
-#define classname(class_ptr)   demangle_classname(typeid(*(class_ptr)).name())
+#define classname(class_ptr)   demangle_classname (typeid (* (class_ptr)))
 
 const char *
-demangle_classname (const char*);
+demangle_classname (std::type_info const &);
 
 /**
 
    Virtual copy constructor. Make up for C++'s lack of a standard
-   clone() function.  Uses a typeof hack.  Usage:
+   clone () function.  Uses a typeof hack.  Usage:
 
    class Foo : Baseclass {
-       VIRTUAL_COPY_CONS(Baseclass);
+       VIRTUAL_COPY_CONS (Baseclass);
    };
    
  */
 
-// fix constness: gcc-2.95 is correct in defining
-//    typeof (*this)
-// in a const member function to be const
-
-#if 0
-#define VIRTUAL_COPY_CONS(base) \
-  virtual base *clone () const \
-  { \
-    return new typeof(*this) (*this); \
-  }
-#else
+/*
+  fix constness: gcc-2.95 is correct in defining
+  
+    typeof (*this)
+    
+  in a const member function to be const
+*/
 #define VIRTUAL_COPY_CONS(base) \
   virtual base* clone_const_helper () \
     { \
@@ -50,6 +45,6 @@ demangle_classname (const char*);
       base* urg = (base*)this; \
       return urg->clone_const_helper (); \
     }
-#endif 
+
 
 #endif /* VIRTUAL_METHODS_HH */