diff options
| author | NAKAMURA Takumi <geek4civic@gmail.com> | 2011-07-14 05:16:18 +0000 | 
|---|---|---|
| committer | NAKAMURA Takumi <geek4civic@gmail.com> | 2011-07-14 05:16:18 +0000 | 
| commit | 91d831bc2dbf3fe5a25b9eb2f8e41dfcb5f809b4 (patch) | |
| tree | 83929fe2b2a16b5d76444706f00643ce9c8fb6e1 /clang/lib/Analysis | |
| parent | 5cf0e1534af401a4f8835defbfe92e168c4d56a6 (diff) | |
| download | bcm5719-llvm-91d831bc2dbf3fe5a25b9eb2f8e41dfcb5f809b4.tar.gz bcm5719-llvm-91d831bc2dbf3fe5a25b9eb2f8e41dfcb5f809b4.zip  | |
Revert r135075, "format string checking: long and int have the same widths on 32-bit, so we shouldn't warn about using"
It fails on freebsd, mingw and msvc10.
llvm-svn: 135129
Diffstat (limited to 'clang/lib/Analysis')
| -rw-r--r-- | clang/lib/Analysis/FormatString.cpp | 19 | 
1 files changed, 10 insertions, 9 deletions
diff --git a/clang/lib/Analysis/FormatString.cpp b/clang/lib/Analysis/FormatString.cpp index 74f1e927944..5f3cd4c6154 100644 --- a/clang/lib/Analysis/FormatString.cpp +++ b/clang/lib/Analysis/FormatString.cpp @@ -206,10 +206,6 @@ clang::analyze_format_string::ParseLengthModifier(FormatSpecifier &FS,  // Methods on ArgTypeResult.  //===----------------------------------------------------------------------===// -static bool hasSameSize(ASTContext &astContext, QualType typeA, QualType typeB) { -  return astContext.getTypeSize(typeA) == astContext.getTypeSize(typeB); -} -  bool ArgTypeResult::matchesType(ASTContext &C, QualType argTy) const {    switch (K) {      case InvalidTy: @@ -230,21 +226,26 @@ bool ArgTypeResult::matchesType(ASTContext &C, QualType argTy) const {              break;            case BuiltinType::Char_S:            case BuiltinType::SChar: +            return T == C.UnsignedCharTy;            case BuiltinType::Char_U:            case BuiltinType::UChar:                     -            return hasSameSize(C, T, C.UnsignedCharTy);             +            return T == C.SignedCharTy;            case BuiltinType::Short: +            return T == C.UnsignedShortTy;            case BuiltinType::UShort: -            return hasSameSize(C, T, C.ShortTy); +            return T == C.ShortTy;            case BuiltinType::Int: +            return T == C.UnsignedIntTy;            case BuiltinType::UInt: -            return hasSameSize(C, T, C.IntTy); +            return T == C.IntTy;            case BuiltinType::Long: +            return T == C.UnsignedLongTy;            case BuiltinType::ULong: -            return hasSameSize(C, T, C.LongTy); +            return T == C.LongTy;            case BuiltinType::LongLong: +            return T == C.UnsignedLongLongTy;            case BuiltinType::ULongLong: -            return hasSameSize(C, T, C.LongLongTy); +            return T == C.LongLongTy;          }        return false;      }  | 

