[cfe-commits] r157445 - /cfe/trunk/lib/Frontend/TextDiagnostic.cpp
Marshall Clow
mclow.lists at gmail.com
Thu May 24 17:50:00 PDT 2012
On May 24, 2012, at 5:03 PM, Seth Cantrell wrote:
> Author: socantre
> Date: Thu May 24 19:03:29 2012
> New Revision: 157445
>
> URL: http://llvm.org/viewvc/llvm-project?rev=157445&view=rev
> Log:
> ensure value passed to is space is representable as unsigned char
Note that in C++ you can use the current facet which has a templated isspace function, so you don't have to use the C 'isspace'. (with all its' limitations)
namespace std {
template <class charT> bool isspace (charT c, const locale& loc);
};
and you can get a copy of the current locale using std::locale ()
Example program:
#include <iostream>
#include <locale>
int main(int argc, char *argv[] ) {
const char *p = argv[1];
std::locale loc = std::locale (); // copy of current locale
while (*p) {
if ( std::isspace (*p, loc))
std::cout << '*';
else
std::cout << *p;
p++;
}
std::cout << std::endl;
return 0;
}
>
> if the value isn't an unsigned char or EOF behavior is undefined
> (and on Windows there's an assertion)
>
> Modified:
> cfe/trunk/lib/Frontend/TextDiagnostic.cpp
>
> Modified: cfe/trunk/lib/Frontend/TextDiagnostic.cpp
> URL: http://llvm.org/viewvc/llvm-project/cfe/trunk/lib/Frontend/TextDiagnostic.cpp?rev=157445&r1=157444&r2=157445&view=diff
> ==============================================================================
> --- cfe/trunk/lib/Frontend/TextDiagnostic.cpp (original)
> +++ cfe/trunk/lib/Frontend/TextDiagnostic.cpp Thu May 24 19:03:29 2012
> @@ -307,11 +307,11 @@
> // correctly.
> unsigned CaretStart = 0, CaretEnd = CaretLine.size();
> for (; CaretStart != CaretEnd; ++CaretStart)
> - if (!isspace(CaretLine[CaretStart]))
> + if (!isspace(static_cast<unsigned char>(CaretLine[CaretStart])))
> break;
>
> for (; CaretEnd != CaretStart; --CaretEnd)
> - if (!isspace(CaretLine[CaretEnd - 1]))
> + if (!isspace(static_cast<unsigned char>(CaretLine[CaretEnd - 1])))
> break;
>
> // caret has already been inserted into CaretLine so the above whitespace
> @@ -322,11 +322,11 @@
> if (!FixItInsertionLine.empty()) {
> unsigned FixItStart = 0, FixItEnd = FixItInsertionLine.size();
> for (; FixItStart != FixItEnd; ++FixItStart)
> - if (!isspace(FixItInsertionLine[FixItStart]))
> + if (!isspace(static_cast<unsigned char>(FixItInsertionLine[FixItStart])))
> break;
>
> for (; FixItEnd != FixItStart; --FixItEnd)
> - if (!isspace(FixItInsertionLine[FixItEnd - 1]))
> + if (!isspace(static_cast<unsigned char>(FixItInsertionLine[FixItEnd - 1])))
> break;
>
> CaretStart = std::min(FixItStart, CaretStart);
> @@ -382,12 +382,14 @@
> // Skip over any whitespace we see here; we're looking for
> // another bit of interesting text.
> while (NewStart &&
> - (map.byteToColumn(NewStart)==-1 || isspace(SourceLine[NewStart])))
> + (map.byteToColumn(NewStart)==-1 ||
> + isspace(static_cast<unsigned char>(SourceLine[NewStart]))))
> --NewStart;
>
> // Skip over this bit of "interesting" text.
> while (NewStart &&
> - (map.byteToColumn(NewStart)!=-1 && !isspace(SourceLine[NewStart])))
> + (map.byteToColumn(NewStart)!=-1 &&
> + !isspace(static_cast<unsigned char>(SourceLine[NewStart]))))
> --NewStart;
>
> // Move up to the non-whitespace character we just saw.
> @@ -408,12 +410,14 @@
> // Skip over any whitespace we see here; we're looking for
> // another bit of interesting text.
> while (NewEnd<SourceLine.size() &&
> - (map.byteToColumn(NewEnd)==-1 || isspace(SourceLine[NewEnd])))
> + (map.byteToColumn(NewEnd)==-1 ||
> + isspace(static_cast<unsigned char>(SourceLine[NewEnd]))))
> ++NewEnd;
>
> // Skip over this bit of "interesting" text.
> while (NewEnd<SourceLine.size() &&
> - (map.byteToColumn(NewEnd)!=-1 && !isspace(SourceLine[NewEnd])))
> + (map.byteToColumn(NewEnd)!=-1 &&
> + !isspace(static_cast<unsigned char>(SourceLine[NewEnd]))))
> ++NewEnd;
>
> unsigned NewColumns = map.byteToColumn(NewEnd) -
>
>
> _______________________________________________
> cfe-commits mailing list
> cfe-commits at cs.uiuc.edu
> http://lists.cs.uiuc.edu/mailman/listinfo/cfe-commits
-- Marshall
Marshall Clow Idio Software <mailto:mclow.lists at gmail.com>
A.D. 1517: Martin Luther nails his 95 Theses to the church door and is promptly moderated down to (-1, Flamebait).
-- Yu Suzuki
More information about the cfe-commits
mailing list