diff options
author | Vsevolod Stakhov <vsevolod@highsecure.ru> | 2015-11-11 17:10:16 +0000 |
---|---|---|
committer | Vsevolod Stakhov <vsevolod@highsecure.ru> | 2015-11-11 17:10:16 +0000 |
commit | 613265222dc98a7dfdffa4a84966606f4c3e8445 (patch) | |
tree | b06965e9dbb41fe3b6e534b7e93454f01397d2a5 | |
parent | c957650442639c53be7103a585a0015c198e4a8e (diff) | |
download | rspamd-613265222dc98a7dfdffa4a84966606f4c3e8445.tar.gz rspamd-613265222dc98a7dfdffa4a84966606f4c3e8445.zip |
Improve format string parsing.
-rw-r--r-- | clang-plugin/printf_check.cc | 15 |
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) |