diff options
author | Ted Kremenek <kremenek@apple.com> | 2011-07-14 06:49:52 +0000 |
---|---|---|
committer | Ted Kremenek <kremenek@apple.com> | 2011-07-14 06:49:52 +0000 |
commit | ba84cf53bc67bc622de0ae0599dd9166183b77c8 (patch) | |
tree | 245abd8b22cd2a77091c8b566ee0315d699007b3 /clang/lib/Analysis/FormatString.cpp | |
parent | 0c666b46642d30ef063e5ead76525b81509fcfda (diff) | |
download | bcm5719-llvm-ba84cf53bc67bc622de0ae0599dd9166183b77c8.tar.gz bcm5719-llvm-ba84cf53bc67bc622de0ae0599dd9166183b77c8.zip |
Reapply r135075, but modify format-strings.c and format-strings-fixit.c test cases to be more portable with an explicit target triple.
llvm-svn: 135134
Diffstat (limited to 'clang/lib/Analysis/FormatString.cpp')
-rw-r--r-- | clang/lib/Analysis/FormatString.cpp | 19 |
1 files changed, 9 insertions, 10 deletions
diff --git a/clang/lib/Analysis/FormatString.cpp b/clang/lib/Analysis/FormatString.cpp index 5f3cd4c6154..74f1e927944 100644 --- a/clang/lib/Analysis/FormatString.cpp +++ b/clang/lib/Analysis/FormatString.cpp @@ -206,6 +206,10 @@ 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: @@ -226,26 +230,21 @@ 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 T == C.SignedCharTy; + return hasSameSize(C, T, C.UnsignedCharTy); case BuiltinType::Short: - return T == C.UnsignedShortTy; case BuiltinType::UShort: - return T == C.ShortTy; + return hasSameSize(C, T, C.ShortTy); case BuiltinType::Int: - return T == C.UnsignedIntTy; case BuiltinType::UInt: - return T == C.IntTy; + return hasSameSize(C, T, C.IntTy); case BuiltinType::Long: - return T == C.UnsignedLongTy; case BuiltinType::ULong: - return T == C.LongTy; + return hasSameSize(C, T, C.LongTy); case BuiltinType::LongLong: - return T == C.UnsignedLongLongTy; case BuiltinType::ULongLong: - return T == C.LongLongTy; + return hasSameSize(C, T, C.LongLongTy); } return false; } |