diff options
author | Lauro Ramos Venancio <lauro.venancio@gmail.com> | 2008-01-28 18:23:23 +0000 |
---|---|---|
committer | Lauro Ramos Venancio <lauro.venancio@gmail.com> | 2008-01-28 18:23:23 +0000 |
commit | 3445904638e63a7b77a7d8198a196a5933dec35f (patch) | |
tree | a2aa7277df63e6f280810fc0baa7be24e98f1525 /lib/Support | |
parent | 3fc88d34c4433e95705ea62d5626c873115e644f (diff) | |
download | external_llvm-3445904638e63a7b77a7d8198a196a5933dec35f.zip external_llvm-3445904638e63a7b77a7d8198a196a5933dec35f.tar.gz external_llvm-3445904638e63a7b77a7d8198a196a5933dec35f.tar.bz2 |
Fix fpcmp infinite loop when comparing "29-266" with "29-268".
git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@46455 91177308-0d34-0410-b5e6-96231b3b80d8
Diffstat (limited to 'lib/Support')
-rw-r--r-- | lib/Support/FileUtilities.cpp | 26 |
1 files changed, 21 insertions, 5 deletions
diff --git a/lib/Support/FileUtilities.cpp b/lib/Support/FileUtilities.cpp index eff6fc9..30463e8 100644 --- a/lib/Support/FileUtilities.cpp +++ b/lib/Support/FileUtilities.cpp @@ -20,11 +20,15 @@ #include <cctype> using namespace llvm; -static bool isNumberChar(char C) { +static bool isSignedChar(char C) { + if (C == '+' || C == '-') + return true; + else + return false; +} + +static bool isExpoentChar(char C) { switch (C) { - case '0': case '1': case '2': case '3': case '4': - case '5': case '6': case '7': case '8': case '9': - case '.': case '+': case '-': case 'D': // Strange exponential notation. case 'd': // Strange exponential notation. case 'e': @@ -33,13 +37,25 @@ static bool isNumberChar(char C) { } } +static bool isNumberChar(char C) { + switch (C) { + case '0': case '1': case '2': case '3': case '4': + case '5': case '6': case '7': case '8': case '9': + case '.': return true; + default: return isSignedChar(C) || isExpoentChar(C); + } +} + static char *BackupNumber(char *Pos, char *FirstChar) { // If we didn't stop in the middle of a number, don't backup. if (!isNumberChar(*Pos)) return Pos; // Otherwise, return to the start of the number. - while (Pos > FirstChar && isNumberChar(Pos[-1])) + while (Pos > FirstChar && isNumberChar(Pos[-1])) { --Pos; + if (Pos > FirstChar && isSignedChar(Pos[0]) && !isExpoentChar(Pos[-1])) + break; + } return Pos; } |