com.ibm.wala.dataflow.graph.BitVectorKillGen Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of com.ibm.wala.util Show documentation
Show all versions of com.ibm.wala.util Show documentation
T. J. Watson Libraries for Analysis
/*
* Copyright (c) 2002 - 2006 IBM Corporation.
* All rights reserved. This program and the accompanying materials
* are made available under the terms of the Eclipse Public License v1.0
* which accompanies this distribution, and is available at
* http://www.eclipse.org/legal/epl-v10.html
*
* Contributors:
* IBM Corporation - initial API and implementation
*/
package com.ibm.wala.dataflow.graph;
import com.ibm.wala.fixpoint.BitVectorVariable;
import com.ibm.wala.fixpoint.UnaryOperator;
import com.ibm.wala.util.intset.BitVector;
import com.ibm.wala.util.intset.BitVectorIntSet;
import org.jspecify.annotations.Nullable;
/** Operator OUT = (IN - kill) U gen */
public class BitVectorKillGen extends UnaryOperator {
private final BitVectorIntSet kill;
private final BitVectorIntSet gen;
public BitVectorKillGen(BitVector kill, BitVector gen) {
if (kill == null) {
throw new IllegalArgumentException("null kill");
}
if (gen == null) {
throw new IllegalArgumentException("null gen");
}
this.kill = new BitVectorIntSet(kill);
this.gen = new BitVectorIntSet(gen);
}
@Override
public byte evaluate(@Nullable BitVectorVariable lhs, BitVectorVariable rhs)
throws IllegalArgumentException {
if (rhs == null) {
throw new IllegalArgumentException("rhs == null");
}
if (lhs == null) {
throw new IllegalArgumentException("lhs == null");
}
BitVectorVariable U = new BitVectorVariable();
BitVectorIntSet bv = new BitVectorIntSet();
if (rhs.getValue() != null) {
bv.addAll(rhs.getValue());
}
bv.removeAll(kill);
bv.addAll(gen);
U.addAll(bv.getBitVector());
if (!lhs.sameValue(U)) {
lhs.copyState(U);
return CHANGED;
} else {
return NOT_CHANGED;
}
}
@Override
public String toString() {
return "GenKill";
}
@Override
public int hashCode() {
return 9901 * kill.hashCode() + 1213 * gen.hashCode();
}
@Override
public boolean equals(Object o) {
if (o instanceof BitVectorKillGen) {
BitVectorKillGen other = (BitVectorKillGen) o;
return kill.sameValue(other.kill) && gen.sameValue(other.gen);
} else {
return false;
}
}
}