/// A pointer to a uint64_t value, to render as an unsigned decimal
/// integer.
- UDecKind,
+ UDec32Kind,
- /// A pointer to a uint64_t value, to render as an unsigned hexadecimal
+ /// A pointer to a uint64_t value, to render as a signed decimal integer.
+ SDec32Kind,
+
+ /// A pointer to a uint64_t value, to render as an unsigned decimal
/// integer.
- UHexKind,
+ UDec64Kind,
/// A pointer to a uint64_t value, to render as a signed decimal integer.
- SDecKind
+ SDec64Kind,
+
+ /// A pointer to a uint64_t value, to render as an unsigned hexadecimal
+ /// integer.
+ UHexKind
};
private:
assert(isValid() && "Invalid twine!");
}
+ /// Construct a twine to print \arg Val as an unsigned decimal integer.
+ Twine(const uint32_t &Val)
+ : LHS(&Val), LHSKind(UDec32Kind), RHSKind(EmptyKind) {
+ }
+
+ /// Construct a twine to print \arg Val as a signed decimal integer.
+ Twine(const int32_t &Val)
+ : LHS(&Val), LHSKind(SDec32Kind), RHSKind(EmptyKind) {
+ }
+
+ /// Construct a twine to print \arg Val as an unsigned decimal integer.
+ Twine(const uint64_t &Val)
+ : LHS(&Val), LHSKind(UDec64Kind), RHSKind(EmptyKind) {
+ }
+
+ /// Construct a twine to print \arg Val as a signed decimal integer.
+ Twine(const int64_t &Val)
+ : LHS(&Val), LHSKind(SDec64Kind), RHSKind(EmptyKind) {
+ }
+
// FIXME: Unfortunately, to make sure this is as efficient as possible we
// need extra binary constructors from particular types. We can't rely on
// the compiler to be smart enough to fold operator+()/concat() down to the
/// @name Numeric Conversions
/// @{
- /// Construct a twine to print \arg Val as an unsigned decimal integer.
- static Twine utostr(const uint64_t &Val) {
- return Twine(&Val, UDecKind, 0, EmptyKind);
- }
-
- /// Construct a twine to print \arg Val as a signed decimal integer.
- static Twine itostr(const int64_t &Val) {
- return Twine(&Val, SDecKind, 0, EmptyKind);
- }
-
// Construct a twine to print \arg Val as an unsigned hexadecimal integer.
static Twine utohexstr(const uint64_t &Val) {
return Twine(&Val, UHexKind, 0, EmptyKind);
case Twine::StringRefKind:
OS << *static_cast<const StringRef*>(Ptr);
break;
- case Twine::UDecKind:
+ case Twine::UDec32Kind:
+ OS << *static_cast<const uint32_t*>(Ptr);
+ break;
+ case Twine::SDec32Kind:
+ OS << *static_cast<const int32_t*>(Ptr);
+ break;
+ case Twine::UDec64Kind:
OS << *static_cast<const uint64_t*>(Ptr);
break;
- case Twine::SDecKind:
+ case Twine::SDec64Kind:
OS << *static_cast<const int64_t*>(Ptr);
break;
case Twine::UHexKind:
OS << "stringref:\""
<< static_cast<const StringRef*>(Ptr) << "\"";
break;
- case Twine::UDecKind:
- OS << "udec:" << static_cast<const uint64_t*>(Ptr) << "\"";
+ case Twine::UDec32Kind:
+ OS << "udec32:" << static_cast<const uint64_t*>(Ptr) << "\"";
+ break;
+ case Twine::SDec32Kind:
+ OS << "sdec32:" << static_cast<const int64_t*>(Ptr) << "\"";
+ break;
+ case Twine::UDec64Kind:
+ OS << "udec64:" << static_cast<const uint64_t*>(Ptr) << "\"";
break;
- case Twine::SDecKind:
- OS << "sdec:" << static_cast<const int64_t*>(Ptr) << "\"";
+ case Twine::SDec64Kind:
+ OS << "sdec64:" << static_cast<const int64_t*>(Ptr) << "\"";
break;
case Twine::UHexKind:
OS << "uhex:" << static_cast<const uint64_t*>(Ptr) << "\"";
}
TEST(TwineTest, Numbers) {
- EXPECT_EQ("123", Twine::utostr(123).str());
- EXPECT_EQ("-123", Twine::itostr(-123).str());
- EXPECT_EQ("123", Twine::utostr(123).str());
- EXPECT_EQ("-123", Twine::itostr(-123).str());
- EXPECT_EQ("123", Twine::utostr((char) 123).str());
- EXPECT_EQ("-123", Twine::itostr((signed char) -123).str());
+ EXPECT_EQ("123", Twine(123U).str());
+ EXPECT_EQ("123", Twine(123).str());
+ EXPECT_EQ("-123", Twine(-123).str());
+ EXPECT_EQ("123", Twine(123).str());
+ EXPECT_EQ("-123", Twine(-123).str());
+ EXPECT_EQ("123", Twine((char) 123).str());
+ EXPECT_EQ("-123", Twine((signed char) -123).str());
EXPECT_EQ("7B", Twine::utohexstr(123).str());
EXPECT_EQ("FFFFFFFFFFFFFF85", Twine::itohexstr(-123).str());