Browse Source

Improving chord \[ parsing

pull/54/head
Louis 11 years ago
parent
commit
950d9b36f8
  1. 42
      songbook_core/plastex_chord.py

42
songbook_core/plastex_chord.py

@ -5,9 +5,13 @@ r"""PlasTeX module to deal with chords commands of the songs LaTeX package
Chords are set using commands like \[C]. This package parses those commands. Chords are set using commands like \[C]. This package parses those commands.
""" """
import logging
from plasTeX import Command, Environment, Macro from plasTeX import Command, Environment, Macro
from plasTeX.Base.LaTeX.Math import BeginDisplayMath from plasTeX.Base.LaTeX.Math import BeginDisplayMath
LOGGER = logging.getLogger(__name__)
# Count the number of levels of 'verse' environment: IN_VERSE==1 means that we # Count the number of levels of 'verse' environment: IN_VERSE==1 means that we
# are in a 'verse' environment; IN_VERSE==2 means that we are in two included # are in a 'verse' environment; IN_VERSE==2 means that we are in two included
# 'verse' environment, and so on. # 'verse' environment, and so on.
@ -55,19 +59,19 @@ class Chorus(Environment):
class BeginChord(Command): class Chord(Command):
"""Beginning of a chord notation""" """Beginning of a chord notation"""
macroName = 'chord' macroName = 'chord'
macroMode = Command.MODE_BEGIN macroMode = Command.MODE_NONE
def __init__(self, *args, **kwargs):
super(Chord, self).__init__(*args, **kwargs)
self.chord = ""
@property @property
def source(self): def source(self):
"""Return chord LaTeX code.""" """Return chord LaTeX code."""
return r'\[{}]'.format(''.join([str(item) for item in self.childNodes])) return r'\[{}]'.format(self.chord)
class EndChord(Command):
"""End of a chord notation"""
macroMode = Command.MODE_END
class BeginChordOrDisplayMath(BeginDisplayMath): class BeginChordOrDisplayMath(BeginDisplayMath):
r"""Wrapper to BeginDisplayMath r"""Wrapper to BeginDisplayMath
@ -92,19 +96,25 @@ class BeginChordOrDisplayMath(BeginDisplayMath):
def invoke(self, tex): def invoke(self, tex):
"""Process this macro""" """Process this macro"""
if IN_VERSE: if IN_VERSE:
begin = BeginChord() chord = Chord()
self.ownerDocument.context.push(begin) # pylint: disable=no-member
self.parse(tex)
for token in tex: for token in tex:
if token.nodeType == token.TEXT_NODE and token.nodeValue == ']': if token.nodeType == token.TEXT_NODE and token.nodeValue == ']':
break break
else: else:
begin.appendChild(token) if token.nodeName == '#text':
chord.chord += str(token)
end = EndChord() elif token.nodeName == "active::&":
self.ownerDocument.context.push(end) # pylint: disable=no-member chord.chord += '&'
else:
return [begin] LOGGER.warning((
"{}: Unexpected character '{}' in chord "
"argument. Continuing anyway.").format(
tex.filename,
token.source,
))
break
return [chord]
else: else:
return super(BeginChordOrDisplayMath, self).invoke(tex) return super(BeginChordOrDisplayMath, self).invoke(tex)

Loading…
Cancel
Save