make operator== work with non-equal sized bitvectors, as long as
authorChris Lattner <sabre@nondot.org>
Fri, 12 Oct 2007 03:48:59 +0000 (03:48 +0000)
committerChris Lattner <sabre@nondot.org>
Fri, 12 Oct 2007 03:48:59 +0000 (03:48 +0000)
the extra bits are all zeros.  This allows  "010" and "010000" to be
treated as equal.

git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@42889 91177308-0d34-0410-b5e6-96231b3b80d8

include/llvm/ADT/BitVector.h

index dc408af4ae2ba90535c46a05cb80434c3cc48992..000cdd3d67e34656e9ceec0c8c878b5177018471 100644 (file)
@@ -259,12 +259,23 @@ public:
 
   // Comparison operators.
   bool operator==(const BitVector &RHS) const {
-    if (Size != RHS.Size)
-      return false;
-
-    for (unsigned i = 0; i < NumBitWords(size()); ++i)
+    unsigned ThisWords = NumBitWords(size());
+    unsigned RHSWords  = NumBitWords(RHS.size());
+    unsigned i;
+    for (i = 0; i != std::min(ThisWords, RHSWords); ++i)
       if (Bits[i] != RHS.Bits[i])
         return false;
+    
+    // Verify that any extra words are all zeros.
+    if (i != ThisWords) {
+      for (; i != ThisWords; ++i)
+        if (Bits[i])
+          return false;
+    } else if (i != RHSWords) {
+      for (; i != RHSWords; ++i)
+        if (RHS.Bits[i])
+          return false;
+    }
     return true;
   }