diff options
Diffstat (limited to 'lib/Analysis/DataStructure/DataStructure.cpp')
-rw-r--r-- | lib/Analysis/DataStructure/DataStructure.cpp | 22 |
1 files changed, 22 insertions, 0 deletions
diff --git a/lib/Analysis/DataStructure/DataStructure.cpp b/lib/Analysis/DataStructure/DataStructure.cpp index d90d84a06b..13d3dce174 100644 --- a/lib/Analysis/DataStructure/DataStructure.cpp +++ b/lib/Analysis/DataStructure/DataStructure.cpp @@ -90,6 +90,28 @@ const PointerValSet &PointerValSet::operator=(const PointerValSet &PVS) { return *this; } +// operator< - Allow insertion into a map... +bool PointerValSet::operator<(const PointerValSet &PVS) const { + if (Vals.size() < PVS.Vals.size()) return true; + if (Vals.size() > PVS.Vals.size()) return false; + if (Vals.size() == 1) return Vals[0] < PVS.Vals[0]; // Most common case + + vector<PointerVal> S1(Vals), S2(PVS.Vals); + sort(S1.begin(), S1.end()); + sort(S2.begin(), S2.end()); + return S1 < S2; +} + +bool PointerValSet::operator==(const PointerValSet &PVS) const { + if (Vals.size() != PVS.Vals.size()) return false; + if (Vals.size() == 1) return Vals[0] == PVS.Vals[0]; // Most common case... + + vector<PointerVal> S1(Vals), S2(PVS.Vals); + sort(S1.begin(), S1.end()); + sort(S2.begin(), S2.end()); + return S1 == S2; +} + bool PointerValSet::add(const PointerVal &PV, Value *Pointer) { if (std::find(Vals.begin(), Vals.end(), PV) != Vals.end()) |