summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorAndrew Reynolds <andrew.j.reynolds@gmail.com>2019-07-23 12:29:58 -0500
committerGitHub <noreply@github.com>2019-07-23 12:29:58 -0500
commit5f384849d20c915374c7b189a232c5d811c186ef (patch)
tree26c830da54c5536cd28462ce4fd274e394b32314
parent2a96d7de381aa565a6eacf724848c0e7839c7cf6 (diff)
Fix sygus datatype parsing in sygus v1 format (#3113)
-rw-r--r--src/parser/smt2/smt2.cpp2
-rw-r--r--test/regress/CMakeLists.txt1
-rw-r--r--test/regress/regress0/sygus/dt-sel-parse1.sy48
3 files changed, 50 insertions, 1 deletions
diff --git a/src/parser/smt2/smt2.cpp b/src/parser/smt2/smt2.cpp
index af374274b..278f2bdfd 100644
--- a/src/parser/smt2/smt2.cpp
+++ b/src/parser/smt2/smt2.cpp
@@ -1088,7 +1088,7 @@ Type Smt2::processSygusNestedGTerm( int sub_dt_index, std::string& sub_dname, st
}
}
Kind sk = sop.getKind() != kind::BUILTIN
- ? kind::APPLY_UF
+ ? getKindForFunction(sop)
: getExprManager()->operatorToKind(sop);
Debug("parser-sygus") << ": operator " << sop << " with " << sop.getKind() << " " << sk << std::endl;
Expr e = getExprManager()->mkExpr( sk, children );
diff --git a/test/regress/CMakeLists.txt b/test/regress/CMakeLists.txt
index 29f31960c..659071fc3 100644
--- a/test/regress/CMakeLists.txt
+++ b/test/regress/CMakeLists.txt
@@ -879,6 +879,7 @@ set(regress_0_tests
regress0/sygus/check-generic-red.sy
regress0/sygus/const-var-test.sy
regress0/sygus/dt-no-syntax.sy
+ regress0/sygus/dt-sel-parse1.sy
regress0/sygus/hd-05-d1-prog-nogrammar.sy
regress0/sygus/inv-different-var-order.sy
regress0/sygus/let-ringer.sy
diff --git a/test/regress/regress0/sygus/dt-sel-parse1.sy b/test/regress/regress0/sygus/dt-sel-parse1.sy
new file mode 100644
index 000000000..52edb3278
--- /dev/null
+++ b/test/regress/regress0/sygus/dt-sel-parse1.sy
@@ -0,0 +1,48 @@
+; COMMAND-LINE: --sygus-out=status
+; EXPECT: unsat
+(set-logic ALL_SUPPORTED)
+
+(declare-datatypes ((IntRange 0))
+ (((IntRange (lower Int) (upper Int)))))
+
+(declare-datatypes ((Loc 0))
+ (((Loc (x Int) (y Int)))))
+
+(declare-datatypes ((LocRange 0))
+ (((LocRange (xD IntRange) (yD IntRange)))))
+
+(declare-datatypes ((Ship 0))
+ (((Ship (shipCapacity Int) (shipLoc Loc)))))
+
+(declare-datatypes ((ShipRange 0))
+ (((ShipRange (shipCapacityD IntRange) (shipLocD LocRange)))))
+
+(define-fun max ((x Int) (y Int)) Int
+ (ite (>= x y) x y)
+)
+
+(define-fun min ((x Int) (y Int)) Int
+ (ite (<= x y) x y)
+)
+
+; provide synthesis template
+(synth-fun f ((secret Ship) (prior ShipRange) (response Bool)) ShipRange
+(
+ (Start ShipRange ((ite B SR SR)))
+ (B Bool (response))
+ (SR ShipRange ((ShipRange IR LR) prior))
+ (IR IntRange ((IntRange I I) (shipCapacityD SR)))
+ (LR LocRange ((LocRange IR IR) (shipLocD SR)))
+ (I Int ((lower IR) (upper IR)
+ (max I (lower (shipCapacityD SR)))
+ (min I I) 50 51))
+ )
+)
+
+(declare-var secret Ship)
+(declare-var prior ShipRange)
+(declare-var response Bool)
+
+(constraint true)
+
+(check-synth)
generated by cgit on debian on lair
contact matthew@masot.net with questions or feedback