73 return !(*
this ==
rhs);
119 o <<
cvar.toString();
130template<
class Element>
223 if(
rhs.empty() || (*
this ==
rhs))
242 return ((*
this !=
rhs) ==
false);
281 rawstr << (*i).toString() <<
" ";
446 if(
rit !=
rhs.pointsTo().end())
469 if (
rit ==
rhs.pointsTo().end())
493 const Cond& cond =
it->first;
509 if (
cpts1.pointsTo().empty())
514 else if (
cpts2.pointsTo().empty())
526 if (
cpts2.hasPointsTo(cond))
552 const Cond& cond =
it->first;
554 if (
cpts1.hasPointsTo(cond))
570 else if (
rhs.empty())
580 const Cond& cond =
it->first;
582 if (
rhs.hasPointsTo(cond))
584 if (
pts &=
rhs.pointsTo(cond))
603 return !(*
this ==
rhs);
638 else if (
pointsTo().size() ==
rhs.pointsTo().size())
654 else if (
lpts.count() ==
rpts.count())
664 else if (*bit > *
rbit)
683 return pts.test_and_set(
var.get_id());
690 return pts.test(
var.get_id());
772 return !(*
this ==
RHS);
846template <
typename Cond>
847struct std::hash<const
SVF::CondVar<Cond>>
856template <
typename Cond>
857struct std::hash<
SVF::CondVar<Cond>>
866template <
typename Element>
867struct std::hash<
SVF::CondStdSet<Element>>
874 return h(std::make_pair(*css.
begin(), css.
size()));
Conditional Points-to Set Iterator.
PointsTo::iterator _ptIter
bool operator!=(const CondPtsSetIterator &RHS) const
CondPtsSetIterator(CondPointsToSet< Cond > &n, bool ae=false)
CondPointsToSet< Cond >::CondPtsIter _curIter
CondPointsToSet< Cond >::CondPtsIter _endIter
SingleCondVar operator*(void)
bool operator==(const CondPtsSetIterator &RHS) const
Operator overloading.
PointsTo::iterator _ptEndIter
bool operator&=(const CondPointsToSet< Cond > &rhs)
Overloading operator &=.
CondVar< Cond > SingleCondVar
bool test(const SingleCondVar &var) const
const PointsTo & pointsTo(Cond cond) const
iterator begin()
iterators
CondPointsToSet()
Constructor.
void dump(OutStream &O) const
bool operator<(const CondPointsToSet< Cond > &rhs) const
void intersectWithComplement(const CondPointsToSet< Cond > &cpts1, const CondPointsToSet< Cond > &cpts2)
Result of cpts1 & ~cpts2 is stored into this bitmap.
void intersectWithComplement(const CondPointsToSet< Cond > &cpts1)
Result of cur & ~cpts1 is stored into this bitmap.
CondPointsToSet(const Cond &cond, const PointsTo &pts)
bool operator|=(const CondPointsToSet< Cond > &rhs)
CondPtsSetIterator iterator
bool intersects(const CondPointsToSet< Cond > *rhs) const
Return TRUE if this and RHS share any common element.
unsigned numElement() const
Get number of points-to targets.
CondPtsConstIter cptsEnd() const
CondPts::const_iterator CondPtsConstIter
CondPointsToSet(const CondPointsToSet< Cond > &cptsSet)
Copy constructor.
Map< Cond, PointsTo > CondPts
void set(const SingleCondVar &var)
bool hasPointsTo(Cond cond) const
std::string dumpStr() const
bool operator==(const CondPointsToSet< Cond > &rhs) const
Overloading operator ==.
bool test_and_set(const SingleCondVar &var)
Test and set.
bool empty() const
Return true if no element in the set.
CondPtsIter cptsBegin()
iterators
CondPointsToSet< Cond > & operator=(const CondPointsToSet< Cond > &other)
Overloading operators.
void reset(const SingleCondVar &var)
bool isSubset(const CondPointsToSet< Cond > &rhs) const
Check whether this CondPointsToSet is a subset of RHS.
const CondPts & pointsTo(void) const
CondPtsConstIter cptsBegin() const
CondPts::iterator CondPtsIter
bool operator!=(const CondPointsToSet< Cond > &rhs)
Overloading operator !=.
PointsTo & pointsTo(Cond cond)
CondPts & pointsTo(void)
Get Conditional PointsTo and standard points-to.
bool aliased(const CondPointsToSet< Cond > &rhs) const
bool empty() const
Set size.
bool operator!=(const CondStdSet< Element > &rhs) const
std::string toString() const
void checkAndRemap(void) const
TODO: dummy to use for PointsTo in the various PTData.
bool test_and_set(const Element &var)
Return true if the element is added.
CondStdSet(const CondStdSet< Element > &cptsSet)
Copy constructor.
OrderedSet< Element > ElementSet
CondStdSet< Element > & operator=(const CondStdSet< Element > &rhs)
OrderedSet< Element >::const_iterator const_iterator
bool operator==(const CondStdSet< Element > &rhs) const
bool test(const Element &var) const
Return true if the element is in the set.
OrderedSet< Element >::iterator iterator
void reset(const Element &var)
Remove var from the set.
bool operator|=(const CondStdSet< Element > &rhs)
Overload operators.
bool operator&=(const CondStdSet< Element > &rhs)
const ElementSet & getElementSet() const
bool intersects(const CondStdSet< Element > &rhs) const
bool operator<(const CondStdSet< Element > &rhs) const
iterator begin()
Iterators.
void set(const Element &var)
Add the element into set.
CondVar(const Cond &cond, NodeID id)
Constructor.
std::string toString() const
bool operator!=(const CondVar &rhs) const
bool operator==(const CondVar &rhs) const
friend OutStream & operator<<(OutStream &o, const CondVar< Cond > &cvar)
CondVar()
Default constructor.
CondVar & operator=(const CondVar &rhs)
bool operator<(const CondVar &rhs) const
const Cond & get_cond() const
CondVar(const CondVar &conVar)
Copy constructor.
void clear()
Empty the set.
u32_t count() const
Returns number of elements.
bool intersectWithComplement(const PointsTo &rhs)
void dumpSet(NodeBS To, OutStream &O=SVFUtil::outs())
Dump sparse bitvector set.
std::set< Key, Compare, Allocator > OrderedSet
llvm::IRBuilder IRBuilder
size_t operator()(const SVF::CondStdSet< Element > &css) const
size_t operator()(const SVF::CondVar< Cond > &cv) const
size_t operator()(const SVF::CondVar< Cond > &cv) const