Report DSL errors from RulesDsl.makeRules as a DslAggregateException
This commit is contained in:
parent
f930242ee8
commit
0d89711772
core/src
main/java/it/cavallium/warppi/math/rules
test/java/it/cavallium/warppi/math/rules/dsl
@ -21,6 +21,7 @@ import it.cavallium.warppi.math.MathContext;
|
|||||||
import it.cavallium.warppi.math.functions.Expression;
|
import it.cavallium.warppi.math.functions.Expression;
|
||||||
import it.cavallium.warppi.math.functions.Variable;
|
import it.cavallium.warppi.math.functions.Variable;
|
||||||
import it.cavallium.warppi.math.functions.Variable.V_TYPE;
|
import it.cavallium.warppi.math.functions.Variable.V_TYPE;
|
||||||
|
import it.cavallium.warppi.math.rules.dsl.DslAggregateException;
|
||||||
import it.cavallium.warppi.math.rules.dsl.RulesDsl;
|
import it.cavallium.warppi.math.rules.dsl.RulesDsl;
|
||||||
import it.cavallium.warppi.math.solver.MathSolver;
|
import it.cavallium.warppi.math.solver.MathSolver;
|
||||||
import it.cavallium.warppi.util.Error;
|
import it.cavallium.warppi.util.Error;
|
||||||
@ -152,13 +153,13 @@ public class RulesManager {
|
|||||||
if (cacheFileStream != null) {
|
if (cacheFileStream != null) {
|
||||||
cacheFileStream.close();
|
cacheFileStream.close();
|
||||||
}
|
}
|
||||||
} catch (URISyntaxException | IOException | RuntimeException e) {
|
} catch (URISyntaxException | IOException | DslAggregateException e) {
|
||||||
e.printStackTrace();
|
e.printStackTrace();
|
||||||
Engine.getPlatform().exit(1);
|
Engine.getPlatform().exit(1);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
private static void loadDslRules() throws IOException {
|
private static void loadDslRules() throws IOException, DslAggregateException {
|
||||||
final StorageUtils storageUtils = Engine.getPlatform().getStorageUtils();
|
final StorageUtils storageUtils = Engine.getPlatform().getStorageUtils();
|
||||||
|
|
||||||
final File dslRulesPath = storageUtils.get("rules/dsl/");
|
final File dslRulesPath = storageUtils.get("rules/dsl/");
|
||||||
|
@ -0,0 +1,27 @@
|
|||||||
|
package it.cavallium.warppi.math.rules.dsl;
|
||||||
|
|
||||||
|
import java.util.List;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Thrown when processing DSL code which contains one or more errors.
|
||||||
|
*
|
||||||
|
* Contains a list of {@link DslException}s, which should not be empty.
|
||||||
|
*/
|
||||||
|
public class DslAggregateException extends Exception {
|
||||||
|
private final List<DslException> exceptions;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Constructs a <code>DslAggregateException</code> containing the specified list of exceptions.
|
||||||
|
* @param exceptions The list of exceptions. Should not be empty.
|
||||||
|
*/
|
||||||
|
public DslAggregateException(final List<DslException> exceptions) {
|
||||||
|
this.exceptions = exceptions;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @return The list of errors detected in the DSL code.
|
||||||
|
*/
|
||||||
|
public List<DslException> getExceptions() {
|
||||||
|
return exceptions;
|
||||||
|
}
|
||||||
|
}
|
@ -10,7 +10,7 @@ import java.util.*;
|
|||||||
public class RulesDsl {
|
public class RulesDsl {
|
||||||
private RulesDsl() {}
|
private RulesDsl() {}
|
||||||
|
|
||||||
public static List<Rule> makeRules(final String source) {
|
public static List<Rule> makeRules(final String source) throws DslAggregateException {
|
||||||
final List<DslException> errors = new ArrayList<>();
|
final List<DslException> errors = new ArrayList<>();
|
||||||
|
|
||||||
final Lexer lexer = new Lexer(source, errors::add);
|
final Lexer lexer = new Lexer(source, errors::add);
|
||||||
@ -25,7 +25,7 @@ public class RulesDsl {
|
|||||||
}
|
}
|
||||||
|
|
||||||
if (!errors.isEmpty()) {
|
if (!errors.isEmpty()) {
|
||||||
throw new RuntimeException("Errors in DSL source code");
|
throw new DslAggregateException(errors);
|
||||||
}
|
}
|
||||||
|
|
||||||
return Collections.unmodifiableList(rules);
|
return Collections.unmodifiableList(rules);
|
||||||
|
@ -16,7 +16,7 @@ import static org.junit.Assert.*;
|
|||||||
|
|
||||||
public class RulesDslTest {
|
public class RulesDslTest {
|
||||||
@Test
|
@Test
|
||||||
public void validRules() {
|
public void validRules() throws DslAggregateException {
|
||||||
final List<Rule> rules = RulesDsl.makeRules(
|
final List<Rule> rules = RulesDsl.makeRules(
|
||||||
"reduction test1: x -> x\n" +
|
"reduction test1: x -> x\n" +
|
||||||
"expansion test2:\n" +
|
"expansion test2:\n" +
|
||||||
@ -52,18 +52,18 @@ public class RulesDslTest {
|
|||||||
assertEquals(expected, rules);
|
assertEquals(expected, rules);
|
||||||
}
|
}
|
||||||
|
|
||||||
@Test(expected = RuntimeException.class)
|
@Test(expected = DslAggregateException.class)
|
||||||
public void lexerError() {
|
public void lexerError() throws DslAggregateException {
|
||||||
RulesDsl.makeRules("reduction test: 2. 5 -> 1");
|
RulesDsl.makeRules("reduction test: 2. 5 -> 1");
|
||||||
}
|
}
|
||||||
|
|
||||||
@Test(expected = RuntimeException.class)
|
@Test(expected = DslAggregateException.class)
|
||||||
public void parserError() {
|
public void parserError() throws DslAggregateException {
|
||||||
RulesDsl.makeRules("existence test: x + y ->");
|
RulesDsl.makeRules("existence test: x + y ->");
|
||||||
}
|
}
|
||||||
|
|
||||||
@Test(expected = RuntimeException.class)
|
@Test(expected = DslAggregateException.class)
|
||||||
public void undefinedSubFunction() {
|
public void undefinedSubFunction() throws DslAggregateException {
|
||||||
RulesDsl.makeRules("expansion test: x -> x + y");
|
RulesDsl.makeRules("expansion test: x -> x + y");
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
Loading…
x
Reference in New Issue
Block a user