mirror of
https://github.com/AdaCore/cvc5.git
synced 2026-02-12 12:32:16 -08:00
Enable CI for Junit tests (#7436)
This PR enables CI for java tests by adding --java-bindings to ci.yml. It also replaces the unreliable finalize method and instead uses AutoCloseable and explicit close method to clean up dynamic memory allocated by java native interface. The PR fixes compile errors for SolverTest.java and runtime errors for Solver.defineFun.
This commit is contained in:
@@ -21,71 +21,73 @@ public class Strings
|
||||
{
|
||||
public static void main(String args[]) throws CVC5ApiException
|
||||
{
|
||||
Solver slv = new Solver();
|
||||
|
||||
// Set the logic
|
||||
slv.setLogic("QF_SLIA");
|
||||
// Produce models
|
||||
slv.setOption("produce-models", "true");
|
||||
// The option strings-exp is needed
|
||||
slv.setOption("strings-exp", "true");
|
||||
// Set output language to SMTLIB2
|
||||
slv.setOption("output-language", "smt2");
|
||||
|
||||
// String type
|
||||
Sort string = slv.getStringSort();
|
||||
|
||||
// std::string
|
||||
String str_ab = "ab";
|
||||
// String constants
|
||||
Term ab = slv.mkString(str_ab);
|
||||
Term abc = slv.mkString("abc");
|
||||
// String variables
|
||||
Term x = slv.mkConst(string, "x");
|
||||
Term y = slv.mkConst(string, "y");
|
||||
Term z = slv.mkConst(string, "z");
|
||||
|
||||
// String concatenation: x.ab.y
|
||||
Term lhs = slv.mkTerm(STRING_CONCAT, x, ab, y);
|
||||
// String concatenation: abc.z
|
||||
Term rhs = slv.mkTerm(STRING_CONCAT, abc, z);
|
||||
// x.ab.y = abc.z
|
||||
Term formula1 = slv.mkTerm(EQUAL, lhs, rhs);
|
||||
|
||||
// Length of y: |y|
|
||||
Term leny = slv.mkTerm(STRING_LENGTH, y);
|
||||
// |y| >= 0
|
||||
Term formula2 = slv.mkTerm(GEQ, leny, slv.mkInteger(0));
|
||||
|
||||
// Regular expression: (ab[c-e]*f)|g|h
|
||||
Term r = slv.mkTerm(REGEXP_UNION,
|
||||
slv.mkTerm(REGEXP_CONCAT,
|
||||
slv.mkTerm(STRING_TO_REGEXP, slv.mkString("ab")),
|
||||
slv.mkTerm(REGEXP_STAR, slv.mkTerm(REGEXP_RANGE, slv.mkString("c"), slv.mkString("e"))),
|
||||
slv.mkTerm(STRING_TO_REGEXP, slv.mkString("f"))),
|
||||
slv.mkTerm(STRING_TO_REGEXP, slv.mkString("g")),
|
||||
slv.mkTerm(STRING_TO_REGEXP, slv.mkString("h")));
|
||||
|
||||
// String variables
|
||||
Term s1 = slv.mkConst(string, "s1");
|
||||
Term s2 = slv.mkConst(string, "s2");
|
||||
// String concatenation: s1.s2
|
||||
Term s = slv.mkTerm(STRING_CONCAT, s1, s2);
|
||||
|
||||
// s1.s2 in (ab[c-e]*f)|g|h
|
||||
Term formula3 = slv.mkTerm(STRING_IN_REGEXP, s, r);
|
||||
|
||||
// Make a query
|
||||
Term q = slv.mkTerm(AND, formula1, formula2, formula3);
|
||||
|
||||
// check sat
|
||||
Result result = slv.checkSatAssuming(q);
|
||||
System.out.println("cvc5 reports: " + q + " is " + result + ".");
|
||||
|
||||
if (result.isSat())
|
||||
try (Solver slv = new Solver())
|
||||
{
|
||||
System.out.println(" x = " + slv.getValue(x));
|
||||
System.out.println(" s1.s2 = " + slv.getValue(s));
|
||||
// Set the logic
|
||||
slv.setLogic("QF_SLIA");
|
||||
// Produce models
|
||||
slv.setOption("produce-models", "true");
|
||||
// The option strings-exp is needed
|
||||
slv.setOption("strings-exp", "true");
|
||||
// Set output language to SMTLIB2
|
||||
slv.setOption("output-language", "smt2");
|
||||
|
||||
// String type
|
||||
Sort string = slv.getStringSort();
|
||||
|
||||
// std::string
|
||||
String str_ab = "ab";
|
||||
// String constants
|
||||
Term ab = slv.mkString(str_ab);
|
||||
Term abc = slv.mkString("abc");
|
||||
// String variables
|
||||
Term x = slv.mkConst(string, "x");
|
||||
Term y = slv.mkConst(string, "y");
|
||||
Term z = slv.mkConst(string, "z");
|
||||
|
||||
// String concatenation: x.ab.y
|
||||
Term lhs = slv.mkTerm(STRING_CONCAT, x, ab, y);
|
||||
// String concatenation: abc.z
|
||||
Term rhs = slv.mkTerm(STRING_CONCAT, abc, z);
|
||||
// x.ab.y = abc.z
|
||||
Term formula1 = slv.mkTerm(EQUAL, lhs, rhs);
|
||||
|
||||
// Length of y: |y|
|
||||
Term leny = slv.mkTerm(STRING_LENGTH, y);
|
||||
// |y| >= 0
|
||||
Term formula2 = slv.mkTerm(GEQ, leny, slv.mkInteger(0));
|
||||
|
||||
// Regular expression: (ab[c-e]*f)|g|h
|
||||
Term r = slv.mkTerm(REGEXP_UNION,
|
||||
slv.mkTerm(REGEXP_CONCAT,
|
||||
slv.mkTerm(STRING_TO_REGEXP, slv.mkString("ab")),
|
||||
slv.mkTerm(
|
||||
REGEXP_STAR, slv.mkTerm(REGEXP_RANGE, slv.mkString("c"), slv.mkString("e"))),
|
||||
slv.mkTerm(STRING_TO_REGEXP, slv.mkString("f"))),
|
||||
slv.mkTerm(STRING_TO_REGEXP, slv.mkString("g")),
|
||||
slv.mkTerm(STRING_TO_REGEXP, slv.mkString("h")));
|
||||
|
||||
// String variables
|
||||
Term s1 = slv.mkConst(string, "s1");
|
||||
Term s2 = slv.mkConst(string, "s2");
|
||||
// String concatenation: s1.s2
|
||||
Term s = slv.mkTerm(STRING_CONCAT, s1, s2);
|
||||
|
||||
// s1.s2 in (ab[c-e]*f)|g|h
|
||||
Term formula3 = slv.mkTerm(STRING_IN_REGEXP, s, r);
|
||||
|
||||
// Make a query
|
||||
Term q = slv.mkTerm(AND, formula1, formula2, formula3);
|
||||
|
||||
// check sat
|
||||
Result result = slv.checkSatAssuming(q);
|
||||
System.out.println("cvc5 reports: " + q + " is " + result + ".");
|
||||
|
||||
if (result.isSat())
|
||||
{
|
||||
System.out.println(" x = " + slv.getValue(x));
|
||||
System.out.println(" s1.s2 = " + slv.getValue(s));
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
Reference in New Issue
Block a user