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:
parent
446d06af1d
commit
9dbbfdd663
@ -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);
|
||||||
|
Loading…
Reference in New Issue
Block a user