19 #ifndef LLVM_CLANG_ANALYSIS_ANALYSES_FORMATSTRING_H 20 #define LLVM_CLANG_ANALYSIS_ANALYSES_FORMATSTRING_H 30 namespace analyze_format_string {
37 : representation(Representation), flag(
false) {}
38 bool isSet()
const {
return flag; }
39 void set() { flag =
true; }
44 this->position = position;
50 const char *
toString()
const {
return representation; }
53 explicit operator bool()
const {
return flag; }
59 const char *representation;
88 : Position(nullptr),
kind(None) {}
90 : Position(pos),
kind(k) {}
117 const char *Position;
124 InvalidSpecifier = 0,
171 ObjCBeg = ObjCObjArg,
172 ObjCEnd = ObjCObjArg,
183 PrintfConvBeg = ObjCObjArg,
184 PrintfConvEnd = PrintErrno,
188 ScanfConvBeg = ScanListArg,
189 ScanfConvEnd = ScanListArg
193 : IsPrintf(isPrintf), Position(nullptr), EndScanList(nullptr),
194 kind(InvalidSpecifier) {}
197 : IsPrintf(isPrintf), Position(pos), EndScanList(nullptr),
kind(k) {}
204 return StringRef(getStart(), getLength());
214 case InvalidSpecifier:
224 return EndScanList ? EndScanList - Position : 1;
229 kind == FreeBSDrArg ||
kind == FreeBSDyArg; }
233 return kind >= DoubleArgBeg &&
kind <= DoubleArgEnd;
252 AnyCharTy, CStrTy, WCStrTy, WIntTy };
254 enum MatchKind { NoMatch = 0, Match = 1, NoMatchPedantic };
263 : K(k), Name(n), Ptr(
false) {}
265 : K(SpecificTy), T(t), Name(n), Ptr(
false) {}
269 bool isValid()
const {
return K != InvalidTy; }
273 assert(A.K >= InvalidTy &&
"ArgType cannot be pointer to invalid/unknown");
283 std::string getRepresentativeTypeName(
ASTContext &C)
const;
292 const char *amountStart,
293 unsigned amountLength,
294 bool usesPositionalArg)
295 : start(amountStart),
length(amountLength), hs(howSpecified), amt(amount),
296 UsesPositionalArg(usesPositionalArg), UsesDotPrefix(0) {}
299 : start(nullptr),
length(0), hs(valid ? NotSpecified : Invalid), amt(0),
300 UsesPositionalArg(0), UsesDotPrefix(0) {}
303 return hs == Invalid;
312 assert(hasDataArgument());
317 assert(hs == Constant);
323 return start - UsesDotPrefix;
327 assert(hs == Constant);
328 return length + UsesDotPrefix;
333 void toString(raw_ostream &os)
const;
337 assert(hasDataArgument());
349 bool UsesPositionalArg : 1;
366 : CS(isPrintf), UsesPositionalArg(
false), argIndex(0) {}
400 bool hasValidLengthModifier(
const TargetInfo &Target)
const;
402 bool hasStandardLengthModifier()
const;
406 bool hasStandardConversionSpecifier(
const LangOptions &LangOpt)
const;
408 bool hasStandardLengthConversionCombination()
const;
420 namespace analyze_printf {
426 : ConversionSpecifier(
true, nullptr, InvalidSpecifier) {}
429 : ConversionSpecifier(
true, pos, k) {}
433 kind <= DoubleArgEnd; }
458 : FormatSpecifier(
true), HasThousandsGrouping(
"'"),
459 IsLeftJustified(
"-"), HasPlusPrefix(
"+"), HasSpacePrefix(
" "),
460 HasAlternativeForm(
"#"), HasLeadingZeroes(
"0"),
461 HasObjCTechnicalTerm(
"tt"), IsPrivate(
"private"), IsPublic(
"public") {}
497 return cast<PrintfConversionSpecifier>(CS);
510 return getConversionSpecifier().consumesDataArgument();
521 return HasThousandsGrouping;
539 void toString(raw_ostream &os)
const;
542 bool hasValidPlusPrefix()
const;
543 bool hasValidAlternativeForm()
const;
544 bool hasValidLeadingZeros()
const;
545 bool hasValidSpacePrefix()
const;
546 bool hasValidLeftJustified()
const;
547 bool hasValidThousandsGroupingPrefix()
const;
549 bool hasValidPrecision()
const;
550 bool hasValidFieldWidth()
const;
557 namespace analyze_scanf {
563 : ConversionSpecifier(
false, nullptr, InvalidSpecifier) {}
566 : ConversionSpecifier(
false, pos, k) {}
582 FormatSpecifier(
false),
583 SuppressAssignment(
"*") {}
590 return SuppressAssignment;
598 return cast<ScanfConversionSpecifier>(CS);
602 return CS.consumesDataArgument() && !SuppressAssignment;
610 void toString(raw_ostream &os)
const;
620 namespace analyze_format_string {
639 unsigned specifierLen) {}
642 unsigned flagsLen) {}
648 const char *flagsEnd,
649 const char *conversionPosition) {}
654 const char *startSpecifier,
655 unsigned specifierLen) {
660 const char *startSpecifier,
661 unsigned specifierLen) {
669 const char *startSpecifier,
670 unsigned specifierLen) {
675 const char *startSpecifier,
676 unsigned specifierLen) {
684 const char *beg,
const char *end,
const LangOptions &LO,
685 const TargetInfo &Target,
bool isFreeBSDKPrintf);
691 const char *beg,
const char *end,
const LangOptions &LO,
const OptionalFlag & hasAlternativeForm() const
A (possibly-)qualified type.
const ScanfConversionSpecifier & getConversionSpecifier() const
void setIsPublic(const char *position)
const OptionalFlag & getSuppressAssignment() const
bool consumesDataArgument() const
void setHasLeadingZeros(const char *position)
bool usesPositionalArg() const
const OptionalFlag & hasThousandsGrouping() const
PrintfConversionSpecifier(const char *pos, Kind k)
static bool classof(const analyze_format_string::ConversionSpecifier *CS)
void setPrecision(const OptionalAmount &Amt)
Holds long-lived AST nodes (such as types and decls) that can be referred to throughout the semantic ...
void setHasSpacePrefix(const char *position)
Keeps track of the various options that can be enabled, which controls the dialect of C or C++ that i...
void setConversionSpecifier(const PrintfConversionSpecifier &cs)
void setIsLeftJustified(const char *position)
void setUsesPositionalArg()
ScanfConversionSpecifier(const char *pos, Kind k)
const OptionalFlag & hasLeadingZeros() const
const OptionalFlag & hasPlusPrefix() const
Exposes information about the current target.
const OptionalFlag & isLeftJustified() const
const FunctionProtoType * T
float __ovld __cnfn length(float p)
Return the length of vector p, i.e., sqrt(p.x2 + p.y 2 + ...)
void setIsPrivate(const char *position)
void setHasThousandsGrouping(const char *position)
void setConversionSpecifier(const ScanfConversionSpecifier &cs)
const PrintfConversionSpecifier & getConversionSpecifier() const
const OptionalFlag & hasObjCTechnicalTerm() const
Dataflow Directional Tag Classes.
void setSuppressAssignment(const char *position)
PrintfConversionSpecifier()
const OptionalFlag & isPrivate() const
void setHasObjCTechnicalTerm(const char *position)
const OptionalAmount & getPrecision() const
void setHasPlusPrefix(const char *position)
const OptionalFlag & isPublic() const
const OptionalFlag & hasSpacePrefix() const
ScanfConversionSpecifier()
bool consumesDataArgument() const
unsigned kind
All of the diagnostics that can be emitted by the frontend.
static bool classof(const analyze_format_string::ConversionSpecifier *CS)
void setHasAlternativeForm(const char *position)