mirror of
https://github.com/RPCSX/llvm.git
synced 2025-01-24 05:09:34 +00:00
Speculative fix for build failures due to consumeInteger.
A recent patch added support for consumeInteger() and made getAsInteger delegate to this function. A few buildbots are failing as a result with an assertion failure. On a hunch, I tested what happens if I call getAsInteger() on an empty string, and sure enough it crashes the same way that the buildbots are crashing. I confirmed that getAsInteger() on an empty string did not crash before my patch, so I suspect this to be the cause. I also added a unit test for the empty string. git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@282170 91177308-0d34-0410-b5e6-96231b3b80d8
This commit is contained in:
parent
3e55f3d023
commit
20bb0322fd
@ -351,6 +351,9 @@ size_t StringRef::count(StringRef Str) const {
|
||||
}
|
||||
|
||||
static unsigned GetAutoSenseRadix(StringRef &Str) {
|
||||
if (Str.empty())
|
||||
return 10;
|
||||
|
||||
if (Str.startswith("0x") || Str.startswith("0X")) {
|
||||
Str = Str.substr(2);
|
||||
return 16;
|
||||
|
@ -571,7 +571,8 @@ TEST(StringRefTest, getAsInteger) {
|
||||
|
||||
|
||||
static const char* BadStrings[] = {
|
||||
"18446744073709551617" // value just over max
|
||||
"" // empty string
|
||||
, "18446744073709551617" // value just over max
|
||||
, "123456789012345678901" // value way too large
|
||||
, "4t23v" // illegal decimal characters
|
||||
, "0x123W56" // illegal hex characters
|
||||
|
Loading…
x
Reference in New Issue
Block a user