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.Comment
Base class for tokens that belong to a block/multiline comment.
- end¶
- pos¶
- class ly.lex.BlockCommentEnd(string, pos)[source]¶
Bases:
ly.lex._token.BlockComment
Base class for tokens that end a block/multiline comment.
- end¶
- pos¶
- class ly.lex.BlockCommentStart(string, pos)[source]¶
Bases:
ly.lex._token.BlockComment
Base class for tokens that start a block/multiline comment.
- end¶
- pos¶
- class ly.lex.Character(string, pos)[source]¶
Bases:
ly.lex._token.Token
Base class for tokens that are an (escaped) character.
- end¶
- pos¶
- class ly.lex.Comment(string, pos)[source]¶
Bases:
ly.lex._token.Token
Base class for tokens that belong to a comment.
- end¶
- pos¶
- class ly.lex.Dedent[source]¶
Bases:
object
Mixin class for tokens that have the text on the next line indent less.
- class ly.lex.Error(string, pos)[source]¶
Bases:
ly.lex._token.Token
Base 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:
object
Mixin class for tokens that have the text on the next line indent more.
- class ly.lex.LineComment(string, pos)[source]¶
Bases:
ly.lex._token.Comment
Base class for items that are a whole line comment.
- end¶
- pos¶
- class ly.lex.MatchEnd[source]¶
Bases:
object
Mixin 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:
object
Mixin 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.Space
A token that is a single newline.
- end¶
- pos¶
- rx = '\\n'¶
- class ly.lex.Numeric(string, pos)[source]¶
Bases:
ly.lex._token.Token
Base 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.Token
A 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.Token
Base class for tokens that belong to a quote-delimited string.
- end¶
- pos¶
- class ly.lex.StringEnd(string, pos)[source]¶
Bases:
ly.lex._token.String
Base class for tokens that end a quote-delimited string.
- end¶
- pos¶
- class ly.lex.StringStart(string, pos)[source]¶
Bases:
ly.lex._token.String
Base 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.Token
Represents 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.Comment(string, pos)[source]¶
Bases:
ly.lex._token.Comment
- end¶
- pos¶
- 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.FallthroughParser
Finds 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.String(string, pos)[source]¶
Bases:
ly.lex._token.String
- end¶
- pos¶
- 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.Tag(string, pos)[source]¶
Bases:
ly.lex._token.Token
- end¶
- pos¶
- 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.Accidental(string, pos)[source]¶
Bases:
ly.lex._token.Token
- end¶
- pos¶
- 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|choral|choral-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.Token
Base 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.Beam(string, pos)[source]¶
Bases:
ly.lex._token.Token
- end¶
- pos¶
- 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.Token
Base 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.Token
Base 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.Comment(string, pos)[source]¶
Bases:
ly.lex._token.Comment
- end¶
- pos¶
- 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.Delimiter(string, pos)[source]¶
Bases:
ly.lex._token.Token
- end¶
- pos¶
- 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.Delimiter
A 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.Duration(string, pos)[source]¶
Bases:
ly.lex._token.Token
- end¶
- pos¶
- 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.Error(string, pos)[source]¶
Bases:
ly.lex._token.Error
- end¶
- pos¶
- 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.ParseLilyPond
Waits 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.ParseLilyPond
Waits 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.Token
Base class for Figure items.
- end¶
- pos¶
- class ly.lex.lilypond.FigureAccidental(string, pos)[source]¶
Bases:
ly.lex.lilypond.Figure
A 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.Figure
A 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.Figure
A 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.Variable
A 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.Token
A 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.Token
A 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.Variable
A 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.Ligature(string, pos)[source]¶
Bases:
ly.lex._token.Token
- end¶
- pos¶
- 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.Item
Base 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.Item
Base class for all markup commands.
- end¶
- pos¶
- class ly.lex.lilypond.MarkupCommand(string, pos)[source]¶
Bases:
ly.lex.lilypond.Markup
,ly.lex.lilypond.IdentifierRef
A 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.IdentifierRef
A 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.Token
A note, rest, spacer,
\skip
orq
.- end¶
- pos¶
- class ly.lex.lilypond.Name(string, pos)[source]¶
Bases:
ly.lex.lilypond.UserVariable
A 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.Indent
An 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.Indent
An 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.Variable
A 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.ParseLilyPond
Parses 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.ParseLilyPond
Parses 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.ParseMusic
LilyPond 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.ParseMusic
Parser for
\chords
and\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.ParseLilyPond
Parses 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.FallthroughParser
Parses 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.ParseMusic
LilyPond 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.ParseMusic
Parser for
\drums
and\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.Parser
Parse 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.ParseMusic
Parser for
\figures
and\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.ParseLilyPond
Parses 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.ParseLilyPond
Parses 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.ParseLilyPond
Base class for parser for mode-changing music commands.
- class ly.lex.lilypond.ParseLayout(argcount=None)[source]¶
Bases:
ly.lex.lilypond.ParseLilyPond
Parses 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.ParseInputMode
Parser 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.ParseLilyPond
Parses 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.ParseLilyPond
Parses 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.ParseMusic
Parser for
\notes
and\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.ParseLilyPond
Parses 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.FallthroughParser
parse 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.ParseLilyPond
Parses 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.ParseLilyPond
Parses 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.Slur(string, pos)[source]¶
Bases:
ly.lex._token.Token
- end¶
- pos¶
- 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.Specifier(string, pos)[source]¶
Bases:
ly.lex._token.Token
- end¶
- pos¶
- class ly.lex.lilypond.String(string, pos)[source]¶
Bases:
ly.lex._token.String
- end¶
- pos¶
- 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.Tremolo(string, pos)[source]¶
Bases:
ly.lex._token.Token
- end¶
- pos¶
- 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.Comment(string, pos)[source]¶
Bases:
ly.lex._token.Comment
- end¶
- pos¶
- 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.LilyPond(string, pos)[source]¶
Bases:
ly.lex._token.Token
- end¶
- pos¶
- 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.Token
Baseclass for Scheme tokens.
- end¶
- pos¶
- class ly.lex.scheme.String(string, pos)[source]¶
Bases:
ly.lex._token.String
- 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.Attribute(string, pos)[source]¶
Bases:
ly.lex._token.Token
- end¶
- pos¶
- class ly.lex.texinfo.Block(string, pos)[source]¶
Bases:
ly.lex._token.Token
- end¶
- pos¶
- 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.Comment(string, pos)[source]¶
Bases:
ly.lex._token.Comment
- end¶
- pos¶
- 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.Verbatim(string, pos)[source]¶
Bases:
ly.lex._token.Token
- end¶
- pos¶
- 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.