Skip to content
Open
Show file tree
Hide file tree
Changes from all commits
Commits
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
Original file line number Diff line number Diff line change
Expand Up @@ -75,7 +75,8 @@ private Optional<Substitution> findSubstitution(VCImplication implication) {
if (implication == null)
return Optional.empty();

Optional<Substitution> current = getSubstitution(implication);
Optional<Substitution> current = containsVar(implication.getNext(), implication.getName())
? getSubstitution(implication) : Optional.empty();
if (current.isPresent())
return current;

Expand Down Expand Up @@ -120,4 +121,15 @@ private boolean containsVar(Expression expression, String name) {
expression.getVariableNames(names);
return names.contains(name);
}

/**
* Checks whether a VC suffix contains a variable name
*/
private boolean containsVar(VCImplication implication, String name) {
for (VCImplication current = implication; current != null; current = current.getNext()) {
if (containsVar(current.getRefinement().getExpression(), name))
return true;
}
return false;
}
}
Original file line number Diff line number Diff line change
Expand Up @@ -53,10 +53,17 @@ void preservesRemainingBinderAfterSubstitution() {
}

@Test
void removesSourceNodeWhenItIsLastInChain() {
void keepsSourceNodeWhenItIsLastInChain() {
VCImplication implication = vc("x > 0", "∀y:int. y == 1");

assertSimplificationSteps(substitution::apply, implication, chain(expect("x > 0")));
assertSimplificationSteps(substitution::apply, implication, chain(expect("x > 0"), expect("y == 1")));
}

@Test
void keepsReturnBinderWhenConclusionIsSeparate() {
VCImplication implication = vc("∀x:int. true", "∀#ret_8:int. #ret_8 == x + 1");

assertSimplificationSteps(substitution::apply, implication, chain(expect("true"), expect("#ret⁸ == x + 1")));
}

@Test
Expand Down
Loading