/*
* RTLAssume.java - This file is part of the Jakstab project.
* Copyright 2007-2015 Johannes Kinder <jk@jakstab.org>
*
* This code is free software; you can redistribute it and/or modify it
* under the terms of the GNU General Public License version 2 only, as
* published by the Free Software Foundation.
*
* This code is distributed in the hope that it will be useful, but WITHOUT
* ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
* FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License
* version 2 for more details (a copy is included in the LICENSE file that
* accompanied this code).
*
* You should have received a copy of the GNU General Public License version
* 2 along with this work; if not, see <http://www.gnu.org/licenses/>.
*/
package org.jakstab.rtl.statements;
import java.util.Set;
import org.jakstab.rtl.Context;
import org.jakstab.rtl.expressions.*;
import org.jakstab.util.Logger;
/**
* Assumptions are generated during control flow reconstruction and encode conditions for
* control flow branches.
*
* @author Johannes Kinder
*/
public class RTLAssume extends AbstractRTLStatement implements RTLStatement {
@SuppressWarnings("unused")
private static final Logger logger = Logger.getLogger(RTLAssume.class);
private RTLExpression assumption;
private RTLGoto source;
/**
* @param assumption
*/
public RTLAssume(RTLExpression assumption, RTLGoto source) {
super();
this.assumption = assumption;
this.source = source;
}
@Override
protected SetOfVariables initDefinedVariables() {
return SetOfVariables.EMPTY_SET;
}
@Override
protected Set<RTLMemoryLocation> initUsedMemoryLocations() {
return assumption.getUsedMemoryLocations();
}
@Override
protected SetOfVariables initUsedVariables() {
return assumption.getUsedVariables();
}
public RTLExpression getAssumption() {
return assumption;
}
@Override
public <T> T accept(StatementVisitor<T> visitor) {
return visitor.visit(this);
}
@Override
public RTLStatement evaluate(Context context) {
invalidateCache();
assumption = assumption.evaluate(context);
ExpressionSimplifier simplifier = ExpressionSimplifier.getInstance();
assumption = simplifier.simplify(assumption);
/*if (assumption.equals(ExpressionFactory.getInstance().TRUE))
return null;*/
return this;
}
@Override
public String toString() {
return "assume " + assumption.toString();
}
public RTLGoto getSource() {
return source;
}
public boolean isCall() {
if (source == null)
return false;
return RTLGoto.Type.CALL.equals(source.getType());
}
public boolean isReturn() {
if (source == null)
return false;
return RTLGoto.Type.RETURN.equals(source.getType());
}
@Override
public int hashCode() {
final int prime = 31;
int result = super.hashCode();
result = prime * result
+ ((assumption == null) ? 0 : assumption.hashCode());
result = prime * result + ((source == null) ? 0 : source.hashCode());
return result;
}
@Override
public boolean equals(Object obj) {
if (this == obj)
return true;
if (!super.equals(obj))
return false;
if (getClass() != obj.getClass())
return false;
RTLAssume other = (RTLAssume) obj;
if (assumption == null) {
if (other.assumption != null)
return false;
} else if (!assumption.equals(other.assumption))
return false;
if (source == null) {
if (other.source != null)
return false;
} else if (!source.equals(other.source))
return false;
return true;
}
}