1
0
mirror of https://github.com/AppleCommander/bastools.git synced 2025-01-03 16:32:36 +00:00

Fixing some directive parsing snafus.

This commit is contained in:
Rob Greene 2018-07-13 00:00:12 -05:00
parent 446d06af1d
commit 9dbbfdd663

View File

@ -91,15 +91,20 @@ public abstract class Directive {
* (probably EOL) to prevent loss of information. * (probably EOL) to prevent loss of information.
*/ */
public void append(Token token) { public void append(Token token) {
if (token.type == Type.EOL || (token.type == Type.SYNTAX && ",".equals(token.text))) { if (token.type == Type.EOL) {
String name = requireIdentToken(); while (!paramTokens.isEmpty()) {
if (!parameterNames.contains(name)) { String name = requireIdentToken();
String message = String.format("Parameter '%s' is invalid for %s directive", name, directiveName); if (!parameterNames.contains(name)) {
throw new RuntimeException(message); String message = String.format("Parameter '%s' is invalid for %s directive", name, directiveName);
throw new RuntimeException(message);
}
requireSyntaxToken("=");
Expression expr = buildExpression();
parameters.put(name, expr);
if (!paramTokens.isEmpty()) {
requireSyntaxToken(",");
}
} }
requireSyntaxToken("=");
Expression expr = buildExpression();
parameters.put(name, expr);
} else { } else {
paramTokens.add(token); paramTokens.add(token);
} }
@ -166,6 +171,7 @@ public abstract class Directive {
} }
} }
private boolean checkSyntaxToken(String syntax) { private boolean checkSyntaxToken(String syntax) {
if (paramTokens.isEmpty()) return false;
Type tokenType = ApplesoftKeyword.find(syntax).map(t -> Type.KEYWORD).orElse(Type.SYNTAX); Type tokenType = ApplesoftKeyword.find(syntax).map(t -> Type.KEYWORD).orElse(Type.SYNTAX);
Token token = paramTokens.get(0); Token token = paramTokens.get(0);
return tokenType == token.type && syntax.equals(token.text); return tokenType == token.type && syntax.equals(token.text);