diff options
Diffstat (limited to 'llvm/lib/Support/APInt.cpp')
| -rw-r--r-- | llvm/lib/Support/APInt.cpp | 26 | 
1 files changed, 11 insertions, 15 deletions
| diff --git a/llvm/lib/Support/APInt.cpp b/llvm/lib/Support/APInt.cpp index f74178b1ba4e..afe7478a8b2a 100644 --- a/llvm/lib/Support/APInt.cpp +++ b/llvm/lib/Support/APInt.cpp @@ -15,7 +15,6 @@  #include "llvm/ADT/ArrayRef.h"  #include "llvm/ADT/FoldingSet.h"  #include "llvm/ADT/Hashing.h" -#include "llvm/ADT/Optional.h"  #include "llvm/ADT/SmallString.h"  #include "llvm/ADT/StringRef.h"  #include "llvm/ADT/bit.h" @@ -25,7 +24,8 @@  #include "llvm/Support/MathExtras.h"  #include "llvm/Support/raw_ostream.h"  #include <cmath> -#include <cstring> +#include <optional> +  using namespace llvm;  #define DEBUG_TYPE "apint" @@ -108,7 +108,7 @@ APInt::APInt(unsigned numBits, ArrayRef<uint64_t> bigVal) : BitWidth(numBits) {  APInt::APInt(unsigned numBits, unsigned numWords, const uint64_t bigVal[])      : BitWidth(numBits) { -  initFromArray(makeArrayRef(bigVal, numWords)); +  initFromArray(ArrayRef(bigVal, numWords));  }  APInt::APInt(unsigned numbits, StringRef Str, uint8_t radix) @@ -459,7 +459,7 @@ APInt APInt::extractBits(unsigned numBits, unsigned bitPosition) const {    // Extracting bits that start on a source word boundary can be done    // as a fast memory copy.    if (loBit == 0) -    return APInt(numBits, makeArrayRef(U.pVal + loWord, 1 + hiWord - loWord)); +    return APInt(numBits, ArrayRef(U.pVal + loWord, 1 + hiWord - loWord));    // General case - shift + copy source words directly into place.    APInt Result(numBits, 0); @@ -684,7 +684,7 @@ unsigned APInt::countTrailingOnesSlowCase() const {  unsigned APInt::countPopulationSlowCase() const {    unsigned Count = 0;    for (unsigned i = 0; i < getNumWords(); ++i) -    Count += llvm::countPopulation(U.pVal[i]); +    Count += llvm::popcount(U.pVal[i]);    return Count;  } @@ -2292,15 +2292,11 @@ static inline APInt::WordType highHalf(APInt::WordType part) {  /// Returns the bit number of the most significant set bit of a part.  /// If the input number has no bits set -1U is returned. -static unsigned partMSB(APInt::WordType value) { -  return findLastSet(value, ZB_Max); -} +static unsigned partMSB(APInt::WordType value) { return findLastSet(value); }  /// Returns the bit number of the least significant set bit of a part.  If the  /// input number has no bits set -1U is returned. -static unsigned partLSB(APInt::WordType value) { -  return findFirstSet(value, ZB_Max); -} +static unsigned partLSB(APInt::WordType value) { return findFirstSet(value); }  /// Sets the least significant part of a bignum to the input value, and zeroes  /// out higher parts. @@ -2770,7 +2766,7 @@ APInt llvm::APIntOps::RoundingSDiv(const APInt &A, const APInt &B,    llvm_unreachable("Unknown APInt::Rounding enum");  } -Optional<APInt> +std::optional<APInt>  llvm::APIntOps::SolveQuadraticEquationWrap(APInt A, APInt B, APInt C,                                             unsigned RangeWidth) {    unsigned CoeffWidth = A.getBitWidth(); @@ -2952,7 +2948,7 @@ llvm::APIntOps::SolveQuadraticEquationWrap(APInt A, APInt B, APInt C,    // between them, so they would both be contained between X and X+1.    if (!SignChange) {      LLVM_DEBUG(dbgs() << __func__ << ": no valid solution\n"); -    return None; +    return std::nullopt;    }    X += 1; @@ -2960,11 +2956,11 @@ llvm::APIntOps::SolveQuadraticEquationWrap(APInt A, APInt B, APInt C,    return X;  } -Optional<unsigned> +std::optional<unsigned>  llvm::APIntOps::GetMostSignificantDifferentBit(const APInt &A, const APInt &B) {    assert(A.getBitWidth() == B.getBitWidth() && "Must have the same bitwidth");    if (A == B) -    return llvm::None; +    return std::nullopt;    return A.getBitWidth() - ((A ^ B).countLeadingZeros() + 1);  } | 
