diff options
author | Andrew Reynolds <andrew.j.reynolds@gmail.com> | 2020-06-05 17:57:25 -0500 |
---|---|---|
committer | GitHub <noreply@github.com> | 2020-06-05 17:57:25 -0500 |
commit | c8015e6dc858a3fd13234ec4acb22c80cb339ddc (patch) | |
tree | 0a5e7c4fc112f3753eae8dc8e6283933373aa840 /src/api/cvc4cpp.h | |
parent | 5c4b9e1a6ffa97a0a1f8af41069f29764eb6c74b (diff) |
Datatypes with nested recursion are not handled in TheoryDatatypes unless option is set (#3707)
Towards experimental support for non-simply recursive datatypes (https://github.com/ajreynol/CVC4/tree/dtNonSimpleRec). Builds a check for non-simple recursion in the DType class. If a term of a datatype type is registered to TheoryDatatypes for a datatype that has nested recursion, we throw a LogicException unless the option dtNestedRec is set to true. Also includes a bug discovered in the TypeMatcher utility and another in expr::getComponentTypes.
It also adds a unit test using the new API for a simple parametric datatype example as well, not related to nested recursion, as this was previously missing.
Diffstat (limited to 'src/api/cvc4cpp.h')
-rw-r--r-- | src/api/cvc4cpp.h | 11 |
1 files changed, 11 insertions, 0 deletions
diff --git a/src/api/cvc4cpp.h b/src/api/cvc4cpp.h index 73e3ed856..adf3691ab 100644 --- a/src/api/cvc4cpp.h +++ b/src/api/cvc4cpp.h @@ -1673,6 +1673,17 @@ class CVC4_PUBLIC Datatype bool isWellFounded() const; /** + * Does this datatype have nested recursion? This method returns false if a + * value of this datatype includes a subterm of its type that is nested + * beneath a non-datatype type constructor. For example, a datatype + * T containing a constructor having a selector with range type (Set T) has + * nested recursion. + * + * @return true if this datatype has nested recursion + */ + bool hasNestedRecursion() const; + + /** * @return a string representation of this datatype */ std::string toString() const; |