]> git.donarmstrong.com Git - lilypond.git/blobdiff - lily/include/my-lily-lexer.hh
2003 -> 2004
[lilypond.git] / lily / include / my-lily-lexer.hh
index 06449288ed14a011ce7747375f7d8fb68357fe84..a7653902e64dbfdeba37c03f4f7ae724f360f0fd 100644 (file)
@@ -3,20 +3,19 @@
 
   source file of the GNU LilyPond music typesetter
 
-  (c)  1997--2002 Han-Wen Nienhuys <hanwen@cs.uu.nl>
+  (c) 1997--2004 Han-Wen Nienhuys <hanwen@cs.uu.nl>
 */
 
 #ifndef LEXER_HH
 #define LEXER_HH
 
-#include <FlexLexer.h>
+#include "includable-lexer.hh"
 
-#include "dictionary.hh"
+#include "input.hh"
 #include "lily-proto.hh"
 #include "flower-proto.hh"
 #include "array.hh"
 #include "string.hh"
-#include "includable-lexer.hh"
 #include "duration.hh"
 #include "pitch.hh"
 #include "protected-scm.hh"
@@ -25,12 +24,12 @@ bool busy_parsing ();
 void kill_lexer ();
 void set_lexer ();
 
-/// lexer for Lilypond
+/// lexer for LilyPond
 class My_lily_lexer : public Includable_lexer 
 {
   Protected_scm scopes_;
 public:
-  String main_input_string_;
+  String main_input_name_;
   void * lexval;
   bool main_input_b_;
 
@@ -38,7 +37,7 @@ public:
     Scheme hash tables with (oct name acc)  values, and symbol keys
    */
   Protected_scm chordmodifier_tab_;
-  Protected_scm pitchname_tab_;
+  Protected_scm pitchname_tab_stack_;
   Keyword_table * keytable_;
   int errorlevel_;
 
@@ -46,17 +45,21 @@ public:
   ~My_lily_lexer ();
   int yylex ();
 
+  Input last_input_;
+  void prepare_for_next_token ();
+  int try_special_identifiers (SCM* ,SCM);
   Input here_input () const;
-
+  
   void add_scope (SCM);
   SCM remove_scope ();
   
   void start_main_input ();
 
   SCM lookup_identifier (String s);
-  void push_note_state ();
+  void push_note_state (SCM tab);
+  void push_chord_state (SCM tab);
+  void push_markup_state ();
   void push_figuredbass_state ();
-  void push_chord_state ();
   void push_lyric_state ();
   void pop_state ();
   void LexerError (char const *);
@@ -68,8 +71,9 @@ public:
 private:
   int lookup_keyword (String);
   int scan_bare_word (String);
+  SCM scan_markup_word (String);
   int scan_escaped_word (String);
-
+  int identifier_type (SCM);
   char escaped_char (char) const;
 };