<div dir="ltr">So, I always push for leading upper case variable names. Over time we've gotten to the point where the majority of the code that I read in clang follows this convention. You seem to be pushing the other direction. What do you think we should be doing?<div><br></div>I'll admit the LLVM naming conventions are dumb, but I just don't care anymore, and would rather have it all look the same.<div><a href="http://llvm.org/docs/CodingStandards.html#name-types-functions-variables-and-enumerators-properly">http://llvm.org/docs/CodingStandards.html#name-types-functions-variables-and-enumerators-properly</a></div><div><br></div><div>I only mention it because you're modifying code that was clearly in the leading uppercase camp to leading lower case, so you weren't fitting into an existing style common to some local source file.</div></div><div class="gmail_extra"><br><div class="gmail_quote">On Wed, Nov 30, 2016 at 12:19 PM, John McCall via cfe-commits <span dir="ltr"><<a href="mailto:cfe-commits@lists.llvm.org" target="_blank">cfe-commits@lists.llvm.org</a>></span> wrote:<br><blockquote class="gmail_quote" style="margin:0 0 0 .8ex;border-left:1px #ccc solid;padding-left:1ex">Author: rjmccall<br>
Date: Wed Nov 30 14:19:46 2016<br>
New Revision: 288269<br>
<br>
URL: <a href="http://llvm.org/viewvc/llvm-project?rev=288269&view=rev" rel="noreferrer" target="_blank">http://llvm.org/viewvc/llvm-<wbr>project?rev=288269&view=rev</a><br>
Log:<br>
Finish adopting ConstantInitBuilder in CGObjCGNU. NFC.<br>
<br>
Modified:<br>
cfe/trunk/lib/CodeGen/<wbr>CGObjCGNU.cpp<br>
cfe/trunk/lib/CodeGen/<wbr>ConstantBuilder.h<br>
<br>
Modified: cfe/trunk/lib/CodeGen/<wbr>CGObjCGNU.cpp<br>
URL: <a href="http://llvm.org/viewvc/llvm-project/cfe/trunk/lib/CodeGen/CGObjCGNU.cpp?rev=288269&r1=288268&r2=288269&view=diff" rel="noreferrer" target="_blank">http://llvm.org/viewvc/llvm-<wbr>project/cfe/trunk/lib/CodeGen/<wbr>CGObjCGNU.cpp?rev=288269&r1=<wbr>288268&r2=288269&view=diff</a><br>
==============================<wbr>==============================<wbr>==================<br>
--- cfe/trunk/lib/CodeGen/<wbr>CGObjCGNU.cpp (original)<br>
+++ cfe/trunk/lib/CodeGen/<wbr>CGObjCGNU.cpp Wed Nov 30 14:19:46 2016<br>
@@ -164,9 +164,8 @@ protected:<br>
/// Helper function that generates a constant string and returns a pointer to<br>
/// the start of the string. The result of this function can be used anywhere<br>
/// where the C code specifies const char*.<br>
- llvm::Constant *MakeConstantString(const std::string &Str,<br>
- const std::string &Name="") {<br>
- ConstantAddress Array = CGM.GetAddrOfConstantCString(<wbr>Str, Name.c_str());<br>
+ llvm::Constant *MakeConstantString(StringRef Str, const char *Name = "") {<br>
+ ConstantAddress Array = CGM.GetAddrOfConstantCString(<wbr>Str, Name);<br>
return llvm::ConstantExpr::<wbr>getGetElementPtr(Array.<wbr>getElementType(),<br>
Array.getPointer(), Zeros);<br>
}<br>
@@ -1530,23 +1529,24 @@ GenerateMethodList(StringRef ClassName,<br>
MethodList.addInt(Int32Ty, MethodTypes.size());<br>
<br>
// Get the method structure type.<br>
- llvm::StructType *ObjCMethodTy = llvm::StructType::get(<br>
- PtrToInt8Ty, // Really a selector, but the runtime creates it us.<br>
- PtrToInt8Ty, // Method types<br>
- IMPTy, //Method pointer<br>
- nullptr);<br>
+ llvm::StructType *ObjCMethodTy =<br>
+ llvm::StructType::get(CGM.<wbr>getLLVMContext(), {<br>
+ PtrToInt8Ty, // Really a selector, but the runtime creates it us.<br>
+ PtrToInt8Ty, // Method types<br>
+ IMPTy // Method pointer<br>
+ });<br>
auto Methods = MethodList.beginArray();<br>
for (unsigned int i = 0, e = MethodTypes.size(); i < e; ++i) {<br>
- llvm::Constant *Method =<br>
+ llvm::Constant *FnPtr =<br>
TheModule.getFunction(<wbr>SymbolNameForMethod(ClassName, CategoryName,<br>
MethodSels[i],<br>
isClassMethodList));<br>
- assert(Method && "Can't generate metadata for method that doesn't exist");<br>
- llvm::Constant *C = MakeConstantString(MethodSels[<wbr>i].getAsString());<br>
- Method = llvm::ConstantExpr::<wbr>getBitCast(Method,<br>
- IMPTy);<br>
- Methods.add(<br>
- llvm::ConstantStruct::get(<wbr>ObjCMethodTy, {C, MethodTypes[i], Method}));<br>
+ assert(FnPtr && "Can't generate metadata for method that doesn't exist");<br>
+ auto Method = Methods.beginStruct(<wbr>ObjCMethodTy);<br>
+ Method.add(MakeConstantString(<wbr>MethodSels[i].getAsString()));<br>
+ Method.add(MethodTypes[i]);<br>
+ Method.addBitCast(FnPtr, IMPTy);<br>
+ Method.finishAndAddTo(Methods)<wbr>;<br>
}<br>
Methods.finishAndAddTo(<wbr>MethodList);<br>
<br>
@@ -1644,7 +1644,7 @@ llvm::Constant *CGObjCGNU::GenerateClass<br>
// Fill in the structure<br>
<br>
// isa<br>
- Elements.add(llvm::<wbr>ConstantExpr::getBitCast(<wbr>MetaClass, PtrToInt8Ty));<br>
+ Elements.addBitCast(MetaClass, PtrToInt8Ty);<br>
// super_class<br>
Elements.add(SuperClass);<br>
// name<br>
@@ -1673,7 +1673,7 @@ llvm::Constant *CGObjCGNU::GenerateClass<br>
// sibling_class<br>
Elements.add(NULLPtr);<br>
// protocols<br>
- Elements.add(llvm::<wbr>ConstantExpr::getBitCast(<wbr>Protocols, PtrTy));<br>
+ Elements.addBitCast(Protocols, PtrTy);<br>
// gc_object_type<br>
Elements.add(NULLPtr);<br>
// abi_version<br>
@@ -1746,9 +1746,7 @@ CGObjCGNU::<wbr>GenerateProtocolList(ArrayRef<br>
} else {<br>
protocol = value->getValue();<br>
}<br>
- llvm::Constant *Ptr = llvm::ConstantExpr::<wbr>getBitCast(protocol,<br>
- PtrToInt8Ty);<br>
- Elements.add(Ptr);<br>
+ Elements.addBitCast(protocol, PtrToInt8Ty);<br>
}<br>
Elements.finishAndAddTo(<wbr>ProtocolList);<br>
return ProtocolList.<wbr>finishAndCreateGlobal(".objc_<wbr>protocol_list",<br>
@@ -1959,11 +1957,11 @@ void CGObjCGNU::<wbr>GenerateProtocolHolderCa<br>
Elements.add(<wbr>MakeConstantString(<wbr>CategoryName));<br>
Elements.add(<wbr>MakeConstantString(ClassName))<wbr>;<br>
// Instance method list<br>
- Elements.add(llvm::<wbr>ConstantExpr::getBitCast(<wbr>GenerateMethodList(<br>
- ClassName, CategoryName, MethodSels, MethodTypes, false), PtrTy));<br>
+ Elements.addBitCast(<wbr>GenerateMethodList(<br>
+ ClassName, CategoryName, MethodSels, MethodTypes, false), PtrTy);<br>
// Class method list<br>
- Elements.add(llvm::<wbr>ConstantExpr::getBitCast(<wbr>GenerateMethodList(<br>
- ClassName, CategoryName, MethodSels, MethodTypes, true), PtrTy));<br>
+ Elements.addBitCast(<wbr>GenerateMethodList(<br>
+ ClassName, CategoryName, MethodSels, MethodTypes, true), PtrTy);<br>
<br>
// Protocol list<br>
ConstantInitBuilder ProtocolListBuilder(CGM);<br>
@@ -1973,15 +1971,13 @@ void CGObjCGNU::<wbr>GenerateProtocolHolderCa<br>
auto ProtocolElements = ProtocolList.beginArray(PtrTy)<wbr>;<br>
for (auto iter = ExistingProtocols.begin(), endIter = ExistingProtocols.end();<br>
iter != endIter ; iter++) {<br>
- llvm::Constant *Ptr = llvm::ConstantExpr::<wbr>getBitCast(iter->getValue(),<br>
- PtrTy);<br>
- ProtocolElements.add(Ptr);<br>
+ ProtocolElements.addBitCast(<wbr>iter->getValue(), PtrTy);<br>
}<br>
ProtocolElements.<wbr>finishAndAddTo(ProtocolList);<br>
- Elements.add(llvm::<wbr>ConstantExpr::getBitCast(<br>
+ Elements.addBitCast(<br>
ProtocolList.<wbr>finishAndCreateGlobal(".objc_<wbr>protocol_list",<br>
CGM.getPointerAlign()),<br>
- PtrTy));<br>
+ PtrTy);<br>
Categories.push_back(llvm::<wbr>ConstantExpr::getBitCast(<br>
Elements.<wbr>finishAndCreateGlobal("", CGM.getPointerAlign()),<br>
PtrTy));<br>
@@ -2066,18 +2062,17 @@ void CGObjCGNU::GenerateCategory(<wbr>const O<br>
Elements.add(<wbr>MakeConstantString(<wbr>CategoryName));<br>
Elements.add(<wbr>MakeConstantString(ClassName))<wbr>;<br>
// Instance method list<br>
- Elements.add(llvm::<wbr>ConstantExpr::getBitCast(<br>
+ Elements.addBitCast(<br>
GenerateMethodList(ClassName, CategoryName, InstanceMethodSels,<br>
InstanceMethodTypes, false),<br>
- PtrTy));<br>
+ PtrTy);<br>
// Class method list<br>
- Elements.add(llvm::<wbr>ConstantExpr::getBitCast(<br>
- GenerateMethodList(ClassName, CategoryName,<br>
- ClassMethodSels, ClassMethodTypes, true),<br>
- PtrTy));<br>
+ Elements.addBitCast(<br>
+ GenerateMethodList(ClassName, CategoryName, ClassMethodSels,<br>
+ ClassMethodTypes, true),<br>
+ PtrTy);<br>
// Protocol list<br>
- Elements.add(llvm::<wbr>ConstantExpr::getBitCast(<br>
- GenerateProtocolList(<wbr>Protocols), PtrTy));<br>
+ Elements.addBitCast(<wbr>GenerateProtocolList(<wbr>Protocols), PtrTy);<br>
Categories.push_back(llvm::<wbr>ConstantExpr::getBitCast(<br>
Elements.<wbr>finishAndCreateGlobal("", CGM.getPointerAlign()),<br>
PtrTy));<br>
@@ -2406,173 +2401,179 @@ llvm::Function *CGObjCGNU::ModuleInitFun<br>
// Add all referenced protocols to a category.<br>
GenerateProtocolHolderCategory<wbr>();<br>
<br>
- llvm::StructType *SelStructTy = dyn_cast<llvm::StructType>(<br>
- SelectorTy->getElementType());<br>
- llvm::Type *SelStructPtrTy = SelectorTy;<br>
- if (!SelStructTy) {<br>
- SelStructTy = llvm::StructType::get(<wbr>PtrToInt8Ty, PtrToInt8Ty, nullptr);<br>
- SelStructPtrTy = llvm::PointerType::getUnqual(<wbr>SelStructTy);<br>
+ llvm::StructType *selStructTy =<br>
+ dyn_cast<llvm::StructType>(<wbr>SelectorTy->getElementType());<br>
+ llvm::Type *selStructPtrTy = SelectorTy;<br>
+ if (!selStructTy) {<br>
+ selStructTy = llvm::StructType::get(CGM.<wbr>getLLVMContext(),<br>
+ { PtrToInt8Ty, PtrToInt8Ty });<br>
+ selStructPtrTy = llvm::PointerType::getUnqual(<wbr>selStructTy);<br>
}<br>
<br>
- std::vector<llvm::Constant*> Elements;<br>
- llvm::Constant *Statics = NULLPtr;<br>
// Generate statics list:<br>
+ llvm::Constant *statics = NULLPtr;<br>
if (!ConstantStrings.empty()) {<br>
- llvm::ArrayType *StaticsArrayTy = llvm::ArrayType::get(<wbr>PtrToInt8Ty,<br>
- ConstantStrings.size() + 1);<br>
- ConstantStrings.push_back(<wbr>NULLPtr);<br>
-<br>
- StringRef StringClass = CGM.getLangOpts().<wbr>ObjCConstantStringClass;<br>
-<br>
- if (StringClass.empty()) StringClass = "NXConstantString";<br>
-<br>
- Elements.push_back(<wbr>MakeConstantString(<wbr>StringClass,<br>
- ".objc_static_class_name"));<br>
- Elements.push_back(llvm::<wbr>ConstantArray::get(<wbr>StaticsArrayTy,<br>
- ConstantStrings));<br>
- Statics = MakeGlobal(llvm::<wbr>ConstantStruct::getAnon(<wbr>Elements),<br>
- CGM.getPointerAlign(), ".objc_statics");<br>
- llvm::Type *StaticsListPtrTy = Statics->getType();<br>
- llvm::ArrayType *StaticsListArrayTy =<br>
- llvm::ArrayType::get(<wbr>StaticsListPtrTy, 2);<br>
- Elements.clear();<br>
- Elements.push_back(Statics);<br>
- Elements.push_back(llvm::<wbr>Constant::getNullValue(<wbr>StaticsListPtrTy));<br>
- Statics = MakeGlobal(llvm::<wbr>ConstantArray::get(<wbr>StaticsListArrayTy, Elements),<br>
- CGM.getPointerAlign(), ".objc_statics_ptr");<br>
- Statics = llvm::ConstantExpr::<wbr>getBitCast(Statics, PtrTy);<br>
- }<br>
- // Array of classes, categories, and constant objects<br>
- llvm::ArrayType *ClassListTy = llvm::ArrayType::get(<wbr>PtrToInt8Ty,<br>
- Classes.size() + Categories.size() + 2);<br>
- llvm::StructType *SymTabTy = llvm::StructType::get(LongTy, SelStructPtrTy,<br>
- llvm::Type::getInt16Ty(<wbr>VMContext),<br>
- llvm::Type::getInt16Ty(<wbr>VMContext),<br>
- ClassListTy, nullptr);<br>
+ llvm::GlobalVariable *fileStatics = [&] {<br>
+ ConstantInitBuilder builder(CGM);<br>
+ auto staticsStruct = builder.beginStruct();<br>
+<br>
+ StringRef stringClass = CGM.getLangOpts().<wbr>ObjCConstantStringClass;<br>
+ if (stringClass.empty()) stringClass = "NXConstantString";<br>
+ staticsStruct.add(<wbr>MakeConstantString(<wbr>stringClass,<br>
+ ".objc_static_class_name"));<br>
+<br>
+ auto array = staticsStruct.beginArray();<br>
+ array.addAll(ConstantStrings);<br>
+ array.add(NULLPtr);<br>
+ array.finishAndAddTo(<wbr>staticsStruct);<br>
+<br>
+ return staticsStruct.<wbr>finishAndCreateGlobal(".objc_<wbr>statics",<br>
+ CGM.getPointerAlign());<br>
+ }();<br>
+<br>
+ ConstantInitBuilder builder(CGM);<br>
+ auto allStaticsArray = builder.beginArray(<wbr>fileStatics->getType());<br>
+ allStaticsArray.add(<wbr>fileStatics);<br>
+ allStaticsArray.<wbr>addNullPointer(fileStatics-><wbr>getType());<br>
+<br>
+ statics = allStaticsArray.<wbr>finishAndCreateGlobal(".objc_<wbr>statics_ptr",<br>
+ CGM.getPointerAlign());<br>
+ statics = llvm::ConstantExpr::<wbr>getBitCast(statics, PtrTy);<br>
+ }<br>
+<br>
+ // Array of classes, categories, and constant objects.<br>
+<br>
+ SmallVector<llvm::GlobalAlias*<wbr>, 16> selectorAliases;<br>
+ unsigned selectorCount;<br>
<br>
- Elements.clear();<br>
// Pointer to an array of selectors used in this module.<br>
- ConstantInitBuilder SelectorBuilder(CGM);<br>
- auto Selectors = SelectorBuilder.beginArray(<wbr>SelStructTy);<br>
- std::vector<llvm::GlobalAlias*<wbr>> SelectorAliases;<br>
- for (SelectorMap::iterator iter = SelectorTable.begin(),<br>
- iterEnd = SelectorTable.end(); iter != iterEnd ; ++iter) {<br>
-<br>
- std::string SelNameStr = iter->first.getAsString();<br>
- llvm::Constant *SelName = ExportUniqueString(SelNameStr, ".objc_sel_name");<br>
-<br>
- SmallVectorImpl<TypedSelector> &Types = iter->second;<br>
- for (SmallVectorImpl<<wbr>TypedSelector>::iterator i = Types.begin(),<br>
- e = Types.end() ; i!=e ; i++) {<br>
-<br>
- llvm::Constant *SelectorTypeEncoding = NULLPtr;<br>
- if (!i->first.empty())<br>
- SelectorTypeEncoding = MakeConstantString(i->first, ".objc_sel_types");<br>
-<br>
- auto SelStruct = Selectors.beginStruct(<wbr>SelStructTy);<br>
- SelStruct.add(SelName);<br>
- SelStruct.add(<wbr>SelectorTypeEncoding);<br>
- SelStruct.finishAndAddTo(<wbr>Selectors);<br>
-<br>
- // Store the selector alias for later replacement<br>
- SelectorAliases.push_back(i-><wbr>second);<br>
- }<br>
- }<br>
- unsigned SelectorCount = Selectors.size();<br>
- // NULL-terminate the selector list. This should not actually be required,<br>
- // because the selector list has a length field. Unfortunately, the GCC<br>
- // runtime decides to ignore the length field and expects a NULL terminator,<br>
- // and GCC cooperates with this by always setting the length to 0.<br>
- {<br>
- auto SelStruct = Selectors.beginStruct(<wbr>SelStructTy);<br>
- SelStruct.add(NULLPtr);<br>
- SelStruct.add(NULLPtr);<br>
- SelStruct.finishAndAddTo(<wbr>Selectors);<br>
- }<br>
+ llvm::GlobalVariable *selectorList = [&] {<br>
+ ConstantInitBuilder builder(CGM);<br>
+ auto selectors = builder.beginArray(<wbr>selStructTy);<br>
+ for (auto &entry : SelectorTable) {<br>
+<br>
+ std::string selNameStr = entry.first.getAsString();<br>
+ llvm::Constant *selName = ExportUniqueString(selNameStr, ".objc_sel_name");<br>
+<br>
+ for (TypedSelector &sel : entry.second) {<br>
+ llvm::Constant *selectorTypeEncoding = NULLPtr;<br>
+ if (!sel.first.empty())<br>
+ selectorTypeEncoding =<br>
+ MakeConstantString(sel.first, ".objc_sel_types");<br>
+<br>
+ auto selStruct = selectors.beginStruct(<wbr>selStructTy);<br>
+ selStruct.add(selName);<br>
+ selStruct.add(<wbr>selectorTypeEncoding);<br>
+ selStruct.finishAndAddTo(<wbr>selectors);<br>
+<br>
+ // Store the selector alias for later replacement<br>
+ selectorAliases.push_back(sel.<wbr>second);<br>
+ }<br>
+ }<br>
<br>
- // Number of static selectors<br>
- Elements.push_back(llvm::<wbr>ConstantInt::get(LongTy, SelectorCount));<br>
- llvm::GlobalVariable *SelectorList =<br>
- Selectors.<wbr>finishAndCreateGlobal(".objc_<wbr>selector_list",<br>
- CGM.getPointerAlign());<br>
- Elements.push_back(llvm::<wbr>ConstantExpr::getBitCast(<wbr>SelectorList,<br>
- SelStructPtrTy));<br>
+ // Remember the number of entries in the selector table.<br>
+ selectorCount = selectors.size();<br>
<br>
- // Now that all of the static selectors exist, create pointers to them.<br>
- for (unsigned int i=0 ; i<SelectorCount ; i++) {<br>
+ // NULL-terminate the selector list. This should not actually be required,<br>
+ // because the selector list has a length field. Unfortunately, the GCC<br>
+ // runtime decides to ignore the length field and expects a NULL terminator,<br>
+ // and GCC cooperates with this by always setting the length to 0.<br>
+ auto selStruct = selectors.beginStruct(<wbr>selStructTy);<br>
+ selStruct.add(NULLPtr);<br>
+ selStruct.add(NULLPtr);<br>
+ selStruct.finishAndAddTo(<wbr>selectors);<br>
<br>
- llvm::Constant *Idxs[] = {Zeros[0],<br>
- llvm::ConstantInt::get(<wbr>Int32Ty, i), Zeros[0]};<br>
+ return selectors.<wbr>finishAndCreateGlobal(".objc_<wbr>selector_list",<br>
+ CGM.getPointerAlign());<br>
+ }();<br>
+<br>
+ // Now that all of the static selectors exist, create pointers to them.<br>
+ for (unsigned i = 0; i < selectorCount; ++i) {<br>
+ llvm::Constant *idxs[] = {<br>
+ Zeros[0],<br>
+ llvm::ConstantInt::get(<wbr>Int32Ty, i)<br>
+ };<br>
// FIXME: We're generating redundant loads and stores here!<br>
- llvm::Constant *SelPtr = llvm::ConstantExpr::<wbr>getGetElementPtr(<br>
- SelectorList->getValueType(), SelectorList, makeArrayRef(Idxs, 2));<br>
+ llvm::Constant *selPtr = llvm::ConstantExpr::<wbr>getGetElementPtr(<br>
+ selectorList->getValueType(), selectorList, idxs);<br>
// If selectors are defined as an opaque type, cast the pointer to this<br>
// type.<br>
- SelPtr = llvm::ConstantExpr::<wbr>getBitCast(SelPtr, SelectorTy);<br>
- SelectorAliases[i]-><wbr>replaceAllUsesWith(SelPtr);<br>
- SelectorAliases[i]-><wbr>eraseFromParent();<br>
- }<br>
-<br>
- // Number of classes defined.<br>
- Elements.push_back(llvm::<wbr>ConstantInt::get(llvm::Type::<wbr>getInt16Ty(VMContext),<br>
- Classes.size()));<br>
- // Number of categories defined<br>
- Elements.push_back(llvm::<wbr>ConstantInt::get(llvm::Type::<wbr>getInt16Ty(VMContext),<br>
- Categories.size()));<br>
- // Create an array of classes, then categories, then static object instances<br>
- Classes.insert(Classes.end(), Categories.begin(), Categories.end());<br>
- // NULL-terminated list of static object instances (mainly constant strings)<br>
- Classes.push_back(Statics);<br>
- Classes.push_back(NULLPtr);<br>
- llvm::Constant *ClassList = llvm::ConstantArray::get(<wbr>ClassListTy, Classes);<br>
- Elements.push_back(ClassList);<br>
- // Construct the symbol table<br>
- llvm::Constant *SymTab =<br>
- MakeGlobal(llvm::<wbr>ConstantStruct::get(SymTabTy, Elements),<br>
- CGM.getPointerAlign());<br>
+ selPtr = llvm::ConstantExpr::<wbr>getBitCast(selPtr, SelectorTy);<br>
+ selectorAliases[i]-><wbr>replaceAllUsesWith(selPtr);<br>
+ selectorAliases[i]-><wbr>eraseFromParent();<br>
+ }<br>
+<br>
+ llvm::GlobalVariable *symtab = [&] {<br>
+ ConstantInitBuilder builder(CGM);<br>
+ auto symtab = builder.beginStruct();<br>
+<br>
+ // Number of static selectors<br>
+ symtab.addInt(LongTy, selectorCount);<br>
+<br>
+ symtab.addBitCast(<wbr>selectorList, selStructPtrTy);<br>
+<br>
+ // Number of classes defined.<br>
+ symtab.addInt(CGM.Int16Ty, Classes.size());<br>
+ // Number of categories defined<br>
+ symtab.addInt(CGM.Int16Ty, Categories.size());<br>
+<br>
+ // Create an array of classes, then categories, then static object instances<br>
+ auto classList = symtab.beginArray(PtrToInt8Ty)<wbr>;<br>
+ classList.addAll(Classes);<br>
+ classList.addAll(Categories);<br>
+ // NULL-terminated list of static object instances (mainly constant strings)<br>
+ classList.add(statics);<br>
+ classList.add(NULLPtr);<br>
+ classList.finishAndAddTo(<wbr>symtab);<br>
+<br>
+ // Construct the symbol table.<br>
+ return symtab.finishAndCreateGlobal("<wbr>", CGM.getPointerAlign());<br>
+ }();<br>
<br>
// The symbol table is contained in a module which has some version-checking<br>
// constants<br>
- llvm::StructType * ModuleTy = llvm::StructType::get(LongTy, LongTy,<br>
- PtrToInt8Ty, llvm::PointerType::getUnqual(<wbr>SymTabTy),<br>
- (RuntimeVersion >= 10) ? IntTy : nullptr, nullptr);<br>
- Elements.clear();<br>
- // Runtime version, used for ABI compatibility checking.<br>
- Elements.push_back(llvm::<wbr>ConstantInt::get(LongTy, RuntimeVersion));<br>
- // sizeof(ModuleTy)<br>
- llvm::DataLayout td(&TheModule);<br>
- Elements.push_back(<br>
- llvm::ConstantInt::get(LongTy,<br>
- td.getTypeSizeInBits(ModuleTy) /<br>
- CGM.getContext().getCharWidth(<wbr>)));<br>
-<br>
- // The path to the source file where this module was declared<br>
- SourceManager &SM = CGM.getContext().<wbr>getSourceManager();<br>
- const FileEntry *mainFile = SM.getFileEntryForID(SM.<wbr>getMainFileID());<br>
- std::string path =<br>
+ llvm::Constant *module = [&] {<br>
+ llvm::Type *moduleEltTys[] = {<br>
+ LongTy, LongTy, PtrToInt8Ty, symtab->getType(), IntTy<br>
+ };<br>
+ llvm::StructType *moduleTy =<br>
+ llvm::StructType::get(CGM.<wbr>getLLVMContext(),<br>
+ makeArrayRef(moduleEltTys).<wbr>drop_back(unsigned(<wbr>RuntimeVersion < 10)));<br>
+<br>
+ ConstantInitBuilder builder(CGM);<br>
+ auto module = builder.beginStruct(moduleTy);<br>
+ // Runtime version, used for ABI compatibility checking.<br>
+ module.addInt(LongTy, RuntimeVersion);<br>
+ // sizeof(ModuleTy)<br>
+ module.addInt(LongTy, CGM.getDataLayout().<wbr>getTypeStoreSize(moduleTy));<br>
+<br>
+ // The path to the source file where this module was declared<br>
+ SourceManager &SM = CGM.getContext().<wbr>getSourceManager();<br>
+ const FileEntry *mainFile = SM.getFileEntryForID(SM.<wbr>getMainFileID());<br>
+ std::string path =<br>
(Twine(mainFile->getDir()-><wbr>getName()) + "/" + mainFile->getName()).str();<br>
- Elements.push_back(<wbr>MakeConstantString(path, ".objc_source_file_name"));<br>
- Elements.push_back(SymTab);<br>
+ module.add(MakeConstantString(<wbr>path, ".objc_source_file_name"));<br>
+ module.add(symtab);<br>
<br>
- if (RuntimeVersion >= 10)<br>
- switch (CGM.getLangOpts().getGC()) {<br>
+ if (RuntimeVersion >= 10) {<br>
+ switch (CGM.getLangOpts().getGC()) {<br>
case LangOptions::GCOnly:<br>
- Elements.push_back(llvm::<wbr>ConstantInt::get(IntTy, 2));<br>
+ module.addInt(IntTy, 2);<br>
break;<br>
case LangOptions::NonGC:<br>
if (CGM.getLangOpts().<wbr>ObjCAutoRefCount)<br>
- Elements.push_back(llvm::<wbr>ConstantInt::get(IntTy, 1));<br>
+ module.addInt(IntTy, 1);<br>
else<br>
- Elements.push_back(llvm::<wbr>ConstantInt::get(IntTy, 0));<br>
+ module.addInt(IntTy, 0);<br>
break;<br>
case LangOptions::HybridGC:<br>
- Elements.push_back(llvm::<wbr>ConstantInt::get(IntTy, 1));<br>
+ module.addInt(IntTy, 1);<br>
break;<br>
+ }<br>
}<br>
<br>
- llvm::Value *Module =<br>
- MakeGlobal(llvm::<wbr>ConstantStruct::get(ModuleTy, Elements),<br>
- CGM.getPointerAlign());<br>
+ return module.finishAndCreateGlobal("<wbr>", CGM.getPointerAlign());<br>
+ }();<br>
<br>
// Create the load function calling the runtime entry point with the module<br>
// structure<br>
@@ -2586,10 +2587,9 @@ llvm::Function *CGObjCGNU::ModuleInitFun<br>
Builder.SetInsertPoint(<wbr>EntryBB);<br>
<br>
llvm::FunctionType *FT =<br>
- llvm::FunctionType::get(<wbr>Builder.getVoidTy(),<br>
- llvm::PointerType::getUnqual(<wbr>ModuleTy), true);<br>
+ llvm::FunctionType::get(<wbr>Builder.getVoidTy(), module->getType(), true);<br>
llvm::Value *Register = CGM.CreateRuntimeFunction(FT, "__objc_exec_class");<br>
- Builder.CreateCall(Register, Module);<br>
+ Builder.CreateCall(Register, module);<br>
<br>
if (!ClassAliases.empty()) {<br>
llvm::Type *ArgTypes[2] = {PtrTy, PtrToInt8Ty};<br>
<br>
Modified: cfe/trunk/lib/CodeGen/<wbr>ConstantBuilder.h<br>
URL: <a href="http://llvm.org/viewvc/llvm-project/cfe/trunk/lib/CodeGen/ConstantBuilder.h?rev=288269&r1=288268&r2=288269&view=diff" rel="noreferrer" target="_blank">http://llvm.org/viewvc/llvm-<wbr>project/cfe/trunk/lib/CodeGen/<wbr>ConstantBuilder.h?rev=288269&<wbr>r1=288268&r2=288269&view=diff</a><br>
==============================<wbr>==============================<wbr>==================<br>
--- cfe/trunk/lib/CodeGen/<wbr>ConstantBuilder.h (original)<br>
+++ cfe/trunk/lib/CodeGen/<wbr>ConstantBuilder.h Wed Nov 30 14:19:46 2016<br>
@@ -155,6 +155,13 @@ public:<br>
add(llvm::ConstantExpr::<wbr>getBitCast(value, type));<br>
}<br>
<br>
+ /// Add a bunch of new values to this initializer.<br>
+ void addAll(ArrayRef<llvm::Constant *> values) {<br>
+ assert(!Finished && "cannot add more values after finishing builder");<br>
+ assert(!Frozen && "cannot add values while subbuilder is active");<br>
+ Builder.Buffer.append(values.<wbr>begin(), values.end());<br>
+ }<br>
+<br>
/// An opaque class to hold the abstract position of a placeholder.<br>
class PlaceholderPosition {<br>
size_t Index;<br>
<br>
<br>
______________________________<wbr>_________________<br>
cfe-commits mailing list<br>
<a href="mailto:cfe-commits@lists.llvm.org">cfe-commits@lists.llvm.org</a><br>
<a href="http://lists.llvm.org/cgi-bin/mailman/listinfo/cfe-commits" rel="noreferrer" target="_blank">http://lists.llvm.org/cgi-bin/<wbr>mailman/listinfo/cfe-commits</a><br>
</blockquote></div><br></div>