Revert "[APSInt] Fix bug in APSInt mentioned in https://github.com/llvm/llvm-project...
authorPeter Rong <PeterRong96@gmail.com>
Sun, 18 Dec 2022 22:01:08 +0000 (14:01 -0800)
committerPeter Rong <PeterRong96@gmail.com>
Sun, 18 Dec 2022 22:05:17 +0000 (14:05 -0800)
This reverts commit 7859d6e79ca90df2f3f206192a1dfa89e3cb10f1.

Signed-off-by: Peter Rong <PeterRong96@gmail.com>
llvm/include/llvm/ADT/APSInt.h
llvm/unittests/ADT/APSIntTest.cpp

index 90b9888..c64cf30 100644 (file)
@@ -85,26 +85,12 @@ public:
   }
   using APInt::toString;
 
-  /// If this int is representable using an int64_t.
-  bool isRepresentableByInt64() const {
-    // For unsigned values with 64 active bits, they technically fit into a
-    // int64_t, but the user may get negative numbers and has to manually cast
-    // them to unsigned. Let's not bet the user has the sanity to do that and
-    // not give them a vague value at the first place.
-    return isSigned() ? isSignedIntN(64) : isIntN(63);
-  }
-
   /// Get the correctly-extended \c int64_t value.
   int64_t getExtValue() const {
-    assert(isRepresentableByInt64() && "Too many bits for int64_t");
+    assert(getMinSignedBits() <= 64 && "Too many bits for int64_t");
     return isSigned() ? getSExtValue() : getZExtValue();
   }
 
-  std::optional<int64_t> tryExtValue() const {
-    return isRepresentableByInt64() ? std::optional<int64_t>(getExtValue())
-                                    : std::nullopt;
-  }
-
   APSInt trunc(uint32_t width) const {
     return APSInt(APInt::trunc(width), IsUnsigned);
   }
index f804eba..932f54c 100644 (file)
@@ -62,13 +62,6 @@ TEST(APSIntTest, getUnsigned) {
   EXPECT_EQ(UINT64_C(0) - 7, APSInt::getUnsigned(-7).getZExtValue());
 }
 
-TEST(APSIntTest, isRepresentableByInt64) {
-  ASSERT_TRUE(APSInt(APInt(3, 7), true).isRepresentableByInt64());
-  ASSERT_TRUE(APSInt(APInt(128, 7), true).isRepresentableByInt64());
-  ASSERT_TRUE(APSInt(APInt(128, 7), false).isRepresentableByInt64());
-  ASSERT_TRUE(APSInt(APInt(64, -1), false).isRepresentableByInt64());
-  ASSERT_FALSE(APSInt(APInt(64, (uint64_t)-1), true).isRepresentableByInt64());
-}
 TEST(APSIntTest, getExtValue) {
   EXPECT_TRUE(APSInt(APInt(3, 7), true).isUnsigned());
   EXPECT_TRUE(APSInt(APInt(3, 7), false).isSigned());
@@ -83,16 +76,6 @@ TEST(APSIntTest, getExtValue) {
   EXPECT_EQ(9, APSInt(APInt(4, -7), true).getExtValue());
   EXPECT_EQ(-7, APSInt(APInt(4, -7), false).getExtValue());
 }
-TEST(APSIntTest, tryExtValue) {
-  ASSERT_EQ(-7, APSInt(APInt(64, -7), false).tryExtValue().value_or(42));
-  ASSERT_EQ(42, APSInt(APInt(128, -7), false).tryExtValue().value_or(42));
-  ASSERT_EQ(-1,
-            APSInt(APInt::getAllOnes(128), false).tryExtValue().value_or(42));
-  ASSERT_EQ(42, APSInt(APInt(64, -7), true).tryExtValue().value_or(42));
-  ASSERT_EQ(1, APSInt(APInt(128, 1), true).tryExtValue().value_or(42));
-  ASSERT_EQ(42,
-            APSInt(APInt::getAllOnes(128), true).tryExtValue().value_or(42));
-}
 
 TEST(APSIntTest, compareValues) {
   auto U = [](uint64_t V) { return APSInt::getUnsigned(V); };