Browse Source

Improvement of chord parsing: \[

closes #52
pull/58/head
Louis 11 years ago
parent
commit
af9c395079
  1. 25
      patacrep/plastex_chord.py

25
patacrep/plastex_chord.py

@ -67,15 +67,6 @@ class Chord(Command):
macroName = 'chord' macroName = 'chord'
macroMode = Command.MODE_NONE macroMode = Command.MODE_NONE
def __init__(self, *args, **kwargs):
super(Chord, self).__init__(*args, **kwargs)
self.chord = ""
@property
def source(self):
"""Return chord LaTeX code."""
return ur'\[{}]'.format(self.chord)
class BeginChordOrDisplayMath(BeginDisplayMath): class BeginChordOrDisplayMath(BeginDisplayMath):
r"""Wrapper to BeginDisplayMath r"""Wrapper to BeginDisplayMath
@ -91,22 +82,14 @@ class BeginChordOrDisplayMath(BeginDisplayMath):
if IN_VERSE: if IN_VERSE:
chord = Chord() chord = Chord()
self.ownerDocument.context.push()
self.ownerDocument.context.catcode("&", 13)
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 == ']':
self.ownerDocument.context.pop()
break break
else: else:
if token.nodeName == '#text': chord.appendChild(token)
chord.chord += str(token)
elif token.nodeName == "active::&":
chord.chord += '&'
else:
LOGGER.warning((
"{}: Unexpected character '{}' in chord "
"argument. Continuing anyway.").format(
tex.filename,
token.source,
))
break
return [chord] return [chord]
else: else:

Loading…
Cancel
Save