]> git.donarmstrong.com Git - lilypond.git/blobdiff - lily/identifier.cc
release: 1.3.107
[lilypond.git] / lily / identifier.cc
index 72224f92f91c7cfb342767476f22dce220bf9f6b..28e450ac496c99cd4a8c2a41d15ec4736ce94552 100644 (file)
 /*
   identifier.cc -- implement identifier and derived classes
 
-  source file of the LilyPond music typesetter
+  source file of the GNU LilyPond music typesetter
 
-  (c) 1997 Han-Wen Nienhuys <hanwen@stack.nl>
+  (c)  1997--2000 Han-Wen Nienhuys <hanwen@cs.uu.nl>
 */
 
+
+/*
+  JUNKTHIS!
+ */
 #include <assert.h>
 
+#include "music-output-def.hh"
+#include "score.hh"
 #include "identifier.hh"
 #include "my-lily-lexer.hh"
 #include "debug.hh"
-#include "input-register.hh"
-#include "input-score.hh" 
-#include "symtable.hh"
-#include "input-staff.hh"
-#include "input-music.hh"
-#include "lookup.hh"
-#include "script-def.hh"
-#include "request.hh"
-#include "input-register.hh"
+#include "ly-smobs.icc"
 
-Identifier::~Identifier()
+
+IMPLEMENT_UNSMOB(Identifier, identifier);
+IMPLEMENT_SMOBS(Identifier);
+IMPLEMENT_DEFAULT_EQUAL_P(Identifier);
+
+Identifier::Identifier (int code)
 {
-    if (!accessed_b_ && !init_b_)
-       warning("Variable not used");
+  token_code_i_ = code;
+  accessed_b_ = 0;
+  smobify_self ();
 }
-void
-Identifier::error(String expect)
+
+Identifier::Identifier (Identifier const&s)
+  : Input (s)
 {
-    String e("Wrong identifier type: ");
-    e += String(classname()) + "(expected " + expect + ")";
-    ::error(e);
+  smobify_self ();  
+  token_code_i_ = s.token_code_i_;
+  accessed_b_ = s.accessed_b_;
 }
 
-Identifier::Identifier(String n, int code)
-    :  name_str_(n) 
+Identifier::~Identifier()
 {
-    token_code_i_ = code; 
-    data = 0;
-    accessed_b_ = 0;
-    init_b_ = 0;
 }
 
 void
-Identifier::print()const
+Identifier::error (String expect) const
 {
-    mtor << "identifier \'" << name_str_ << "\'=";
-    do_print();
+  ::error (_f ("wrong identifier type, expected: `%s'", expect));
 }
 
-/* ugh. */
-#define DEFAULT_PRINT(Class, Content_type, accessor) \
-void \
-Class::do_print() const { \
-    ((Class*)this)->accessor(false)->print(); \
-} \
-class Class
-
-DEFAULT_PRINT(Script_id, Script_def, script);
-DEFAULT_PRINT(Lookup_id, Lookup, lookup);
-DEFAULT_PRINT(Symtables_id, Symtables, symtables);
-DEFAULT_PRINT(Staff_id, Input_staff, staff);
-DEFAULT_PRINT(M_chord_id, Music_general_chord, mchord);
-DEFAULT_PRINT(M_voice_id, Music_voice, mvoice);
-DEFAULT_PRINT(Request_id, Request, request);
-DEFAULT_PRINT(Score_id, Input_score, score);
-DEFAULT_PRINT(Input_regs_id, Input_register, iregs);
+String
+Identifier::str () const
+{
+  return do_str ();
+}
 
-void
-Real_id::do_print() const
+String
+Identifier::do_str () const
 {
-    Identifier::print();
-    mtor << *((Real_id*)this)->real(false)<< "\n";
+  return "";
 }
 
-#define implement_id_class(Idclass, Class, accessor)   \
-char const * Idclass::classname() const\
+
+/* ugh. */
+#define DUMMY_STR(Class) \
+String \
+Class ## _identifier::do_str () const { \
+  return String (#Class); \
+}
+
+DUMMY_STR(Score);
+DUMMY_STR(Music_output_def);
+
+  
+#define DEFAULT_STR(Class) \
+String \
+Class ## _identifier::do_str () const\
 {\
-    return #Class;\
-}\
+  return to_str (*data_p_);\
+}
+
+  
+
+/*
+  fucking C++ blows me.
+ */
+
+#define DEFAULT_ACCESSOR(Class)\
+Class*\
+Class ## _identifier::access_content_ ## Class (bool copy_b) const {\
+  ((Class ## _identifier*)this)->accessed_b_ = true;\
+  return copy_b ? new Class (*data_p_) : data_p_;\
+}
+
+#define VIRTUAL_ACCESSOR(Class)\
 Class*\
-Idclass::accessor(bool copy) {\
-       if (copy){ \
-           accessed_b_ = true;\
-           return new Class(* (Class*) data);\
-        }else\
-           return (Class*) data;\
-    }\
-Idclass::~Idclass() { delete accessor(false); }\
-Idclass::Idclass(String s, Class*st, int code):Identifier(s,code) { data = st; }\
-
-
-implement_id_class(Real_id, Real, real);
-implement_id_class(Script_id, Script_def, script);
-implement_id_class(Lookup_id, Lookup, lookup);
-implement_id_class(Symtables_id, Symtables, symtables);
-implement_id_class(Staff_id, Input_staff, staff);
-implement_id_class(M_chord_id, Music_general_chord, mchord);
-implement_id_class(M_voice_id, Music_voice, mvoice);
-implement_id_class(Score_id, Input_score, score);
-implement_id_class(Request_id, Request, request);
-implement_id_class(Input_regs_id, Input_register, iregs);
-
-Identifier::Identifier(Identifier const&)
+Class ## _identifier::access_content_ ## Class (bool copy_b) const{\
+  ((Class ## _identifier*)this)->accessed_b_ = true;\
+  return copy_b ? dynamic_cast<Class*> (data_p_->clone()) : data_p_;\
+}
+
+#define IMPLEMENT_ID_CLASS(Class)      \
+       Class ## _identifier::~Class ## _identifier() { delete data_p_; }\
+       Class ## _identifier::Class ## _identifier (Class*st, int code) \
+         :Identifier (code)\
+       {\
+         data_p_ = st;\
+       }\
+Class ## _identifier::Class ## _identifier (Class ## _identifier const &s) \
+  : Identifier (s)\
+{\
+   data_p_ = s.access_content_ ## Class (true);\
+} 
+
+
+IMPLEMENT_ID_CLASS(Score);
+IMPLEMENT_ID_CLASS(Music_output_def);
+VIRTUAL_ACCESSOR(Music_output_def);
+DEFAULT_ACCESSOR(Score);
+
+
+int
+Identifier::print_smob (SCM s, SCM p, scm_print_state*)
 {
-    assert(false);
+ return 1;  
 }
+
+SCM
+Identifier::mark_smob (SCM s)
+{
+  return SCM_EOL;
+}
+
+
+