2 identifier.cc -- implement identifier and derived classes
4 source file of the GNU LilyPond music typesetter
6 (c) 1997--2000 Han-Wen Nienhuys <hanwen@cs.uu.nl>
14 #include "music-output-def.hh"
16 #include "identifier.hh"
17 #include "my-lily-lexer.hh"
19 #include "translator-group.hh"
20 #include "ly-smobs.icc"
23 IMPLEMENT_UNSMOB(Identifier, identifier);
24 IMPLEMENT_SMOBS(Identifier);
25 IMPLEMENT_DEFAULT_EQUAL_P(Identifier);
27 Identifier::Identifier (int code)
34 Identifier::Identifier (Identifier const&s)
38 token_code_i_ = s.token_code_i_;
39 accessed_b_ = s.accessed_b_;
42 Identifier::~Identifier()
47 Identifier::error (String expect) const
49 ::error (_f ("wrong identifier type, expected: `%s'", expect));
53 Identifier::str () const
59 Identifier::do_str () const
65 Identifier::print () const
67 DEBUG_OUT << "identifier ";
71 Identifier::do_print () const
76 #define DEFAULT_PRINT(Class) \
78 Class ## _identifier::do_print () const { \
79 Class *cl = ((Class ## _identifier *)this)->access_content_ ## Class(false);\
85 DEFAULT_PRINT(Translator_group);
87 DEFAULT_PRINT(Music_output_def);
90 #define DUMMY_STR(Class) \
92 Class ## _identifier::do_str () const { \
93 return String (#Class); \
97 DUMMY_STR(Translator_group);
99 DUMMY_STR(Music_output_def);
102 #define STRING_PRINT(Class) \
104 Class ## _identifier::do_print () const\
106 DEBUG_OUT << do_str () << '\n';\
110 STRING_PRINT(Duration);
112 #define DEFAULT_STR(Class) \
114 Class ## _identifier::do_str () const\
116 return to_str (*data_p_);\
122 fucking C++ blows me.
125 #define DEFAULT_ACCESSOR(Class)\
127 Class ## _identifier::access_content_ ## Class (bool copy_b) const {\
128 ((Class ## _identifier*)this)->accessed_b_ = true;\
129 return copy_b ? new Class (*data_p_) : data_p_;\
132 #define VIRTUAL_ACCESSOR(Class)\
134 Class ## _identifier::access_content_ ## Class (bool copy_b) const{\
135 ((Class ## _identifier*)this)->accessed_b_ = true;\
136 return copy_b ? dynamic_cast<Class*> (data_p_->clone()) : data_p_;\
139 #define IMPLEMENT_ID_CLASS(Class) \
140 Class ## _identifier::~Class ## _identifier() { delete data_p_; }\
141 Class ## _identifier::Class ## _identifier (Class*st, int code) \
146 Class ## _identifier::Class ## _identifier (Class ## _identifier const &s) \
149 data_p_ = s.access_content_ ## Class (true);\
153 IMPLEMENT_ID_CLASS(Duration);
154 IMPLEMENT_ID_CLASS(Translator_group);
155 IMPLEMENT_ID_CLASS(Score);
156 IMPLEMENT_ID_CLASS(Music_output_def);
157 VIRTUAL_ACCESSOR(Translator_group);
158 VIRTUAL_ACCESSOR(Music_output_def);
159 DEFAULT_ACCESSOR(Duration);
160 DEFAULT_ACCESSOR(Score);
164 Identifier::print_smob (SCM s, SCM p, scm_print_state*)
170 Identifier::mark_smob (SCM s)