ly.lex package¶
Module contents¶
This module is built on top of slexer and can parse LilyPond input and other formats.
The base functionality is delegated to modules with an underscore in this package. The modules describing parsing modes (filetypes) are the files without underscore.
Currently available are modes for lilypond, latex, html, texinfo, scheme, and docbook.
The ‘underscored’ modules should not be imported in application code. What is needed from them is available here, in the ly.lex namespace.
If you add new files for parsing other file types, you should add them in _mode.py. The _token.py module contains base Token types and Token mixin classes.
The State, Parser, FallthroughParser and Fridge classes from slexer are all slightly extended here,
Usage:
>>> import ly.lex
>>> txt = r"\relative c' { c d e f-^ g }"
>>> s = ly.lex.state("lilypond")
>>> for t in s.tokens(txt):
... print(t, t.__class__.__name__)
\relative Command
Space
c Name
' Unparsed
Space
{ SequentialStart
Space
c Note
Space
d Note
Space
e Note
Space
f Note
- Direction
^ ScriptAbbreviation
Space
g Note
Space
} SequentialEnd
A State() is used to parse text. The text is given to the tokens() method, that returns an iterator iterating over Token instances as they are found. Each token has a ‘pos’ and an ‘end’ attribute describing its position in the original string.
While iterating over the tokens(), the State maintains information about what kind of text is parsed. (So don’t iterate over more than one call to tokens() of the same State object at the same time.)
Use ly.lex.state(“name”) to get a state for a specific mode to start parsing with. If you don’t know the type of text, you can use ly.lex.guessState(text), where text is the text you want to parse. A quick heuristic is then used to determine the type of the text.
See for more information the documentation of the slexer module.
-
class
ly.lex.BlockComment(string, pos)[source]¶ Bases:
ly.lex._token.CommentBase class for tokens that belong to a block/multiline comment.
-
end¶
-
pos¶
-
-
class
ly.lex.BlockCommentEnd(string, pos)[source]¶ Bases:
ly.lex._token.BlockCommentBase class for tokens that end a block/multiline comment.
-
end¶
-
pos¶
-
-
class
ly.lex.BlockCommentStart(string, pos)[source]¶ Bases:
ly.lex._token.BlockCommentBase class for tokens that start a block/multiline comment.
-
end¶
-
pos¶
-
-
class
ly.lex.Character(string, pos)[source]¶ Bases:
ly.lex._token.TokenBase class for tokens that are an (escaped) character.
-
end¶
-
pos¶
-
-
class
ly.lex.Comment(string, pos)[source]¶ Bases:
ly.lex._token.TokenBase class for tokens that belong to a comment.
-
end¶
-
pos¶
-
-
class
ly.lex.Dedent[source]¶ Bases:
objectMixin class for tokens that have the text on the next line indent less.
-
class
ly.lex.Error(string, pos)[source]¶ Bases:
ly.lex._token.TokenBase class for tokens that represent erroneous input.
-
end¶
-
pos¶
-
-
class
ly.lex.Fridge(stateClass=<class 'ly.lex.State'>)[source]¶ Bases:
ly.slexer.Fridge
-
class
ly.lex.Indent[source]¶ Bases:
objectMixin class for tokens that have the text on the next line indent more.
-
class
ly.lex.LineComment(string, pos)[source]¶ Bases:
ly.lex._token.CommentBase class for items that are a whole line comment.
-
end¶
-
pos¶
-
-
class
ly.lex.MatchEnd[source]¶ Bases:
objectMixin class for tokens that have a matching token backward in the text.
The matchname attribute should give a unique name.
-
matchname= ''¶
-
-
class
ly.lex.MatchStart[source]¶ Bases:
objectMixin class for tokens that have a matching token forward in the text.
The matchname attribute should give a unique name.
-
matchname= ''¶
-
-
class
ly.lex.Newline(string, pos)[source]¶ Bases:
ly.lex._token.SpaceA token that is a single newline.
-
end¶
-
pos¶
-
rx= '\\n'¶
-
-
class
ly.lex.Numeric(string, pos)[source]¶ Bases:
ly.lex._token.TokenBase class for tokens that are a numerical value.
-
end¶
-
pos¶
-
-
class
ly.lex.Parser(argcount=None)[source]¶ Bases:
ly.slexer.Parser-
argcount= 0¶
-
default¶ alias of
ly.lex._token.Unparsed
-
mode= None¶
-
re_flags= 40¶
-
-
class
ly.lex.Space(string, pos)[source]¶ Bases:
ly.lex._token.TokenA token containing whitespace.
-
end¶
-
pos¶
-
rx= '\\s+'¶
-
-
class
ly.lex.State(initialParserClass)[source]¶ Bases:
ly.slexer.State
-
class
ly.lex.String(string, pos)[source]¶ Bases:
ly.lex._token.TokenBase class for tokens that belong to a quote-delimited string.
-
end¶
-
pos¶
-
-
class
ly.lex.StringEnd(string, pos)[source]¶ Bases:
ly.lex._token.StringBase class for tokens that end a quote-delimited string.
-
end¶
-
pos¶
-
-
class
ly.lex.StringStart(string, pos)[source]¶ Bases:
ly.lex._token.StringBase class for tokens that start a quote-delimited string.
-
end¶
-
pos¶
-
-
class
ly.lex.Token(string, pos)[source]¶ Bases:
ly.slexer.Token-
end¶
-
pos¶
-
-
class
ly.lex.Unparsed(string, pos)[source]¶ Bases:
ly.lex._token.TokenRepresents an unparsed piece of input text.
-
end¶
-
pos¶
-
Submodules¶
ly.lex.docbook module¶
Parses and tokenizes DocBook input, recognizing LilyPond in DocBook.
ly.lex.html module¶
Parses and tokenizes HTML input, recognizing LilyPond in HTML.
-
class
ly.lex.html.AttrName(string, pos)[source]¶ Bases:
ly.lex._token.Token-
end¶
-
pos¶
-
rx= '\\w+([-_:]\\w+)?'¶
-
-
class
ly.lex.html.CommentEnd(string, pos)[source]¶ Bases:
ly.lex.html.Comment,ly.lex._token.Leaver,ly.lex._token.BlockCommentEnd-
end¶
-
pos¶
-
rx= '-->'¶
-
-
class
ly.lex.html.CommentStart(string, pos)[source]¶ Bases:
ly.lex.html.Comment,ly.lex._token.BlockCommentStart-
end¶
-
pos¶
-
rx= '<!--'¶
-
update_state(state)[source]¶ Lets the token update the state, e.g. enter a different parser.
This method is called by the State upon instantiation of the tokens.
Don’t use it later on to have a State follow already instantiated Tokens because the FallthroughParser type can also change the state without generating a Token. Use State.follow() to have a State follow instantiated Tokens.
The default implementation lets the Parser decide on state change.
-
-
class
ly.lex.html.EntityRef(string, pos)[source]¶ Bases:
ly.lex._token.Character-
end¶
-
pos¶
-
rx= '\\&(#\\d+|#[xX][0-9A-Fa-f]+|[A-Za-z_:][\\w.:_-]*);'¶
-
-
class
ly.lex.html.EqualSign(string, pos)[source]¶ Bases:
ly.lex._token.Token-
end¶
-
pos¶
-
rx= '='¶
-
update_state(state)[source]¶ Lets the token update the state, e.g. enter a different parser.
This method is called by the State upon instantiation of the tokens.
Don’t use it later on to have a State follow already instantiated Tokens because the FallthroughParser type can also change the state without generating a Token. Use State.follow() to have a State follow instantiated Tokens.
The default implementation lets the Parser decide on state change.
-
-
class
ly.lex.html.LilyPondCloseTag(string, pos)[source]¶ Bases:
ly.lex.html.LilyPondTag,ly.lex._token.Leaver-
end¶
-
pos¶
-
rx= '</lilypond>'¶
-
-
class
ly.lex.html.LilyPondFileTag(string, pos)[source]¶ Bases:
ly.lex.html.LilyPondTag-
end¶
-
pos¶
-
rx= '</?lilypondfile\\b'¶
-
update_state(state)[source]¶ Lets the token update the state, e.g. enter a different parser.
This method is called by the State upon instantiation of the tokens.
Don’t use it later on to have a State follow already instantiated Tokens because the FallthroughParser type can also change the state without generating a Token. Use State.follow() to have a State follow instantiated Tokens.
The default implementation lets the Parser decide on state change.
-
-
class
ly.lex.html.LilyPondFileTagEnd(string, pos)[source]¶ Bases:
ly.lex.html.LilyPondTag,ly.lex._token.Leaver-
end¶
-
pos¶
-
rx= '/?>'¶
-
-
class
ly.lex.html.LilyPondInlineTag(string, pos)[source]¶ Bases:
ly.lex.html.LilyPondTag-
end¶
-
pos¶
-
rx= '<lilypond\\b'¶
-
update_state(state)[source]¶ Lets the token update the state, e.g. enter a different parser.
This method is called by the State upon instantiation of the tokens.
Don’t use it later on to have a State follow already instantiated Tokens because the FallthroughParser type can also change the state without generating a Token. Use State.follow() to have a State follow instantiated Tokens.
The default implementation lets the Parser decide on state change.
-
-
class
ly.lex.html.LilyPondInlineTagEnd(string, pos)[source]¶ Bases:
ly.lex.html.LilyPondTag,ly.lex._token.Leaver-
end¶
-
pos¶
-
rx= '/?>'¶
-
-
class
ly.lex.html.LilyPondTag(string, pos)[source]¶ Bases:
ly.lex.html.Tag-
end¶
-
pos¶
-
-
class
ly.lex.html.LilyPondTagEnd(string, pos)[source]¶ Bases:
ly.lex.html.LilyPondTag-
end¶
-
pos¶
-
rx= '>'¶
-
update_state(state)[source]¶ Lets the token update the state, e.g. enter a different parser.
This method is called by the State upon instantiation of the tokens.
Don’t use it later on to have a State follow already instantiated Tokens because the FallthroughParser type can also change the state without generating a Token. Use State.follow() to have a State follow instantiated Tokens.
The default implementation lets the Parser decide on state change.
-
-
class
ly.lex.html.LilyPondVersionTag(string, pos)[source]¶ Bases:
ly.lex.html.LilyPondTag-
end¶
-
pos¶
-
rx= '<lilypondversion/?>'¶
-
-
class
ly.lex.html.ParseAttr(argcount=None)[source]¶ Bases:
ly.lex.Parser-
items= (<class 'ly.lex._token.Space'>, <class 'ly.lex.html.TagEnd'>, <class 'ly.lex.html.AttrName'>, <class 'ly.lex.html.EqualSign'>, <class 'ly.lex.html.StringDQStart'>, <class 'ly.lex.html.StringSQStart'>)¶
-
pattern= re.compile('(?P<g_0>\\s+)|(?P<g_1>/?>)|(?P<g_2>\\w+([-_:]\\w+)?)|(?P<g_3>=)|(?P<g_4>")|(?P<g_5>\')', re.MULTILINE)¶
-
-
class
ly.lex.html.ParseComment(argcount=None)[source]¶ Bases:
ly.lex.Parser-
default¶ alias of
ly.lex.html.Comment
-
items= (<class 'ly.lex.html.CommentEnd'>,)¶
-
pattern= re.compile('(?P<g_0>-->)', re.MULTILINE)¶
-
-
class
ly.lex.html.ParseHTML(argcount=None)[source]¶ Bases:
ly.lex.Parser-
items= (<class 'ly.lex._token.Space'>, <class 'ly.lex.html.LilyPondVersionTag'>, <class 'ly.lex.html.LilyPondFileTag'>, <class 'ly.lex.html.LilyPondInlineTag'>, <class 'ly.lex.html.CommentStart'>, <class 'ly.lex.html.TagStart'>, <class 'ly.lex.html.EntityRef'>)¶
-
mode= 'html'¶
-
pattern= re.compile('(?P<g_0>\\s+)|(?P<g_1><lilypondversion/?>)|(?P<g_2></?lilypondfile\\b)|(?P<g_3><lilypond\\b)|(?P<g_4><!--)|(?P<g_5></?\\w[-_:\\w]*\\b)|(?P<g_6>\\&(#\\d+|#[xX][0-9A-Fa-f]+|[A-Za-z_:][\\w.:_-]*);)', re.MULTILINE)¶
-
-
class
ly.lex.html.ParseLilyPond(argcount=None)[source]¶ Bases:
ly.lex.lilypond.ParseGlobal-
items= (<class 'ly.lex.html.LilyPondCloseTag'>, <class 'ly.lex.lilypond.Book'>, <class 'ly.lex.lilypond.BookPart'>, <class 'ly.lex.lilypond.Score'>, <class 'ly.lex.lilypond.MarkupStart'>, <class 'ly.lex.lilypond.MarkupLines'>, <class 'ly.lex.lilypond.MarkupList'>, <class 'ly.lex.lilypond.Paper'>, <class 'ly.lex.lilypond.Header'>, <class 'ly.lex.lilypond.Layout'>, <class 'ly.lex._token.Space'>, <class 'ly.lex.lilypond.BlockCommentStart'>, <class 'ly.lex.lilypond.LineComment'>, <class 'ly.lex.lilypond.SchemeStart'>, <class 'ly.lex.lilypond.StringQuotedStart'>, <class 'ly.lex.lilypond.SequentialStart'>, <class 'ly.lex.lilypond.SimultaneousStart'>, <class 'ly.lex.lilypond.Repeat'>, <class 'ly.lex.lilypond.PitchCommand'>, <class 'ly.lex.lilypond.Override'>, <class 'ly.lex.lilypond.Revert'>, <class 'ly.lex.lilypond.Set'>, <class 'ly.lex.lilypond.Unset'>, <class 'ly.lex.lilypond.Hide'>, <class 'ly.lex.lilypond.Omit'>, <class 'ly.lex.lilypond.Tweak'>, <class 'ly.lex.lilypond.New'>, <class 'ly.lex.lilypond.Context'>, <class 'ly.lex.lilypond.Change'>, <class 'ly.lex.lilypond.With'>, <class 'ly.lex.lilypond.Clef'>, <class 'ly.lex.lilypond.Tempo'>, <class 'ly.lex.lilypond.Partial'>, <class 'ly.lex.lilypond.KeySignatureMode'>, <class 'ly.lex.lilypond.AccidentalStyle'>, <class 'ly.lex.lilypond.AlterBroken'>, <class 'ly.lex.lilypond.SimultaneousOrSequentialCommand'>, <class 'ly.lex.lilypond.ChordMode'>, <class 'ly.lex.lilypond.DrumMode'>, <class 'ly.lex.lilypond.FigureMode'>, <class 'ly.lex.lilypond.LyricMode'>, <class 'ly.lex.lilypond.NoteMode'>, <class 'ly.lex.lilypond.MarkupStart'>, <class 'ly.lex.lilypond.MarkupLines'>, <class 'ly.lex.lilypond.MarkupList'>, <class 'ly.lex.lilypond.ArticulationCommand'>, <class 'ly.lex.lilypond.Keyword'>, <class 'ly.lex.lilypond.Command'>, <class 'ly.lex.lilypond.SimultaneousOrSequentialCommand'>, <class 'ly.lex.lilypond.UserCommand'>, <class 'ly.lex.lilypond.Name'>, <class 'ly.lex.lilypond.DotPath'>, <class 'ly.lex.lilypond.EqualSign'>, <class 'ly.lex.lilypond.Fraction'>, <class 'ly.lex.lilypond.DecimalValue'>)¶
-
pattern= re.compile('(?P<g_0></lilypond>)|(?P<g_1>\\\\book\\b)|(?P<g_2>\\\\bookpart\\b)|(?P<g_3>\\\\score\\b)|(?P<g_4>\\\\markup(?![_-]?[^\\W\\d]))|(?P<g_5>\\\\markuplines(?![_-]?[^\\W\\d]))|(?P<g_6>\\\\markuplist(?![_-], re.MULTILINE)¶
-
-
class
ly.lex.html.ParseLilyPondAttr(argcount=None)[source]¶ Bases:
ly.lex.Parser-
items= (<class 'ly.lex._token.Space'>, <class 'ly.lex.html.AttrName'>, <class 'ly.lex.html.EqualSign'>, <class 'ly.lex.html.StringDQStart'>, <class 'ly.lex.html.StringSQStart'>, <class 'ly.lex.html.LilyPondTagEnd'>, <class 'ly.lex.html.SemiColon'>)¶
-
pattern= re.compile('(?P<g_0>\\s+)|(?P<g_1>\\w+([-_:]\\w+)?)|(?P<g_2>=)|(?P<g_3>")|(?P<g_4>\')|(?P<g_5>>)|(?P<g_6>:)', re.MULTILINE)¶
-
-
class
ly.lex.html.ParseLilyPondFileOptions(argcount=None)[source]¶ Bases:
ly.lex.Parser-
items= (<class 'ly.lex._token.Space'>, <class 'ly.lex.html.AttrName'>, <class 'ly.lex.html.EqualSign'>, <class 'ly.lex.html.StringDQStart'>, <class 'ly.lex.html.StringSQStart'>, <class 'ly.lex.html.LilyPondFileTagEnd'>)¶
-
pattern= re.compile('(?P<g_0>\\s+)|(?P<g_1>\\w+([-_:]\\w+)?)|(?P<g_2>=)|(?P<g_3>")|(?P<g_4>\')|(?P<g_5>/?>)', re.MULTILINE)¶
-
-
class
ly.lex.html.ParseLilyPondInline(argcount=None)[source]¶ Bases:
ly.lex.lilypond.ParseMusic-
items= (<class 'ly.lex.html.LilyPondInlineTagEnd'>, <class 'ly.lex._token.Space'>, <class 'ly.lex.lilypond.BlockCommentStart'>, <class 'ly.lex.lilypond.LineComment'>, <class 'ly.lex.lilypond.SchemeStart'>, <class 'ly.lex.lilypond.StringQuotedStart'>, <class 'ly.lex.lilypond.Dynamic'>, <class 'ly.lex.lilypond.Skip'>, <class 'ly.lex.lilypond.Spacer'>, <class 'ly.lex.lilypond.Q'>, <class 'ly.lex.lilypond.Rest'>, <class 'ly.lex.lilypond.Note'>, <class 'ly.lex.lilypond.Fraction'>, <class 'ly.lex.lilypond.Length'>, <class 'ly.lex.lilypond.Octave'>, <class 'ly.lex.lilypond.OctaveCheck'>, <class 'ly.lex.lilypond.AccidentalCautionary'>, <class 'ly.lex.lilypond.AccidentalReminder'>, <class 'ly.lex.lilypond.PipeSymbol'>, <class 'ly.lex.lilypond.VoiceSeparator'>, <class 'ly.lex.lilypond.SequentialStart'>, <class 'ly.lex.lilypond.SequentialEnd'>, <class 'ly.lex.lilypond.SimultaneousStart'>, <class 'ly.lex.lilypond.SimultaneousEnd'>, <class 'ly.lex.lilypond.ChordStart'>, <class 'ly.lex.lilypond.ContextName'>, <class 'ly.lex.lilypond.GrobName'>, <class 'ly.lex.lilypond.SlurStart'>, <class 'ly.lex.lilypond.SlurEnd'>, <class 'ly.lex.lilypond.PhrasingSlurStart'>, <class 'ly.lex.lilypond.PhrasingSlurEnd'>, <class 'ly.lex.lilypond.Tie'>, <class 'ly.lex.lilypond.BeamStart'>, <class 'ly.lex.lilypond.BeamEnd'>, <class 'ly.lex.lilypond.LigatureStart'>, <class 'ly.lex.lilypond.LigatureEnd'>, <class 'ly.lex.lilypond.Direction'>, <class 'ly.lex.lilypond.StringNumber'>, <class 'ly.lex.lilypond.IntegerValue'>, <class 'ly.lex.lilypond.Repeat'>, <class 'ly.lex.lilypond.PitchCommand'>, <class 'ly.lex.lilypond.Override'>, <class 'ly.lex.lilypond.Revert'>, <class 'ly.lex.lilypond.Set'>, <class 'ly.lex.lilypond.Unset'>, <class 'ly.lex.lilypond.Hide'>, <class 'ly.lex.lilypond.Omit'>, <class 'ly.lex.lilypond.Tweak'>, <class 'ly.lex.lilypond.New'>, <class 'ly.lex.lilypond.Context'>, <class 'ly.lex.lilypond.Change'>, <class 'ly.lex.lilypond.With'>, <class 'ly.lex.lilypond.Clef'>, <class 'ly.lex.lilypond.Tempo'>, <class 'ly.lex.lilypond.Partial'>, <class 'ly.lex.lilypond.KeySignatureMode'>, <class 'ly.lex.lilypond.AccidentalStyle'>, <class 'ly.lex.lilypond.AlterBroken'>, <class 'ly.lex.lilypond.SimultaneousOrSequentialCommand'>, <class 'ly.lex.lilypond.ChordMode'>, <class 'ly.lex.lilypond.DrumMode'>, <class 'ly.lex.lilypond.FigureMode'>, <class 'ly.lex.lilypond.LyricMode'>, <class 'ly.lex.lilypond.NoteMode'>, <class 'ly.lex.lilypond.MarkupStart'>, <class 'ly.lex.lilypond.MarkupLines'>, <class 'ly.lex.lilypond.MarkupList'>, <class 'ly.lex.lilypond.ArticulationCommand'>, <class 'ly.lex.lilypond.Keyword'>, <class 'ly.lex.lilypond.Command'>, <class 'ly.lex.lilypond.SimultaneousOrSequentialCommand'>, <class 'ly.lex.lilypond.UserCommand'>, <class 'ly.lex.lilypond.TremoloColon'>)¶
-
pattern= re.compile('(?P<g_0>/?>)|(?P<g_1>\\s+)|(?P<g_2>%{)|(?P<g_3>%.*$)|(?P<g_4>[#$](?![{}]))|(?P<g_5>")|(?P<g_6>\\\\[<!>]|\\\\(f{1,5}|p{1,5}|mf|mp|fp|spp?|sff?|sfz|rfz|cresc|decresc|dim|cr|decr)(?![A-Za-z]))|(?P<g_7>\, re.MULTILINE)¶
-
-
class
ly.lex.html.ParseStringDQ(argcount=None)[source]¶ Bases:
ly.lex.Parser-
default¶ alias of
ly.lex.html.String
-
items= (<class 'ly.lex.html.StringDQEnd'>, <class 'ly.lex.html.EntityRef'>)¶
-
pattern= re.compile('(?P<g_0>")|(?P<g_1>\\&(#\\d+|#[xX][0-9A-Fa-f]+|[A-Za-z_:][\\w.:_-]*);)', re.MULTILINE)¶
-
-
class
ly.lex.html.ParseStringSQ(argcount=None)[source]¶ Bases:
ly.lex.Parser-
default¶ alias of
ly.lex.html.String
-
items= (<class 'ly.lex.html.StringSQEnd'>, <class 'ly.lex.html.EntityRef'>)¶
-
pattern= re.compile("(?P<g_0>')|(?P<g_1>\\&(#\\d+|#[xX][0-9A-Fa-f]+|[A-Za-z_:][\\w.:_-]*);)", re.MULTILINE)¶
-
-
class
ly.lex.html.ParseValue(argcount=None)[source]¶ Bases:
ly.lex.FallthroughParserFinds a value or drops back.
-
fallthrough(state)[source]¶ Called when no match is returned by parse().
This implementation leaves the current parser and returns None (causing the State to continue parsing).
-
items= (<class 'ly.lex._token.Space'>, <class 'ly.lex.html.Value'>)¶
-
pattern= re.compile('(?P<g_0>\\s+)|(?P<g_1>\\w+)', re.MULTILINE)¶
-
-
class
ly.lex.html.SemiColon(string, pos)[source]¶ Bases:
ly.lex._token.Token-
end¶
-
pos¶
-
rx= ':'¶
-
update_state(state)[source]¶ Lets the token update the state, e.g. enter a different parser.
This method is called by the State upon instantiation of the tokens.
Don’t use it later on to have a State follow already instantiated Tokens because the FallthroughParser type can also change the state without generating a Token. Use State.follow() to have a State follow instantiated Tokens.
The default implementation lets the Parser decide on state change.
-
-
class
ly.lex.html.StringDQEnd(string, pos)[source]¶ Bases:
ly.lex.html.String,ly.lex._token.StringEnd,ly.lex._token.Leaver-
end¶
-
pos¶
-
rx= '"'¶
-
-
class
ly.lex.html.StringDQStart(string, pos)[source]¶ Bases:
ly.lex.html.String,ly.lex._token.StringStart-
end¶
-
pos¶
-
rx= '"'¶
-
update_state(state)[source]¶ Lets the token update the state, e.g. enter a different parser.
This method is called by the State upon instantiation of the tokens.
Don’t use it later on to have a State follow already instantiated Tokens because the FallthroughParser type can also change the state without generating a Token. Use State.follow() to have a State follow instantiated Tokens.
The default implementation lets the Parser decide on state change.
-
-
class
ly.lex.html.StringSQEnd(string, pos)[source]¶ Bases:
ly.lex.html.String,ly.lex._token.StringEnd,ly.lex._token.Leaver-
end¶
-
pos¶
-
rx= "'"¶
-
-
class
ly.lex.html.StringSQStart(string, pos)[source]¶ Bases:
ly.lex.html.String,ly.lex._token.StringStart-
end¶
-
pos¶
-
rx= "'"¶
-
update_state(state)[source]¶ Lets the token update the state, e.g. enter a different parser.
This method is called by the State upon instantiation of the tokens.
Don’t use it later on to have a State follow already instantiated Tokens because the FallthroughParser type can also change the state without generating a Token. Use State.follow() to have a State follow instantiated Tokens.
The default implementation lets the Parser decide on state change.
-
-
class
ly.lex.html.TagEnd(string, pos)[source]¶ Bases:
ly.lex.html.Tag,ly.lex._token.Leaver-
end¶
-
pos¶
-
rx= '/?>'¶
-
-
class
ly.lex.html.TagStart(string, pos)[source]¶ Bases:
ly.lex.html.Tag-
end¶
-
pos¶
-
rx= '</?\\w[-_:\\w]*\\b'¶
-
update_state(state)[source]¶ Lets the token update the state, e.g. enter a different parser.
This method is called by the State upon instantiation of the tokens.
Don’t use it later on to have a State follow already instantiated Tokens because the FallthroughParser type can also change the state without generating a Token. Use State.follow() to have a State follow instantiated Tokens.
The default implementation lets the Parser decide on state change.
-
ly.lex.latex module¶
Parses and tokenizes LaTeX input, recognizing LilyPond in LaTeX.
ly.lex.lilypond module¶
Parses and tokenizes LilyPond input.
-
class
ly.lex.lilypond.AccidentalCautionary(string, pos)[source]¶ Bases:
ly.lex.lilypond.Accidental-
end¶
-
pos¶
-
rx= '\\?'¶
-
-
class
ly.lex.lilypond.AccidentalReminder(string, pos)[source]¶ Bases:
ly.lex.lilypond.Accidental-
end¶
-
pos¶
-
rx= '!'¶
-
-
class
ly.lex.lilypond.AccidentalStyle(string, pos)[source]¶ Bases:
ly.lex.lilypond.Command-
end¶
-
pos¶
-
rx= '\\\\accidentalStyle\\b'¶
-
update_state(state)[source]¶ Lets the token update the state, e.g. enter a different parser.
This method is called by the State upon instantiation of the tokens.
Don’t use it later on to have a State follow already instantiated Tokens because the FallthroughParser type can also change the state without generating a Token. Use State.follow() to have a State follow instantiated Tokens.
The default implementation lets the Parser decide on state change.
-
-
class
ly.lex.lilypond.AccidentalStyleSpecifier(string, pos)[source]¶ Bases:
ly.lex.lilypond.Specifier-
end¶
-
pos¶
-
rx= '\\b(default|voice|modern|modern-cautionary|modern-voice|modern-voice-cautionary|piano|piano-cautionary|neo-modern|neo-modern-cautionary|neo-modern-voice|neo-modern-voice-cautionary|dodecaphonic|teaching|no-reset|forget)(?!-?\\w)'¶
-
-
class
ly.lex.lilypond.AlterBroken(string, pos)[source]¶ Bases:
ly.lex.lilypond.Command-
end¶
-
pos¶
-
rx= '\\\\alterBroken\\b'¶
-
update_state(state)[source]¶ Lets the token update the state, e.g. enter a different parser.
This method is called by the State upon instantiation of the tokens.
Don’t use it later on to have a State follow already instantiated Tokens because the FallthroughParser type can also change the state without generating a Token. Use State.follow() to have a State follow instantiated Tokens.
The default implementation lets the Parser decide on state change.
-
-
class
ly.lex.lilypond.Articulation(string, pos)[source]¶ Bases:
ly.lex._token.TokenBase class for articulation things.
-
end¶
-
pos¶
-
-
class
ly.lex.lilypond.ArticulationCommand(string, pos)[source]¶ Bases:
ly.lex.lilypond.Articulation,ly.lex.lilypond.IdentifierRef-
end¶
-
pos¶
-
classmethod
test_match(match)[source]¶ Should return True if the match should indeed instantiate this class.
This class method is only called if multiple Token classes in the Parser’s items list have the same rx attribute. This method is then called for every matching Token subclass until one returns True. That token is then instantiated. (The method is not called for the last class in the list that have the same rx attribute, and also not if there is only one class with that rx attribute.)
The default implementation always returns True.
-
-
class
ly.lex.lilypond.BackSlashedContextName(string, pos)[source]¶ Bases:
ly.lex.lilypond.ContextName-
end¶
-
pos¶
-
rx= '\\\\(ChoirStaff|ChordNames|CueVoice|Devnull|DrumStaff|DrumVoice|Dynamics|FiguredBass|FretBoards|Global|GrandStaff|GregorianTranscriptionStaff|GregorianTranscriptionVoice|KievanStaff|KievanVoice|Lyrics|MensuralStaff|MensuralVoice|NoteNames|NullVoice|PetrucciStaff|PetrucciVoice|PianoStaff|RhythmicStaff|Score|Staff|StaffGroup|TabStaff|TabVoice|Timing|VaticanaStaff|VaticanaVoice|Voice)\\b'¶
-
-
class
ly.lex.lilypond.BeamEnd(string, pos)[source]¶ Bases:
ly.lex.lilypond.Beam,ly.lex._token.MatchEnd-
end¶
-
matchname= 'beam'¶
-
pos¶
-
rx= '\\]'¶
-
-
class
ly.lex.lilypond.BeamStart(string, pos)[source]¶ Bases:
ly.lex.lilypond.Beam,ly.lex._token.MatchStart-
end¶
-
matchname= 'beam'¶
-
pos¶
-
rx= '\\['¶
-
-
class
ly.lex.lilypond.BlockComment(string, pos)[source]¶ Bases:
ly.lex.lilypond.Comment,ly.lex._token.BlockComment-
end¶
-
pos¶
-
-
class
ly.lex.lilypond.BlockCommentEnd(string, pos)[source]¶ Bases:
ly.lex.lilypond.Comment,ly.lex._token.BlockCommentEnd,ly.lex._token.Leaver-
end¶
-
pos¶
-
rx= '%}'¶
-
-
class
ly.lex.lilypond.BlockCommentStart(string, pos)[source]¶ Bases:
ly.lex.lilypond.Comment,ly.lex._token.BlockCommentStart-
end¶
-
pos¶
-
rx= '%{'¶
-
update_state(state)[source]¶ Lets the token update the state, e.g. enter a different parser.
This method is called by the State upon instantiation of the tokens.
Don’t use it later on to have a State follow already instantiated Tokens because the FallthroughParser type can also change the state without generating a Token. Use State.follow() to have a State follow instantiated Tokens.
The default implementation lets the Parser decide on state change.
-
-
class
ly.lex.lilypond.Book(string, pos)[source]¶ Bases:
ly.lex.lilypond.Keyword-
end¶
-
pos¶
-
rx= '\\\\book\\b'¶
-
update_state(state)[source]¶ Lets the token update the state, e.g. enter a different parser.
This method is called by the State upon instantiation of the tokens.
Don’t use it later on to have a State follow already instantiated Tokens because the FallthroughParser type can also change the state without generating a Token. Use State.follow() to have a State follow instantiated Tokens.
The default implementation lets the Parser decide on state change.
-
-
class
ly.lex.lilypond.BookPart(string, pos)[source]¶ Bases:
ly.lex.lilypond.Keyword-
end¶
-
pos¶
-
rx= '\\\\bookpart\\b'¶
-
update_state(state)[source]¶ Lets the token update the state, e.g. enter a different parser.
This method is called by the State upon instantiation of the tokens.
Don’t use it later on to have a State follow already instantiated Tokens because the FallthroughParser type can also change the state without generating a Token. Use State.follow() to have a State follow instantiated Tokens.
The default implementation lets the Parser decide on state change.
-
-
class
ly.lex.lilypond.Change(string, pos)[source]¶ Bases:
ly.lex.lilypond.Translator-
end¶
-
pos¶
-
rx= '\\\\change\\b'¶
-
-
class
ly.lex.lilypond.Chord(string, pos)[source]¶ Bases:
ly.lex._token.TokenBase class for Chord delimiters.
-
end¶
-
pos¶
-
-
class
ly.lex.lilypond.ChordEnd(string, pos)[source]¶ Bases:
ly.lex.lilypond.Chord,ly.lex._token.Leaver-
end¶
-
pos¶
-
rx= '>'¶
-
-
class
ly.lex.lilypond.ChordItem(string, pos)[source]¶ Bases:
ly.lex._token.TokenBase class for chordmode items.
-
end¶
-
pos¶
-
-
class
ly.lex.lilypond.ChordMode(string, pos)[source]¶ Bases:
ly.lex.lilypond.InputMode-
end¶
-
pos¶
-
rx= '\\\\(chords|chordmode)\\b'¶
-
update_state(state)[source]¶ Lets the token update the state, e.g. enter a different parser.
This method is called by the State upon instantiation of the tokens.
Don’t use it later on to have a State follow already instantiated Tokens because the FallthroughParser type can also change the state without generating a Token. Use State.follow() to have a State follow instantiated Tokens.
The default implementation lets the Parser decide on state change.
-
-
class
ly.lex.lilypond.ChordModifier(string, pos)[source]¶ Bases:
ly.lex.lilypond.ChordItem-
end¶
-
pos¶
-
rx= '((?<![a-z])|^)(aug|dim|sus|min|maj|m)(?![a-z])'¶
-
-
class
ly.lex.lilypond.ChordSeparator(string, pos)[source]¶ Bases:
ly.lex.lilypond.ChordItem-
end¶
-
pos¶
-
rx= ':|\\^|/\\+?'¶
-
-
class
ly.lex.lilypond.ChordStart(string, pos)[source]¶ Bases:
ly.lex.lilypond.Chord-
end¶
-
pos¶
-
rx= '<'¶
-
update_state(state)[source]¶ Lets the token update the state, e.g. enter a different parser.
This method is called by the State upon instantiation of the tokens.
Don’t use it later on to have a State follow already instantiated Tokens because the FallthroughParser type can also change the state without generating a Token. Use State.follow() to have a State follow instantiated Tokens.
The default implementation lets the Parser decide on state change.
-
-
class
ly.lex.lilypond.ChordStepNumber(string, pos)[source]¶ Bases:
ly.lex.lilypond.ChordItem-
end¶
-
pos¶
-
rx= '\\d+[-+]?'¶
-
-
class
ly.lex.lilypond.Clef(string, pos)[source]¶ Bases:
ly.lex.lilypond.Command-
end¶
-
pos¶
-
rx= '\\\\clef\\b'¶
-
update_state(state)[source]¶ Lets the token update the state, e.g. enter a different parser.
This method is called by the State upon instantiation of the tokens.
Don’t use it later on to have a State follow already instantiated Tokens because the FallthroughParser type can also change the state without generating a Token. Use State.follow() to have a State follow instantiated Tokens.
The default implementation lets the Parser decide on state change.
-
-
class
ly.lex.lilypond.ClefSpecifier(string, pos)[source]¶ Bases:
ly.lex.lilypond.Specifier-
end¶
-
pos¶
-
rx= '\\b(alto|baritone|bass|C|F|french|G|GG|mezzosoprano|percussion|soprano|subbass|tab|tenor|tenorG|treble|varbaritone|varC|varpercussion|violin)\\b'¶
-
update_state(state)[source]¶ Lets the token update the state, e.g. enter a different parser.
This method is called by the State upon instantiation of the tokens.
Don’t use it later on to have a State follow already instantiated Tokens because the FallthroughParser type can also change the state without generating a Token. Use State.follow() to have a State follow instantiated Tokens.
The default implementation lets the Parser decide on state change.
-
-
class
ly.lex.lilypond.CloseBracket(string, pos)[source]¶ Bases:
ly.lex.lilypond.Delimiter,ly.lex._token.MatchEnd,ly.lex._token.Dedent-
end¶
-
matchname= 'bracket'¶
-
pos¶
-
rx= '\\}'¶
-
update_state(state)[source]¶ Lets the token update the state, e.g. enter a different parser.
This method is called by the State upon instantiation of the tokens.
Don’t use it later on to have a State follow already instantiated Tokens because the FallthroughParser type can also change the state without generating a Token. Use State.follow() to have a State follow instantiated Tokens.
The default implementation lets the Parser decide on state change.
-
-
class
ly.lex.lilypond.CloseBracketMarkup(string, pos)[source]¶ Bases:
ly.lex.lilypond.CloseBracket-
end¶
-
pos¶
-
update_state(state)[source]¶ Lets the token update the state, e.g. enter a different parser.
This method is called by the State upon instantiation of the tokens.
Don’t use it later on to have a State follow already instantiated Tokens because the FallthroughParser type can also change the state without generating a Token. Use State.follow() to have a State follow instantiated Tokens.
The default implementation lets the Parser decide on state change.
-
-
class
ly.lex.lilypond.CloseSimultaneous(string, pos)[source]¶ Bases:
ly.lex.lilypond.Delimiter,ly.lex._token.MatchEnd,ly.lex._token.Dedent-
end¶
-
matchname= 'simultaneous'¶
-
pos¶
-
rx= '>>'¶
-
update_state(state)[source]¶ Lets the token update the state, e.g. enter a different parser.
This method is called by the State upon instantiation of the tokens.
Don’t use it later on to have a State follow already instantiated Tokens because the FallthroughParser type can also change the state without generating a Token. Use State.follow() to have a State follow instantiated Tokens.
The default implementation lets the Parser decide on state change.
-
-
class
ly.lex.lilypond.Command(string, pos)[source]¶ Bases:
ly.lex._token.Item,ly.lex.lilypond.IdentifierRef-
end¶
-
pos¶
-
classmethod
test_match(match)[source]¶ Should return True if the match should indeed instantiate this class.
This class method is only called if multiple Token classes in the Parser’s items list have the same rx attribute. This method is then called for every matching Token subclass until one returns True. That token is then instantiated. (The method is not called for the last class in the list that have the same rx attribute, and also not if there is only one class with that rx attribute.)
The default implementation always returns True.
-
-
class
ly.lex.lilypond.Context(string, pos)[source]¶ Bases:
ly.lex.lilypond.Translator-
end¶
-
pos¶
-
rx= '\\\\context\\b'¶
-
-
class
ly.lex.lilypond.ContextName(string, pos)[source]¶ Bases:
ly.lex._token.Token-
end¶
-
pos¶
-
rx= '\\b(ChoirStaff|ChordNames|CueVoice|Devnull|DrumStaff|DrumVoice|Dynamics|FiguredBass|FretBoards|Global|GrandStaff|GregorianTranscriptionStaff|GregorianTranscriptionVoice|KievanStaff|KievanVoice|Lyrics|MensuralStaff|MensuralVoice|NoteNames|NullVoice|PetrucciStaff|PetrucciVoice|PianoStaff|RhythmicStaff|Score|Staff|StaffGroup|TabStaff|TabVoice|Timing|VaticanaStaff|VaticanaVoice|Voice)\\b'¶
-
-
class
ly.lex.lilypond.ContextProperty(string, pos)[source]¶ Bases:
ly.lex.lilypond.Variable-
end¶
-
pos¶
-
rx= '\\b(aDueText|accidentalGrouping|additionalPitchPrefix|alignAboveContext|alignBassFigureAccidentals|alignBelowContext|alternativeNumberingStyle|associatedVoice|autoAccidentals|autoBeamCheck|autoBeaming|autoCautionaries|automaticBars|barAlways|barCheckSynchronize|barNumberFormatter|barNumberVisibility|baseMoment|bassFigureFormatFunction|bassStaffProperties|beamExceptions|beamHalfMeasure|beatStructure|chordChanges|chordNameExceptions|chordNameExceptionsFull|chordNameExceptionsPartial|chordNameFunction|chordNameLowercaseMinor|chordNameSeparator|chordNoteNamer|chordPrefixSpacer|chordRootNamer|clefGlyph|clefPosition|clefTransposition|clefTranspositionFormatter|clefTranspositionStyle|completionBusy|completionUnit|connectArpeggios|countPercentRepeats|createKeyOnClefChange|createSpacing|crescendoSpanner|crescendoText|cueClefGlyph|cueClefPosition|cueClefTransposition|cueClefTranspositionFormatter|cueClefTranspositionStyle|currentBarNumber|decrescendoSpanner|decrescendoText|defaultBarType|defaultStrings|doubleRepeatSegnoType|doubleRepeatType|doubleSlurs|drumPitchTable|drumStyleTable|endRepeatSegnoType|endRepeatType|explicitClefVisibility|explicitCueClefVisibility|explicitKeySignatureVisibility|extendersOverRests|extraNatural|figuredBassAlterationDirection|figuredBassCenterContinuations|figuredBassFormatter|figuredBassPlusDirection|fingeringOrientations|firstClef|followVoice|fontSize|forbidBreak|forceClef|fretLabels|glissandoMap|gridInterval|handleNegativeFrets|harmonicAccidentals|harmonicDots|highStringOne|ignoreBarChecks|ignoreFiguredBassRest|ignoreMelismata|implicitBassFigures|implicitTimeSignatureVisibility|includeGraceNotes|instrumentCueName|instrumentEqualizer|instrumentName|instrumentTransposition|internalBarNumber|keepAliveInterfaces|keyAlterationOrder|keySignature|lyricMelismaAlignment|majorSevenSymbol|markFormatter|maximumFretStretch|measureLength|measurePosition|melismaBusyProperties|metronomeMarkFormatter|middleCClefPosition|middleCCuePosition|middleCOffset|middleCPosition|midiBalance|midiChannelMapping|midiChorusLevel|midiInstrument|midiMaximumVolume|midiMergeUnisons|midiMinimumVolume|midiPanPosition|midiReverbLevel|minimumFret|minimumPageTurnLength|minimumRepeatLengthForPageTurn|minorChordModifier|noChordSymbol|noteToFretFunction|ottavation|output|partCombineTextsOnNote|pedalSostenutoStrings|pedalSostenutoStyle|pedalSustainStrings|pedalSustainStyle|pedalUnaCordaStrings|pedalUnaCordaStyle|predefinedDiagramTable|printKeyCancellation|printOctaveNames|printPartCombineTexts|proportionalNotationDuration|rehearsalMark|repeatCommands|repeatCountVisibility|restCompletionBusy|restNumberThreshold|restrainOpenStrings|searchForVoice|segnoType|shapeNoteStyles|shortInstrumentName|shortVocalName|skipBars|skipTypesetting|slashChordSeparator|soloIIText|soloText|squashedPosition|staffLineLayoutFunction|stanza|startRepeatSegnoType|startRepeatType|stemLeftBeamCount|stemRightBeamCount|strictBeatBeaming|stringNumberOrientations|stringOneTopmost|stringTunings|strokeFingerOrientations|subdivideBeams|suggestAccidentals|supportNonIntegerFret|systemStartDelimiter|systemStartDelimiterHierarchy|tabStaffLineLayoutFunction|tablatureFormat|tempoHideNote|tempoWholesPerMinute|tieWaitForNote|timeSignatureFraction|timeSignatureSettings|timing|tonic|topLevelAlignment|trebleStaffProperties|tremoloFlags|tupletFullLength|tupletFullLengthNote|tupletSpannerDuration|useBassFigureExtenders|vocalName|voltaSpannerDuration|whichBar)\\b'¶
-
-
class
ly.lex.lilypond.DecimalValue(string, pos)[source]¶ Bases:
ly.lex.lilypond.Value-
end¶
-
pos¶
-
rx= '-?\\d+(\\.\\d+)?'¶
-
-
class
ly.lex.lilypond.Direction(string, pos)[source]¶ Bases:
ly.lex._token.Token-
end¶
-
pos¶
-
rx= '[-_^]'¶
-
update_state(state)[source]¶ Lets the token update the state, e.g. enter a different parser.
This method is called by the State upon instantiation of the tokens.
Don’t use it later on to have a State follow already instantiated Tokens because the FallthroughParser type can also change the state without generating a Token. Use State.follow() to have a State follow instantiated Tokens.
The default implementation lets the Parser decide on state change.
-
-
class
ly.lex.lilypond.Dot(string, pos)[source]¶ Bases:
ly.lex.lilypond.Duration-
end¶
-
pos¶
-
rx= '\\.'¶
-
-
class
ly.lex.lilypond.DotChord(string, pos)[source]¶ Bases:
ly.lex.lilypond.ChordItem-
end¶
-
pos¶
-
rx= '\\.'¶
-
-
class
ly.lex.lilypond.DotPath(string, pos)[source]¶ Bases:
ly.lex.lilypond.DelimiterA dot in dotted path notation.
-
end¶
-
pos¶
-
rx= '\\.'¶
-
-
class
ly.lex.lilypond.DrumChordEnd(string, pos)[source]¶ Bases:
ly.lex.lilypond.ChordEnd-
end¶
-
pos¶
-
-
class
ly.lex.lilypond.DrumChordStart(string, pos)[source]¶ Bases:
ly.lex.lilypond.ChordStart-
end¶
-
pos¶
-
update_state(state)[source]¶ Lets the token update the state, e.g. enter a different parser.
This method is called by the State upon instantiation of the tokens.
Don’t use it later on to have a State follow already instantiated Tokens because the FallthroughParser type can also change the state without generating a Token. Use State.follow() to have a State follow instantiated Tokens.
The default implementation lets the Parser decide on state change.
-
-
class
ly.lex.lilypond.DrumMode(string, pos)[source]¶ Bases:
ly.lex.lilypond.InputMode-
end¶
-
pos¶
-
rx= '\\\\(drums|drummode)\\b'¶
-
update_state(state)[source]¶ Lets the token update the state, e.g. enter a different parser.
This method is called by the State upon instantiation of the tokens.
Don’t use it later on to have a State follow already instantiated Tokens because the FallthroughParser type can also change the state without generating a Token. Use State.follow() to have a State follow instantiated Tokens.
The default implementation lets the Parser decide on state change.
-
-
class
ly.lex.lilypond.DrumNote(string, pos)[source]¶ Bases:
ly.lex.lilypond.MusicItem-
end¶
-
pos¶
-
rx= '[a-z]+(?![A-Za-z])'¶
-
-
class
ly.lex.lilypond.Dynamic(string, pos)[source]¶ Bases:
ly.lex._token.Token-
end¶
-
pos¶
-
rx= '\\\\[<!>]|\\\\(f{1,5}|p{1,5}|mf|mp|fp|spp?|sff?|sfz|rfz|cresc|decresc|dim|cr|decr)(?![A-Za-z])'¶
-
-
class
ly.lex.lilypond.EqualSign(string, pos)[source]¶ Bases:
ly.lex._token.Token-
end¶
-
pos¶
-
rx= '='¶
-
-
class
ly.lex.lilypond.ErrorInChord(string, pos)[source]¶ Bases:
ly.lex.lilypond.Error-
end¶
-
pos¶
-
rx= '[-_^][_.>|!+^-]|<<|>>|\\\\[\\\\\\]\\[\\(\\)()]|(\\\\(maxima|longa|breve)\\b|(1|2|4|8|16|32|64|128|256|512|1024|2048)(?!\\d))|\\*[\\t ]*\\d+(/\\d+)?'¶
-
-
class
ly.lex.lilypond.ExpectBook(argcount=None)[source]¶ Bases:
ly.lex.lilypond.ExpectOpenBracket-
pattern= re.compile('(?P<g_0>\\s+)|(?P<g_1>%{)|(?P<g_2>%.*$)|(?P<g_3>\\{)', re.MULTILINE)¶
-
replace¶ alias of
ly.lex.lilypond.ParseBook
-
-
class
ly.lex.lilypond.ExpectBookPart(argcount=None)[source]¶ Bases:
ly.lex.lilypond.ExpectOpenBracket-
pattern= re.compile('(?P<g_0>\\s+)|(?P<g_1>%{)|(?P<g_2>%.*$)|(?P<g_3>\\{)', re.MULTILINE)¶
-
replace¶ alias of
ly.lex.lilypond.ParseBookPart
-
-
class
ly.lex.lilypond.ExpectChordMode(argcount=None)[source]¶ Bases:
ly.lex.lilypond.ExpectMusicList-
pattern= re.compile('(?P<g_0>\\s+)|(?P<g_1>%{)|(?P<g_2>%.*$)|(?P<g_3>\\{)|(?P<g_4><<)|(?P<g_5>\\\\(simultaneous|sequential)\\b)', re.MULTILINE)¶
-
replace¶ alias of
ly.lex.lilypond.ParseChordMode
-
-
class
ly.lex.lilypond.ExpectContext(argcount=None)[source]¶ Bases:
ly.lex.lilypond.ExpectOpenBracket-
pattern= re.compile('(?P<g_0>\\s+)|(?P<g_1>%{)|(?P<g_2>%.*$)|(?P<g_3>\\{)', re.MULTILINE)¶
-
replace¶ alias of
ly.lex.lilypond.ParseContext
-
-
class
ly.lex.lilypond.ExpectDrumMode(argcount=None)[source]¶ Bases:
ly.lex.lilypond.ExpectMusicList-
pattern= re.compile('(?P<g_0>\\s+)|(?P<g_1>%{)|(?P<g_2>%.*$)|(?P<g_3>\\{)|(?P<g_4><<)|(?P<g_5>\\\\(simultaneous|sequential)\\b)', re.MULTILINE)¶
-
replace¶ alias of
ly.lex.lilypond.ParseDrumMode
-
-
class
ly.lex.lilypond.ExpectFigureMode(argcount=None)[source]¶ Bases:
ly.lex.lilypond.ExpectMusicList-
pattern= re.compile('(?P<g_0>\\s+)|(?P<g_1>%{)|(?P<g_2>%.*$)|(?P<g_3>\\{)|(?P<g_4><<)|(?P<g_5>\\\\(simultaneous|sequential)\\b)', re.MULTILINE)¶
-
replace¶ alias of
ly.lex.lilypond.ParseFigureMode
-
-
class
ly.lex.lilypond.ExpectGrobProperty(argcount=None)[source]¶ Bases:
ly.lex.FallthroughParser-
items= (<class 'ly.lex._token.Space'>, <class 'ly.lex.lilypond.BlockCommentStart'>, <class 'ly.lex.lilypond.LineComment'>, <class 'ly.lex.lilypond.GrobProperty'>)¶
-
pattern= re.compile('(?P<g_0>\\s+)|(?P<g_1>%{)|(?P<g_2>%.*$)|(?P<g_3>\\b([a-z]+|[XY])(-([a-z]+|[XY]))*(?![\\w]))', re.MULTILINE)¶
-
-
class
ly.lex.lilypond.ExpectHeader(argcount=None)[source]¶ Bases:
ly.lex.lilypond.ExpectOpenBracket-
pattern= re.compile('(?P<g_0>\\s+)|(?P<g_1>%{)|(?P<g_2>%.*$)|(?P<g_3>\\{)', re.MULTILINE)¶
-
replace¶ alias of
ly.lex.lilypond.ParseHeader
-
-
class
ly.lex.lilypond.ExpectLayout(argcount=None)[source]¶ Bases:
ly.lex.lilypond.ExpectOpenBracket-
pattern= re.compile('(?P<g_0>\\s+)|(?P<g_1>%{)|(?P<g_2>%.*$)|(?P<g_3>\\{)', re.MULTILINE)¶
-
replace¶ alias of
ly.lex.lilypond.ParseLayout
-
-
class
ly.lex.lilypond.ExpectLyricMode(argcount=None)[source]¶ Bases:
ly.lex.lilypond.ExpectMusicList-
items= (<class 'ly.lex._token.Space'>, <class 'ly.lex.lilypond.BlockCommentStart'>, <class 'ly.lex.lilypond.LineComment'>, <class 'ly.lex.lilypond.OpenBracket'>, <class 'ly.lex.lilypond.OpenSimultaneous'>, <class 'ly.lex.lilypond.SchemeStart'>, <class 'ly.lex.lilypond.StringQuotedStart'>, <class 'ly.lex.lilypond.Name'>, <class 'ly.lex.lilypond.SimultaneousOrSequentialCommand'>)¶
-
pattern= re.compile('(?P<g_0>\\s+)|(?P<g_1>%{)|(?P<g_2>%.*$)|(?P<g_3>\\{)|(?P<g_4><<)|(?P<g_5>[#$](?![{}]))|(?P<g_6>")|(?P<g_7>(?<![^\\W\\d])[^\\W\\d_]+([_-][^\\W\\d_]+)*(?![_-]?[^\\W\\d]))|(?P<g_8>\\\\(simultaneous|sequ, re.MULTILINE)¶
-
replace¶ alias of
ly.lex.lilypond.ParseLyricMode
-
-
class
ly.lex.lilypond.ExpectMidi(argcount=None)[source]¶ Bases:
ly.lex.lilypond.ExpectOpenBracket-
pattern= re.compile('(?P<g_0>\\s+)|(?P<g_1>%{)|(?P<g_2>%.*$)|(?P<g_3>\\{)', re.MULTILINE)¶
-
replace¶ alias of
ly.lex.lilypond.ParseMidi
-
-
class
ly.lex.lilypond.ExpectMusicList(argcount=None)[source]¶ Bases:
ly.lex.FallthroughParser,ly.lex.lilypond.ParseLilyPondWaits for an OpenBracket or << and then replaces the parser with the class set in the replace attribute.
Subclass this to set the destination for the OpenBracket.
-
items= (<class 'ly.lex._token.Space'>, <class 'ly.lex.lilypond.BlockCommentStart'>, <class 'ly.lex.lilypond.LineComment'>, <class 'ly.lex.lilypond.OpenBracket'>, <class 'ly.lex.lilypond.OpenSimultaneous'>, <class 'ly.lex.lilypond.SimultaneousOrSequentialCommand'>)¶
-
pattern= re.compile('(?P<g_0>\\s+)|(?P<g_1>%{)|(?P<g_2>%.*$)|(?P<g_3>\\{)|(?P<g_4><<)|(?P<g_5>\\\\(simultaneous|sequential)\\b)', re.MULTILINE)¶
-
-
class
ly.lex.lilypond.ExpectNoteMode(argcount=None)[source]¶ Bases:
ly.lex.lilypond.ExpectMusicList-
replace¶ alias of
ly.lex.lilypond.ParseNoteMode
-
-
class
ly.lex.lilypond.ExpectOpenBracket(argcount=None)[source]¶ Bases:
ly.lex.FallthroughParser,ly.lex.lilypond.ParseLilyPondWaits for an OpenBracket and then replaces the parser with the class set in the replace attribute.
Subclass this to set the destination for the OpenBracket.
-
default¶ alias of
ly.lex.lilypond.Error
-
items= (<class 'ly.lex._token.Space'>, <class 'ly.lex.lilypond.BlockCommentStart'>, <class 'ly.lex.lilypond.LineComment'>, <class 'ly.lex.lilypond.OpenBracket'>)¶
-
pattern= re.compile('(?P<g_0>\\s+)|(?P<g_1>%{)|(?P<g_2>%.*$)|(?P<g_3>\\{)', re.MULTILINE)¶
-
-
class
ly.lex.lilypond.ExpectPaper(argcount=None)[source]¶ Bases:
ly.lex.lilypond.ExpectOpenBracket-
replace¶ alias of
ly.lex.lilypond.ParsePaper
-
-
class
ly.lex.lilypond.ExpectScore(argcount=None)[source]¶ Bases:
ly.lex.lilypond.ExpectOpenBracket-
replace¶ alias of
ly.lex.lilypond.ParseScore
-
-
class
ly.lex.lilypond.ExpectTranslatorId(argcount=None)[source]¶ Bases:
ly.lex.FallthroughParser-
items= (<class 'ly.lex._token.Space'>, <class 'ly.lex.lilypond.BlockCommentStart'>, <class 'ly.lex.lilypond.LineComment'>, <class 'ly.lex.lilypond.EqualSign'>)¶
-
pattern= re.compile('(?P<g_0>\\s+)|(?P<g_1>%{)|(?P<g_2>%.*$)|(?P<g_3>=)', re.MULTILINE)¶
-
-
class
ly.lex.lilypond.ExpectWith(argcount=None)[source]¶ Bases:
ly.lex.lilypond.ExpectOpenBracket-
replace¶ alias of
ly.lex.lilypond.ParseWith
-
-
class
ly.lex.lilypond.Figure(string, pos)[source]¶ Bases:
ly.lex._token.TokenBase class for Figure items.
-
end¶
-
pos¶
-
-
class
ly.lex.lilypond.FigureAccidental(string, pos)[source]¶ Bases:
ly.lex.lilypond.FigureA figure accidental.
-
end¶
-
pos¶
-
rx= '[-+!]+'¶
-
-
class
ly.lex.lilypond.FigureBracket(string, pos)[source]¶ Bases:
ly.lex.lilypond.Figure-
end¶
-
pos¶
-
rx= '[][]'¶
-
-
class
ly.lex.lilypond.FigureEnd(string, pos)[source]¶ Bases:
ly.lex.lilypond.Figure,ly.lex._token.Leaver-
end¶
-
pos¶
-
rx= '>'¶
-
-
class
ly.lex.lilypond.FigureMode(string, pos)[source]¶ Bases:
ly.lex.lilypond.InputMode-
end¶
-
pos¶
-
rx= '\\\\(figures|figuremode)\\b'¶
-
update_state(state)[source]¶ Lets the token update the state, e.g. enter a different parser.
This method is called by the State upon instantiation of the tokens.
Don’t use it later on to have a State follow already instantiated Tokens because the FallthroughParser type can also change the state without generating a Token. Use State.follow() to have a State follow instantiated Tokens.
The default implementation lets the Parser decide on state change.
-
-
class
ly.lex.lilypond.FigureModifier(string, pos)[source]¶ Bases:
ly.lex.lilypond.FigureA figure modifier.
-
end¶
-
pos¶
-
rx= '\\\\[\\\\!+]|/'¶
-
-
class
ly.lex.lilypond.FigureStart(string, pos)[source]¶ Bases:
ly.lex.lilypond.Figure-
end¶
-
pos¶
-
rx= '<'¶
-
update_state(state)[source]¶ Lets the token update the state, e.g. enter a different parser.
This method is called by the State upon instantiation of the tokens.
Don’t use it later on to have a State follow already instantiated Tokens because the FallthroughParser type can also change the state without generating a Token. Use State.follow() to have a State follow instantiated Tokens.
The default implementation lets the Parser decide on state change.
-
-
class
ly.lex.lilypond.FigureStep(string, pos)[source]¶ Bases:
ly.lex.lilypond.FigureA step figure number or the underscore.
-
end¶
-
pos¶
-
rx= '_|\\d+'¶
-
-
class
ly.lex.lilypond.Fingering(string, pos)[source]¶ Bases:
ly.lex.lilypond.Articulation,ly.lex._token.Leaver-
end¶
-
pos¶
-
rx= '\\d+'¶
-
-
class
ly.lex.lilypond.Fraction(string, pos)[source]¶ Bases:
ly.lex.lilypond.Value-
end¶
-
pos¶
-
rx= '\\d+/\\d+'¶
-
-
class
ly.lex.lilypond.GrobName(string, pos)[source]¶ Bases:
ly.lex._token.Token-
end¶
-
pos¶
-
rx= '\\b(Accidental|AccidentalCautionary|AccidentalPlacement|AccidentalSuggestion|Ambitus|AmbitusAccidental|AmbitusLine|AmbitusNoteHead|Arpeggio|BalloonTextItem|BarLine|BarNumber|BassFigure|BassFigureAlignment|BassFigureAlignmentPositioning|BassFigureBracket|BassFigureContinuation|BassFigureLine|Beam|BendAfter|BreakAlignGroup|BreakAlignment|BreathingSign|ChordName|Clef|ClefModifier|ClusterSpanner|ClusterSpannerBeacon|CombineTextScript|CueClef|CueEndClef|Custos|DotColumn|Dots|DoublePercentRepeat|DoublePercentRepeatCounter|DoubleRepeatSlash|DynamicLineSpanner|DynamicText|DynamicTextSpanner|Episema|Fingering|FingeringColumn|Flag|FootnoteItem|FootnoteSpanner|FretBoard|Glissando|GraceSpacing|GridLine|GridPoint|Hairpin|HorizontalBracket|InstrumentName|InstrumentSwitch|KeyCancellation|KeySignature|KievanLigature|LaissezVibrerTie|LaissezVibrerTieColumn|LedgerLineSpanner|LeftEdge|LigatureBracket|LyricExtender|LyricHyphen|LyricSpace|LyricText|MeasureCounter|MeasureGrouping|MelodyItem|MensuralLigature|MetronomeMark|MultiMeasureRest|MultiMeasureRestNumber|MultiMeasureRestText|NonMusicalPaperColumn|NoteCollision|NoteColumn|NoteHead|NoteName|NoteSpacing|OttavaBracket|PaperColumn|ParenthesesItem|PercentRepeat|PercentRepeatCounter|PhrasingSlur|PianoPedalBracket|RehearsalMark|RepeatSlash|RepeatTie|RepeatTieColumn|Rest|RestCollision|Script|ScriptColumn|ScriptRow|Slur|SostenutoPedal|SostenutoPedalLineSpanner|SpacingSpanner|SpanBar|SpanBarStub|StaffGrouper|StaffSpacing|StaffSymbol|StanzaNumber|Stem|StemStub|StemTremolo|StringNumber|StrokeFinger|SustainPedal|SustainPedalLineSpanner|System|SystemStartBar|SystemStartBrace|SystemStartBracket|SystemStartSquare|TabNoteHead|TextScript|TextSpanner|Tie|TieColumn|TimeSignature|TrillPitchAccidental|TrillPitchGroup|TrillPitchHead|TrillSpanner|TupletBracket|TupletNumber|UnaCordaPedal|UnaCordaPedalLineSpanner|VaticanaLigature|VerticalAlignment|VerticalAxisGroup|VoiceFollower|VoltaBracket|VoltaBracketSpanner)\\b'¶
-
-
class
ly.lex.lilypond.GrobProperty(string, pos)[source]¶ Bases:
ly.lex.lilypond.Variable-
end¶
-
pos¶
-
rx= '\\b([a-z]+|[XY])(-([a-z]+|[XY]))*(?![\\w])'¶
-
-
class
ly.lex.lilypond.Header(string, pos)[source]¶ Bases:
ly.lex.lilypond.Keyword-
end¶
-
pos¶
-
rx= '\\\\header\\b'¶
-
update_state(state)[source]¶ Lets the token update the state, e.g. enter a different parser.
This method is called by the State upon instantiation of the tokens.
Don’t use it later on to have a State follow already instantiated Tokens because the FallthroughParser type can also change the state without generating a Token. Use State.follow() to have a State follow instantiated Tokens.
The default implementation lets the Parser decide on state change.
-
-
class
ly.lex.lilypond.HeaderVariable(string, pos)[source]¶ Bases:
ly.lex.lilypond.VariableA variable inside Header. Always follow this one by UserVariable.
-
end¶
-
pos¶
-
classmethod
test_match(match)[source]¶ Should return True if the match should indeed instantiate this class.
This class method is only called if multiple Token classes in the Parser’s items list have the same rx attribute. This method is then called for every matching Token subclass until one returns True. That token is then instantiated. (The method is not called for the last class in the list that have the same rx attribute, and also not if there is only one class with that rx attribute.)
The default implementation always returns True.
-
-
class
ly.lex.lilypond.Hide(string, pos)[source]¶ Bases:
ly.lex.lilypond.Keyword-
end¶
-
pos¶
-
rx= '\\\\hide\\b'¶
-
update_state(state)[source]¶ Lets the token update the state, e.g. enter a different parser.
This method is called by the State upon instantiation of the tokens.
Don’t use it later on to have a State follow already instantiated Tokens because the FallthroughParser type can also change the state without generating a Token. Use State.follow() to have a State follow instantiated Tokens.
The default implementation lets the Parser decide on state change.
-
-
class
ly.lex.lilypond.Identifier(string, pos)[source]¶ Bases:
ly.lex._token.TokenA variable name, like
some-variable.-
end¶
-
pos¶
-
rx= '(?<![^\\W\\d])[^\\W\\d_]+([_-][^\\W\\d_]+)*(?![_-]?[^\\W\\d])'¶
-
-
class
ly.lex.lilypond.IdentifierRef(string, pos)[source]¶ Bases:
ly.lex._token.TokenA reference to an identifier, e.g.
\some-variable.-
end¶
-
pos¶
-
rx= '\\\\[^\\W\\d_]+([_-][^\\W\\d_]+)*(?![_-]?[^\\W\\d])'¶
-
-
class
ly.lex.lilypond.InputMode(string, pos)[source]¶ Bases:
ly.lex.lilypond.Command-
end¶
-
pos¶
-
-
class
ly.lex.lilypond.IntegerValue(string, pos)[source]¶ Bases:
ly.lex.lilypond.DecimalValue-
end¶
-
pos¶
-
rx= '\\d+'¶
-
-
class
ly.lex.lilypond.KeySignatureMode(string, pos)[source]¶ Bases:
ly.lex.lilypond.Command-
end¶
-
pos¶
-
rx= '\\\\(major|minor|ionian|dorian|phrygian|lydian|mixolydian|aeolian|locrian)(?![A-Za-z])'¶
-
-
class
ly.lex.lilypond.Keyword(string, pos)[source]¶ Bases:
ly.lex._token.Item,ly.lex.lilypond.IdentifierRef-
end¶
-
pos¶
-
classmethod
test_match(match)[source]¶ Should return True if the match should indeed instantiate this class.
This class method is only called if multiple Token classes in the Parser’s items list have the same rx attribute. This method is then called for every matching Token subclass until one returns True. That token is then instantiated. (The method is not called for the last class in the list that have the same rx attribute, and also not if there is only one class with that rx attribute.)
The default implementation always returns True.
-
-
class
ly.lex.lilypond.Layout(string, pos)[source]¶ Bases:
ly.lex.lilypond.Keyword-
end¶
-
pos¶
-
rx= '\\\\layout\\b'¶
-
update_state(state)[source]¶ Lets the token update the state, e.g. enter a different parser.
This method is called by the State upon instantiation of the tokens.
Don’t use it later on to have a State follow already instantiated Tokens because the FallthroughParser type can also change the state without generating a Token. Use State.follow() to have a State follow instantiated Tokens.
The default implementation lets the Parser decide on state change.
-
-
class
ly.lex.lilypond.LayoutContext(string, pos)[source]¶ Bases:
ly.lex.lilypond.Keyword-
end¶
-
pos¶
-
rx= '\\\\context\\b'¶
-
update_state(state)[source]¶ Lets the token update the state, e.g. enter a different parser.
This method is called by the State upon instantiation of the tokens.
Don’t use it later on to have a State follow already instantiated Tokens because the FallthroughParser type can also change the state without generating a Token. Use State.follow() to have a State follow instantiated Tokens.
The default implementation lets the Parser decide on state change.
-
-
class
ly.lex.lilypond.LayoutVariable(string, pos)[source]¶ Bases:
ly.lex.lilypond.VariableA variable inside Header. Always follow this one by UserVariable.
-
end¶
-
pos¶
-
classmethod
test_match(match)[source]¶ Should return True if the match should indeed instantiate this class.
This class method is only called if multiple Token classes in the Parser’s items list have the same rx attribute. This method is then called for every matching Token subclass until one returns True. That token is then instantiated. (The method is not called for the last class in the list that have the same rx attribute, and also not if there is only one class with that rx attribute.)
The default implementation always returns True.
-
-
class
ly.lex.lilypond.Length(string, pos)[source]¶ Bases:
ly.lex.lilypond.Duration-
end¶
-
pos¶
-
rx= '(\\\\(maxima|longa|breve)\\b|(1|2|4|8|16|32|64|128|256|512|1024|2048)(?!\\d))'¶
-
update_state(state)[source]¶ Lets the token update the state, e.g. enter a different parser.
This method is called by the State upon instantiation of the tokens.
Don’t use it later on to have a State follow already instantiated Tokens because the FallthroughParser type can also change the state without generating a Token. Use State.follow() to have a State follow instantiated Tokens.
The default implementation lets the Parser decide on state change.
-
-
class
ly.lex.lilypond.LigatureEnd(string, pos)[source]¶ Bases:
ly.lex.lilypond.Ligature,ly.lex._token.MatchEnd-
end¶
-
matchname= 'ligature'¶
-
pos¶
-
rx= '\\\\\\]'¶
-
-
class
ly.lex.lilypond.LigatureStart(string, pos)[source]¶ Bases:
ly.lex.lilypond.Ligature,ly.lex._token.MatchStart-
end¶
-
matchname= 'ligature'¶
-
pos¶
-
rx= '\\\\\\['¶
-
-
class
ly.lex.lilypond.LineComment(string, pos)[source]¶ Bases:
ly.lex.lilypond.Comment,ly.lex._token.LineComment-
end¶
-
pos¶
-
rx= '%.*$'¶
-
-
class
ly.lex.lilypond.Lyric(string, pos)[source]¶ Bases:
ly.lex._token.ItemBase class for Lyric items.
-
end¶
-
pos¶
-
-
class
ly.lex.lilypond.LyricExtender(string, pos)[source]¶ Bases:
ly.lex.lilypond.Lyric-
end¶
-
pos¶
-
rx= '__(?=($|[\\s\\\\]))'¶
-
-
class
ly.lex.lilypond.LyricHyphen(string, pos)[source]¶ Bases:
ly.lex.lilypond.Lyric-
end¶
-
pos¶
-
rx= '--(?=($|[\\s\\\\]))'¶
-
-
class
ly.lex.lilypond.LyricMode(string, pos)[source]¶ Bases:
ly.lex.lilypond.InputMode-
end¶
-
pos¶
-
rx= '\\\\(lyricmode|((old)?add)?lyrics|lyricsto)\\b'¶
-
update_state(state)[source]¶ Lets the token update the state, e.g. enter a different parser.
This method is called by the State upon instantiation of the tokens.
Don’t use it later on to have a State follow already instantiated Tokens because the FallthroughParser type can also change the state without generating a Token. Use State.follow() to have a State follow instantiated Tokens.
The default implementation lets the Parser decide on state change.
-
-
class
ly.lex.lilypond.LyricSkip(string, pos)[source]¶ Bases:
ly.lex.lilypond.Lyric-
end¶
-
pos¶
-
rx= '_(?=($|[\\s\\\\]))'¶
-
-
class
ly.lex.lilypond.LyricText(string, pos)[source]¶ Bases:
ly.lex.lilypond.Lyric-
end¶
-
pos¶
-
rx= '[^\\\\\\s\\d\\"]+'¶
-
-
class
ly.lex.lilypond.Markup(string, pos)[source]¶ Bases:
ly.lex._token.ItemBase class for all markup commands.
-
end¶
-
pos¶
-
-
class
ly.lex.lilypond.MarkupCommand(string, pos)[source]¶ Bases:
ly.lex.lilypond.Markup,ly.lex.lilypond.IdentifierRefA markup command.
-
end¶
-
pos¶
-
classmethod
test_match(match)[source]¶ Should return True if the match should indeed instantiate this class.
This class method is only called if multiple Token classes in the Parser’s items list have the same rx attribute. This method is then called for every matching Token subclass until one returns True. That token is then instantiated. (The method is not called for the last class in the list that have the same rx attribute, and also not if there is only one class with that rx attribute.)
The default implementation always returns True.
-
update_state(state)[source]¶ Lets the token update the state, e.g. enter a different parser.
This method is called by the State upon instantiation of the tokens.
Don’t use it later on to have a State follow already instantiated Tokens because the FallthroughParser type can also change the state without generating a Token. Use State.follow() to have a State follow instantiated Tokens.
The default implementation lets the Parser decide on state change.
-
-
class
ly.lex.lilypond.MarkupLines(string, pos)[source]¶ Bases:
ly.lex.lilypond.Markup-
end¶
-
pos¶
-
rx= '\\\\markuplines(?![_-]?[^\\W\\d])'¶
-
update_state(state)[source]¶ Lets the token update the state, e.g. enter a different parser.
This method is called by the State upon instantiation of the tokens.
Don’t use it later on to have a State follow already instantiated Tokens because the FallthroughParser type can also change the state without generating a Token. Use State.follow() to have a State follow instantiated Tokens.
The default implementation lets the Parser decide on state change.
-
-
class
ly.lex.lilypond.MarkupList(string, pos)[source]¶ Bases:
ly.lex.lilypond.Markup-
end¶
-
pos¶
-
rx= '\\\\markuplist(?![_-]?[^\\W\\d])'¶
-
update_state(state)[source]¶ Lets the token update the state, e.g. enter a different parser.
This method is called by the State upon instantiation of the tokens.
Don’t use it later on to have a State follow already instantiated Tokens because the FallthroughParser type can also change the state without generating a Token. Use State.follow() to have a State follow instantiated Tokens.
The default implementation lets the Parser decide on state change.
-
-
class
ly.lex.lilypond.MarkupScore(string, pos)[source]¶ Bases:
ly.lex.lilypond.Markup-
end¶
-
pos¶
-
rx= '\\\\score\\b'¶
-
update_state(state)[source]¶ Lets the token update the state, e.g. enter a different parser.
This method is called by the State upon instantiation of the tokens.
Don’t use it later on to have a State follow already instantiated Tokens because the FallthroughParser type can also change the state without generating a Token. Use State.follow() to have a State follow instantiated Tokens.
The default implementation lets the Parser decide on state change.
-
-
class
ly.lex.lilypond.MarkupStart(string, pos)[source]¶ Bases:
ly.lex.lilypond.Markup,ly.lex.lilypond.Command-
end¶
-
pos¶
-
rx= '\\\\markup(?![_-]?[^\\W\\d])'¶
-
update_state(state)[source]¶ Lets the token update the state, e.g. enter a different parser.
This method is called by the State upon instantiation of the tokens.
Don’t use it later on to have a State follow already instantiated Tokens because the FallthroughParser type can also change the state without generating a Token. Use State.follow() to have a State follow instantiated Tokens.
The default implementation lets the Parser decide on state change.
-
-
class
ly.lex.lilypond.MarkupUserCommand(string, pos)[source]¶ Bases:
ly.lex.lilypond.Markup,ly.lex.lilypond.IdentifierRefA user-defined markup (i.e. not in the words markupcommands list).
-
end¶
-
pos¶
-
update_state(state)[source]¶ Lets the token update the state, e.g. enter a different parser.
This method is called by the State upon instantiation of the tokens.
Don’t use it later on to have a State follow already instantiated Tokens because the FallthroughParser type can also change the state without generating a Token. Use State.follow() to have a State follow instantiated Tokens.
The default implementation lets the Parser decide on state change.
-
-
class
ly.lex.lilypond.MarkupWord(string, pos)[source]¶ Bases:
ly.lex._token.Item-
end¶
-
pos¶
-
rx= '[^{}"\\\\\\s#%]+'¶
-
-
class
ly.lex.lilypond.Midi(string, pos)[source]¶ Bases:
ly.lex.lilypond.Keyword-
end¶
-
pos¶
-
rx= '\\\\midi\\b'¶
-
update_state(state)[source]¶ Lets the token update the state, e.g. enter a different parser.
This method is called by the State upon instantiation of the tokens.
Don’t use it later on to have a State follow already instantiated Tokens because the FallthroughParser type can also change the state without generating a Token. Use State.follow() to have a State follow instantiated Tokens.
The default implementation lets the Parser decide on state change.
-
-
class
ly.lex.lilypond.MusicItem(string, pos)[source]¶ Bases:
ly.lex._token.TokenA note, rest, spacer,
\skiporq.-
end¶
-
pos¶
-
-
class
ly.lex.lilypond.Name(string, pos)[source]¶ Bases:
ly.lex.lilypond.UserVariableA variable name without prefix.
-
end¶
-
pos¶
-
-
class
ly.lex.lilypond.New(string, pos)[source]¶ Bases:
ly.lex.lilypond.Translator-
end¶
-
pos¶
-
rx= '\\\\new\\b'¶
-
-
class
ly.lex.lilypond.Note(string, pos)[source]¶ Bases:
ly.lex.lilypond.MusicItem-
end¶
-
pos¶
-
rx= '[a-x]+(?![A-Za-z])'¶
-
-
class
ly.lex.lilypond.NoteMode(string, pos)[source]¶ Bases:
ly.lex.lilypond.InputMode-
end¶
-
pos¶
-
rx= '\\\\(notes|notemode)\\b'¶
-
update_state(state)[source]¶ Lets the token update the state, e.g. enter a different parser.
This method is called by the State upon instantiation of the tokens.
Don’t use it later on to have a State follow already instantiated Tokens because the FallthroughParser type can also change the state without generating a Token. Use State.follow() to have a State follow instantiated Tokens.
The default implementation lets the Parser decide on state change.
-
-
class
ly.lex.lilypond.Octave(string, pos)[source]¶ Bases:
ly.lex._token.Token-
end¶
-
pos¶
-
rx= ",+|'+"¶
-
-
class
ly.lex.lilypond.OctaveCheck(string, pos)[source]¶ Bases:
ly.lex._token.Token-
end¶
-
pos¶
-
rx= "=(,+|'+)?"¶
-
-
class
ly.lex.lilypond.Omit(string, pos)[source]¶ Bases:
ly.lex.lilypond.Keyword-
end¶
-
pos¶
-
rx= '\\\\omit\\b'¶
-
update_state(state)[source]¶ Lets the token update the state, e.g. enter a different parser.
This method is called by the State upon instantiation of the tokens.
Don’t use it later on to have a State follow already instantiated Tokens because the FallthroughParser type can also change the state without generating a Token. Use State.follow() to have a State follow instantiated Tokens.
The default implementation lets the Parser decide on state change.
-
-
class
ly.lex.lilypond.OpenBracket(string, pos)[source]¶ Bases:
ly.lex.lilypond.Delimiter,ly.lex._token.MatchStart,ly.lex._token.IndentAn open bracket, does not enter different parser, subclass or reimplement Parser.update_state().
-
end¶
-
matchname= 'bracket'¶
-
pos¶
-
rx= '\\{'¶
-
-
class
ly.lex.lilypond.OpenBracketMarkup(string, pos)[source]¶ Bases:
ly.lex.lilypond.OpenBracket-
end¶
-
pos¶
-
update_state(state)[source]¶ Lets the token update the state, e.g. enter a different parser.
This method is called by the State upon instantiation of the tokens.
Don’t use it later on to have a State follow already instantiated Tokens because the FallthroughParser type can also change the state without generating a Token. Use State.follow() to have a State follow instantiated Tokens.
The default implementation lets the Parser decide on state change.
-
-
class
ly.lex.lilypond.OpenSimultaneous(string, pos)[source]¶ Bases:
ly.lex.lilypond.Delimiter,ly.lex._token.MatchStart,ly.lex._token.IndentAn open double French quote, does not enter different parser, subclass or reimplement Parser.update_state().
-
end¶
-
matchname= 'simultaneous'¶
-
pos¶
-
rx= '<<'¶
-
-
class
ly.lex.lilypond.Override(string, pos)[source]¶ Bases:
ly.lex.lilypond.Keyword-
end¶
-
pos¶
-
rx= '\\\\override\\b'¶
-
update_state(state)[source]¶ Lets the token update the state, e.g. enter a different parser.
This method is called by the State upon instantiation of the tokens.
Don’t use it later on to have a State follow already instantiated Tokens because the FallthroughParser type can also change the state without generating a Token. Use State.follow() to have a State follow instantiated Tokens.
The default implementation lets the Parser decide on state change.
-
-
class
ly.lex.lilypond.Paper(string, pos)[source]¶ Bases:
ly.lex.lilypond.Keyword-
end¶
-
pos¶
-
rx= '\\\\paper\\b'¶
-
update_state(state)[source]¶ Lets the token update the state, e.g. enter a different parser.
This method is called by the State upon instantiation of the tokens.
Don’t use it later on to have a State follow already instantiated Tokens because the FallthroughParser type can also change the state without generating a Token. Use State.follow() to have a State follow instantiated Tokens.
The default implementation lets the Parser decide on state change.
-
-
class
ly.lex.lilypond.PaperVariable(string, pos)[source]¶ Bases:
ly.lex.lilypond.VariableA variable inside Paper. Always follow this one by UserVariable.
-
end¶
-
pos¶
-
classmethod
test_match(match)[source]¶ Should return True if the match should indeed instantiate this class.
This class method is only called if multiple Token classes in the Parser’s items list have the same rx attribute. This method is then called for every matching Token subclass until one returns True. That token is then instantiated. (The method is not called for the last class in the list that have the same rx attribute, and also not if there is only one class with that rx attribute.)
The default implementation always returns True.
-
-
class
ly.lex.lilypond.ParseAccidentalStyle(argcount=None)[source]¶ Bases:
ly.lex.FallthroughParser-
items= (<class 'ly.lex._token.Space'>, <class 'ly.lex.lilypond.BlockCommentStart'>, <class 'ly.lex.lilypond.LineComment'>, <class 'ly.lex.lilypond.ContextName'>, <class 'ly.lex.lilypond.DotPath'>, <class 'ly.lex.lilypond.AccidentalStyleSpecifier'>)¶
-
pattern= re.compile('(?P<g_0>\\s+)|(?P<g_1>%{)|(?P<g_2>%.*$)|(?P<g_3>\\b(ChoirStaff|ChordNames|CueVoice|Devnull|DrumStaff|DrumVoice|Dynamics|FiguredBass|FretBoards|Global|GrandStaff|GregorianTranscriptionStaff|GregorianT, re.MULTILINE)¶
-
-
class
ly.lex.lilypond.ParseAlterBroken(argcount=None)[source]¶ Bases:
ly.lex.FallthroughParser-
items= (<class 'ly.lex._token.Space'>, <class 'ly.lex.lilypond.BlockCommentStart'>, <class 'ly.lex.lilypond.LineComment'>, <class 'ly.lex.lilypond.GrobProperty'>)¶
-
pattern= re.compile('(?P<g_0>\\s+)|(?P<g_1>%{)|(?P<g_2>%.*$)|(?P<g_3>\\b([a-z]+|[XY])(-([a-z]+|[XY]))*(?![\\w]))', re.MULTILINE)¶
-
-
class
ly.lex.lilypond.ParseBlockComment(argcount=None)[source]¶ Bases:
ly.lex.Parser-
default¶ alias of
ly.lex.lilypond.BlockComment
-
items= (<class 'ly.lex.lilypond.BlockCommentEnd'>,)¶
-
pattern= re.compile('(?P<g_0>%})', re.MULTILINE)¶
-
-
class
ly.lex.lilypond.ParseBook(argcount=None)[source]¶ Bases:
ly.lex.lilypond.ParseLilyPondParses the expression after
\book {, leaving at}-
items= (<class 'ly.lex.lilypond.CloseBracket'>, <class 'ly.lex.lilypond.MarkupStart'>, <class 'ly.lex.lilypond.MarkupLines'>, <class 'ly.lex.lilypond.MarkupList'>, <class 'ly.lex.lilypond.BookPart'>, <class 'ly.lex.lilypond.Score'>, <class 'ly.lex.lilypond.Paper'>, <class 'ly.lex.lilypond.Header'>, <class 'ly.lex.lilypond.Layout'>, <class 'ly.lex._token.Space'>, <class 'ly.lex.lilypond.BlockCommentStart'>, <class 'ly.lex.lilypond.LineComment'>, <class 'ly.lex.lilypond.SchemeStart'>, <class 'ly.lex.lilypond.StringQuotedStart'>, <class 'ly.lex.lilypond.SequentialStart'>, <class 'ly.lex.lilypond.SimultaneousStart'>, <class 'ly.lex.lilypond.Repeat'>, <class 'ly.lex.lilypond.PitchCommand'>, <class 'ly.lex.lilypond.Override'>, <class 'ly.lex.lilypond.Revert'>, <class 'ly.lex.lilypond.Set'>, <class 'ly.lex.lilypond.Unset'>, <class 'ly.lex.lilypond.Hide'>, <class 'ly.lex.lilypond.Omit'>, <class 'ly.lex.lilypond.Tweak'>, <class 'ly.lex.lilypond.New'>, <class 'ly.lex.lilypond.Context'>, <class 'ly.lex.lilypond.Change'>, <class 'ly.lex.lilypond.With'>, <class 'ly.lex.lilypond.Clef'>, <class 'ly.lex.lilypond.Tempo'>, <class 'ly.lex.lilypond.Partial'>, <class 'ly.lex.lilypond.KeySignatureMode'>, <class 'ly.lex.lilypond.AccidentalStyle'>, <class 'ly.lex.lilypond.AlterBroken'>, <class 'ly.lex.lilypond.SimultaneousOrSequentialCommand'>, <class 'ly.lex.lilypond.ChordMode'>, <class 'ly.lex.lilypond.DrumMode'>, <class 'ly.lex.lilypond.FigureMode'>, <class 'ly.lex.lilypond.LyricMode'>, <class 'ly.lex.lilypond.NoteMode'>, <class 'ly.lex.lilypond.MarkupStart'>, <class 'ly.lex.lilypond.MarkupLines'>, <class 'ly.lex.lilypond.MarkupList'>, <class 'ly.lex.lilypond.ArticulationCommand'>, <class 'ly.lex.lilypond.Keyword'>, <class 'ly.lex.lilypond.Command'>, <class 'ly.lex.lilypond.SimultaneousOrSequentialCommand'>, <class 'ly.lex.lilypond.UserCommand'>)¶
-
pattern= re.compile('(?P<g_0>\\})|(?P<g_1>\\\\markup(?![_-]?[^\\W\\d]))|(?P<g_2>\\\\markuplines(?![_-]?[^\\W\\d]))|(?P<g_3>\\\\markuplist(?![_-]?[^\\W\\d]))|(?P<g_4>\\\\bookpart\\b)|(?P<g_5>\\\\score\\b)|(?P<g_6>\\\\pape, re.MULTILINE)¶
-
-
class
ly.lex.lilypond.ParseBookPart(argcount=None)[source]¶ Bases:
ly.lex.lilypond.ParseLilyPondParses the expression after
\bookpart {, leaving at}-
items= (<class 'ly.lex.lilypond.CloseBracket'>, <class 'ly.lex.lilypond.MarkupStart'>, <class 'ly.lex.lilypond.MarkupLines'>, <class 'ly.lex.lilypond.MarkupList'>, <class 'ly.lex.lilypond.Score'>, <class 'ly.lex.lilypond.Paper'>, <class 'ly.lex.lilypond.Header'>, <class 'ly.lex.lilypond.Layout'>, <class 'ly.lex._token.Space'>, <class 'ly.lex.lilypond.BlockCommentStart'>, <class 'ly.lex.lilypond.LineComment'>, <class 'ly.lex.lilypond.SchemeStart'>, <class 'ly.lex.lilypond.StringQuotedStart'>, <class 'ly.lex.lilypond.SequentialStart'>, <class 'ly.lex.lilypond.SimultaneousStart'>, <class 'ly.lex.lilypond.Repeat'>, <class 'ly.lex.lilypond.PitchCommand'>, <class 'ly.lex.lilypond.Override'>, <class 'ly.lex.lilypond.Revert'>, <class 'ly.lex.lilypond.Set'>, <class 'ly.lex.lilypond.Unset'>, <class 'ly.lex.lilypond.Hide'>, <class 'ly.lex.lilypond.Omit'>, <class 'ly.lex.lilypond.Tweak'>, <class 'ly.lex.lilypond.New'>, <class 'ly.lex.lilypond.Context'>, <class 'ly.lex.lilypond.Change'>, <class 'ly.lex.lilypond.With'>, <class 'ly.lex.lilypond.Clef'>, <class 'ly.lex.lilypond.Tempo'>, <class 'ly.lex.lilypond.Partial'>, <class 'ly.lex.lilypond.KeySignatureMode'>, <class 'ly.lex.lilypond.AccidentalStyle'>, <class 'ly.lex.lilypond.AlterBroken'>, <class 'ly.lex.lilypond.SimultaneousOrSequentialCommand'>, <class 'ly.lex.lilypond.ChordMode'>, <class 'ly.lex.lilypond.DrumMode'>, <class 'ly.lex.lilypond.FigureMode'>, <class 'ly.lex.lilypond.LyricMode'>, <class 'ly.lex.lilypond.NoteMode'>, <class 'ly.lex.lilypond.MarkupStart'>, <class 'ly.lex.lilypond.MarkupLines'>, <class 'ly.lex.lilypond.MarkupList'>, <class 'ly.lex.lilypond.ArticulationCommand'>, <class 'ly.lex.lilypond.Keyword'>, <class 'ly.lex.lilypond.Command'>, <class 'ly.lex.lilypond.SimultaneousOrSequentialCommand'>, <class 'ly.lex.lilypond.UserCommand'>)¶
-
pattern= re.compile('(?P<g_0>\\})|(?P<g_1>\\\\markup(?![_-]?[^\\W\\d]))|(?P<g_2>\\\\markuplines(?![_-]?[^\\W\\d]))|(?P<g_3>\\\\markuplist(?![_-]?[^\\W\\d]))|(?P<g_4>\\\\score\\b)|(?P<g_5>\\\\paper\\b)|(?P<g_6>\\\\header\, re.MULTILINE)¶
-
-
class
ly.lex.lilypond.ParseChord(argcount=None)[source]¶ Bases:
ly.lex.lilypond.ParseMusicLilyPond inside chords
< >-
items= (<class 'ly.lex.lilypond.ErrorInChord'>, <class 'ly.lex.lilypond.ChordEnd'>, <class 'ly.lex._token.Space'>, <class 'ly.lex.lilypond.BlockCommentStart'>, <class 'ly.lex.lilypond.LineComment'>, <class 'ly.lex.lilypond.SchemeStart'>, <class 'ly.lex.lilypond.StringQuotedStart'>, <class 'ly.lex.lilypond.Dynamic'>, <class 'ly.lex.lilypond.Skip'>, <class 'ly.lex.lilypond.Spacer'>, <class 'ly.lex.lilypond.Q'>, <class 'ly.lex.lilypond.Rest'>, <class 'ly.lex.lilypond.Note'>, <class 'ly.lex.lilypond.Fraction'>, <class 'ly.lex.lilypond.Length'>, <class 'ly.lex.lilypond.Octave'>, <class 'ly.lex.lilypond.OctaveCheck'>, <class 'ly.lex.lilypond.AccidentalCautionary'>, <class 'ly.lex.lilypond.AccidentalReminder'>, <class 'ly.lex.lilypond.PipeSymbol'>, <class 'ly.lex.lilypond.VoiceSeparator'>, <class 'ly.lex.lilypond.SequentialStart'>, <class 'ly.lex.lilypond.SequentialEnd'>, <class 'ly.lex.lilypond.SimultaneousStart'>, <class 'ly.lex.lilypond.SimultaneousEnd'>, <class 'ly.lex.lilypond.ChordStart'>, <class 'ly.lex.lilypond.ContextName'>, <class 'ly.lex.lilypond.GrobName'>, <class 'ly.lex.lilypond.SlurStart'>, <class 'ly.lex.lilypond.SlurEnd'>, <class 'ly.lex.lilypond.PhrasingSlurStart'>, <class 'ly.lex.lilypond.PhrasingSlurEnd'>, <class 'ly.lex.lilypond.Tie'>, <class 'ly.lex.lilypond.BeamStart'>, <class 'ly.lex.lilypond.BeamEnd'>, <class 'ly.lex.lilypond.LigatureStart'>, <class 'ly.lex.lilypond.LigatureEnd'>, <class 'ly.lex.lilypond.Direction'>, <class 'ly.lex.lilypond.StringNumber'>, <class 'ly.lex.lilypond.IntegerValue'>, <class 'ly.lex.lilypond.Repeat'>, <class 'ly.lex.lilypond.PitchCommand'>, <class 'ly.lex.lilypond.Override'>, <class 'ly.lex.lilypond.Revert'>, <class 'ly.lex.lilypond.Set'>, <class 'ly.lex.lilypond.Unset'>, <class 'ly.lex.lilypond.Hide'>, <class 'ly.lex.lilypond.Omit'>, <class 'ly.lex.lilypond.Tweak'>, <class 'ly.lex.lilypond.New'>, <class 'ly.lex.lilypond.Context'>, <class 'ly.lex.lilypond.Change'>, <class 'ly.lex.lilypond.With'>, <class 'ly.lex.lilypond.Clef'>, <class 'ly.lex.lilypond.Tempo'>, <class 'ly.lex.lilypond.Partial'>, <class 'ly.lex.lilypond.KeySignatureMode'>, <class 'ly.lex.lilypond.AccidentalStyle'>, <class 'ly.lex.lilypond.AlterBroken'>, <class 'ly.lex.lilypond.SimultaneousOrSequentialCommand'>, <class 'ly.lex.lilypond.ChordMode'>, <class 'ly.lex.lilypond.DrumMode'>, <class 'ly.lex.lilypond.FigureMode'>, <class 'ly.lex.lilypond.LyricMode'>, <class 'ly.lex.lilypond.NoteMode'>, <class 'ly.lex.lilypond.MarkupStart'>, <class 'ly.lex.lilypond.MarkupLines'>, <class 'ly.lex.lilypond.MarkupList'>, <class 'ly.lex.lilypond.ArticulationCommand'>, <class 'ly.lex.lilypond.Keyword'>, <class 'ly.lex.lilypond.Command'>, <class 'ly.lex.lilypond.SimultaneousOrSequentialCommand'>, <class 'ly.lex.lilypond.UserCommand'>)¶
-
pattern= re.compile('(?P<g_0>[-_^][_.>|!+^-]|<<|>>|\\\\[\\\\\\]\\[\\(\\)()]|(\\\\(maxima|longa|breve)\\b|(1|2|4|8|16|32|64|128|256|512|1024|2048)(?!\\d))|\\*[\\t ]*\\d+(/\\d+)?)|(?P<g_1>>)|(?P<g_2>\\s+)|(?P<g_3>%{)|(?P<g, re.MULTILINE)¶
-
-
class
ly.lex.lilypond.ParseChordItems(argcount=None)[source]¶ Bases:
ly.lex.FallthroughParser-
items= (<class 'ly.lex.lilypond.ChordSeparator'>, <class 'ly.lex.lilypond.ChordModifier'>, <class 'ly.lex.lilypond.ChordStepNumber'>, <class 'ly.lex.lilypond.DotChord'>, <class 'ly.lex.lilypond.Note'>)¶
-
pattern= re.compile('(?P<g_0>:|\\^|/\\+?)|(?P<g_1>((?<![a-z])|^)(aug|dim|sus|min|maj|m)(?![a-z]))|(?P<g_2>\\d+[-+]?)|(?P<g_3>\\.)|(?P<g_4>[a-x]+(?![A-Za-z]))', re.MULTILINE)¶
-
-
class
ly.lex.lilypond.ParseChordMode(argcount=None)[source]¶ Bases:
ly.lex.lilypond.ParseInputMode,ly.lex.lilypond.ParseMusicParser for
\chordsand\chordmode.-
items= (<class 'ly.lex.lilypond.OpenBracket'>, <class 'ly.lex.lilypond.OpenSimultaneous'>, <class 'ly.lex._token.Space'>, <class 'ly.lex.lilypond.BlockCommentStart'>, <class 'ly.lex.lilypond.LineComment'>, <class 'ly.lex.lilypond.SchemeStart'>, <class 'ly.lex.lilypond.StringQuotedStart'>, <class 'ly.lex.lilypond.Dynamic'>, <class 'ly.lex.lilypond.Skip'>, <class 'ly.lex.lilypond.Spacer'>, <class 'ly.lex.lilypond.Q'>, <class 'ly.lex.lilypond.Rest'>, <class 'ly.lex.lilypond.Note'>, <class 'ly.lex.lilypond.Fraction'>, <class 'ly.lex.lilypond.Length'>, <class 'ly.lex.lilypond.Octave'>, <class 'ly.lex.lilypond.OctaveCheck'>, <class 'ly.lex.lilypond.AccidentalCautionary'>, <class 'ly.lex.lilypond.AccidentalReminder'>, <class 'ly.lex.lilypond.PipeSymbol'>, <class 'ly.lex.lilypond.VoiceSeparator'>, <class 'ly.lex.lilypond.SequentialStart'>, <class 'ly.lex.lilypond.SequentialEnd'>, <class 'ly.lex.lilypond.SimultaneousStart'>, <class 'ly.lex.lilypond.SimultaneousEnd'>, <class 'ly.lex.lilypond.ChordStart'>, <class 'ly.lex.lilypond.ContextName'>, <class 'ly.lex.lilypond.GrobName'>, <class 'ly.lex.lilypond.SlurStart'>, <class 'ly.lex.lilypond.SlurEnd'>, <class 'ly.lex.lilypond.PhrasingSlurStart'>, <class 'ly.lex.lilypond.PhrasingSlurEnd'>, <class 'ly.lex.lilypond.Tie'>, <class 'ly.lex.lilypond.BeamStart'>, <class 'ly.lex.lilypond.BeamEnd'>, <class 'ly.lex.lilypond.LigatureStart'>, <class 'ly.lex.lilypond.LigatureEnd'>, <class 'ly.lex.lilypond.Direction'>, <class 'ly.lex.lilypond.StringNumber'>, <class 'ly.lex.lilypond.IntegerValue'>, <class 'ly.lex.lilypond.Repeat'>, <class 'ly.lex.lilypond.PitchCommand'>, <class 'ly.lex.lilypond.Override'>, <class 'ly.lex.lilypond.Revert'>, <class 'ly.lex.lilypond.Set'>, <class 'ly.lex.lilypond.Unset'>, <class 'ly.lex.lilypond.Hide'>, <class 'ly.lex.lilypond.Omit'>, <class 'ly.lex.lilypond.Tweak'>, <class 'ly.lex.lilypond.New'>, <class 'ly.lex.lilypond.Context'>, <class 'ly.lex.lilypond.Change'>, <class 'ly.lex.lilypond.With'>, <class 'ly.lex.lilypond.Clef'>, <class 'ly.lex.lilypond.Tempo'>, <class 'ly.lex.lilypond.Partial'>, <class 'ly.lex.lilypond.KeySignatureMode'>, <class 'ly.lex.lilypond.AccidentalStyle'>, <class 'ly.lex.lilypond.AlterBroken'>, <class 'ly.lex.lilypond.SimultaneousOrSequentialCommand'>, <class 'ly.lex.lilypond.ChordMode'>, <class 'ly.lex.lilypond.DrumMode'>, <class 'ly.lex.lilypond.FigureMode'>, <class 'ly.lex.lilypond.LyricMode'>, <class 'ly.lex.lilypond.NoteMode'>, <class 'ly.lex.lilypond.MarkupStart'>, <class 'ly.lex.lilypond.MarkupLines'>, <class 'ly.lex.lilypond.MarkupList'>, <class 'ly.lex.lilypond.ArticulationCommand'>, <class 'ly.lex.lilypond.Keyword'>, <class 'ly.lex.lilypond.Command'>, <class 'ly.lex.lilypond.SimultaneousOrSequentialCommand'>, <class 'ly.lex.lilypond.UserCommand'>, <class 'ly.lex.lilypond.ChordSeparator'>)¶
-
pattern= re.compile('(?P<g_0>\\{)|(?P<g_1><<)|(?P<g_2>\\s+)|(?P<g_3>%{)|(?P<g_4>%.*$)|(?P<g_5>[#$](?![{}]))|(?P<g_6>")|(?P<g_7>\\\\[<!>]|\\\\(f{1,5}|p{1,5}|mf|mp|fp|spp?|sff?|sfz|rfz|cresc|decresc|dim|cr|decr)(?![A-Za-z], re.MULTILINE)¶
-
-
class
ly.lex.lilypond.ParseClef(argcount=None)[source]¶ Bases:
ly.lex.FallthroughParser-
argcount= 1¶
-
items= (<class 'ly.lex._token.Space'>, <class 'ly.lex.lilypond.BlockCommentStart'>, <class 'ly.lex.lilypond.LineComment'>, <class 'ly.lex.lilypond.ClefSpecifier'>, <class 'ly.lex.lilypond.StringQuotedStart'>)¶
-
pattern= re.compile('(?P<g_0>\\s+)|(?P<g_1>%{)|(?P<g_2>%.*$)|(?P<g_3>\\b(alto|baritone|bass|C|F|french|G|GG|mezzosoprano|percussion|soprano|subbass|tab|tenor|tenorG|treble|varbaritone|varC|varpercussion|violin)\\b)|(?P<g, re.MULTILINE)¶
-
-
class
ly.lex.lilypond.ParseContext(argcount=None)[source]¶ Bases:
ly.lex.lilypond.ParseLilyPondParses the expression after (
\layout {)\context {, leaving at}-
items= (<class 'ly.lex.lilypond.CloseBracket'>, <class 'ly.lex.lilypond.BackSlashedContextName'>, <class 'ly.lex.lilypond.ContextProperty'>, <class 'ly.lex.lilypond.EqualSign'>, <class 'ly.lex.lilypond.DotPath'>, <class 'ly.lex._token.Space'>, <class 'ly.lex.lilypond.BlockCommentStart'>, <class 'ly.lex.lilypond.LineComment'>, <class 'ly.lex.lilypond.SchemeStart'>, <class 'ly.lex.lilypond.StringQuotedStart'>, <class 'ly.lex.lilypond.SequentialStart'>, <class 'ly.lex.lilypond.SimultaneousStart'>, <class 'ly.lex.lilypond.Repeat'>, <class 'ly.lex.lilypond.PitchCommand'>, <class 'ly.lex.lilypond.Override'>, <class 'ly.lex.lilypond.Revert'>, <class 'ly.lex.lilypond.Set'>, <class 'ly.lex.lilypond.Unset'>, <class 'ly.lex.lilypond.Hide'>, <class 'ly.lex.lilypond.Omit'>, <class 'ly.lex.lilypond.Tweak'>, <class 'ly.lex.lilypond.New'>, <class 'ly.lex.lilypond.Context'>, <class 'ly.lex.lilypond.Change'>, <class 'ly.lex.lilypond.With'>, <class 'ly.lex.lilypond.Clef'>, <class 'ly.lex.lilypond.Tempo'>, <class 'ly.lex.lilypond.Partial'>, <class 'ly.lex.lilypond.KeySignatureMode'>, <class 'ly.lex.lilypond.AccidentalStyle'>, <class 'ly.lex.lilypond.AlterBroken'>, <class 'ly.lex.lilypond.SimultaneousOrSequentialCommand'>, <class 'ly.lex.lilypond.ChordMode'>, <class 'ly.lex.lilypond.DrumMode'>, <class 'ly.lex.lilypond.FigureMode'>, <class 'ly.lex.lilypond.LyricMode'>, <class 'ly.lex.lilypond.NoteMode'>, <class 'ly.lex.lilypond.MarkupStart'>, <class 'ly.lex.lilypond.MarkupLines'>, <class 'ly.lex.lilypond.MarkupList'>, <class 'ly.lex.lilypond.ArticulationCommand'>, <class 'ly.lex.lilypond.Keyword'>, <class 'ly.lex.lilypond.Command'>, <class 'ly.lex.lilypond.SimultaneousOrSequentialCommand'>, <class 'ly.lex.lilypond.UserCommand'>)¶
-
pattern= re.compile('(?P<g_0>\\})|(?P<g_1>\\\\(ChoirStaff|ChordNames|CueVoice|Devnull|DrumStaff|DrumVoice|Dynamics|FiguredBass|FretBoards|Global|GrandStaff|GregorianTranscriptionStaff|GregorianTranscriptionVoice|KievanSt, re.MULTILINE)¶
-
-
class
ly.lex.lilypond.ParseDecimalValue(argcount=None)[source]¶ Bases:
ly.lex.FallthroughParserParses a decimal value without a # before it (if present).
-
items= (<class 'ly.lex._token.Space'>, <class 'ly.lex.lilypond.BlockCommentStart'>, <class 'ly.lex.lilypond.LineComment'>, <class 'ly.lex.lilypond.Fraction'>, <class 'ly.lex.lilypond.DecimalValue'>)¶
-
pattern= re.compile('(?P<g_0>\\s+)|(?P<g_1>%{)|(?P<g_2>%.*$)|(?P<g_3>\\d+/\\d+)|(?P<g_4>-?\\d+(\\.\\d+)?)', re.MULTILINE)¶
-
-
class
ly.lex.lilypond.ParseDrumChord(argcount=None)[source]¶ Bases:
ly.lex.lilypond.ParseMusicLilyPond inside chords in drummode
< >-
items= (<class 'ly.lex._token.Space'>, <class 'ly.lex.lilypond.BlockCommentStart'>, <class 'ly.lex.lilypond.LineComment'>, <class 'ly.lex.lilypond.SchemeStart'>, <class 'ly.lex.lilypond.StringQuotedStart'>, <class 'ly.lex.lilypond.ErrorInChord'>, <class 'ly.lex.lilypond.DrumChordEnd'>, <class 'ly.lex.lilypond.Dynamic'>, <class 'ly.lex.lilypond.Skip'>, <class 'ly.lex.lilypond.Spacer'>, <class 'ly.lex.lilypond.Q'>, <class 'ly.lex.lilypond.Rest'>, <class 'ly.lex.lilypond.DrumNote'>, <class 'ly.lex.lilypond.Fraction'>, <class 'ly.lex.lilypond.Length'>, <class 'ly.lex.lilypond.PipeSymbol'>, <class 'ly.lex.lilypond.VoiceSeparator'>, <class 'ly.lex.lilypond.SequentialStart'>, <class 'ly.lex.lilypond.SequentialEnd'>, <class 'ly.lex.lilypond.SimultaneousStart'>, <class 'ly.lex.lilypond.SimultaneousEnd'>, <class 'ly.lex.lilypond.ChordStart'>, <class 'ly.lex.lilypond.ContextName'>, <class 'ly.lex.lilypond.GrobName'>, <class 'ly.lex.lilypond.SlurStart'>, <class 'ly.lex.lilypond.SlurEnd'>, <class 'ly.lex.lilypond.PhrasingSlurStart'>, <class 'ly.lex.lilypond.PhrasingSlurEnd'>, <class 'ly.lex.lilypond.Tie'>, <class 'ly.lex.lilypond.BeamStart'>, <class 'ly.lex.lilypond.BeamEnd'>, <class 'ly.lex.lilypond.LigatureStart'>, <class 'ly.lex.lilypond.LigatureEnd'>, <class 'ly.lex.lilypond.Direction'>, <class 'ly.lex.lilypond.StringNumber'>, <class 'ly.lex.lilypond.IntegerValue'>, <class 'ly.lex.lilypond.Repeat'>, <class 'ly.lex.lilypond.PitchCommand'>, <class 'ly.lex.lilypond.Override'>, <class 'ly.lex.lilypond.Revert'>, <class 'ly.lex.lilypond.Set'>, <class 'ly.lex.lilypond.Unset'>, <class 'ly.lex.lilypond.Hide'>, <class 'ly.lex.lilypond.Omit'>, <class 'ly.lex.lilypond.Tweak'>, <class 'ly.lex.lilypond.New'>, <class 'ly.lex.lilypond.Context'>, <class 'ly.lex.lilypond.Change'>, <class 'ly.lex.lilypond.With'>, <class 'ly.lex.lilypond.Clef'>, <class 'ly.lex.lilypond.Tempo'>, <class 'ly.lex.lilypond.Partial'>, <class 'ly.lex.lilypond.KeySignatureMode'>, <class 'ly.lex.lilypond.AccidentalStyle'>, <class 'ly.lex.lilypond.AlterBroken'>, <class 'ly.lex.lilypond.SimultaneousOrSequentialCommand'>, <class 'ly.lex.lilypond.ChordMode'>, <class 'ly.lex.lilypond.DrumMode'>, <class 'ly.lex.lilypond.FigureMode'>, <class 'ly.lex.lilypond.LyricMode'>, <class 'ly.lex.lilypond.NoteMode'>, <class 'ly.lex.lilypond.MarkupStart'>, <class 'ly.lex.lilypond.MarkupLines'>, <class 'ly.lex.lilypond.MarkupList'>, <class 'ly.lex.lilypond.ArticulationCommand'>, <class 'ly.lex.lilypond.Keyword'>, <class 'ly.lex.lilypond.Command'>, <class 'ly.lex.lilypond.SimultaneousOrSequentialCommand'>, <class 'ly.lex.lilypond.UserCommand'>)¶
-
pattern= re.compile('(?P<g_0>\\s+)|(?P<g_1>%{)|(?P<g_2>%.*$)|(?P<g_3>[#$](?![{}]))|(?P<g_4>")|(?P<g_5>[-_^][_.>|!+^-]|<<|>>|\\\\[\\\\\\]\\[\\(\\)()]|(\\\\(maxima|longa|breve)\\b|(1|2|4|8|16|32|64|128|256|512|1024|2048)(?, re.MULTILINE)¶
-
-
class
ly.lex.lilypond.ParseDrumMode(argcount=None)[source]¶ Bases:
ly.lex.lilypond.ParseInputMode,ly.lex.lilypond.ParseMusicParser for
\drumsand\drummode.-
items= (<class 'ly.lex.lilypond.OpenBracket'>, <class 'ly.lex.lilypond.OpenSimultaneous'>, <class 'ly.lex._token.Space'>, <class 'ly.lex.lilypond.BlockCommentStart'>, <class 'ly.lex.lilypond.LineComment'>, <class 'ly.lex.lilypond.SchemeStart'>, <class 'ly.lex.lilypond.StringQuotedStart'>, <class 'ly.lex.lilypond.Dynamic'>, <class 'ly.lex.lilypond.Skip'>, <class 'ly.lex.lilypond.Spacer'>, <class 'ly.lex.lilypond.Q'>, <class 'ly.lex.lilypond.Rest'>, <class 'ly.lex.lilypond.DrumNote'>, <class 'ly.lex.lilypond.Fraction'>, <class 'ly.lex.lilypond.Length'>, <class 'ly.lex.lilypond.PipeSymbol'>, <class 'ly.lex.lilypond.VoiceSeparator'>, <class 'ly.lex.lilypond.SequentialStart'>, <class 'ly.lex.lilypond.SequentialEnd'>, <class 'ly.lex.lilypond.SimultaneousStart'>, <class 'ly.lex.lilypond.SimultaneousEnd'>, <class 'ly.lex.lilypond.DrumChordStart'>, <class 'ly.lex.lilypond.ContextName'>, <class 'ly.lex.lilypond.GrobName'>, <class 'ly.lex.lilypond.SlurStart'>, <class 'ly.lex.lilypond.SlurEnd'>, <class 'ly.lex.lilypond.PhrasingSlurStart'>, <class 'ly.lex.lilypond.PhrasingSlurEnd'>, <class 'ly.lex.lilypond.Tie'>, <class 'ly.lex.lilypond.BeamStart'>, <class 'ly.lex.lilypond.BeamEnd'>, <class 'ly.lex.lilypond.LigatureStart'>, <class 'ly.lex.lilypond.LigatureEnd'>, <class 'ly.lex.lilypond.Direction'>, <class 'ly.lex.lilypond.StringNumber'>, <class 'ly.lex.lilypond.IntegerValue'>, <class 'ly.lex.lilypond.Repeat'>, <class 'ly.lex.lilypond.PitchCommand'>, <class 'ly.lex.lilypond.Override'>, <class 'ly.lex.lilypond.Revert'>, <class 'ly.lex.lilypond.Set'>, <class 'ly.lex.lilypond.Unset'>, <class 'ly.lex.lilypond.Hide'>, <class 'ly.lex.lilypond.Omit'>, <class 'ly.lex.lilypond.Tweak'>, <class 'ly.lex.lilypond.New'>, <class 'ly.lex.lilypond.Context'>, <class 'ly.lex.lilypond.Change'>, <class 'ly.lex.lilypond.With'>, <class 'ly.lex.lilypond.Clef'>, <class 'ly.lex.lilypond.Tempo'>, <class 'ly.lex.lilypond.Partial'>, <class 'ly.lex.lilypond.KeySignatureMode'>, <class 'ly.lex.lilypond.AccidentalStyle'>, <class 'ly.lex.lilypond.AlterBroken'>, <class 'ly.lex.lilypond.SimultaneousOrSequentialCommand'>, <class 'ly.lex.lilypond.ChordMode'>, <class 'ly.lex.lilypond.DrumMode'>, <class 'ly.lex.lilypond.FigureMode'>, <class 'ly.lex.lilypond.LyricMode'>, <class 'ly.lex.lilypond.NoteMode'>, <class 'ly.lex.lilypond.MarkupStart'>, <class 'ly.lex.lilypond.MarkupLines'>, <class 'ly.lex.lilypond.MarkupList'>, <class 'ly.lex.lilypond.ArticulationCommand'>, <class 'ly.lex.lilypond.Keyword'>, <class 'ly.lex.lilypond.Command'>, <class 'ly.lex.lilypond.SimultaneousOrSequentialCommand'>, <class 'ly.lex.lilypond.UserCommand'>)¶
-
pattern= re.compile('(?P<g_0>\\{)|(?P<g_1><<)|(?P<g_2>\\s+)|(?P<g_3>%{)|(?P<g_4>%.*$)|(?P<g_5>[#$](?![{}]))|(?P<g_6>")|(?P<g_7>\\\\[<!>]|\\\\(f{1,5}|p{1,5}|mf|mp|fp|spp?|sff?|sfz|rfz|cresc|decresc|dim|cr|decr)(?![A-Za-z], re.MULTILINE)¶
-
-
class
ly.lex.lilypond.ParseDuration(argcount=None)[source]¶ Bases:
ly.lex.FallthroughParser-
fallthrough(state)[source]¶ Called when no match is returned by parse().
This implementation leaves the current parser and returns None (causing the State to continue parsing).
-
items= (<class 'ly.lex._token.Space'>, <class 'ly.lex.lilypond.BlockCommentStart'>, <class 'ly.lex.lilypond.LineComment'>, <class 'ly.lex.lilypond.Dot'>)¶
-
pattern= re.compile('(?P<g_0>\\s+)|(?P<g_1>%{)|(?P<g_2>%.*$)|(?P<g_3>\\.)', re.MULTILINE)¶
-
-
class
ly.lex.lilypond.ParseDurationScaling(argcount=None)[source]¶ Bases:
ly.lex.lilypond.ParseDuration-
fallthrough(state)[source]¶ Called when no match is returned by parse().
This implementation leaves the current parser and returns None (causing the State to continue parsing).
-
items= (<class 'ly.lex._token.Space'>, <class 'ly.lex.lilypond.BlockCommentStart'>, <class 'ly.lex.lilypond.LineComment'>, <class 'ly.lex.lilypond.Scaling'>)¶
-
pattern= re.compile('(?P<g_0>\\s+)|(?P<g_1>%{)|(?P<g_2>%.*$)|(?P<g_3>\\*[\\t ]*\\d+(/\\d+)?)', re.MULTILINE)¶
-
-
class
ly.lex.lilypond.ParseFigure(argcount=None)[source]¶ Bases:
ly.lex.ParserParse inside
< >in figure mode.-
items= (<class 'ly.lex._token.Space'>, <class 'ly.lex.lilypond.BlockCommentStart'>, <class 'ly.lex.lilypond.LineComment'>, <class 'ly.lex.lilypond.SchemeStart'>, <class 'ly.lex.lilypond.StringQuotedStart'>, <class 'ly.lex.lilypond.FigureEnd'>, <class 'ly.lex.lilypond.FigureBracket'>, <class 'ly.lex.lilypond.FigureStep'>, <class 'ly.lex.lilypond.FigureAccidental'>, <class 'ly.lex.lilypond.FigureModifier'>, <class 'ly.lex.lilypond.MarkupStart'>, <class 'ly.lex.lilypond.MarkupLines'>, <class 'ly.lex.lilypond.MarkupList'>)¶
-
pattern= re.compile('(?P<g_0>\\s+)|(?P<g_1>%{)|(?P<g_2>%.*$)|(?P<g_3>[#$](?![{}]))|(?P<g_4>")|(?P<g_5>>)|(?P<g_6>[][])|(?P<g_7>_|\\d+)|(?P<g_8>[-+!]+)|(?P<g_9>\\\\[\\\\!+]|/)|(?P<g_10>\\\\markup(?![_-]?[^\\W\\d]))|(?P<g_, re.MULTILINE)¶
-
-
class
ly.lex.lilypond.ParseFigureMode(argcount=None)[source]¶ Bases:
ly.lex.lilypond.ParseInputMode,ly.lex.lilypond.ParseMusicParser for
\figuresand\figuremode.-
items= (<class 'ly.lex._token.Space'>, <class 'ly.lex.lilypond.BlockCommentStart'>, <class 'ly.lex.lilypond.LineComment'>, <class 'ly.lex.lilypond.SchemeStart'>, <class 'ly.lex.lilypond.StringQuotedStart'>, <class 'ly.lex.lilypond.CloseBracket'>, <class 'ly.lex.lilypond.CloseSimultaneous'>, <class 'ly.lex.lilypond.OpenBracket'>, <class 'ly.lex.lilypond.OpenSimultaneous'>, <class 'ly.lex.lilypond.PipeSymbol'>, <class 'ly.lex.lilypond.FigureStart'>, <class 'ly.lex.lilypond.Skip'>, <class 'ly.lex.lilypond.Spacer'>, <class 'ly.lex.lilypond.Rest'>, <class 'ly.lex.lilypond.Length'>, <class 'ly.lex.lilypond.Repeat'>, <class 'ly.lex.lilypond.PitchCommand'>, <class 'ly.lex.lilypond.Override'>, <class 'ly.lex.lilypond.Revert'>, <class 'ly.lex.lilypond.Set'>, <class 'ly.lex.lilypond.Unset'>, <class 'ly.lex.lilypond.Hide'>, <class 'ly.lex.lilypond.Omit'>, <class 'ly.lex.lilypond.Tweak'>, <class 'ly.lex.lilypond.New'>, <class 'ly.lex.lilypond.Context'>, <class 'ly.lex.lilypond.Change'>, <class 'ly.lex.lilypond.With'>, <class 'ly.lex.lilypond.Clef'>, <class 'ly.lex.lilypond.Tempo'>, <class 'ly.lex.lilypond.Partial'>, <class 'ly.lex.lilypond.KeySignatureMode'>, <class 'ly.lex.lilypond.AccidentalStyle'>, <class 'ly.lex.lilypond.AlterBroken'>, <class 'ly.lex.lilypond.SimultaneousOrSequentialCommand'>, <class 'ly.lex.lilypond.ChordMode'>, <class 'ly.lex.lilypond.DrumMode'>, <class 'ly.lex.lilypond.FigureMode'>, <class 'ly.lex.lilypond.LyricMode'>, <class 'ly.lex.lilypond.NoteMode'>, <class 'ly.lex.lilypond.MarkupStart'>, <class 'ly.lex.lilypond.MarkupLines'>, <class 'ly.lex.lilypond.MarkupList'>, <class 'ly.lex.lilypond.ArticulationCommand'>, <class 'ly.lex.lilypond.Keyword'>, <class 'ly.lex.lilypond.Command'>, <class 'ly.lex.lilypond.SimultaneousOrSequentialCommand'>, <class 'ly.lex.lilypond.UserCommand'>)¶
-
pattern= re.compile('(?P<g_0>\\s+)|(?P<g_1>%{)|(?P<g_2>%.*$)|(?P<g_3>[#$](?![{}]))|(?P<g_4>")|(?P<g_5>\\})|(?P<g_6>>>)|(?P<g_7>\\{)|(?P<g_8><<)|(?P<g_9>\\|)|(?P<g_10><)|(?P<g_11>\\\\skip(?![_-]?[^\\W\\d]))|(?P<g_12>s(?![, re.MULTILINE)¶
-
-
class
ly.lex.lilypond.ParseGlobal(argcount=None)[source]¶ Bases:
ly.lex.lilypond.ParseLilyPondParses LilyPond from the toplevel of a file.
-
items= (<class 'ly.lex.lilypond.Book'>, <class 'ly.lex.lilypond.BookPart'>, <class 'ly.lex.lilypond.Score'>, <class 'ly.lex.lilypond.MarkupStart'>, <class 'ly.lex.lilypond.MarkupLines'>, <class 'ly.lex.lilypond.MarkupList'>, <class 'ly.lex.lilypond.Paper'>, <class 'ly.lex.lilypond.Header'>, <class 'ly.lex.lilypond.Layout'>, <class 'ly.lex._token.Space'>, <class 'ly.lex.lilypond.BlockCommentStart'>, <class 'ly.lex.lilypond.LineComment'>, <class 'ly.lex.lilypond.SchemeStart'>, <class 'ly.lex.lilypond.StringQuotedStart'>, <class 'ly.lex.lilypond.SequentialStart'>, <class 'ly.lex.lilypond.SimultaneousStart'>, <class 'ly.lex.lilypond.Repeat'>, <class 'ly.lex.lilypond.PitchCommand'>, <class 'ly.lex.lilypond.Override'>, <class 'ly.lex.lilypond.Revert'>, <class 'ly.lex.lilypond.Set'>, <class 'ly.lex.lilypond.Unset'>, <class 'ly.lex.lilypond.Hide'>, <class 'ly.lex.lilypond.Omit'>, <class 'ly.lex.lilypond.Tweak'>, <class 'ly.lex.lilypond.New'>, <class 'ly.lex.lilypond.Context'>, <class 'ly.lex.lilypond.Change'>, <class 'ly.lex.lilypond.With'>, <class 'ly.lex.lilypond.Clef'>, <class 'ly.lex.lilypond.Tempo'>, <class 'ly.lex.lilypond.Partial'>, <class 'ly.lex.lilypond.KeySignatureMode'>, <class 'ly.lex.lilypond.AccidentalStyle'>, <class 'ly.lex.lilypond.AlterBroken'>, <class 'ly.lex.lilypond.SimultaneousOrSequentialCommand'>, <class 'ly.lex.lilypond.ChordMode'>, <class 'ly.lex.lilypond.DrumMode'>, <class 'ly.lex.lilypond.FigureMode'>, <class 'ly.lex.lilypond.LyricMode'>, <class 'ly.lex.lilypond.NoteMode'>, <class 'ly.lex.lilypond.MarkupStart'>, <class 'ly.lex.lilypond.MarkupLines'>, <class 'ly.lex.lilypond.MarkupList'>, <class 'ly.lex.lilypond.ArticulationCommand'>, <class 'ly.lex.lilypond.Keyword'>, <class 'ly.lex.lilypond.Command'>, <class 'ly.lex.lilypond.SimultaneousOrSequentialCommand'>, <class 'ly.lex.lilypond.UserCommand'>, <class 'ly.lex.lilypond.Name'>, <class 'ly.lex.lilypond.DotPath'>, <class 'ly.lex.lilypond.EqualSign'>, <class 'ly.lex.lilypond.Fraction'>, <class 'ly.lex.lilypond.DecimalValue'>)¶
-
pattern= re.compile('(?P<g_0>\\\\book\\b)|(?P<g_1>\\\\bookpart\\b)|(?P<g_2>\\\\score\\b)|(?P<g_3>\\\\markup(?![_-]?[^\\W\\d]))|(?P<g_4>\\\\markuplines(?![_-]?[^\\W\\d]))|(?P<g_5>\\\\markuplist(?![_-]?[^\\W\\d]))|(?P<g_6>, re.MULTILINE)¶
-
-
class
ly.lex.lilypond.ParseGlobalAssignment(argcount=None)[source]¶ Bases:
ly.lex.FallthroughParser,ly.lex.lilypond.ParseLilyPond-
items= (<class 'ly.lex._token.Space'>, <class 'ly.lex.lilypond.BlockCommentStart'>, <class 'ly.lex.lilypond.LineComment'>, <class 'ly.lex.lilypond.Skip'>, <class 'ly.lex.lilypond.Spacer'>, <class 'ly.lex.lilypond.Q'>, <class 'ly.lex.lilypond.Rest'>, <class 'ly.lex.lilypond.Note'>, <class 'ly.lex.lilypond.Length'>, <class 'ly.lex.lilypond.Fraction'>, <class 'ly.lex.lilypond.DecimalValue'>, <class 'ly.lex.lilypond.Direction'>, <class 'ly.lex.lilypond.StringNumber'>, <class 'ly.lex.lilypond.Dynamic'>)¶
-
pattern= re.compile('(?P<g_0>\\s+)|(?P<g_1>%{)|(?P<g_2>%.*$)|(?P<g_3>\\\\skip(?![_-]?[^\\W\\d]))|(?P<g_4>s(?![A-Za-z]))|(?P<g_5>q(?![A-Za-z]))|(?P<g_6>[Rr](?![A-Za-z]))|(?P<g_7>[a-x]+(?![A-Za-z]))|(?P<g_8>(\\\\(maxima|lo, re.MULTILINE)¶
-
-
class
ly.lex.lilypond.ParseGrobPropertyPath(argcount=None)[source]¶ Bases:
ly.lex.FallthroughParser-
items= (<class 'ly.lex._token.Space'>, <class 'ly.lex.lilypond.BlockCommentStart'>, <class 'ly.lex.lilypond.LineComment'>, <class 'ly.lex.lilypond.DotPath'>)¶
-
pattern= re.compile('(?P<g_0>\\s+)|(?P<g_1>%{)|(?P<g_2>%.*$)|(?P<g_3>\\.)', re.MULTILINE)¶
-
-
class
ly.lex.lilypond.ParseHeader(argcount=None)[source]¶ Bases:
ly.lex.lilypond.ParseLilyPondParses the expression after
\header {, leaving at}-
items= (<class 'ly.lex.lilypond.CloseBracket'>, <class 'ly.lex.lilypond.MarkupStart'>, <class 'ly.lex.lilypond.MarkupLines'>, <class 'ly.lex.lilypond.MarkupList'>, <class 'ly.lex.lilypond.HeaderVariable'>, <class 'ly.lex.lilypond.UserVariable'>, <class 'ly.lex.lilypond.EqualSign'>, <class 'ly.lex.lilypond.DotPath'>, <class 'ly.lex._token.Space'>, <class 'ly.lex.lilypond.BlockCommentStart'>, <class 'ly.lex.lilypond.LineComment'>, <class 'ly.lex.lilypond.SchemeStart'>, <class 'ly.lex.lilypond.StringQuotedStart'>, <class 'ly.lex.lilypond.SequentialStart'>, <class 'ly.lex.lilypond.SimultaneousStart'>, <class 'ly.lex.lilypond.Repeat'>, <class 'ly.lex.lilypond.PitchCommand'>, <class 'ly.lex.lilypond.Override'>, <class 'ly.lex.lilypond.Revert'>, <class 'ly.lex.lilypond.Set'>, <class 'ly.lex.lilypond.Unset'>, <class 'ly.lex.lilypond.Hide'>, <class 'ly.lex.lilypond.Omit'>, <class 'ly.lex.lilypond.Tweak'>, <class 'ly.lex.lilypond.New'>, <class 'ly.lex.lilypond.Context'>, <class 'ly.lex.lilypond.Change'>, <class 'ly.lex.lilypond.With'>, <class 'ly.lex.lilypond.Clef'>, <class 'ly.lex.lilypond.Tempo'>, <class 'ly.lex.lilypond.Partial'>, <class 'ly.lex.lilypond.KeySignatureMode'>, <class 'ly.lex.lilypond.AccidentalStyle'>, <class 'ly.lex.lilypond.AlterBroken'>, <class 'ly.lex.lilypond.SimultaneousOrSequentialCommand'>, <class 'ly.lex.lilypond.ChordMode'>, <class 'ly.lex.lilypond.DrumMode'>, <class 'ly.lex.lilypond.FigureMode'>, <class 'ly.lex.lilypond.LyricMode'>, <class 'ly.lex.lilypond.NoteMode'>, <class 'ly.lex.lilypond.MarkupStart'>, <class 'ly.lex.lilypond.MarkupLines'>, <class 'ly.lex.lilypond.MarkupList'>, <class 'ly.lex.lilypond.ArticulationCommand'>, <class 'ly.lex.lilypond.Keyword'>, <class 'ly.lex.lilypond.Command'>, <class 'ly.lex.lilypond.SimultaneousOrSequentialCommand'>, <class 'ly.lex.lilypond.UserCommand'>)¶
-
pattern= re.compile('(?P<g_0>\\})|(?P<g_1>\\\\markup(?![_-]?[^\\W\\d]))|(?P<g_2>\\\\markuplines(?![_-]?[^\\W\\d]))|(?P<g_3>\\\\markuplist(?![_-]?[^\\W\\d]))|(?P<g_4>(?<![^\\W\\d])[^\\W\\d_]+([_-][^\\W\\d_]+)*(?![_-]?[^\\, re.MULTILINE)¶
-
-
class
ly.lex.lilypond.ParseHideOmit(argcount=None)[source]¶ Bases:
ly.lex.FallthroughParser-
items= (<class 'ly.lex._token.Space'>, <class 'ly.lex.lilypond.BlockCommentStart'>, <class 'ly.lex.lilypond.LineComment'>, <class 'ly.lex.lilypond.ContextName'>, <class 'ly.lex.lilypond.DotPath'>, <class 'ly.lex.lilypond.GrobName'>)¶
-
pattern= re.compile('(?P<g_0>\\s+)|(?P<g_1>%{)|(?P<g_2>%.*$)|(?P<g_3>\\b(ChoirStaff|ChordNames|CueVoice|Devnull|DrumStaff|DrumVoice|Dynamics|FiguredBass|FretBoards|Global|GrandStaff|GregorianTranscriptionStaff|GregorianT, re.MULTILINE)¶
-
-
class
ly.lex.lilypond.ParseInputMode(argcount=None)[source]¶ Bases:
ly.lex.lilypond.ParseLilyPondBase class for parser for mode-changing music commands.
-
class
ly.lex.lilypond.ParseLayout(argcount=None)[source]¶ Bases:
ly.lex.lilypond.ParseLilyPondParses the expression after
\layout {, leaving at}-
items= (<class 'ly.lex._token.Space'>, <class 'ly.lex.lilypond.BlockCommentStart'>, <class 'ly.lex.lilypond.LineComment'>, <class 'ly.lex.lilypond.SchemeStart'>, <class 'ly.lex.lilypond.StringQuotedStart'>, <class 'ly.lex.lilypond.CloseBracket'>, <class 'ly.lex.lilypond.LayoutContext'>, <class 'ly.lex.lilypond.LayoutVariable'>, <class 'ly.lex.lilypond.UserVariable'>, <class 'ly.lex.lilypond.EqualSign'>, <class 'ly.lex.lilypond.DotPath'>, <class 'ly.lex.lilypond.DecimalValue'>, <class 'ly.lex.lilypond.Unit'>, <class 'ly.lex.lilypond.ContextName'>, <class 'ly.lex.lilypond.GrobName'>, <class 'ly.lex.lilypond.Repeat'>, <class 'ly.lex.lilypond.PitchCommand'>, <class 'ly.lex.lilypond.Override'>, <class 'ly.lex.lilypond.Revert'>, <class 'ly.lex.lilypond.Set'>, <class 'ly.lex.lilypond.Unset'>, <class 'ly.lex.lilypond.Hide'>, <class 'ly.lex.lilypond.Omit'>, <class 'ly.lex.lilypond.Tweak'>, <class 'ly.lex.lilypond.New'>, <class 'ly.lex.lilypond.Context'>, <class 'ly.lex.lilypond.Change'>, <class 'ly.lex.lilypond.With'>, <class 'ly.lex.lilypond.Clef'>, <class 'ly.lex.lilypond.Tempo'>, <class 'ly.lex.lilypond.Partial'>, <class 'ly.lex.lilypond.KeySignatureMode'>, <class 'ly.lex.lilypond.AccidentalStyle'>, <class 'ly.lex.lilypond.AlterBroken'>, <class 'ly.lex.lilypond.SimultaneousOrSequentialCommand'>, <class 'ly.lex.lilypond.ChordMode'>, <class 'ly.lex.lilypond.DrumMode'>, <class 'ly.lex.lilypond.FigureMode'>, <class 'ly.lex.lilypond.LyricMode'>, <class 'ly.lex.lilypond.NoteMode'>, <class 'ly.lex.lilypond.MarkupStart'>, <class 'ly.lex.lilypond.MarkupLines'>, <class 'ly.lex.lilypond.MarkupList'>, <class 'ly.lex.lilypond.ArticulationCommand'>, <class 'ly.lex.lilypond.Keyword'>, <class 'ly.lex.lilypond.Command'>, <class 'ly.lex.lilypond.SimultaneousOrSequentialCommand'>, <class 'ly.lex.lilypond.UserCommand'>)¶
-
pattern= re.compile('(?P<g_0>\\s+)|(?P<g_1>%{)|(?P<g_2>%.*$)|(?P<g_3>[#$](?![{}]))|(?P<g_4>")|(?P<g_5>\\})|(?P<g_6>\\\\context\\b)|(?P<g_7>(?<![^\\W\\d])[^\\W\\d_]+([_-][^\\W\\d_]+)*(?![_-]?[^\\W\\d]))|(?P<g_8>=)|(?P<g_9, re.MULTILINE)¶
-
-
class
ly.lex.lilypond.ParseLilyPond(argcount=None)[source]¶ Bases:
ly.lex.Parser-
mode= 'lilypond'¶
-
-
class
ly.lex.lilypond.ParseLyricMode(argcount=None)[source]¶ Bases:
ly.lex.lilypond.ParseInputModeParser for
\lyrics,\lyricmode,\addlyrics, etc.-
items= (<class 'ly.lex._token.Space'>, <class 'ly.lex.lilypond.BlockCommentStart'>, <class 'ly.lex.lilypond.LineComment'>, <class 'ly.lex.lilypond.SchemeStart'>, <class 'ly.lex.lilypond.StringQuotedStart'>, <class 'ly.lex.lilypond.CloseBracket'>, <class 'ly.lex.lilypond.CloseSimultaneous'>, <class 'ly.lex.lilypond.OpenBracket'>, <class 'ly.lex.lilypond.OpenSimultaneous'>, <class 'ly.lex.lilypond.PipeSymbol'>, <class 'ly.lex.lilypond.LyricHyphen'>, <class 'ly.lex.lilypond.LyricExtender'>, <class 'ly.lex.lilypond.LyricSkip'>, <class 'ly.lex.lilypond.LyricText'>, <class 'ly.lex.lilypond.Dynamic'>, <class 'ly.lex.lilypond.Skip'>, <class 'ly.lex.lilypond.Length'>, <class 'ly.lex.lilypond.MarkupStart'>, <class 'ly.lex.lilypond.MarkupLines'>, <class 'ly.lex.lilypond.MarkupList'>, <class 'ly.lex.lilypond.Repeat'>, <class 'ly.lex.lilypond.PitchCommand'>, <class 'ly.lex.lilypond.Override'>, <class 'ly.lex.lilypond.Revert'>, <class 'ly.lex.lilypond.Set'>, <class 'ly.lex.lilypond.Unset'>, <class 'ly.lex.lilypond.Hide'>, <class 'ly.lex.lilypond.Omit'>, <class 'ly.lex.lilypond.Tweak'>, <class 'ly.lex.lilypond.New'>, <class 'ly.lex.lilypond.Context'>, <class 'ly.lex.lilypond.Change'>, <class 'ly.lex.lilypond.With'>, <class 'ly.lex.lilypond.Clef'>, <class 'ly.lex.lilypond.Tempo'>, <class 'ly.lex.lilypond.Partial'>, <class 'ly.lex.lilypond.KeySignatureMode'>, <class 'ly.lex.lilypond.AccidentalStyle'>, <class 'ly.lex.lilypond.AlterBroken'>, <class 'ly.lex.lilypond.SimultaneousOrSequentialCommand'>, <class 'ly.lex.lilypond.ChordMode'>, <class 'ly.lex.lilypond.DrumMode'>, <class 'ly.lex.lilypond.FigureMode'>, <class 'ly.lex.lilypond.LyricMode'>, <class 'ly.lex.lilypond.NoteMode'>, <class 'ly.lex.lilypond.MarkupStart'>, <class 'ly.lex.lilypond.MarkupLines'>, <class 'ly.lex.lilypond.MarkupList'>, <class 'ly.lex.lilypond.ArticulationCommand'>, <class 'ly.lex.lilypond.Keyword'>, <class 'ly.lex.lilypond.Command'>, <class 'ly.lex.lilypond.SimultaneousOrSequentialCommand'>, <class 'ly.lex.lilypond.UserCommand'>)¶
-
pattern= re.compile('(?P<g_0>\\s+)|(?P<g_1>%{)|(?P<g_2>%.*$)|(?P<g_3>[#$](?![{}]))|(?P<g_4>")|(?P<g_5>\\})|(?P<g_6>>>)|(?P<g_7>\\{)|(?P<g_8><<)|(?P<g_9>\\|)|(?P<g_10>--(?=($|[\\s\\\\])))|(?P<g_11>__(?=($|[\\s\\\\])))|(?P, re.MULTILINE)¶
-
-
class
ly.lex.lilypond.ParseMarkup(argcount=None)[source]¶ Bases:
ly.lex.Parser-
items= (<class 'ly.lex.lilypond.MarkupScore'>, <class 'ly.lex.lilypond.MarkupCommand'>, <class 'ly.lex.lilypond.MarkupUserCommand'>, <class 'ly.lex.lilypond.OpenBracketMarkup'>, <class 'ly.lex.lilypond.CloseBracketMarkup'>, <class 'ly.lex.lilypond.MarkupWord'>, <class 'ly.lex._token.Space'>, <class 'ly.lex.lilypond.BlockCommentStart'>, <class 'ly.lex.lilypond.LineComment'>, <class 'ly.lex.lilypond.SchemeStart'>, <class 'ly.lex.lilypond.StringQuotedStart'>)¶
-
pattern= re.compile('(?P<g_0>\\\\score\\b)|(?P<g_1>\\\\[^\\W\\d_]+([_-][^\\W\\d_]+)*(?![_-]?[^\\W\\d]))|(?P<g_2>\\{)|(?P<g_3>\\})|(?P<g_4>[^{}"\\\\\\s#%]+)|(?P<g_5>\\s+)|(?P<g_6>%{)|(?P<g_7>%.*$)|(?P<g_8>[#$](?![{}]))|(?, re.MULTILINE)¶
-
-
class
ly.lex.lilypond.ParseMidi(argcount=None)[source]¶ Bases:
ly.lex.lilypond.ParseLilyPondParses the expression after
\midi {, leaving at}-
items= (<class 'ly.lex._token.Space'>, <class 'ly.lex.lilypond.BlockCommentStart'>, <class 'ly.lex.lilypond.LineComment'>, <class 'ly.lex.lilypond.SchemeStart'>, <class 'ly.lex.lilypond.StringQuotedStart'>, <class 'ly.lex.lilypond.CloseBracket'>, <class 'ly.lex.lilypond.LayoutContext'>, <class 'ly.lex.lilypond.LayoutVariable'>, <class 'ly.lex.lilypond.UserVariable'>, <class 'ly.lex.lilypond.EqualSign'>, <class 'ly.lex.lilypond.DotPath'>, <class 'ly.lex.lilypond.DecimalValue'>, <class 'ly.lex.lilypond.Unit'>, <class 'ly.lex.lilypond.ContextName'>, <class 'ly.lex.lilypond.GrobName'>, <class 'ly.lex.lilypond.Repeat'>, <class 'ly.lex.lilypond.PitchCommand'>, <class 'ly.lex.lilypond.Override'>, <class 'ly.lex.lilypond.Revert'>, <class 'ly.lex.lilypond.Set'>, <class 'ly.lex.lilypond.Unset'>, <class 'ly.lex.lilypond.Hide'>, <class 'ly.lex.lilypond.Omit'>, <class 'ly.lex.lilypond.Tweak'>, <class 'ly.lex.lilypond.New'>, <class 'ly.lex.lilypond.Context'>, <class 'ly.lex.lilypond.Change'>, <class 'ly.lex.lilypond.With'>, <class 'ly.lex.lilypond.Clef'>, <class 'ly.lex.lilypond.Tempo'>, <class 'ly.lex.lilypond.Partial'>, <class 'ly.lex.lilypond.KeySignatureMode'>, <class 'ly.lex.lilypond.AccidentalStyle'>, <class 'ly.lex.lilypond.AlterBroken'>, <class 'ly.lex.lilypond.SimultaneousOrSequentialCommand'>, <class 'ly.lex.lilypond.ChordMode'>, <class 'ly.lex.lilypond.DrumMode'>, <class 'ly.lex.lilypond.FigureMode'>, <class 'ly.lex.lilypond.LyricMode'>, <class 'ly.lex.lilypond.NoteMode'>, <class 'ly.lex.lilypond.MarkupStart'>, <class 'ly.lex.lilypond.MarkupLines'>, <class 'ly.lex.lilypond.MarkupList'>, <class 'ly.lex.lilypond.ArticulationCommand'>, <class 'ly.lex.lilypond.Keyword'>, <class 'ly.lex.lilypond.Command'>, <class 'ly.lex.lilypond.SimultaneousOrSequentialCommand'>, <class 'ly.lex.lilypond.UserCommand'>)¶
-
pattern= re.compile('(?P<g_0>\\s+)|(?P<g_1>%{)|(?P<g_2>%.*$)|(?P<g_3>[#$](?![{}]))|(?P<g_4>")|(?P<g_5>\\})|(?P<g_6>\\\\context\\b)|(?P<g_7>(?<![^\\W\\d])[^\\W\\d_]+([_-][^\\W\\d_]+)*(?![_-]?[^\\W\\d]))|(?P<g_8>=)|(?P<g_9, re.MULTILINE)¶
-
-
class
ly.lex.lilypond.ParseMusic(argcount=None)[source]¶ Bases:
ly.lex.lilypond.ParseLilyPondParses LilyPond music expressions.
-
items= (<class 'ly.lex._token.Space'>, <class 'ly.lex.lilypond.BlockCommentStart'>, <class 'ly.lex.lilypond.LineComment'>, <class 'ly.lex.lilypond.SchemeStart'>, <class 'ly.lex.lilypond.StringQuotedStart'>, <class 'ly.lex.lilypond.Dynamic'>, <class 'ly.lex.lilypond.Skip'>, <class 'ly.lex.lilypond.Spacer'>, <class 'ly.lex.lilypond.Q'>, <class 'ly.lex.lilypond.Rest'>, <class 'ly.lex.lilypond.Note'>, <class 'ly.lex.lilypond.Fraction'>, <class 'ly.lex.lilypond.Length'>, <class 'ly.lex.lilypond.Octave'>, <class 'ly.lex.lilypond.OctaveCheck'>, <class 'ly.lex.lilypond.AccidentalCautionary'>, <class 'ly.lex.lilypond.AccidentalReminder'>, <class 'ly.lex.lilypond.PipeSymbol'>, <class 'ly.lex.lilypond.VoiceSeparator'>, <class 'ly.lex.lilypond.SequentialStart'>, <class 'ly.lex.lilypond.SequentialEnd'>, <class 'ly.lex.lilypond.SimultaneousStart'>, <class 'ly.lex.lilypond.SimultaneousEnd'>, <class 'ly.lex.lilypond.ChordStart'>, <class 'ly.lex.lilypond.ContextName'>, <class 'ly.lex.lilypond.GrobName'>, <class 'ly.lex.lilypond.SlurStart'>, <class 'ly.lex.lilypond.SlurEnd'>, <class 'ly.lex.lilypond.PhrasingSlurStart'>, <class 'ly.lex.lilypond.PhrasingSlurEnd'>, <class 'ly.lex.lilypond.Tie'>, <class 'ly.lex.lilypond.BeamStart'>, <class 'ly.lex.lilypond.BeamEnd'>, <class 'ly.lex.lilypond.LigatureStart'>, <class 'ly.lex.lilypond.LigatureEnd'>, <class 'ly.lex.lilypond.Direction'>, <class 'ly.lex.lilypond.StringNumber'>, <class 'ly.lex.lilypond.IntegerValue'>, <class 'ly.lex.lilypond.Repeat'>, <class 'ly.lex.lilypond.PitchCommand'>, <class 'ly.lex.lilypond.Override'>, <class 'ly.lex.lilypond.Revert'>, <class 'ly.lex.lilypond.Set'>, <class 'ly.lex.lilypond.Unset'>, <class 'ly.lex.lilypond.Hide'>, <class 'ly.lex.lilypond.Omit'>, <class 'ly.lex.lilypond.Tweak'>, <class 'ly.lex.lilypond.New'>, <class 'ly.lex.lilypond.Context'>, <class 'ly.lex.lilypond.Change'>, <class 'ly.lex.lilypond.With'>, <class 'ly.lex.lilypond.Clef'>, <class 'ly.lex.lilypond.Tempo'>, <class 'ly.lex.lilypond.Partial'>, <class 'ly.lex.lilypond.KeySignatureMode'>, <class 'ly.lex.lilypond.AccidentalStyle'>, <class 'ly.lex.lilypond.AlterBroken'>, <class 'ly.lex.lilypond.SimultaneousOrSequentialCommand'>, <class 'ly.lex.lilypond.ChordMode'>, <class 'ly.lex.lilypond.DrumMode'>, <class 'ly.lex.lilypond.FigureMode'>, <class 'ly.lex.lilypond.LyricMode'>, <class 'ly.lex.lilypond.NoteMode'>, <class 'ly.lex.lilypond.MarkupStart'>, <class 'ly.lex.lilypond.MarkupLines'>, <class 'ly.lex.lilypond.MarkupList'>, <class 'ly.lex.lilypond.ArticulationCommand'>, <class 'ly.lex.lilypond.Keyword'>, <class 'ly.lex.lilypond.Command'>, <class 'ly.lex.lilypond.SimultaneousOrSequentialCommand'>, <class 'ly.lex.lilypond.UserCommand'>, <class 'ly.lex.lilypond.TremoloColon'>)¶
-
pattern= re.compile('(?P<g_0>\\s+)|(?P<g_1>%{)|(?P<g_2>%.*$)|(?P<g_3>[#$](?![{}]))|(?P<g_4>")|(?P<g_5>\\\\[<!>]|\\\\(f{1,5}|p{1,5}|mf|mp|fp|spp?|sff?|sfz|rfz|cresc|decresc|dim|cr|decr)(?![A-Za-z]))|(?P<g_6>\\\\skip(?![_-, re.MULTILINE)¶
-
-
class
ly.lex.lilypond.ParseNoteMode(argcount=None)[source]¶ Bases:
ly.lex.lilypond.ParseMusicParser for
\notesand\notemode. Same as Music itself.
-
class
ly.lex.lilypond.ParseOverride(argcount=None)[source]¶ Bases:
ly.lex.lilypond.ParseLilyPond-
argcount= 0¶
-
items= (<class 'ly.lex.lilypond.ContextName'>, <class 'ly.lex.lilypond.DotPath'>, <class 'ly.lex.lilypond.GrobName'>, <class 'ly.lex.lilypond.GrobProperty'>, <class 'ly.lex.lilypond.EqualSign'>, <class 'ly.lex._token.Space'>, <class 'ly.lex.lilypond.BlockCommentStart'>, <class 'ly.lex.lilypond.LineComment'>, <class 'ly.lex.lilypond.SchemeStart'>, <class 'ly.lex.lilypond.StringQuotedStart'>)¶
-
pattern= re.compile('(?P<g_0>\\b(ChoirStaff|ChordNames|CueVoice|Devnull|DrumStaff|DrumVoice|Dynamics|FiguredBass|FretBoards|Global|GrandStaff|GregorianTranscriptionStaff|GregorianTranscriptionVoice|KievanStaff|KievanVoic, re.MULTILINE)¶
-
-
class
ly.lex.lilypond.ParsePaper(argcount=None)[source]¶ Bases:
ly.lex.lilypond.ParseLilyPondParses the expression after
\paper {, leaving at}-
items= (<class 'ly.lex._token.Space'>, <class 'ly.lex.lilypond.BlockCommentStart'>, <class 'ly.lex.lilypond.LineComment'>, <class 'ly.lex.lilypond.SchemeStart'>, <class 'ly.lex.lilypond.StringQuotedStart'>, <class 'ly.lex.lilypond.CloseBracket'>, <class 'ly.lex.lilypond.MarkupStart'>, <class 'ly.lex.lilypond.MarkupLines'>, <class 'ly.lex.lilypond.MarkupList'>, <class 'ly.lex.lilypond.PaperVariable'>, <class 'ly.lex.lilypond.UserVariable'>, <class 'ly.lex.lilypond.EqualSign'>, <class 'ly.lex.lilypond.DotPath'>, <class 'ly.lex.lilypond.DecimalValue'>, <class 'ly.lex.lilypond.Unit'>)¶
-
pattern= re.compile('(?P<g_0>\\s+)|(?P<g_1>%{)|(?P<g_2>%.*$)|(?P<g_3>[#$](?![{}]))|(?P<g_4>")|(?P<g_5>\\})|(?P<g_6>\\\\markup(?![_-]?[^\\W\\d]))|(?P<g_7>\\\\markuplines(?![_-]?[^\\W\\d]))|(?P<g_8>\\\\markuplist(?![_-]?[^, re.MULTILINE)¶
-
-
class
ly.lex.lilypond.ParsePitchCommand(argcount=None)[source]¶ Bases:
ly.lex.FallthroughParser-
argcount= 1¶
-
items= (<class 'ly.lex._token.Space'>, <class 'ly.lex.lilypond.BlockCommentStart'>, <class 'ly.lex.lilypond.LineComment'>, <class 'ly.lex.lilypond.Note'>, <class 'ly.lex.lilypond.Octave'>)¶
-
pattern= re.compile("(?P<g_0>\\s+)|(?P<g_1>%{)|(?P<g_2>%.*$)|(?P<g_3>[a-x]+(?![A-Za-z]))|(?P<g_4>,+|'+)", re.MULTILINE)¶
-
-
class
ly.lex.lilypond.ParseRepeat(argcount=None)[source]¶ Bases:
ly.lex.FallthroughParser-
items= (<class 'ly.lex._token.Space'>, <class 'ly.lex.lilypond.BlockCommentStart'>, <class 'ly.lex.lilypond.LineComment'>, <class 'ly.lex.lilypond.RepeatSpecifier'>, <class 'ly.lex.lilypond.StringQuotedStart'>, <class 'ly.lex.lilypond.RepeatCount'>)¶
-
pattern= re.compile('(?P<g_0>\\s+)|(?P<g_1>%{)|(?P<g_2>%.*$)|(?P<g_3>\\b(unfold|percent|volta|tremolo)(?![A-Za-z]))|(?P<g_4>")|(?P<g_5>\\d+)', re.MULTILINE)¶
-
-
class
ly.lex.lilypond.ParseRevert(argcount=None)[source]¶ Bases:
ly.lex.FallthroughParserparse the arguments of
\revert-
items= (<class 'ly.lex._token.Space'>, <class 'ly.lex.lilypond.BlockCommentStart'>, <class 'ly.lex.lilypond.LineComment'>, <class 'ly.lex.lilypond.ContextName'>, <class 'ly.lex.lilypond.DotPath'>, <class 'ly.lex.lilypond.GrobName'>, <class 'ly.lex.lilypond.GrobProperty'>)¶
-
pattern= re.compile('(?P<g_0>\\s+)|(?P<g_1>%{)|(?P<g_2>%.*$)|(?P<g_3>\\b(ChoirStaff|ChordNames|CueVoice|Devnull|DrumStaff|DrumVoice|Dynamics|FiguredBass|FretBoards|Global|GrandStaff|GregorianTranscriptionStaff|GregorianT, re.MULTILINE)¶
-
-
class
ly.lex.lilypond.ParseScore(argcount=None)[source]¶ Bases:
ly.lex.lilypond.ParseLilyPondParses the expression after
\score {, leaving at}-
items= (<class 'ly.lex.lilypond.CloseBracket'>, <class 'ly.lex.lilypond.Header'>, <class 'ly.lex.lilypond.Layout'>, <class 'ly.lex.lilypond.Midi'>, <class 'ly.lex.lilypond.With'>, <class 'ly.lex._token.Space'>, <class 'ly.lex.lilypond.BlockCommentStart'>, <class 'ly.lex.lilypond.LineComment'>, <class 'ly.lex.lilypond.SchemeStart'>, <class 'ly.lex.lilypond.StringQuotedStart'>, <class 'ly.lex.lilypond.SequentialStart'>, <class 'ly.lex.lilypond.SimultaneousStart'>, <class 'ly.lex.lilypond.Repeat'>, <class 'ly.lex.lilypond.PitchCommand'>, <class 'ly.lex.lilypond.Override'>, <class 'ly.lex.lilypond.Revert'>, <class 'ly.lex.lilypond.Set'>, <class 'ly.lex.lilypond.Unset'>, <class 'ly.lex.lilypond.Hide'>, <class 'ly.lex.lilypond.Omit'>, <class 'ly.lex.lilypond.Tweak'>, <class 'ly.lex.lilypond.New'>, <class 'ly.lex.lilypond.Context'>, <class 'ly.lex.lilypond.Change'>, <class 'ly.lex.lilypond.With'>, <class 'ly.lex.lilypond.Clef'>, <class 'ly.lex.lilypond.Tempo'>, <class 'ly.lex.lilypond.Partial'>, <class 'ly.lex.lilypond.KeySignatureMode'>, <class 'ly.lex.lilypond.AccidentalStyle'>, <class 'ly.lex.lilypond.AlterBroken'>, <class 'ly.lex.lilypond.SimultaneousOrSequentialCommand'>, <class 'ly.lex.lilypond.ChordMode'>, <class 'ly.lex.lilypond.DrumMode'>, <class 'ly.lex.lilypond.FigureMode'>, <class 'ly.lex.lilypond.LyricMode'>, <class 'ly.lex.lilypond.NoteMode'>, <class 'ly.lex.lilypond.MarkupStart'>, <class 'ly.lex.lilypond.MarkupLines'>, <class 'ly.lex.lilypond.MarkupList'>, <class 'ly.lex.lilypond.ArticulationCommand'>, <class 'ly.lex.lilypond.Keyword'>, <class 'ly.lex.lilypond.Command'>, <class 'ly.lex.lilypond.SimultaneousOrSequentialCommand'>, <class 'ly.lex.lilypond.UserCommand'>)¶
-
pattern= re.compile('(?P<g_0>\\})|(?P<g_1>\\\\header\\b)|(?P<g_2>\\\\layout\\b)|(?P<g_3>\\\\midi\\b)|(?P<g_4>\\\\with\\b)|(?P<g_5>\\s+)|(?P<g_6>%{)|(?P<g_7>%.*$)|(?P<g_8>[#$](?![{}]))|(?P<g_9>")|(?P<g_10>\\{)|(?P<g_11><<, re.MULTILINE)¶
-
-
class
ly.lex.lilypond.ParseScriptAbbreviationOrFingering(argcount=None)[source]¶ Bases:
ly.lex.FallthroughParser-
argcount= 1¶
-
items= (<class 'ly.lex._token.Space'>, <class 'ly.lex.lilypond.BlockCommentStart'>, <class 'ly.lex.lilypond.LineComment'>, <class 'ly.lex.lilypond.ScriptAbbreviation'>, <class 'ly.lex.lilypond.Fingering'>)¶
-
pattern= re.compile('(?P<g_0>\\s+)|(?P<g_1>%{)|(?P<g_2>%.*$)|(?P<g_3>[+|!>._^-])|(?P<g_4>\\d+)', re.MULTILINE)¶
-
-
class
ly.lex.lilypond.ParseSet(argcount=None)[source]¶ Bases:
ly.lex.lilypond.ParseLilyPond-
argcount= 0¶
-
items= (<class 'ly.lex.lilypond.ContextName'>, <class 'ly.lex.lilypond.DotPath'>, <class 'ly.lex.lilypond.ContextProperty'>, <class 'ly.lex.lilypond.EqualSign'>, <class 'ly.lex.lilypond.Name'>, <class 'ly.lex._token.Space'>, <class 'ly.lex.lilypond.BlockCommentStart'>, <class 'ly.lex.lilypond.LineComment'>, <class 'ly.lex.lilypond.SchemeStart'>, <class 'ly.lex.lilypond.StringQuotedStart'>)¶
-
pattern= re.compile('(?P<g_0>\\b(ChoirStaff|ChordNames|CueVoice|Devnull|DrumStaff|DrumVoice|Dynamics|FiguredBass|FretBoards|Global|GrandStaff|GregorianTranscriptionStaff|GregorianTranscriptionVoice|KievanStaff|KievanVoic, re.MULTILINE)¶
-
-
class
ly.lex.lilypond.ParseString(argcount=None)[source]¶ Bases:
ly.lex.Parser-
default¶ alias of
ly.lex.lilypond.String
-
items= (<class 'ly.lex.lilypond.StringQuotedEnd'>, <class 'ly.lex.lilypond.StringQuoteEscape'>)¶
-
pattern= re.compile('(?P<g_0>")|(?P<g_1>\\\\[\\\\"])', re.MULTILINE)¶
-
-
class
ly.lex.lilypond.ParseTempo(argcount=None)[source]¶ Bases:
ly.lex.FallthroughParser-
items= (<class 'ly.lex._token.Space'>, <class 'ly.lex.lilypond.BlockCommentStart'>, <class 'ly.lex.lilypond.LineComment'>, <class 'ly.lex.lilypond.MarkupStart'>, <class 'ly.lex.lilypond.StringQuotedStart'>, <class 'ly.lex.lilypond.SchemeStart'>, <class 'ly.lex.lilypond.Length'>, <class 'ly.lex.lilypond.EqualSign'>)¶
-
pattern= re.compile('(?P<g_0>\\s+)|(?P<g_1>%{)|(?P<g_2>%.*$)|(?P<g_3>\\\\markup(?![_-]?[^\\W\\d]))|(?P<g_4>")|(?P<g_5>[#$](?![{}]))|(?P<g_6>(\\\\(maxima|longa|breve)\\b|(1|2|4|8|16|32|64|128|256|512|1024|2048)(?!\\d)))|(, re.MULTILINE)¶
-
-
class
ly.lex.lilypond.ParseTempoAfterEqualSign(argcount=None)[source]¶ Bases:
ly.lex.FallthroughParser-
items= (<class 'ly.lex._token.Space'>, <class 'ly.lex.lilypond.BlockCommentStart'>, <class 'ly.lex.lilypond.LineComment'>, <class 'ly.lex.lilypond.IntegerValue'>, <class 'ly.lex.lilypond.TempoSeparator'>)¶
-
pattern= re.compile('(?P<g_0>\\s+)|(?P<g_1>%{)|(?P<g_2>%.*$)|(?P<g_3>\\d+)|(?P<g_4>[-~](?=\\s*\\d))', re.MULTILINE)¶
-
-
class
ly.lex.lilypond.ParseTranslator(argcount=None)[source]¶ Bases:
ly.lex.FallthroughParser-
items= (<class 'ly.lex._token.Space'>, <class 'ly.lex.lilypond.BlockCommentStart'>, <class 'ly.lex.lilypond.LineComment'>, <class 'ly.lex.lilypond.ContextName'>, <class 'ly.lex.lilypond.Name'>)¶
-
pattern= re.compile('(?P<g_0>\\s+)|(?P<g_1>%{)|(?P<g_2>%.*$)|(?P<g_3>\\b(ChoirStaff|ChordNames|CueVoice|Devnull|DrumStaff|DrumVoice|Dynamics|FiguredBass|FretBoards|Global|GrandStaff|GregorianTranscriptionStaff|GregorianT, re.MULTILINE)¶
-
-
class
ly.lex.lilypond.ParseTranslatorId(argcount=None)[source]¶ Bases:
ly.lex.FallthroughParser-
argcount= 1¶
-
items= (<class 'ly.lex._token.Space'>, <class 'ly.lex.lilypond.BlockCommentStart'>, <class 'ly.lex.lilypond.LineComment'>, <class 'ly.lex.lilypond.Name'>, <class 'ly.lex.lilypond.StringQuotedStart'>)¶
-
pattern= re.compile('(?P<g_0>\\s+)|(?P<g_1>%{)|(?P<g_2>%.*$)|(?P<g_3>(?<![^\\W\\d])[^\\W\\d_]+([_-][^\\W\\d_]+)*(?![_-]?[^\\W\\d]))|(?P<g_4>")', re.MULTILINE)¶
-
-
class
ly.lex.lilypond.ParseTremolo(argcount=None)[source]¶ Bases:
ly.lex.FallthroughParser-
items= (<class 'ly.lex.lilypond.TremoloDuration'>,)¶
-
pattern= re.compile('(?P<g_0>\\b(8|16|32|64|128|256|512|1024|2048)(?!\\d))', re.MULTILINE)¶
-
-
class
ly.lex.lilypond.ParseTweak(argcount=None)[source]¶ Bases:
ly.lex.FallthroughParser-
items= (<class 'ly.lex._token.Space'>, <class 'ly.lex.lilypond.BlockCommentStart'>, <class 'ly.lex.lilypond.LineComment'>, <class 'ly.lex.lilypond.GrobName'>, <class 'ly.lex.lilypond.DotPath'>, <class 'ly.lex.lilypond.GrobProperty'>)¶
-
pattern= re.compile('(?P<g_0>\\s+)|(?P<g_1>%{)|(?P<g_2>%.*$)|(?P<g_3>\\b(Accidental|AccidentalCautionary|AccidentalPlacement|AccidentalSuggestion|Ambitus|AmbitusAccidental|AmbitusLine|AmbitusNoteHead|Arpeggio|BalloonText, re.MULTILINE)¶
-
-
class
ly.lex.lilypond.ParseTweakGrobProperty(argcount=None)[source]¶ Bases:
ly.lex.FallthroughParser-
items= (<class 'ly.lex._token.Space'>, <class 'ly.lex.lilypond.BlockCommentStart'>, <class 'ly.lex.lilypond.LineComment'>, <class 'ly.lex.lilypond.DotPath'>, <class 'ly.lex.lilypond.DecimalValue'>)¶
-
pattern= re.compile('(?P<g_0>\\s+)|(?P<g_1>%{)|(?P<g_2>%.*$)|(?P<g_3>\\.)|(?P<g_4>-?\\d+(\\.\\d+)?)', re.MULTILINE)¶
-
-
class
ly.lex.lilypond.ParseUnset(argcount=None)[source]¶ Bases:
ly.lex.FallthroughParser-
items= (<class 'ly.lex._token.Space'>, <class 'ly.lex.lilypond.BlockCommentStart'>, <class 'ly.lex.lilypond.LineComment'>, <class 'ly.lex.lilypond.ContextName'>, <class 'ly.lex.lilypond.DotPath'>, <class 'ly.lex.lilypond.ContextProperty'>, <class 'ly.lex.lilypond.Name'>)¶
-
pattern= re.compile('(?P<g_0>\\s+)|(?P<g_1>%{)|(?P<g_2>%.*$)|(?P<g_3>\\b(ChoirStaff|ChordNames|CueVoice|Devnull|DrumStaff|DrumVoice|Dynamics|FiguredBass|FretBoards|Global|GrandStaff|GregorianTranscriptionStaff|GregorianT, re.MULTILINE)¶
-
-
class
ly.lex.lilypond.ParseWith(argcount=None)[source]¶ Bases:
ly.lex.lilypond.ParseLilyPondParses the expression after
\with {, leaving at}-
items= (<class 'ly.lex.lilypond.CloseBracket'>, <class 'ly.lex.lilypond.ContextName'>, <class 'ly.lex.lilypond.GrobName'>, <class 'ly.lex.lilypond.ContextProperty'>, <class 'ly.lex.lilypond.EqualSign'>, <class 'ly.lex.lilypond.DotPath'>, <class 'ly.lex._token.Space'>, <class 'ly.lex.lilypond.BlockCommentStart'>, <class 'ly.lex.lilypond.LineComment'>, <class 'ly.lex.lilypond.SchemeStart'>, <class 'ly.lex.lilypond.StringQuotedStart'>, <class 'ly.lex.lilypond.SequentialStart'>, <class 'ly.lex.lilypond.SimultaneousStart'>, <class 'ly.lex.lilypond.Repeat'>, <class 'ly.lex.lilypond.PitchCommand'>, <class 'ly.lex.lilypond.Override'>, <class 'ly.lex.lilypond.Revert'>, <class 'ly.lex.lilypond.Set'>, <class 'ly.lex.lilypond.Unset'>, <class 'ly.lex.lilypond.Hide'>, <class 'ly.lex.lilypond.Omit'>, <class 'ly.lex.lilypond.Tweak'>, <class 'ly.lex.lilypond.New'>, <class 'ly.lex.lilypond.Context'>, <class 'ly.lex.lilypond.Change'>, <class 'ly.lex.lilypond.With'>, <class 'ly.lex.lilypond.Clef'>, <class 'ly.lex.lilypond.Tempo'>, <class 'ly.lex.lilypond.Partial'>, <class 'ly.lex.lilypond.KeySignatureMode'>, <class 'ly.lex.lilypond.AccidentalStyle'>, <class 'ly.lex.lilypond.AlterBroken'>, <class 'ly.lex.lilypond.SimultaneousOrSequentialCommand'>, <class 'ly.lex.lilypond.ChordMode'>, <class 'ly.lex.lilypond.DrumMode'>, <class 'ly.lex.lilypond.FigureMode'>, <class 'ly.lex.lilypond.LyricMode'>, <class 'ly.lex.lilypond.NoteMode'>, <class 'ly.lex.lilypond.MarkupStart'>, <class 'ly.lex.lilypond.MarkupLines'>, <class 'ly.lex.lilypond.MarkupList'>, <class 'ly.lex.lilypond.ArticulationCommand'>, <class 'ly.lex.lilypond.Keyword'>, <class 'ly.lex.lilypond.Command'>, <class 'ly.lex.lilypond.SimultaneousOrSequentialCommand'>, <class 'ly.lex.lilypond.UserCommand'>)¶
-
pattern= re.compile('(?P<g_0>\\})|(?P<g_1>\\b(ChoirStaff|ChordNames|CueVoice|Devnull|DrumStaff|DrumVoice|Dynamics|FiguredBass|FretBoards|Global|GrandStaff|GregorianTranscriptionStaff|GregorianTranscriptionVoice|KievanSta, re.MULTILINE)¶
-
-
class
ly.lex.lilypond.Partial(string, pos)[source]¶ Bases:
ly.lex.lilypond.Command-
end¶
-
pos¶
-
rx= '\\\\partial\\b'¶
-
-
class
ly.lex.lilypond.PhrasingSlurEnd(string, pos)[source]¶ Bases:
ly.lex.lilypond.SlurEnd-
end¶
-
matchname= 'phrasingslur'¶
-
pos¶
-
rx= '\\\\\\)'¶
-
-
class
ly.lex.lilypond.PhrasingSlurStart(string, pos)[source]¶ Bases:
ly.lex.lilypond.SlurStart-
end¶
-
matchname= 'phrasingslur'¶
-
pos¶
-
rx= '\\\\\\('¶
-
-
class
ly.lex.lilypond.PipeSymbol(string, pos)[source]¶ Bases:
ly.lex.lilypond.Delimiter-
end¶
-
pos¶
-
rx= '\\|'¶
-
-
class
ly.lex.lilypond.PitchCommand(string, pos)[source]¶ Bases:
ly.lex.lilypond.Command-
end¶
-
pos¶
-
rx= '\\\\(relative|transpose|transposition|key|octaveCheck)\\b'¶
-
update_state(state)[source]¶ Lets the token update the state, e.g. enter a different parser.
This method is called by the State upon instantiation of the tokens.
Don’t use it later on to have a State follow already instantiated Tokens because the FallthroughParser type can also change the state without generating a Token. Use State.follow() to have a State follow instantiated Tokens.
The default implementation lets the Parser decide on state change.
-
-
class
ly.lex.lilypond.Q(string, pos)[source]¶ Bases:
ly.lex.lilypond.MusicItem-
end¶
-
pos¶
-
rx= 'q(?![A-Za-z])'¶
-
-
class
ly.lex.lilypond.Repeat(string, pos)[source]¶ Bases:
ly.lex.lilypond.Command-
end¶
-
pos¶
-
rx= '\\\\repeat(?![A-Za-z])'¶
-
update_state(state)[source]¶ Lets the token update the state, e.g. enter a different parser.
This method is called by the State upon instantiation of the tokens.
Don’t use it later on to have a State follow already instantiated Tokens because the FallthroughParser type can also change the state without generating a Token. Use State.follow() to have a State follow instantiated Tokens.
The default implementation lets the Parser decide on state change.
-
-
class
ly.lex.lilypond.RepeatCount(string, pos)[source]¶ Bases:
ly.lex.lilypond.IntegerValue,ly.lex._token.Leaver-
end¶
-
pos¶
-
-
class
ly.lex.lilypond.RepeatSpecifier(string, pos)[source]¶ Bases:
ly.lex.lilypond.Specifier-
end¶
-
pos¶
-
rx= '\\b(unfold|percent|volta|tremolo)(?![A-Za-z])'¶
-
-
class
ly.lex.lilypond.Rest(string, pos)[source]¶ Bases:
ly.lex.lilypond.MusicItem-
end¶
-
pos¶
-
rx= '[Rr](?![A-Za-z])'¶
-
-
class
ly.lex.lilypond.Revert(string, pos)[source]¶ Bases:
ly.lex.lilypond.Override-
end¶
-
pos¶
-
rx= '\\\\revert\\b'¶
-
update_state(state)[source]¶ Lets the token update the state, e.g. enter a different parser.
This method is called by the State upon instantiation of the tokens.
Don’t use it later on to have a State follow already instantiated Tokens because the FallthroughParser type can also change the state without generating a Token. Use State.follow() to have a State follow instantiated Tokens.
The default implementation lets the Parser decide on state change.
-
-
class
ly.lex.lilypond.Scaling(string, pos)[source]¶ Bases:
ly.lex.lilypond.Duration-
end¶
-
pos¶
-
rx= '\\*[\\t ]*\\d+(/\\d+)?'¶
-
-
class
ly.lex.lilypond.SchemeStart(string, pos)[source]¶ Bases:
ly.lex._token.Item-
end¶
-
pos¶
-
rx= '[#$](?![{}])'¶
-
update_state(state)[source]¶ Lets the token update the state, e.g. enter a different parser.
This method is called by the State upon instantiation of the tokens.
Don’t use it later on to have a State follow already instantiated Tokens because the FallthroughParser type can also change the state without generating a Token. Use State.follow() to have a State follow instantiated Tokens.
The default implementation lets the Parser decide on state change.
-
-
class
ly.lex.lilypond.Score(string, pos)[source]¶ Bases:
ly.lex.lilypond.Keyword-
end¶
-
pos¶
-
rx= '\\\\score\\b'¶
-
update_state(state)[source]¶ Lets the token update the state, e.g. enter a different parser.
This method is called by the State upon instantiation of the tokens.
Don’t use it later on to have a State follow already instantiated Tokens because the FallthroughParser type can also change the state without generating a Token. Use State.follow() to have a State follow instantiated Tokens.
The default implementation lets the Parser decide on state change.
-
-
class
ly.lex.lilypond.ScriptAbbreviation(string, pos)[source]¶ Bases:
ly.lex.lilypond.Articulation,ly.lex._token.Leaver-
end¶
-
pos¶
-
rx= '[+|!>._^-]'¶
-
-
class
ly.lex.lilypond.SequentialEnd(string, pos)[source]¶ Bases:
ly.lex.lilypond.CloseBracket-
end¶
-
pos¶
-
-
class
ly.lex.lilypond.SequentialStart(string, pos)[source]¶ Bases:
ly.lex.lilypond.OpenBracket-
end¶
-
pos¶
-
update_state(state)[source]¶ Lets the token update the state, e.g. enter a different parser.
This method is called by the State upon instantiation of the tokens.
Don’t use it later on to have a State follow already instantiated Tokens because the FallthroughParser type can also change the state without generating a Token. Use State.follow() to have a State follow instantiated Tokens.
The default implementation lets the Parser decide on state change.
-
-
class
ly.lex.lilypond.Set(string, pos)[source]¶ Bases:
ly.lex.lilypond.Override-
end¶
-
pos¶
-
rx= '\\\\set\\b'¶
-
update_state(state)[source]¶ Lets the token update the state, e.g. enter a different parser.
This method is called by the State upon instantiation of the tokens.
Don’t use it later on to have a State follow already instantiated Tokens because the FallthroughParser type can also change the state without generating a Token. Use State.follow() to have a State follow instantiated Tokens.
The default implementation lets the Parser decide on state change.
-
-
class
ly.lex.lilypond.SimultaneousEnd(string, pos)[source]¶ Bases:
ly.lex.lilypond.CloseSimultaneous-
end¶
-
pos¶
-
-
class
ly.lex.lilypond.SimultaneousOrSequentialCommand(string, pos)[source]¶ Bases:
ly.lex.lilypond.Keyword-
end¶
-
pos¶
-
rx= '\\\\(simultaneous|sequential)\\b'¶
-
-
class
ly.lex.lilypond.SimultaneousStart(string, pos)[source]¶ Bases:
ly.lex.lilypond.OpenSimultaneous-
end¶
-
pos¶
-
update_state(state)[source]¶ Lets the token update the state, e.g. enter a different parser.
This method is called by the State upon instantiation of the tokens.
Don’t use it later on to have a State follow already instantiated Tokens because the FallthroughParser type can also change the state without generating a Token. Use State.follow() to have a State follow instantiated Tokens.
The default implementation lets the Parser decide on state change.
-
-
class
ly.lex.lilypond.Skip(string, pos)[source]¶ Bases:
ly.lex.lilypond.MusicItem-
end¶
-
pos¶
-
rx= '\\\\skip(?![_-]?[^\\W\\d])'¶
-
-
class
ly.lex.lilypond.SlurEnd(string, pos)[source]¶ Bases:
ly.lex.lilypond.Slur,ly.lex._token.MatchEnd-
end¶
-
matchname= 'slur'¶
-
pos¶
-
rx= '\\)'¶
-
-
class
ly.lex.lilypond.SlurStart(string, pos)[source]¶ Bases:
ly.lex.lilypond.Slur,ly.lex._token.MatchStart-
end¶
-
matchname= 'slur'¶
-
pos¶
-
rx= '\\('¶
-
-
class
ly.lex.lilypond.Spacer(string, pos)[source]¶ Bases:
ly.lex.lilypond.MusicItem-
end¶
-
pos¶
-
rx= 's(?![A-Za-z])'¶
-
-
class
ly.lex.lilypond.StringNumber(string, pos)[source]¶ Bases:
ly.lex.lilypond.Articulation-
end¶
-
pos¶
-
rx= '\\\\\\d+'¶
-
-
class
ly.lex.lilypond.StringQuoteEscape(string, pos)[source]¶ Bases:
ly.lex._token.Character-
end¶
-
pos¶
-
rx= '\\\\[\\\\"]'¶
-
-
class
ly.lex.lilypond.StringQuotedEnd(string, pos)[source]¶ Bases:
ly.lex.lilypond.String,ly.lex._token.StringEnd-
end¶
-
pos¶
-
rx= '"'¶
-
update_state(state)[source]¶ Lets the token update the state, e.g. enter a different parser.
This method is called by the State upon instantiation of the tokens.
Don’t use it later on to have a State follow already instantiated Tokens because the FallthroughParser type can also change the state without generating a Token. Use State.follow() to have a State follow instantiated Tokens.
The default implementation lets the Parser decide on state change.
-
-
class
ly.lex.lilypond.StringQuotedStart(string, pos)[source]¶ Bases:
ly.lex.lilypond.String,ly.lex._token.StringStart-
end¶
-
pos¶
-
rx= '"'¶
-
update_state(state)[source]¶ Lets the token update the state, e.g. enter a different parser.
This method is called by the State upon instantiation of the tokens.
Don’t use it later on to have a State follow already instantiated Tokens because the FallthroughParser type can also change the state without generating a Token. Use State.follow() to have a State follow instantiated Tokens.
The default implementation lets the Parser decide on state change.
-
-
class
ly.lex.lilypond.Tempo(string, pos)[source]¶ Bases:
ly.lex.lilypond.Command-
end¶
-
pos¶
-
rx= '\\\\tempo\\b'¶
-
update_state(state)[source]¶ Lets the token update the state, e.g. enter a different parser.
This method is called by the State upon instantiation of the tokens.
Don’t use it later on to have a State follow already instantiated Tokens because the FallthroughParser type can also change the state without generating a Token. Use State.follow() to have a State follow instantiated Tokens.
The default implementation lets the Parser decide on state change.
-
-
class
ly.lex.lilypond.TempoSeparator(string, pos)[source]¶ Bases:
ly.lex.lilypond.Delimiter-
end¶
-
pos¶
-
rx= '[-~](?=\\s*\\d)'¶
-
-
class
ly.lex.lilypond.Translator(string, pos)[source]¶ Bases:
ly.lex.lilypond.Command-
end¶
-
pos¶
-
update_state(state)[source]¶ Lets the token update the state, e.g. enter a different parser.
This method is called by the State upon instantiation of the tokens.
Don’t use it later on to have a State follow already instantiated Tokens because the FallthroughParser type can also change the state without generating a Token. Use State.follow() to have a State follow instantiated Tokens.
The default implementation lets the Parser decide on state change.
-
-
class
ly.lex.lilypond.TremoloColon(string, pos)[source]¶ Bases:
ly.lex.lilypond.Tremolo-
end¶
-
pos¶
-
rx= ':'¶
-
update_state(state)[source]¶ Lets the token update the state, e.g. enter a different parser.
This method is called by the State upon instantiation of the tokens.
Don’t use it later on to have a State follow already instantiated Tokens because the FallthroughParser type can also change the state without generating a Token. Use State.follow() to have a State follow instantiated Tokens.
The default implementation lets the Parser decide on state change.
-
-
class
ly.lex.lilypond.TremoloDuration(string, pos)[source]¶ Bases:
ly.lex.lilypond.Tremolo,ly.lex._token.Leaver-
end¶
-
pos¶
-
rx= '\\b(8|16|32|64|128|256|512|1024|2048)(?!\\d)'¶
-
-
class
ly.lex.lilypond.Tweak(string, pos)[source]¶ Bases:
ly.lex.lilypond.Keyword-
end¶
-
pos¶
-
rx= '\\\\tweak\\b'¶
-
update_state(state)[source]¶ Lets the token update the state, e.g. enter a different parser.
This method is called by the State upon instantiation of the tokens.
Don’t use it later on to have a State follow already instantiated Tokens because the FallthroughParser type can also change the state without generating a Token. Use State.follow() to have a State follow instantiated Tokens.
The default implementation lets the Parser decide on state change.
-
-
class
ly.lex.lilypond.Unit(string, pos)[source]¶ Bases:
ly.lex.lilypond.Command-
end¶
-
pos¶
-
rx= '\\\\(mm|cm|in|pt)\\b'¶
-
-
class
ly.lex.lilypond.Unset(string, pos)[source]¶ Bases:
ly.lex.lilypond.Keyword-
end¶
-
pos¶
-
rx= '\\\\unset\\b'¶
-
update_state(state)[source]¶ Lets the token update the state, e.g. enter a different parser.
This method is called by the State upon instantiation of the tokens.
Don’t use it later on to have a State follow already instantiated Tokens because the FallthroughParser type can also change the state without generating a Token. Use State.follow() to have a State follow instantiated Tokens.
The default implementation lets the Parser decide on state change.
-
-
class
ly.lex.lilypond.UserCommand(string, pos)[source]¶ Bases:
ly.lex.lilypond.IdentifierRef-
end¶
-
pos¶
-
-
class
ly.lex.lilypond.UserVariable(string, pos)[source]¶ Bases:
ly.lex.lilypond.Identifier-
end¶
-
pos¶
-
-
class
ly.lex.lilypond.Value(string, pos)[source]¶ Bases:
ly.lex._token.Item,ly.lex._token.Numeric-
end¶
-
pos¶
-
-
class
ly.lex.lilypond.Variable(string, pos)[source]¶ Bases:
ly.lex.lilypond.Identifier-
end¶
-
pos¶
-
-
class
ly.lex.lilypond.VoiceSeparator(string, pos)[source]¶ Bases:
ly.lex.lilypond.Delimiter-
end¶
-
pos¶
-
rx= '\\\\\\\\'¶
-
-
class
ly.lex.lilypond.With(string, pos)[source]¶ Bases:
ly.lex.lilypond.Keyword-
end¶
-
pos¶
-
rx= '\\\\with\\b'¶
-
update_state(state)[source]¶ Lets the token update the state, e.g. enter a different parser.
This method is called by the State upon instantiation of the tokens.
Don’t use it later on to have a State follow already instantiated Tokens because the FallthroughParser type can also change the state without generating a Token. Use State.follow() to have a State follow instantiated Tokens.
The default implementation lets the Parser decide on state change.
-
ly.lex.scheme module¶
Parses and tokenizes Scheme input.
-
class
ly.lex.scheme.BlockComment(string, pos)[source]¶ Bases:
ly.lex.scheme.Comment,ly.lex._token.BlockComment-
end¶
-
pos¶
-
-
class
ly.lex.scheme.BlockCommentEnd(string, pos)[source]¶ Bases:
ly.lex.scheme.Comment,ly.lex._token.BlockCommentEnd,ly.lex._token.Leaver-
end¶
-
pos¶
-
rx= '!#'¶
-
-
class
ly.lex.scheme.BlockCommentStart(string, pos)[source]¶ Bases:
ly.lex.scheme.Comment,ly.lex._token.BlockCommentStart-
end¶
-
pos¶
-
rx= '#!'¶
-
update_state(state)[source]¶ Lets the token update the state, e.g. enter a different parser.
This method is called by the State upon instantiation of the tokens.
Don’t use it later on to have a State follow already instantiated Tokens because the FallthroughParser type can also change the state without generating a Token. Use State.follow() to have a State follow instantiated Tokens.
The default implementation lets the Parser decide on state change.
-
-
class
ly.lex.scheme.Bool(string, pos)[source]¶ Bases:
ly.lex.scheme.Scheme,ly.lex._token.Item-
end¶
-
pos¶
-
rx= '#[tf]\\b'¶
-
-
class
ly.lex.scheme.Char(string, pos)[source]¶ Bases:
ly.lex.scheme.Scheme,ly.lex._token.Item-
end¶
-
pos¶
-
rx= '#\\\\([a-z]+|.)'¶
-
-
class
ly.lex.scheme.CloseParen(string, pos)[source]¶ Bases:
ly.lex.scheme.Scheme,ly.lex._token.MatchEnd,ly.lex._token.Dedent-
end¶
-
matchname= 'schemeparen'¶
-
pos¶
-
rx= '\\)'¶
-
update_state(state)[source]¶ Lets the token update the state, e.g. enter a different parser.
This method is called by the State upon instantiation of the tokens.
Don’t use it later on to have a State follow already instantiated Tokens because the FallthroughParser type can also change the state without generating a Token. Use State.follow() to have a State follow instantiated Tokens.
The default implementation lets the Parser decide on state change.
-
-
class
ly.lex.scheme.Constant(string, pos)[source]¶ Bases:
ly.lex.scheme.Word-
end¶
-
pos¶
-
classmethod
test_match(match)[source]¶ Should return True if the match should indeed instantiate this class.
This class method is only called if multiple Token classes in the Parser’s items list have the same rx attribute. This method is then called for every matching Token subclass until one returns True. That token is then instantiated. (The method is not called for the last class in the list that have the same rx attribute, and also not if there is only one class with that rx attribute.)
The default implementation always returns True.
-
-
class
ly.lex.scheme.Dot(string, pos)[source]¶ Bases:
ly.lex.scheme.Scheme-
end¶
-
pos¶
-
rx= '\\.(?!\\S)'¶
-
-
class
ly.lex.scheme.Float(string, pos)[source]¶ Bases:
ly.lex.scheme.Number-
end¶
-
pos¶
-
rx= '-?((\\d+(\\.\\d*)|\\.\\d+)(E\\d+)?)(?=$|[)\\s])'¶
-
-
class
ly.lex.scheme.Fraction(string, pos)[source]¶ Bases:
ly.lex.scheme.Number-
end¶
-
pos¶
-
rx= '-?\\d+/\\d+(?=$|[)\\s])'¶
-
-
class
ly.lex.scheme.Function(string, pos)[source]¶ Bases:
ly.lex.scheme.Word-
end¶
-
pos¶
-
classmethod
test_match(match)[source]¶ Should return True if the match should indeed instantiate this class.
This class method is only called if multiple Token classes in the Parser’s items list have the same rx attribute. This method is then called for every matching Token subclass until one returns True. That token is then instantiated. (The method is not called for the last class in the list that have the same rx attribute, and also not if there is only one class with that rx attribute.)
The default implementation always returns True.
-
-
class
ly.lex.scheme.Keyword(string, pos)[source]¶ Bases:
ly.lex.scheme.Word-
end¶
-
pos¶
-
classmethod
test_match(match)[source]¶ Should return True if the match should indeed instantiate this class.
This class method is only called if multiple Token classes in the Parser’s items list have the same rx attribute. This method is then called for every matching Token subclass until one returns True. That token is then instantiated. (The method is not called for the last class in the list that have the same rx attribute, and also not if there is only one class with that rx attribute.)
The default implementation always returns True.
-
-
class
ly.lex.scheme.LilyPondEnd(string, pos)[source]¶ Bases:
ly.lex.scheme.LilyPond,ly.lex._token.Leaver,ly.lex._token.MatchEnd,ly.lex._token.Dedent-
end¶
-
matchname= 'schemelily'¶
-
pos¶
-
rx= '#}'¶
-
-
class
ly.lex.scheme.LilyPondStart(string, pos)[source]¶ Bases:
ly.lex.scheme.LilyPond,ly.lex._token.MatchStart,ly.lex._token.Indent-
end¶
-
matchname= 'schemelily'¶
-
pos¶
-
rx= '#{'¶
-
update_state(state)[source]¶ Lets the token update the state, e.g. enter a different parser.
This method is called by the State upon instantiation of the tokens.
Don’t use it later on to have a State follow already instantiated Tokens because the FallthroughParser type can also change the state without generating a Token. Use State.follow() to have a State follow instantiated Tokens.
The default implementation lets the Parser decide on state change.
-
-
class
ly.lex.scheme.LineComment(string, pos)[source]¶ Bases:
ly.lex.scheme.Comment,ly.lex._token.LineComment-
end¶
-
pos¶
-
rx= ';.*$'¶
-
-
class
ly.lex.scheme.Number(string, pos)[source]¶ Bases:
ly.lex._token.Item,ly.lex._token.Numeric-
end¶
-
pos¶
-
rx= '(-?\\d+|#(b[0-1]+|o[0-7]+|x[0-9a-fA-F]+)|[-+]inf.0|[-+]?nan.0)(?=$|[)\\s])'¶
-
-
class
ly.lex.scheme.OpenParen(string, pos)[source]¶ Bases:
ly.lex.scheme.Scheme,ly.lex._token.MatchStart,ly.lex._token.Indent-
end¶
-
matchname= 'schemeparen'¶
-
pos¶
-
rx= '\\('¶
-
update_state(state)[source]¶ Lets the token update the state, e.g. enter a different parser.
This method is called by the State upon instantiation of the tokens.
Don’t use it later on to have a State follow already instantiated Tokens because the FallthroughParser type can also change the state without generating a Token. Use State.follow() to have a State follow instantiated Tokens.
The default implementation lets the Parser decide on state change.
-
-
class
ly.lex.scheme.ParseBlockComment(argcount=None)[source]¶ Bases:
ly.lex.Parser-
default¶ alias of
ly.lex.scheme.BlockComment
-
items= (<class 'ly.lex.scheme.BlockCommentEnd'>,)¶
-
pattern= re.compile('(?P<g_0>!#)', re.MULTILINE)¶
-
-
class
ly.lex.scheme.ParseLilyPond(argcount=None)[source]¶ Bases:
ly.lex.lilypond.ParseMusic-
items= (<class 'ly.lex.scheme.LilyPondEnd'>, <class 'ly.lex._token.Space'>, <class 'ly.lex.lilypond.BlockCommentStart'>, <class 'ly.lex.lilypond.LineComment'>, <class 'ly.lex.lilypond.SchemeStart'>, <class 'ly.lex.lilypond.StringQuotedStart'>, <class 'ly.lex.lilypond.Dynamic'>, <class 'ly.lex.lilypond.Skip'>, <class 'ly.lex.lilypond.Spacer'>, <class 'ly.lex.lilypond.Q'>, <class 'ly.lex.lilypond.Rest'>, <class 'ly.lex.lilypond.Note'>, <class 'ly.lex.lilypond.Fraction'>, <class 'ly.lex.lilypond.Length'>, <class 'ly.lex.lilypond.Octave'>, <class 'ly.lex.lilypond.OctaveCheck'>, <class 'ly.lex.lilypond.AccidentalCautionary'>, <class 'ly.lex.lilypond.AccidentalReminder'>, <class 'ly.lex.lilypond.PipeSymbol'>, <class 'ly.lex.lilypond.VoiceSeparator'>, <class 'ly.lex.lilypond.SequentialStart'>, <class 'ly.lex.lilypond.SequentialEnd'>, <class 'ly.lex.lilypond.SimultaneousStart'>, <class 'ly.lex.lilypond.SimultaneousEnd'>, <class 'ly.lex.lilypond.ChordStart'>, <class 'ly.lex.lilypond.ContextName'>, <class 'ly.lex.lilypond.GrobName'>, <class 'ly.lex.lilypond.SlurStart'>, <class 'ly.lex.lilypond.SlurEnd'>, <class 'ly.lex.lilypond.PhrasingSlurStart'>, <class 'ly.lex.lilypond.PhrasingSlurEnd'>, <class 'ly.lex.lilypond.Tie'>, <class 'ly.lex.lilypond.BeamStart'>, <class 'ly.lex.lilypond.BeamEnd'>, <class 'ly.lex.lilypond.LigatureStart'>, <class 'ly.lex.lilypond.LigatureEnd'>, <class 'ly.lex.lilypond.Direction'>, <class 'ly.lex.lilypond.StringNumber'>, <class 'ly.lex.lilypond.IntegerValue'>, <class 'ly.lex.lilypond.Repeat'>, <class 'ly.lex.lilypond.PitchCommand'>, <class 'ly.lex.lilypond.Override'>, <class 'ly.lex.lilypond.Revert'>, <class 'ly.lex.lilypond.Set'>, <class 'ly.lex.lilypond.Unset'>, <class 'ly.lex.lilypond.Hide'>, <class 'ly.lex.lilypond.Omit'>, <class 'ly.lex.lilypond.Tweak'>, <class 'ly.lex.lilypond.New'>, <class 'ly.lex.lilypond.Context'>, <class 'ly.lex.lilypond.Change'>, <class 'ly.lex.lilypond.With'>, <class 'ly.lex.lilypond.Clef'>, <class 'ly.lex.lilypond.Tempo'>, <class 'ly.lex.lilypond.Partial'>, <class 'ly.lex.lilypond.KeySignatureMode'>, <class 'ly.lex.lilypond.AccidentalStyle'>, <class 'ly.lex.lilypond.AlterBroken'>, <class 'ly.lex.lilypond.SimultaneousOrSequentialCommand'>, <class 'ly.lex.lilypond.ChordMode'>, <class 'ly.lex.lilypond.DrumMode'>, <class 'ly.lex.lilypond.FigureMode'>, <class 'ly.lex.lilypond.LyricMode'>, <class 'ly.lex.lilypond.NoteMode'>, <class 'ly.lex.lilypond.MarkupStart'>, <class 'ly.lex.lilypond.MarkupLines'>, <class 'ly.lex.lilypond.MarkupList'>, <class 'ly.lex.lilypond.ArticulationCommand'>, <class 'ly.lex.lilypond.Keyword'>, <class 'ly.lex.lilypond.Command'>, <class 'ly.lex.lilypond.SimultaneousOrSequentialCommand'>, <class 'ly.lex.lilypond.UserCommand'>, <class 'ly.lex.lilypond.TremoloColon'>)¶
-
pattern= re.compile('(?P<g_0>#})|(?P<g_1>\\s+)|(?P<g_2>%{)|(?P<g_3>%.*$)|(?P<g_4>[#$](?![{}]))|(?P<g_5>")|(?P<g_6>\\\\[<!>]|\\\\(f{1,5}|p{1,5}|mf|mp|fp|spp?|sff?|sfz|rfz|cresc|decresc|dim|cr|decr)(?![A-Za-z]))|(?P<g_7>\\, re.MULTILINE)¶
-
-
class
ly.lex.scheme.ParseScheme(argcount=None)[source]¶ Bases:
ly.lex.Parser-
items= (<class 'ly.lex._token.Space'>, <class 'ly.lex.scheme.OpenParen'>, <class 'ly.lex.scheme.CloseParen'>, <class 'ly.lex.scheme.LineComment'>, <class 'ly.lex.scheme.BlockCommentStart'>, <class 'ly.lex.scheme.LilyPondStart'>, <class 'ly.lex.scheme.VectorStart'>, <class 'ly.lex.scheme.Dot'>, <class 'ly.lex.scheme.Bool'>, <class 'ly.lex.scheme.Char'>, <class 'ly.lex.scheme.Quote'>, <class 'ly.lex.scheme.Fraction'>, <class 'ly.lex.scheme.Float'>, <class 'ly.lex.scheme.Number'>, <class 'ly.lex.scheme.Constant'>, <class 'ly.lex.scheme.Keyword'>, <class 'ly.lex.scheme.Function'>, <class 'ly.lex.scheme.Variable'>, <class 'ly.lex.scheme.Word'>, <class 'ly.lex.scheme.StringQuotedStart'>)¶
-
mode= 'scheme'¶
-
pattern= re.compile('(?P<g_0>\\s+)|(?P<g_1>\\()|(?P<g_2>\\))|(?P<g_3>;.*$)|(?P<g_4>#!)|(?P<g_5>#{)|(?P<g_6>#\\()|(?P<g_7>\\.(?!\\S))|(?P<g_8>#[tf]\\b)|(?P<g_9>#\\\\([a-z]+|.))|(?P<g_10>[\'`,])|(?P<g_11>-?\\d+/\\d+(?=$|[), re.MULTILINE)¶
-
-
class
ly.lex.scheme.ParseString(argcount=None)[source]¶ Bases:
ly.lex.Parser-
default¶ alias of
ly.lex.scheme.String
-
items= (<class 'ly.lex.scheme.StringQuotedEnd'>, <class 'ly.lex.scheme.StringQuoteEscape'>)¶
-
pattern= re.compile('(?P<g_0>")|(?P<g_1>\\\\[\\\\"])', re.MULTILINE)¶
-
-
class
ly.lex.scheme.Scheme(string, pos)[source]¶ Bases:
ly.lex._token.TokenBaseclass for Scheme tokens.
-
end¶
-
pos¶
-
-
class
ly.lex.scheme.StringQuoteEscape(string, pos)[source]¶ Bases:
ly.lex._token.Character-
end¶
-
pos¶
-
rx= '\\\\[\\\\"]'¶
-
-
class
ly.lex.scheme.StringQuotedEnd(string, pos)[source]¶ Bases:
ly.lex.scheme.String,ly.lex._token.StringEnd-
end¶
-
pos¶
-
rx= '"'¶
-
update_state(state)[source]¶ Lets the token update the state, e.g. enter a different parser.
This method is called by the State upon instantiation of the tokens.
Don’t use it later on to have a State follow already instantiated Tokens because the FallthroughParser type can also change the state without generating a Token. Use State.follow() to have a State follow instantiated Tokens.
The default implementation lets the Parser decide on state change.
-
-
class
ly.lex.scheme.StringQuotedStart(string, pos)[source]¶ Bases:
ly.lex.scheme.String,ly.lex._token.StringStart-
end¶
-
pos¶
-
rx= '"'¶
-
update_state(state)[source]¶ Lets the token update the state, e.g. enter a different parser.
This method is called by the State upon instantiation of the tokens.
Don’t use it later on to have a State follow already instantiated Tokens because the FallthroughParser type can also change the state without generating a Token. Use State.follow() to have a State follow instantiated Tokens.
The default implementation lets the Parser decide on state change.
-
-
class
ly.lex.scheme.Variable(string, pos)[source]¶ Bases:
ly.lex.scheme.Word-
end¶
-
pos¶
-
classmethod
test_match(match)[source]¶ Should return True if the match should indeed instantiate this class.
This class method is only called if multiple Token classes in the Parser’s items list have the same rx attribute. This method is then called for every matching Token subclass until one returns True. That token is then instantiated. (The method is not called for the last class in the list that have the same rx attribute, and also not if there is only one class with that rx attribute.)
The default implementation always returns True.
-
ly.lex.texinfo module¶
Parses and tokenizes Texinfo input, recognizing LilyPond in Texinfo.
-
class
ly.lex.texinfo.Accent(string, pos)[source]¶ Bases:
ly.lex.texinfo.EscapeChar-
end¶
-
pos¶
-
rx= '@[\'"\',=^`~](\\{[a-zA-Z]\\}|[a-zA-Z]\\b)'¶
-
-
class
ly.lex.texinfo.BlockCommentEnd(string, pos)[source]¶ Bases:
ly.lex.texinfo.Comment,ly.lex._token.Leaver,ly.lex._token.BlockCommentEnd-
end¶
-
pos¶
-
rx= '@end\\s+ignore\\b'¶
-
-
class
ly.lex.texinfo.BlockCommentStart(string, pos)[source]¶ Bases:
ly.lex.texinfo.Comment,ly.lex._token.BlockCommentStart-
end¶
-
pos¶
-
rx= '@ignore\\b'¶
-
update_state(state)[source]¶ Lets the token update the state, e.g. enter a different parser.
This method is called by the State upon instantiation of the tokens.
Don’t use it later on to have a State follow already instantiated Tokens because the FallthroughParser type can also change the state without generating a Token. Use State.follow() to have a State follow instantiated Tokens.
The default implementation lets the Parser decide on state change.
-
-
class
ly.lex.texinfo.BlockEnd(string, pos)[source]¶ Bases:
ly.lex.texinfo.Block,ly.lex._token.Leaver-
end¶
-
pos¶
-
rx= '\\}'¶
-
-
class
ly.lex.texinfo.BlockStart(string, pos)[source]¶ Bases:
ly.lex.texinfo.Block-
end¶
-
pos¶
-
rx= '@[a-zA-Z]+\\{'¶
-
update_state(state)[source]¶ Lets the token update the state, e.g. enter a different parser.
This method is called by the State upon instantiation of the tokens.
Don’t use it later on to have a State follow already instantiated Tokens because the FallthroughParser type can also change the state without generating a Token. Use State.follow() to have a State follow instantiated Tokens.
The default implementation lets the Parser decide on state change.
-
-
class
ly.lex.texinfo.EscapeChar(string, pos)[source]¶ Bases:
ly.lex._token.Character-
end¶
-
pos¶
-
rx= '@[@{}]'¶
-
-
class
ly.lex.texinfo.Keyword(string, pos)[source]¶ Bases:
ly.lex._token.Token-
end¶
-
pos¶
-
rx= '@[a-zA-Z]+'¶
-
-
class
ly.lex.texinfo.LilyPondAttrEnd(string, pos)[source]¶ Bases:
ly.lex.texinfo.Attribute,ly.lex._token.Leaver-
end¶
-
pos¶
-
rx= '\\]'¶
-
-
class
ly.lex.texinfo.LilyPondAttrStart(string, pos)[source]¶ Bases:
ly.lex.texinfo.Attribute-
end¶
-
pos¶
-
rx= '\\['¶
-
update_state(state)[source]¶ Lets the token update the state, e.g. enter a different parser.
This method is called by the State upon instantiation of the tokens.
Don’t use it later on to have a State follow already instantiated Tokens because the FallthroughParser type can also change the state without generating a Token. Use State.follow() to have a State follow instantiated Tokens.
The default implementation lets the Parser decide on state change.
-
-
class
ly.lex.texinfo.LilyPondBlockEnd(string, pos)[source]¶ Bases:
ly.lex.texinfo.Block,ly.lex._token.Leaver-
end¶
-
pos¶
-
rx= '\\}'¶
-
-
class
ly.lex.texinfo.LilyPondBlockStart(string, pos)[source]¶ Bases:
ly.lex.texinfo.Block-
end¶
-
pos¶
-
rx= '@lilypond(?=(\\[[a-zA-Z,=0-9\\\\\\s]+\\])?\\{)'¶
-
update_state(state)[source]¶ Lets the token update the state, e.g. enter a different parser.
This method is called by the State upon instantiation of the tokens.
Don’t use it later on to have a State follow already instantiated Tokens because the FallthroughParser type can also change the state without generating a Token. Use State.follow() to have a State follow instantiated Tokens.
The default implementation lets the Parser decide on state change.
-
-
class
ly.lex.texinfo.LilyPondBlockStartBrace(string, pos)[source]¶ Bases:
ly.lex.texinfo.Block-
end¶
-
pos¶
-
rx= '\\{'¶
-
update_state(state)[source]¶ Lets the token update the state, e.g. enter a different parser.
This method is called by the State upon instantiation of the tokens.
Don’t use it later on to have a State follow already instantiated Tokens because the FallthroughParser type can also change the state without generating a Token. Use State.follow() to have a State follow instantiated Tokens.
The default implementation lets the Parser decide on state change.
-
-
class
ly.lex.texinfo.LilyPondEnvEnd(string, pos)[source]¶ Bases:
ly.lex.texinfo.Keyword,ly.lex._token.Leaver-
end¶
-
pos¶
-
rx= '@end\\s+lilypond\\b'¶
-
-
class
ly.lex.texinfo.LilyPondEnvStart(string, pos)[source]¶ Bases:
ly.lex.texinfo.Keyword-
end¶
-
pos¶
-
rx= '@lilypond\\b'¶
-
update_state(state)[source]¶ Lets the token update the state, e.g. enter a different parser.
This method is called by the State upon instantiation of the tokens.
Don’t use it later on to have a State follow already instantiated Tokens because the FallthroughParser type can also change the state without generating a Token. Use State.follow() to have a State follow instantiated Tokens.
The default implementation lets the Parser decide on state change.
-
-
class
ly.lex.texinfo.LilyPondFileStart(string, pos)[source]¶ Bases:
ly.lex.texinfo.Block-
end¶
-
pos¶
-
rx= '@lilypondfile\\b'¶
-
update_state(state)[source]¶ Lets the token update the state, e.g. enter a different parser.
This method is called by the State upon instantiation of the tokens.
Don’t use it later on to have a State follow already instantiated Tokens because the FallthroughParser type can also change the state without generating a Token. Use State.follow() to have a State follow instantiated Tokens.
The default implementation lets the Parser decide on state change.
-
-
class
ly.lex.texinfo.LilyPondFileStartBrace(string, pos)[source]¶ Bases:
ly.lex.texinfo.Block-
end¶
-
pos¶
-
rx= '\\{'¶
-
update_state(state)[source]¶ Lets the token update the state, e.g. enter a different parser.
This method is called by the State upon instantiation of the tokens.
Don’t use it later on to have a State follow already instantiated Tokens because the FallthroughParser type can also change the state without generating a Token. Use State.follow() to have a State follow instantiated Tokens.
The default implementation lets the Parser decide on state change.
-
-
class
ly.lex.texinfo.LineComment(string, pos)[source]¶ Bases:
ly.lex.texinfo.Comment,ly.lex._token.LineComment-
end¶
-
pos¶
-
rx= '@c\\b.*$'¶
-
-
class
ly.lex.texinfo.ParseBlock(argcount=None)[source]¶ Bases:
ly.lex.Parser-
items= (<class 'ly.lex.texinfo.BlockEnd'>, <class 'ly.lex.texinfo.Accent'>, <class 'ly.lex.texinfo.EscapeChar'>, <class 'ly.lex.texinfo.BlockStart'>, <class 'ly.lex.texinfo.Keyword'>)¶
-
pattern= re.compile('(?P<g_0>\\})|(?P<g_1>@[\'"\',=^`~](\\{[a-zA-Z]\\}|[a-zA-Z]\\b))|(?P<g_2>@[@{}])|(?P<g_3>@[a-zA-Z]+\\{)|(?P<g_4>@[a-zA-Z]+)', re.MULTILINE)¶
-
-
class
ly.lex.texinfo.ParseComment(argcount=None)[source]¶ Bases:
ly.lex.Parser-
default¶ alias of
ly.lex.texinfo.Comment
-
items= (<class 'ly.lex.texinfo.BlockCommentEnd'>,)¶
-
pattern= re.compile('(?P<g_0>@end\\s+ignore\\b)', re.MULTILINE)¶
-
-
class
ly.lex.texinfo.ParseLilyPondAttr(argcount=None)[source]¶ Bases:
ly.lex.Parser-
default¶ alias of
ly.lex.texinfo.Attribute
-
items= (<class 'ly.lex.texinfo.LilyPondAttrEnd'>,)¶
-
pattern= re.compile('(?P<g_0>\\])', re.MULTILINE)¶
-
-
class
ly.lex.texinfo.ParseLilyPondBlock(argcount=None)[source]¶ Bases:
ly.lex.lilypond.ParseGlobal-
items= (<class 'ly.lex.texinfo.LilyPondBlockEnd'>, <class 'ly.lex.lilypond.Book'>, <class 'ly.lex.lilypond.BookPart'>, <class 'ly.lex.lilypond.Score'>, <class 'ly.lex.lilypond.MarkupStart'>, <class 'ly.lex.lilypond.MarkupLines'>, <class 'ly.lex.lilypond.MarkupList'>, <class 'ly.lex.lilypond.Paper'>, <class 'ly.lex.lilypond.Header'>, <class 'ly.lex.lilypond.Layout'>, <class 'ly.lex._token.Space'>, <class 'ly.lex.lilypond.BlockCommentStart'>, <class 'ly.lex.lilypond.LineComment'>, <class 'ly.lex.lilypond.SchemeStart'>, <class 'ly.lex.lilypond.StringQuotedStart'>, <class 'ly.lex.lilypond.SequentialStart'>, <class 'ly.lex.lilypond.SimultaneousStart'>, <class 'ly.lex.lilypond.Repeat'>, <class 'ly.lex.lilypond.PitchCommand'>, <class 'ly.lex.lilypond.Override'>, <class 'ly.lex.lilypond.Revert'>, <class 'ly.lex.lilypond.Set'>, <class 'ly.lex.lilypond.Unset'>, <class 'ly.lex.lilypond.Hide'>, <class 'ly.lex.lilypond.Omit'>, <class 'ly.lex.lilypond.Tweak'>, <class 'ly.lex.lilypond.New'>, <class 'ly.lex.lilypond.Context'>, <class 'ly.lex.lilypond.Change'>, <class 'ly.lex.lilypond.With'>, <class 'ly.lex.lilypond.Clef'>, <class 'ly.lex.lilypond.Tempo'>, <class 'ly.lex.lilypond.Partial'>, <class 'ly.lex.lilypond.KeySignatureMode'>, <class 'ly.lex.lilypond.AccidentalStyle'>, <class 'ly.lex.lilypond.AlterBroken'>, <class 'ly.lex.lilypond.SimultaneousOrSequentialCommand'>, <class 'ly.lex.lilypond.ChordMode'>, <class 'ly.lex.lilypond.DrumMode'>, <class 'ly.lex.lilypond.FigureMode'>, <class 'ly.lex.lilypond.LyricMode'>, <class 'ly.lex.lilypond.NoteMode'>, <class 'ly.lex.lilypond.MarkupStart'>, <class 'ly.lex.lilypond.MarkupLines'>, <class 'ly.lex.lilypond.MarkupList'>, <class 'ly.lex.lilypond.ArticulationCommand'>, <class 'ly.lex.lilypond.Keyword'>, <class 'ly.lex.lilypond.Command'>, <class 'ly.lex.lilypond.SimultaneousOrSequentialCommand'>, <class 'ly.lex.lilypond.UserCommand'>, <class 'ly.lex.lilypond.Name'>, <class 'ly.lex.lilypond.DotPath'>, <class 'ly.lex.lilypond.EqualSign'>, <class 'ly.lex.lilypond.Fraction'>, <class 'ly.lex.lilypond.DecimalValue'>)¶
-
pattern= re.compile('(?P<g_0>\\})|(?P<g_1>\\\\book\\b)|(?P<g_2>\\\\bookpart\\b)|(?P<g_3>\\\\score\\b)|(?P<g_4>\\\\markup(?![_-]?[^\\W\\d]))|(?P<g_5>\\\\markuplines(?![_-]?[^\\W\\d]))|(?P<g_6>\\\\markuplist(?![_-]?[^\\W\\, re.MULTILINE)¶
-
-
class
ly.lex.texinfo.ParseLilyPondBlockAttr(argcount=None)[source]¶ Bases:
ly.lex.Parser-
items= (<class 'ly.lex.texinfo.LilyPondAttrStart'>, <class 'ly.lex.texinfo.LilyPondBlockStartBrace'>)¶
-
pattern= re.compile('(?P<g_0>\\[)|(?P<g_1>\\{)', re.MULTILINE)¶
-
-
class
ly.lex.texinfo.ParseLilyPondEnv(argcount=None)[source]¶ Bases:
ly.lex.lilypond.ParseGlobal-
items= (<class 'ly.lex.texinfo.LilyPondEnvEnd'>, <class 'ly.lex.lilypond.Book'>, <class 'ly.lex.lilypond.BookPart'>, <class 'ly.lex.lilypond.Score'>, <class 'ly.lex.lilypond.MarkupStart'>, <class 'ly.lex.lilypond.MarkupLines'>, <class 'ly.lex.lilypond.MarkupList'>, <class 'ly.lex.lilypond.Paper'>, <class 'ly.lex.lilypond.Header'>, <class 'ly.lex.lilypond.Layout'>, <class 'ly.lex._token.Space'>, <class 'ly.lex.lilypond.BlockCommentStart'>, <class 'ly.lex.lilypond.LineComment'>, <class 'ly.lex.lilypond.SchemeStart'>, <class 'ly.lex.lilypond.StringQuotedStart'>, <class 'ly.lex.lilypond.SequentialStart'>, <class 'ly.lex.lilypond.SimultaneousStart'>, <class 'ly.lex.lilypond.Repeat'>, <class 'ly.lex.lilypond.PitchCommand'>, <class 'ly.lex.lilypond.Override'>, <class 'ly.lex.lilypond.Revert'>, <class 'ly.lex.lilypond.Set'>, <class 'ly.lex.lilypond.Unset'>, <class 'ly.lex.lilypond.Hide'>, <class 'ly.lex.lilypond.Omit'>, <class 'ly.lex.lilypond.Tweak'>, <class 'ly.lex.lilypond.New'>, <class 'ly.lex.lilypond.Context'>, <class 'ly.lex.lilypond.Change'>, <class 'ly.lex.lilypond.With'>, <class 'ly.lex.lilypond.Clef'>, <class 'ly.lex.lilypond.Tempo'>, <class 'ly.lex.lilypond.Partial'>, <class 'ly.lex.lilypond.KeySignatureMode'>, <class 'ly.lex.lilypond.AccidentalStyle'>, <class 'ly.lex.lilypond.AlterBroken'>, <class 'ly.lex.lilypond.SimultaneousOrSequentialCommand'>, <class 'ly.lex.lilypond.ChordMode'>, <class 'ly.lex.lilypond.DrumMode'>, <class 'ly.lex.lilypond.FigureMode'>, <class 'ly.lex.lilypond.LyricMode'>, <class 'ly.lex.lilypond.NoteMode'>, <class 'ly.lex.lilypond.MarkupStart'>, <class 'ly.lex.lilypond.MarkupLines'>, <class 'ly.lex.lilypond.MarkupList'>, <class 'ly.lex.lilypond.ArticulationCommand'>, <class 'ly.lex.lilypond.Keyword'>, <class 'ly.lex.lilypond.Command'>, <class 'ly.lex.lilypond.SimultaneousOrSequentialCommand'>, <class 'ly.lex.lilypond.UserCommand'>, <class 'ly.lex.lilypond.Name'>, <class 'ly.lex.lilypond.DotPath'>, <class 'ly.lex.lilypond.EqualSign'>, <class 'ly.lex.lilypond.Fraction'>, <class 'ly.lex.lilypond.DecimalValue'>)¶
-
pattern= re.compile('(?P<g_0>@end\\s+lilypond\\b)|(?P<g_1>\\\\book\\b)|(?P<g_2>\\\\bookpart\\b)|(?P<g_3>\\\\score\\b)|(?P<g_4>\\\\markup(?![_-]?[^\\W\\d]))|(?P<g_5>\\\\markuplines(?![_-]?[^\\W\\d]))|(?P<g_6>\\\\markuplis, re.MULTILINE)¶
-
-
class
ly.lex.texinfo.ParseLilyPondEnvAttr(argcount=None)[source]¶ Bases:
ly.lex.FallthroughParser-
fallthrough(state)[source]¶ Called when no match is returned by parse().
This implementation leaves the current parser and returns None (causing the State to continue parsing).
-
items= (<class 'ly.lex.texinfo.LilyPondAttrStart'>,)¶
-
pattern= re.compile('(?P<g_0>\\[)', re.MULTILINE)¶
-
-
class
ly.lex.texinfo.ParseLilyPondFile(argcount=None)[source]¶ Bases:
ly.lex.Parser-
items= (<class 'ly.lex.texinfo.LilyPondAttrStart'>, <class 'ly.lex.texinfo.LilyPondFileStartBrace'>)¶
-
pattern= re.compile('(?P<g_0>\\[)|(?P<g_1>\\{)', re.MULTILINE)¶
-
-
class
ly.lex.texinfo.ParseTexinfo(argcount=None)[source]¶ Bases:
ly.lex.Parser-
items= (<class 'ly.lex.texinfo.LineComment'>, <class 'ly.lex.texinfo.BlockCommentStart'>, <class 'ly.lex.texinfo.Accent'>, <class 'ly.lex.texinfo.EscapeChar'>, <class 'ly.lex.texinfo.LilyPondBlockStart'>, <class 'ly.lex.texinfo.LilyPondEnvStart'>, <class 'ly.lex.texinfo.LilyPondFileStart'>, <class 'ly.lex.texinfo.BlockStart'>, <class 'ly.lex.texinfo.VerbatimStart'>, <class 'ly.lex.texinfo.Keyword'>)¶
-
mode= 'texinfo'¶
-
pattern= re.compile('(?P<g_0>@c\\b.*$)|(?P<g_1>@ignore\\b)|(?P<g_2>@[\'"\',=^`~](\\{[a-zA-Z]\\}|[a-zA-Z]\\b))|(?P<g_3>@[@{}])|(?P<g_4>@lilypond(?=(\\[[a-zA-Z,=0-9\\\\\\s]+\\])?\\{))|(?P<g_5>@lilypond\\b)|(?P<g_6>@lilypon, re.MULTILINE)¶
-
-
class
ly.lex.texinfo.ParseVerbatim(argcount=None)[source]¶ Bases:
ly.lex.Parser-
default¶ alias of
ly.lex.texinfo.Verbatim
-
items= (<class 'ly.lex.texinfo.VerbatimEnd'>,)¶
-
pattern= re.compile('(?P<g_0>@end\\s+verbatim\\b)', re.MULTILINE)¶
-
-
class
ly.lex.texinfo.VerbatimEnd(string, pos)[source]¶ Bases:
ly.lex.texinfo.Keyword,ly.lex._token.Leaver-
end¶
-
pos¶
-
rx= '@end\\s+verbatim\\b'¶
-
-
class
ly.lex.texinfo.VerbatimStart(string, pos)[source]¶ Bases:
ly.lex.texinfo.Keyword-
end¶
-
pos¶
-
rx= '@verbatim\\b'¶
-
update_state(state)[source]¶ Lets the token update the state, e.g. enter a different parser.
This method is called by the State upon instantiation of the tokens.
Don’t use it later on to have a State follow already instantiated Tokens because the FallthroughParser type can also change the state without generating a Token. Use State.follow() to have a State follow instantiated Tokens.
The default implementation lets the Parser decide on state change.
-