diff options
author | Hans Wennborg <hans@hanshq.net> | 2011-12-09 12:22:12 +0000 |
---|---|---|
committer | Hans Wennborg <hans@hanshq.net> | 2011-12-09 12:22:12 +0000 |
commit | a5b1aa99c7844705bad30af65aeb758ea3ec20ad (patch) | |
tree | 1236d54c5d998b5e6ba27b647dde22dc2da8d163 /clang/lib/Analysis/PrintfFormatString.cpp | |
parent | a8b042d31a4ad2d5489e9d7d7f93511f1e00ba3e (diff) | |
download | bcm5719-llvm-a5b1aa99c7844705bad30af65aeb758ea3ec20ad.tar.gz bcm5719-llvm-a5b1aa99c7844705bad30af65aeb758ea3ec20ad.zip |
Make printf warnings refer to wint_t and wchar_t by name
in addition to underlying type.
llvm-svn: 146254
Diffstat (limited to 'clang/lib/Analysis/PrintfFormatString.cpp')
-rw-r--r-- | clang/lib/Analysis/PrintfFormatString.cpp | 15 |
1 files changed, 9 insertions, 6 deletions
diff --git a/clang/lib/Analysis/PrintfFormatString.cpp b/clang/lib/Analysis/PrintfFormatString.cpp index 3b8c45b7e29..2dd9bf7b2ea 100644 --- a/clang/lib/Analysis/PrintfFormatString.cpp +++ b/clang/lib/Analysis/PrintfFormatString.cpp @@ -247,7 +247,8 @@ ArgTypeResult PrintfSpecifier::getArgType(ASTContext &Ctx) const { if (CS.getKind() == ConversionSpecifier::cArg) switch (LM.getKind()) { case LengthModifier::None: return Ctx.IntTy; - case LengthModifier::AsLong: return ArgTypeResult::WIntTy; + case LengthModifier::AsLong: + return ArgTypeResult(ArgTypeResult::WIntTy, "wint_t"); default: return ArgTypeResult::Invalid(); } @@ -296,14 +297,16 @@ ArgTypeResult PrintfSpecifier::getArgType(ASTContext &Ctx) const { } switch (CS.getKind()) { - case ConversionSpecifier::sArg: - return ArgTypeResult(LM.getKind() == LengthModifier::AsWideChar ? - ArgTypeResult::WCStrTy : ArgTypeResult::CStrTy); + case ConversionSpecifier::sArg: { + if (LM.getKind() == LengthModifier::AsWideChar) + return ArgTypeResult(ArgTypeResult::WCStrTy, "wchar_t *"); + return ArgTypeResult::CStrTy; + } case ConversionSpecifier::SArg: // FIXME: This appears to be Mac OS X specific. - return ArgTypeResult::WCStrTy; + return ArgTypeResult(ArgTypeResult::WCStrTy, "wchar_t *"); case ConversionSpecifier::CArg: - return Ctx.WCharTy; + return ArgTypeResult(Ctx.WCharTy, "wchar_t"); case ConversionSpecifier::pArg: return ArgTypeResult::CPointerTy; default: |