From: Anders Carlsson Date: Thu, 11 Oct 2007 01:00:40 +0000 (+0000) Subject: Add __builtin_va_start to the list of builtins, make __builtin_va_list available... X-Git-Url: https://granicus.if.org/sourcecode?a=commitdiff_plain;h=b2cf3573d7351094f6247fcca94703ce88eb9ee0;p=clang Add __builtin_va_start to the list of builtins, make __builtin_va_list available to builtin functions. git-svn-id: https://llvm.org/svn/llvm-project/cfe/trunk@42857 91177308-0d34-0410-b5e6-96231b3b80d8 --- diff --git a/AST/ASTContext.cpp b/AST/ASTContext.cpp index a6c2bc6680..56138c3aa1 100644 --- a/AST/ASTContext.cpp +++ b/AST/ASTContext.cpp @@ -830,3 +830,11 @@ QualType ASTContext::getCFConstantStringType() { return getTagDeclType(CFConstantStringTypeDecl); } + +void ASTContext::setBuiltinVaListType(QualType T) +{ + assert(BuiltinVaListType.isNull() && "__builtin_va_list type already set!"); + + BuiltinVaListType = T; +} + diff --git a/AST/Builtins.cpp b/AST/Builtins.cpp index a227bac480..219f00c479 100644 --- a/AST/Builtins.cpp +++ b/AST/Builtins.cpp @@ -133,6 +133,9 @@ static QualType DecodeTypeFromStr(const char *&Str, ASTContext &Context) { case 'F': Type = Context.getCFConstantStringType(); break; + case 'V': + Type = Context.getBuiltinVaListType(); + break; } Done = false; diff --git a/Sema/SemaDecl.cpp b/Sema/SemaDecl.cpp index 406a745c29..a140265198 100644 --- a/Sema/SemaDecl.cpp +++ b/Sema/SemaDecl.cpp @@ -137,7 +137,16 @@ ScopedDecl *Sema::LazilyCreateBuiltin(IdentifierInfo *II, unsigned bid, Scope *S) { Builtin::ID BID = (Builtin::ID)bid; - QualType R = Context.BuiltinInfo.GetBuiltinType(BID, Context); + if (BID == Builtin::BI__builtin_va_start && + Context.getBuiltinVaListType().isNull()) { + IdentifierInfo *VaIdent = &Context.Idents.get("__builtin_va_list"); + ScopedDecl *VaDecl = LookupScopedDecl(VaIdent, Decl::IDNS_Ordinary, + SourceLocation(), TUScope); + TypedefDecl *VaTypedef = cast(VaDecl); + Context.setBuiltinVaListType(Context.getTypedefType(VaTypedef)); + } + + QualType R = Context.BuiltinInfo.GetBuiltinType(BID, Context); FunctionDecl *New = new FunctionDecl(SourceLocation(), II, R, FunctionDecl::Extern, false, 0); diff --git a/include/clang/AST/ASTContext.h b/include/clang/AST/ASTContext.h index 43e40015d9..b554fcf20c 100644 --- a/include/clang/AST/ASTContext.h +++ b/include/clang/AST/ASTContext.h @@ -41,6 +41,11 @@ class ASTContext { llvm::FoldingSet ObjcQualifiedInterfaceTypes; llvm::DenseMap RecordLayoutInfo; RecordDecl *CFConstantStringTypeDecl; + + /// BuiltinVaListType - built-in va list type. + /// This is initially null and set by Sema::LazilyCreateBuiltin when + /// a builtin that takes a valist is encountered. + QualType BuiltinVaListType; public: SourceManager &SourceMgr; @@ -145,6 +150,9 @@ public: // getCFConstantStringType - Return the type used for constant CFStrings. QualType getCFConstantStringType(); + void setBuiltinVaListType(QualType T); + QualType getBuiltinVaListType() const { return BuiltinVaListType; } + //===--------------------------------------------------------------------===// // Type Sizing and Analysis //===--------------------------------------------------------------------===// diff --git a/include/clang/AST/Builtins.def b/include/clang/AST/Builtins.def index a5e3138c85..3325d385e5 100644 --- a/include/clang/AST/Builtins.def +++ b/include/clang/AST/Builtins.def @@ -30,6 +30,7 @@ // f -> float // d -> double // F -> constant CFString +// V -> __builtin_va_list // . -> "...". This may only occur at the end of the function list. // // Types maybe prefixed with the following modifiers: @@ -58,5 +59,6 @@ BUILTIN(__builtin_fabsl, "LdLd", "ncF") BUILTIN(__builtin_constant_p, "UsUs", "nc") BUILTIN(__builtin_classify_type, "i.", "nc") BUILTIN(__builtin___CFStringMakeConstantString, "FC*cC*", "nc") +BUILTIN(__builtin_va_start, "vV.", "nc") #undef BUILTIN