]> git.donarmstrong.com Git - lilypond.git/blob - lily/include/lily-lexer.hh
eb26403b006d428ef96242893fc70e64c833bab1
[lilypond.git] / lily / include / lily-lexer.hh
1 /*
2   This file is part of LilyPond, the GNU music typesetter.
3
4   Copyright (C) 1997--2015 Han-Wen Nienhuys <hanwen@xs4all.nl>
5
6   LilyPond is free software: you can redistribute it and/or modify
7   it under the terms of the GNU General Public License as published by
8   the Free Software Foundation, either version 3 of the License, or
9   (at your option) any later version.
10
11   LilyPond is distributed in the hope that it will be useful,
12   but WITHOUT ANY WARRANTY; without even the implied warranty of
13   MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
14   GNU General Public License for more details.
15
16   You should have received a copy of the GNU General Public License
17   along with LilyPond.  If not, see <http://www.gnu.org/licenses/>.
18 */
19
20 #ifndef MY_LILY_LEXER_HH
21 #define MY_LILY_LEXER_HH
22
23 #include "includable-lexer.hh"
24
25 #include "input.hh"
26 #include "duration.hh"
27 #include "pitch.hh"
28 #include "parser.hh"
29
30 bool busy_parsing ();
31 void kill_lexer ();
32 void set_lexer ();
33
34 class Lily_lexer : public Smob<Lily_lexer>, public Includable_lexer
35 {
36 public:
37   int print_smob (SCM, scm_print_state *) const;
38   SCM mark_smob () const;
39   static const char * const type_p_name_;
40   virtual ~Lily_lexer ();
41   int scan_word (SCM & output, SCM sym);
42 private:
43   int lookup_keyword (const string&);
44   int scan_bare_word (const string&);
45   int scan_escaped_word (const string&);
46   int scan_shorthand (const string&);
47   int scan_scm_id (SCM);
48   int identifier_type (SCM);
49   char escaped_char (char) const;
50   const char *YYText_utf8 ();
51
52   Lily_parser *parser_;
53   Keyword_table *keytable_;
54   SCM scopes_;
55   SCM start_module_;
56   Input override_input_;
57   SCM eval_scm (SCM, Input, char extra_token = 0);
58 public:
59   SCM eval_scm_token (SCM sval, Input w)
60   {
61     w.step_forward ();
62     return eval_scm (sval, w, '#');
63   }
64   SCM extra_tokens_;
65   SCM *lexval_;
66   Input *lexloc_;
67   bool is_main_input_;
68   vsize main_input_level_;
69
70   Sources *sources_;
71
72   /* Scheme hash tables with (oct name acc)  values, and symbol keys.  */
73   SCM chordmodifier_tab_;
74   SCM pitchname_tab_stack_;
75
76   int error_level_;
77   Input last_input_;
78
79   Lily_lexer (Sources *, Lily_parser *);
80   Lily_lexer (Lily_lexer const &, Lily_parser *, SCM);
81   int yylex ();
82
83   void add_lexed_char (int);
84
85   void prepare_for_next_token ();
86   int try_special_identifiers (SCM *, SCM);
87   Input here_input () const;
88   Input const &override_input (Input const &) const;
89
90   void add_scope (SCM);
91   SCM set_current_scope ();
92   bool has_scope () const;
93   SCM remove_scope ();
94
95   void start_main_input ();
96
97   virtual void new_input (const string &s, Sources *);
98   virtual void new_input (const string &s, string d, Sources *);
99
100   bool top_input () { return include_stack_.size () < 2; }
101   SCM keyword_list () const;
102   SCM lookup_identifier (const string &s);
103   SCM lookup_identifier_symbol (SCM s);
104   void push_extra_token (Input const &where,
105                          int token_type, SCM scm = SCM_UNSPECIFIED);
106   int pop_extra_token ();
107   void push_chord_state (SCM alist);
108   void push_figuredbass_state ();
109   void push_lyric_state ();
110   void push_initial_state ();
111   void push_markup_state ();
112   void push_note_state (SCM alist);
113   void pop_state ();
114   void LexerError (char const *);
115   void LexerWarning (char const *);
116   void set_identifier (SCM path, SCM val);
117   int get_state () const;
118   bool is_note_state () const;
119   bool is_chord_state () const;
120   bool is_lyric_state () const;
121   bool is_figure_state () const;
122   bool is_clean () const;
123 };
124
125 #endif /* MY_LILY_LEXER_HH */