X-Git-Url: https://git.donarmstrong.com/?a=blobdiff_plain;f=flower%2Finclude%2Fvirtual-methods.hh;h=dc91d7b6696f41cccee3e5832e888c71c991ef87;hb=47db9a3883d726ca53e2133a3b2298f78dd6a32e;hp=909267165b01ae9d6c801393af0c6f998cef1d83;hpb=31653bf1d61a33ef8bc8c871d60c6b3452d04d28;p=lilypond.git diff --git a/flower/include/virtual-methods.hh b/flower/include/virtual-methods.hh index 909267165b..dc91d7b669 100644 --- a/flower/include/virtual-methods.hh +++ b/flower/include/virtual-methods.hh @@ -1,96 +1,48 @@ /* - virtual-methods.hh -- declare macros for our do-it-yourself RTTI + This file is part of LilyPond, the GNU music typesetter. - source file of the Flower Library + Copyright (C) 1997--2015 Han-Wen Nienhuys - (c) 1997--1998 Han-Wen Nienhuys -*/ + LilyPond is free software: you can redistribute it and/or modify + it under the terms of the GNU General Public License as published by + the Free Software Foundation, either version 3 of the License, or + (at your option) any later version. + + LilyPond is distributed in the hope that it will be useful, + but WITHOUT ANY WARRANTY; without even the implied warranty of + MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the + GNU General Public License for more details. + You should have received a copy of the GNU General Public License + along with LilyPond. If not, see . +*/ #ifndef VIRTUAL_METHODS_HH #define VIRTUAL_METHODS_HH #include -#include "stdlib.h" // size_t - -/** Declare the classes name as a static and virtual function. - The static_name() can *not* be inlined (this might have the effect that - s->name() != S::static_name (). Overlapping strings need not be merged in C++ - */ -#define DECLARE_MY_RUNTIME_TYPEINFO \ -virtual char const *name() const{ return static_name (); }\ -static char const *static_name() - - -#if 0 - /* - oops. before() has nothing to do with inheritance - */ -inline bool operator > (type_info const &a1, type_info const &a2) -{ - return a2.before (a1); -} - -inline bool operator < (type_info const &a1, type_info const &a2) -{ - return a1.before (a2); -} - -inline bool operator <= (type_info const &a1, type_info const &a2) -{ - return a1 == a2 || a1 < a2; -} - -inline bool operator >= (type_info const &a1, type_info const &a2) -{ - return a1 == a2 || a1 > a2; -} -#endif - -#define IMPLEMENT_STATIC_NAME(c)\ - char const *c::static_name() { return #c; } - - /* - size_t c::static_class_size () { return sizeof (c); } - */ - -#define VIRTUAL_COPY_CONS(T, R)\ - virtual R *clone() const { return new T(*this); } - -#define DECLARE_VIRTUAL_COPY_CONS(T, R)\ - virtual R *clone() const - -#define IMPLEMENT_VIRTUAL_COPY_CONS(T, R)\ - R *T::clone() const { return new T(*this); }\ - - -#define IMPLEMENT_IS_TYPE_B(D)\ - IMPLEMENT_STATIC_NAME(D) +using namespace std; /* - bool D::static_is_type_b (const char *s)\ -{\ - return s == static_name();\ -}*/ +Virtual copy constructor. Make up for C++'s lack of a standard +factory or clone () function. Usage: -#define IMPLEMENT_IS_TYPE_B1(D, B)\ - IMPLEMENT_STATIC_NAME(D) -/* - bool D::static_is_type_b (const char *s)\ -{\ - return s == static_name() || B::static_is_type_b (s);\ -} +class Foo : Baseclass +{ +VIRTUAL_COPY_CONSTRUCTOR (Baseclass, Foo); +}; */ -#define IMPLEMENT_IS_TYPE_B2(D, BA, BB)\ - IMPLEMENT_STATIC_NAME(D) - -/* - - bool D::static_is_type_b (const char *s)\ -{\ - return s == static_name() || BA::static_is_type_b (s) || BB::static_is_type_b (s);\ +#define DECLARE_CLASSNAME(name) \ + virtual const char *class_name () const { \ + return #name; \ } -*/ -#endif +#define VIRTUAL_COPY_CONSTRUCTOR(Base, name) \ + DECLARE_CLASSNAME(name);\ + virtual Base *clone () const \ + { \ + return new name (*this); \ + } + +#endif /* VIRTUAL_METHODS_HH */