aboutsummaryrefslogtreecommitdiffstats
path: root/clang-plugin/printf_check.cc
diff options
context:
space:
mode:
authorVsevolod Stakhov <vsevolod@highsecure.ru>2015-11-11 17:10:16 +0000
committerVsevolod Stakhov <vsevolod@highsecure.ru>2015-11-11 17:10:16 +0000
commit613265222dc98a7dfdffa4a84966606f4c3e8445 (patch)
treeb06965e9dbb41fe3b6e534b7e93454f01397d2a5 /clang-plugin/printf_check.cc
parentc957650442639c53be7103a585a0015c198e4a8e (diff)
downloadrspamd-613265222dc98a7dfdffa4a84966606f4c3e8445.tar.gz
rspamd-613265222dc98a7dfdffa4a84966606f4c3e8445.zip
Improve format string parsing.
Diffstat (limited to 'clang-plugin/printf_check.cc')
-rw-r--r--clang-plugin/printf_check.cc15
1 files changed, 14 insertions, 1 deletions
diff --git a/clang-plugin/printf_check.cc b/clang-plugin/printf_check.cc
index 6873cc398..c2144127b 100644
--- a/clang-plugin/printf_check.cc
+++ b/clang-plugin/printf_check.cc
@@ -29,6 +29,7 @@
#include "clang/AST/ASTConsumer.h"
#include "clang/AST/RecursiveASTVisitor.h"
#include <unordered_map>
+#include <unordered_set>
#include <vector>
#include <sstream>
#include <ctype.h>
@@ -137,6 +138,7 @@ namespace rspamd {
class PrintfCheckVisitor::impl {
std::unordered_map<std::string, unsigned int> printf_functions;
+ std::unordered_set<char> format_specs;
ASTContext *pcontext;
CompilerInstance *ci;
@@ -278,7 +280,13 @@ namespace rspamd {
}
break;
case read_arg:
- if (!isalpha (c)) {
+ auto found = format_specs.find (c);
+ if (found != format_specs.end () || !isalpha (c)) {
+
+ if (isalpha (c)) {
+ flags.push_back (c);
+ }
+
auto handler = parseFlags (flags, e);
if (handler) {
@@ -333,6 +341,11 @@ namespace rspamd {
{"rspamd_snprintf", 2},
{"rspamd_fprintf", 1}
};
+
+ format_specs = {
+ 's', 'd', 'l', 'L', 'v', 'V', 'f', 'F', 'g', 'G',
+ 'T', 'z', 'D', 'c', 'p', 'P', 'e'
+ };
};
bool VisitCallExpr (CallExpr *E)