diff options
| author | Ted Kremenek <kremenek@apple.com> | 2010-07-16 02:11:26 +0000 | 
|---|---|---|
| committer | Ted Kremenek <kremenek@apple.com> | 2010-07-16 02:11:26 +0000 | 
| commit | 575e89dda19085fdc33aeb759432418c48ab5bb9 (patch) | |
| tree | bc0caaf55b34d7b5fdfe586242ff68b4daf46211 /clang/lib/Analysis | |
| parent | 0208793e41018ac168412a3da8b2fba70aba9716 (diff) | |
| download | bcm5719-llvm-575e89dda19085fdc33aeb759432418c48ab5bb9.tar.gz bcm5719-llvm-575e89dda19085fdc33aeb759432418c48ab5bb9.zip  | |
Add missing header file.
llvm-svn: 108501
Diffstat (limited to 'clang/lib/Analysis')
| -rw-r--r-- | clang/lib/Analysis/FormatStringParsing.h | 71 | 
1 files changed, 71 insertions, 0 deletions
diff --git a/clang/lib/Analysis/FormatStringParsing.h b/clang/lib/Analysis/FormatStringParsing.h new file mode 100644 index 00000000000..49d9735f806 --- /dev/null +++ b/clang/lib/Analysis/FormatStringParsing.h @@ -0,0 +1,71 @@ +#ifndef LLVM_CLANG_FORMAT_PARSING_H +#define LLVM_CLANG_FORMAT_PARSING_H + +#include "clang/Analysis/Analyses/FormatString.h" +#include "clang/AST/ASTContext.h" +#include "clang/AST/Type.h" +#include "llvm/Support/raw_ostream.h" + +template <typename T> +class UpdateOnReturn { +  T &ValueToUpdate; +  const T &ValueToCopy; +public: +  UpdateOnReturn(T &valueToUpdate, const T &valueToCopy) +    : ValueToUpdate(valueToUpdate), ValueToCopy(valueToCopy) {} + +  ~UpdateOnReturn() { +    ValueToUpdate = ValueToCopy; +  } +}; + +namespace clang { +namespace analyze_format_string { +   +OptionalAmount ParseAmount(const char *&Beg, const char *E); +OptionalAmount ParseNonPositionAmount(const char *&Beg, const char *E, +                                      unsigned &argIndex); + +OptionalAmount ParsePositionAmount(FormatStringHandler &H, +                                   const char *Start, const char *&Beg, +                                   const char *E, PositionContext p); +   +bool ParseFieldWidth(FormatStringHandler &H, +                     FormatSpecifier &CS, +                     const char *Start, const char *&Beg, const char *E, +                     unsigned *argIndex); +     +bool ParseArgPosition(FormatStringHandler &H, +                      FormatSpecifier &CS, const char *Start, +                      const char *&Beg, const char *E); + +/// Returns true if a LengthModifier was parsed and installed in the +/// FormatSpecifier& argument, and false otherwise. +bool ParseLengthModifier(FormatSpecifier &FS, const char *&Beg, const char *E); +   +template <typename T> class SpecifierResult { +  T FS; +  const char *Start; +  bool Stop; +public: +  SpecifierResult(bool stop = false) +  : Start(0), Stop(stop) {} +  SpecifierResult(const char *start, +                  const T &fs) +  : FS(fs), Start(start), Stop(false) {} +   +  const char *getStart() const { return Start; } +  bool shouldStop() const { return Stop; } +  bool hasValue() const { return Start != 0; } +  const T &getValue() const { +    assert(hasValue()); +    return FS; +  } +  const T &getValue() { return FS; } +}; +   +} // end analyze_format_string namespace +} // end clang namespace + +#endif +  | 

