10 #include "llvm/ADT/SmallBitVector.h" 12 using namespace clang;
18 class OSLogFormatStringHandler
22 const Expr *E =
nullptr;
28 unsigned char Flags = 0;
38 return OSLogBufferItem::StringKind;
40 return OSLogBufferItem::WideStringKind;
42 return OSLogBufferItem::PointerKind;
44 return OSLogBufferItem::ObjCObjKind;
46 return OSLogBufferItem::ErrnoKind;
48 return OSLogBufferItem::ScalarKind;
55 ArgsData.reserve(Args.size());
59 const char *StartSpecifier,
60 unsigned SpecifierLen) {
66 ArgsData.emplace_back();
68 if (ArgIndex < Args.size())
69 ArgsData.back().E = Args[ArgIndex];
73 if (ArgsData.back().Kind != OSLogBufferItem::ErrnoKind &&
84 switch (precision.getHowSpecified()) {
88 ArgsData.back().Size = precision.getConstantAmount();
91 ArgsData.back().Count = Args[precision.getArgIndex()];
100 switch (precision.getHowSpecified()) {
104 ArgsData.back().Size = precision.getConstantAmount();
107 ArgsData.back().Count = Args[precision.getArgIndex()];
125 ArgsData.back().Flags |= OSLogBufferItem::IsSensitive;
127 ArgsData.back().Flags |= OSLogBufferItem::IsPrivate;
129 ArgsData.back().Flags |= OSLogBufferItem::IsPublic;
136 Layout.
Items.clear();
137 for (
auto &Data : ArgsData) {
138 if (!Data.MaskType.empty()) {
140 Layout.
Items.emplace_back(OSLogBufferItem::MaskKind,
nullptr,
141 Size, 0, Data.MaskType);
144 if (Data.FieldWidth) {
146 Layout.
Items.emplace_back(OSLogBufferItem::ScalarKind, *Data.FieldWidth,
149 if (Data.Precision) {
151 Layout.
Items.emplace_back(OSLogBufferItem::ScalarKind, *Data.Precision,
157 Layout.
Items.emplace_back(OSLogBufferItem::CountKind, *Data.Count, Size,
165 if (*Data.Kind == OSLogBufferItem::ErrnoKind)
169 Layout.
Items.emplace_back(*Data.Kind, Data.E, Size, Data.Flags);
172 Layout.
Items.emplace_back(OSLogBufferItem::ScalarKind, Data.E, Size,
184 const Expr *StringArg;
187 case Builtin::BI__builtin_os_log_format_buffer_size:
189 "__builtin_os_log_format_buffer_size takes at least 1 argument");
191 VarArgs = Args.slice(1);
193 case Builtin::BI__builtin_os_log_format:
195 "__builtin_os_log_format takes at least 2 arguments");
197 VarArgs = Args.slice(2);
200 llvm_unreachable(
"non-os_log builtin passed to computeOSLogBufferLayout");
203 const StringLiteral *Lit = cast<StringLiteral>(StringArg->IgnoreParenCasts());
206 OSLogFormatStringHandler H(VarArgs);
210 H.computeLayout(Ctx, Layout);
Expr ** getArgs()
Retrieve the call arguments.
Expr * getArg(unsigned Arg)
getArg - Return the specified argument.
unsigned getNumArgs() const
getNumArgs - Return the number of actual arguments to this call.
bool consumesDataArgument() const
const TargetInfo & getTargetInfo() const
Holds long-lived AST nodes (such as types and decls) that can be referred to throughout the semantic ...
static CharUnits Zero()
Zero - Construct a CharUnits quantity of zero.
CharUnits - This is an opaque type for sizes expressed in character units.
bool computeOSLogBufferLayout(clang::ASTContext &Ctx, const clang::CallExpr *E, OSLogBufferLayout &layout)
StringRef getString() const
An OSLogBufferItem represents a single item in the data written by a call to os_log() or os_trace()...
This represents one expression.
static CharUnits fromQuantity(QuantityType Quantity)
fromQuantity - Construct a CharUnits quantity from a raw integer type.
const OptionalFlag & isSensitive() const
StringRef getMaskType() const
unsigned getBuiltinCallee() const
getBuiltinCallee - If this is a call to a builtin, return the builtin ID of the callee.
const PrintfConversionSpecifier & getConversionSpecifier() const
Dataflow Directional Tag Classes.
const OptionalFlag & isPrivate() const
SmallVector< OSLogBufferItem, 4 > Items
const OptionalAmount & getPrecision() const
const OptionalFlag & isPublic() const
Defines the C++ Decl subclasses, other than those for templates (found in DeclTemplate.h) and friends (in DeclFriend.h).
StringLiteral - This represents a string literal expression, e.g.
CallExpr - Represents a function call (C99 6.5.2.2, C++ [expr.call]).
static Decl::Kind getKind(const Decl *D)
CharUnits getTypeSizeInChars(QualType T) const
Return the size of the specified (complete) type T, in characters.
const LangOptions & getLangOpts() const
Defines enum values for all the target-independent builtin functions.