|
@ -5,7 +5,6 @@ import ply.yacc as yacc |
|
|
import re |
|
|
import re |
|
|
|
|
|
|
|
|
from patacrep.songs.syntax import Parser |
|
|
from patacrep.songs.syntax import Parser |
|
|
from patacrep.songs import errors |
|
|
|
|
|
from patacrep.songs.chordpro import ast |
|
|
from patacrep.songs.chordpro import ast |
|
|
from patacrep.songs.chordpro.lexer import tokens, ChordProLexer |
|
|
from patacrep.songs.chordpro.lexer import tokens, ChordProLexer |
|
|
|
|
|
|
|
@ -145,29 +144,24 @@ class ChordproParser(Parser): |
|
|
|
|
|
|
|
|
if match is None: |
|
|
if match is None: |
|
|
if argument.strip(): |
|
|
if argument.strip(): |
|
|
error = errors.SongSyntaxError( |
|
|
self.error( |
|
|
line=symbols.lexer.lineno, |
|
|
line=symbols.lexer.lineno, |
|
|
message="Invalid chord definition '{}'.".format(argument), |
|
|
message="Invalid chord definition '{}'.".format(argument), |
|
|
) |
|
|
) |
|
|
self.error(line=error.line, message=error.message) |
|
|
|
|
|
else: |
|
|
else: |
|
|
error = errors.SongSyntaxError( |
|
|
self.error( |
|
|
line=symbols.lexer.lineno, |
|
|
line=symbols.lexer.lineno, |
|
|
message="Invalid empty chord definition.", |
|
|
message="Invalid empty chord definition.", |
|
|
) |
|
|
) |
|
|
self.error(line=error.line, message=error.message) |
|
|
|
|
|
self._errors.append(error) |
|
|
|
|
|
symbols[0] = ast.Error() |
|
|
symbols[0] = ast.Error() |
|
|
return |
|
|
return |
|
|
|
|
|
|
|
|
define = self._parse_define(match.groupdict()) |
|
|
define = self._parse_define(match.groupdict()) |
|
|
if define is None: |
|
|
if define is None: |
|
|
error = errors.SongSyntaxError( |
|
|
self.error( |
|
|
line=symbols.lexer.lineno, |
|
|
line=symbols.lexer.lineno, |
|
|
message="Invalid chord definition '{}'.".format(argument), |
|
|
message="Invalid chord definition '{}'.".format(argument), |
|
|
) |
|
|
) |
|
|
self.error(line=error.line, message=error.message) |
|
|
|
|
|
self._errors.append(error) |
|
|
|
|
|
symbols[0] = ast.Error() |
|
|
symbols[0] = ast.Error() |
|
|
return |
|
|
return |
|
|
self._directives.append(define) |
|
|
self._directives.append(define) |
|
@ -198,12 +192,10 @@ class ChordproParser(Parser): |
|
|
|
|
|
|
|
|
def p_line_error(self, symbols): |
|
|
def p_line_error(self, symbols): |
|
|
"""line_error : error directive""" |
|
|
"""line_error : error directive""" |
|
|
error = errors.SongSyntaxError( |
|
|
self.error( |
|
|
line=symbols.lexer.lineno, |
|
|
line=symbols.lexer.lineno, |
|
|
message="Directive can only be preceded or followed by spaces", |
|
|
message="Directive can only be preceded or followed by spaces", |
|
|
) |
|
|
) |
|
|
self._errors.append(error) |
|
|
|
|
|
LOGGER.error(error.message) |
|
|
|
|
|
symbols[0] = ast.Line() |
|
|
symbols[0] = ast.Line() |
|
|
|
|
|
|
|
|
@staticmethod |
|
|
@staticmethod |
|
|