diff options
| author | Richard Trieu <rtrieu@google.com> | 2012-07-23 20:24:23 +0000 |
|---|---|---|
| committer | Richard Trieu <rtrieu@google.com> | 2012-07-23 20:24:23 +0000 |
| commit | 1feac1cef9bba99d0832eac9a58084cb90c669d8 (patch) | |
| tree | 29f81c1376bb3172b1d27dbb88f3e13001ab96e3 | |
| parent | c320c745ccd411caa9afa776bf51548b758bf4fe (diff) | |
| download | bcm5719-llvm-1feac1cef9bba99d0832eac9a58084cb90c669d8.tar.gz bcm5719-llvm-1feac1cef9bba99d0832eac9a58084cb90c669d8.zip | |
Add operator== to APSInt. This will compare the signed bit before doing
the comparison. This prevents large unsigned integers from being equal to
signed negative integers of the same bit width.
llvm-svn: 160642
| -rw-r--r-- | llvm/include/llvm/ADT/APSInt.h | 21 |
1 files changed, 20 insertions, 1 deletions
diff --git a/llvm/include/llvm/ADT/APSInt.h b/llvm/include/llvm/ADT/APSInt.h index 807ca5e1927..048c65ce2c7 100644 --- a/llvm/include/llvm/ADT/APSInt.h +++ b/llvm/include/llvm/ADT/APSInt.h @@ -135,6 +135,19 @@ public: assert(IsUnsigned == RHS.IsUnsigned && "Signedness mismatch!"); return IsUnsigned ? uge(RHS) : sge(RHS); } + inline bool operator==(const APSInt& RHS) const { + assert(IsUnsigned == RHS.IsUnsigned && "Signedness mismatch!"); + return eq(RHS); + } + inline bool operator==(int64_t RHS) const { + return isSameValue(*this, APSInt(APInt(64, RHS), true)); + } + inline bool operator!=(const APSInt& RHS) const { + return !((*this) == RHS); + } + inline bool operator!=(int64_t RHS) const { + return !((*this) == RHS); + } // The remaining operators just wrap the logic of APInt, but retain the // signedness information. @@ -282,12 +295,18 @@ public: void Profile(FoldingSetNodeID& ID) const; }; +inline bool operator==(int64_t V1, const APSInt& V2) { + return V2 == V1; +} +inline bool operator!=(int64_t V1, const APSInt& V2) { + return V2 != V1; +} + inline raw_ostream &operator<<(raw_ostream &OS, const APSInt &I) { I.print(OS, I.isSigned()); return OS; } - } // end namespace llvm #endif |

