summaryrefslogtreecommitdiffstats
path: root/clang
diff options
context:
space:
mode:
authorTed Kremenek <kremenek@apple.com>2010-01-28 00:55:28 +0000
committerTed Kremenek <kremenek@apple.com>2010-01-28 00:55:28 +0000
commitc06ead62f0dafb545ce8abc133dbc299c94a3e3b (patch)
treef7f7544f54ad95b023a125364772db4b88881b6e /clang
parentabb44137281fb63bd6efb5c5c46a0513654dbbee (diff)
downloadbcm5719-llvm-c06ead62f0dafb545ce8abc133dbc299c94a3e3b.tar.gz
bcm5719-llvm-c06ead62f0dafb545ce8abc133dbc299c94a3e3b.zip
Add '@' conversion specifier.
llvm-svn: 94713
Diffstat (limited to 'clang')
-rw-r--r--clang/include/clang/Analysis/Analyses/PrintfFormatString.h10
-rw-r--r--clang/lib/Analysis/PrintfFormatString.cpp9
2 files changed, 14 insertions, 5 deletions
diff --git a/clang/include/clang/Analysis/Analyses/PrintfFormatString.h b/clang/include/clang/Analysis/Analyses/PrintfFormatString.h
index 978486d271a..c5bac8c7266 100644
--- a/clang/include/clang/Analysis/Analyses/PrintfFormatString.h
+++ b/clang/include/clang/Analysis/Analyses/PrintfFormatString.h
@@ -24,6 +24,7 @@ class ConversionSpecifier {
public:
enum Kind {
InvalidSpecifier = 0,
+ // C99 conversion specifiers.
dArg, // 'd'
iArg, // 'i',
oArg, // 'o',
@@ -43,12 +44,19 @@ public:
VoidPtrArg, // 'p'
OutIntPtrArg, // 'n'
PercentArg, // '%'
+ // Objective-C specific specifiers.
+ ObjCObjArg, // '@'
+ // Specifier ranges.
IntArgBeg = dArg,
IntArgEnd = iArg,
UIntArgBeg = oArg,
UIntArgEnd = XArg,
DoubleArgBeg = fArg,
- DoubleArgEnd = AArg
+ DoubleArgEnd = AArg,
+ C99Beg = IntArgBeg,
+ C99End = DoubleArgEnd,
+ ObjCBeg = ObjCObjArg,
+ ObjCEnd = ObjCObjArg
};
ConversionSpecifier(Kind k) : kind(k) {}
diff --git a/clang/lib/Analysis/PrintfFormatString.cpp b/clang/lib/Analysis/PrintfFormatString.cpp
index d7b9a21a3dc..9907dc9d42b 100644
--- a/clang/lib/Analysis/PrintfFormatString.cpp
+++ b/clang/lib/Analysis/PrintfFormatString.cpp
@@ -193,9 +193,8 @@ static FormatSpecifierResult ParseFormatSpecifier(printf::FormatStringHandler &H
switch (*I) {
default:
H.HandleInvalidConversionSpecifier(I);
- return true;
-
- // Handle the cases we know about.
+ return true;
+ // C99: 7.19.6.1 (section 8).
case 'd': cs = ConversionSpecifier::dArg; break;
case 'i': cs = ConversionSpecifier::iArg; break;
case 'o': cs = ConversionSpecifier::oArg; break;
@@ -214,7 +213,9 @@ static FormatSpecifierResult ParseFormatSpecifier(printf::FormatStringHandler &H
case 's': cs = ConversionSpecifier::CStrArg; break;
case 'p': cs = ConversionSpecifier::VoidPtrArg; break;
case 'n': cs = ConversionSpecifier::OutIntPtrArg; break;
- case '%': cs = ConversionSpecifier::PercentArg; break;
+ case '%': cs = ConversionSpecifier::PercentArg; break;
+ // Objective-C.
+ case '@': cs = ConversionSpecifier::ObjCObjArg; break;
}
FS.setConversionSpecifier(cs);
return FormatSpecifierResult(Start, FS);
OpenPOWER on IntegriCloud