lilypond-1.3.65
[lilypond.git] / lily / identifier.cc
blobc35350b07d7a664572a80029956d505d6fa8efec
1 /*
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>
7 */
9 /*
10 JUNKTHIS!
12 #include <assert.h>
13 #include "music-output-def.hh"
14 #include "score.hh"
15 #include "identifier.hh"
16 #include "my-lily-lexer.hh"
17 #include "debug.hh"
18 #include "request.hh"
19 #include "translator-group.hh"
20 #include "ly-smobs.icc"
22 IMPLEMENT_UNSMOB(Identifier, identifier);
23 IMPLEMENT_SMOBS(Identifier);
25 Identifier::Identifier (int code)
27 self_scm_ = SCM_EOL;
28 token_code_i_ = code;
29 accessed_b_ = 0;
32 Identifier::Identifier (Identifier const&s)
33 : Input (s)
35 self_scm_ = SCM_EOL;
36 token_code_i_ = s.token_code_i_;
37 accessed_b_ = s.accessed_b_;
40 Identifier::~Identifier()
44 void
45 Identifier::error (String expect) const
47 ::error (_f ("wrong identifier type, expected: `%s'", expect));
50 String
51 Identifier::str () const
53 return do_str ();
56 String
57 Identifier::do_str () const
59 return "";
62 void
63 Identifier::print () const
65 DEBUG_OUT << "identifier ";
66 do_print ();
68 void
69 Identifier::do_print () const
73 /* ugh. */
74 #define DEFAULT_PRINT(Class) \
75 void \
76 Class ## _identifier::do_print () const { \
77 Class *cl = ((Class ## _identifier *)this)->access_content_ ## Class(false);\
78 cl->print (); \
83 DEFAULT_PRINT(Translator_group);
84 DEFAULT_PRINT(Music);
85 DEFAULT_PRINT(Request);
86 DEFAULT_PRINT(Score);
87 DEFAULT_PRINT(Music_output_def);
89 /* ugh. */
90 #define DUMMY_STR(Class) \
91 String \
92 Class ## _identifier::do_str () const { \
93 return String (#Class); \
97 DUMMY_STR(Translator_group);
98 DUMMY_STR(Music);
99 DUMMY_STR(Request);
100 DUMMY_STR(Score);
101 DUMMY_STR(Music_output_def);
102 DUMMY_STR(Duration);
104 #define STRING_PRINT(Class) \
105 void \
106 Class ## _identifier::do_print () const\
108 DEBUG_OUT << do_str () << '\n';\
112 STRING_PRINT(Duration);
114 #define DEFAULT_STR(Class) \
115 String \
116 Class ## _identifier::do_str () const\
118 return to_str (*data_p_);\
124 fucking C++ blows me.
127 #define DEFAULT_ACCESSOR(Class)\
128 Class*\
129 Class ## _identifier::access_content_ ## Class (bool copy_b) const {\
130 ((Class ## _identifier*)this)->accessed_b_ = true;\
131 return copy_b ? new Class (*data_p_) : data_p_;\
134 #define VIRTUAL_ACCESSOR(Class)\
135 Class*\
136 Class ## _identifier::access_content_ ## Class (bool copy_b) const{\
137 ((Class ## _identifier*)this)->accessed_b_ = true;\
138 return copy_b ? dynamic_cast<Class*> (data_p_->clone()) : data_p_;\
141 #define IMPLEMENT_ID_CLASS(Class) \
142 Class ## _identifier::~Class ## _identifier() { delete data_p_; }\
143 Class ## _identifier::Class ## _identifier (Class*st, int code) \
144 :Identifier (code)\
146 data_p_ = st;\
148 Class ## _identifier::Class ## _identifier (Class ## _identifier const &s) \
149 : Identifier (s)\
151 data_p_ = s.access_content_ ## Class (true);\
155 IMPLEMENT_ID_CLASS(Duration);
156 IMPLEMENT_ID_CLASS(Translator_group);
157 IMPLEMENT_ID_CLASS(Music);
158 IMPLEMENT_ID_CLASS(Score);
159 IMPLEMENT_ID_CLASS(Request);
160 IMPLEMENT_ID_CLASS(Music_output_def);
161 VIRTUAL_ACCESSOR(Music);
162 VIRTUAL_ACCESSOR(Request);
163 VIRTUAL_ACCESSOR(Translator_group);
164 VIRTUAL_ACCESSOR(Music_output_def);
165 DEFAULT_ACCESSOR(Duration);
166 DEFAULT_ACCESSOR(Score);
170 Identifier::print_smob (SCM s, SCM p, scm_print_state*)
172 return 1;
176 Identifier::mark_smob (SCM s)
178 return SCM_EOL;
183 void
184 Identifier::do_smobify_self ()