diff options
author | Clark Barrett <barrett@cs.nyu.edu> | 2014-05-26 12:30:13 -0700 |
---|---|---|
committer | Clark Barrett <barrett@cs.nyu.edu> | 2014-05-26 12:30:13 -0700 |
commit | be13964fbff473449d0936c592c5a5cfb3748833 (patch) | |
tree | abdfaa154d02c23a59c5ab3a945fb37c22c30cf9 /src | |
parent | a4ca46db48f8ba450004dd96cce96efbc20b4362 (diff) |
Fixing Tim's subtype/solving bug for arrays
Diffstat (limited to 'src')
-rw-r--r-- | src/theory/arrays/theory_arrays.cpp | 4 |
1 files changed, 2 insertions, 2 deletions
diff --git a/src/theory/arrays/theory_arrays.cpp b/src/theory/arrays/theory_arrays.cpp index 8aad67883..7569b3e93 100644 --- a/src/theory/arrays/theory_arrays.cpp +++ b/src/theory/arrays/theory_arrays.cpp @@ -316,11 +316,11 @@ Theory::PPAssertStatus TheoryArrays::ppAssert(TNode in, SubstitutionMap& outSubs { d_ppFacts.push_back(in); d_ppEqualityEngine.assertEquality(in, true, in); - if (in[0].isVar() && !in[1].hasSubterm(in[0])) { + if (in[0].isVar() && !in[1].hasSubterm(in[0]) && (in[1].getType()).isSubtypeOf(in[0].getType()) ){ outSubstitutions.addSubstitution(in[0], in[1]); return PP_ASSERT_STATUS_SOLVED; } - if (in[1].isVar() && !in[0].hasSubterm(in[1])) { + if (in[1].isVar() && !in[0].hasSubterm(in[1]) && (in[0].getType()).isSubtypeOf(in[1].getType())){ outSubstitutions.addSubstitution(in[1], in[0]); return PP_ASSERT_STATUS_SOLVED; } |