Use an ArrayRef when we can instead of passing in a SmallVectorImpl reference.

llvm-svn: 151150
This commit is contained in:
Bill Wendling 2012-02-22 09:30:11 +00:00
parent 94602b48ee
commit f1a3fcac0d
4 changed files with 33 additions and 35 deletions

View File

@ -2019,7 +2019,7 @@ Value *CodeGenFunction::EmitARMBuiltinExpr(unsigned BuiltinID,
} }
llvm::Value *CodeGenFunction:: llvm::Value *CodeGenFunction::
BuildVector(const SmallVectorImpl<llvm::Value*> &Ops) { BuildVector(ArrayRef<llvm::Value*> Ops) {
assert((Ops.size() & (Ops.size() - 1)) == 0 && assert((Ops.size() & (Ops.size() - 1)) == 0 &&
"Not a power-of-two sized vector!"); "Not a power-of-two sized vector!");
bool AllConstants = true; bool AllConstants = true;

View File

@ -337,10 +337,9 @@ private:
/// containing a size and an array of structures containing instance variable /// containing a size and an array of structures containing instance variable
/// metadata. This is used purely for introspection in the fragile ABI. In /// metadata. This is used purely for introspection in the fragile ABI. In
/// the non-fragile ABI, it's used for instance variable fixup. /// the non-fragile ABI, it's used for instance variable fixup.
llvm::Constant *GenerateIvarList( llvm::Constant *GenerateIvarList(ArrayRef<llvm::Constant *> IvarNames,
const SmallVectorImpl<llvm::Constant *> &IvarNames, ArrayRef<llvm::Constant *> IvarTypes,
const SmallVectorImpl<llvm::Constant *> &IvarTypes, ArrayRef<llvm::Constant *> IvarOffsets);
const SmallVectorImpl<llvm::Constant *> &IvarOffsets);
/// Generates a method list structure. This is a structure containing a size /// Generates a method list structure. This is a structure containing a size
/// and an array of structures containing method metadata. /// and an array of structures containing method metadata.
/// ///
@ -348,8 +347,8 @@ private:
/// pointer allowing them to be chained together in a linked list. /// pointer allowing them to be chained together in a linked list.
llvm::Constant *GenerateMethodList(const StringRef &ClassName, llvm::Constant *GenerateMethodList(const StringRef &ClassName,
const StringRef &CategoryName, const StringRef &CategoryName,
const SmallVectorImpl<Selector> &MethodSels, ArrayRef<Selector> MethodSels,
const SmallVectorImpl<llvm::Constant *> &MethodTypes, ArrayRef<llvm::Constant *> MethodTypes,
bool isClassMethodList); bool isClassMethodList);
/// Emits an empty protocol. This is used for @protocol() where no protocol /// Emits an empty protocol. This is used for @protocol() where no protocol
/// is found. The runtime will (hopefully) fix up the pointer to refer to the /// is found. The runtime will (hopefully) fix up the pointer to refer to the
@ -362,8 +361,7 @@ private:
SmallVectorImpl<llvm::Constant*> &InstanceMethodTypes); SmallVectorImpl<llvm::Constant*> &InstanceMethodTypes);
/// Generates a list of referenced protocols. Classes, categories, and /// Generates a list of referenced protocols. Classes, categories, and
/// protocols all use this structure. /// protocols all use this structure.
llvm::Constant *GenerateProtocolList( llvm::Constant *GenerateProtocolList(ArrayRef<std::string> Protocols);
const SmallVectorImpl<std::string> &Protocols);
/// To ensure that all protocols are seen by the runtime, we add a category on /// To ensure that all protocols are seen by the runtime, we add a category on
/// a class defined in the runtime, declaring no methods, but adopting the /// a class defined in the runtime, declaring no methods, but adopting the
/// protocols. This is a horribly ugly hack, but it allows us to collect all /// protocols. This is a horribly ugly hack, but it allows us to collect all
@ -388,8 +386,8 @@ private:
/// Generates a method list. This is used by protocols to define the required /// Generates a method list. This is used by protocols to define the required
/// and optional methods. /// and optional methods.
llvm::Constant *GenerateProtocolMethodList( llvm::Constant *GenerateProtocolMethodList(
const SmallVectorImpl<llvm::Constant *> &MethodNames, ArrayRef<llvm::Constant *> MethodNames,
const SmallVectorImpl<llvm::Constant *> &MethodTypes); ArrayRef<llvm::Constant *> MethodTypes);
/// Returns a selector with the specified type encoding. An empty string is /// Returns a selector with the specified type encoding. An empty string is
/// used to return an untyped selector (with the types field set to NULL). /// used to return an untyped selector (with the types field set to NULL).
llvm::Value *GetSelector(CGBuilderTy &Builder, Selector Sel, llvm::Value *GetSelector(CGBuilderTy &Builder, Selector Sel,
@ -428,7 +426,7 @@ protected:
/// significant bit being assumed to come first in the bitfield. Therefore, /// significant bit being assumed to come first in the bitfield. Therefore,
/// a bitfield with the 64th bit set will be (int64_t)&{ 2, [0, 1<<31] }, /// a bitfield with the 64th bit set will be (int64_t)&{ 2, [0, 1<<31] },
/// while a bitfield / with the 63rd bit set will be 1<<64. /// while a bitfield / with the 63rd bit set will be 1<<64.
llvm::Constant *MakeBitField(llvm::SmallVectorImpl<bool> &bits); llvm::Constant *MakeBitField(ArrayRef<bool> bits);
public: public:
CGObjCGNU(CodeGenModule &cgm, unsigned runtimeABIVersion, CGObjCGNU(CodeGenModule &cgm, unsigned runtimeABIVersion,
unsigned protocolClassVersion); unsigned protocolClassVersion);
@ -1257,10 +1255,11 @@ CGObjCGNU::GenerateMessageSend(CodeGenFunction &CGF,
/// Generates a MethodList. Used in construction of a objc_class and /// Generates a MethodList. Used in construction of a objc_class and
/// objc_category structures. /// objc_category structures.
llvm::Constant *CGObjCGNU::GenerateMethodList(const StringRef &ClassName, llvm::Constant *CGObjCGNU::
GenerateMethodList(const StringRef &ClassName,
const StringRef &CategoryName, const StringRef &CategoryName,
const SmallVectorImpl<Selector> &MethodSels, ArrayRef<Selector> MethodSels,
const SmallVectorImpl<llvm::Constant *> &MethodTypes, ArrayRef<llvm::Constant *> MethodTypes,
bool isClassMethodList) { bool isClassMethodList) {
if (MethodSels.empty()) if (MethodSels.empty())
return NULLPtr; return NULLPtr;
@ -1314,10 +1313,10 @@ llvm::Constant *CGObjCGNU::GenerateMethodList(const StringRef &ClassName,
} }
/// Generates an IvarList. Used in construction of a objc_class. /// Generates an IvarList. Used in construction of a objc_class.
llvm::Constant *CGObjCGNU::GenerateIvarList( llvm::Constant *CGObjCGNU::
const SmallVectorImpl<llvm::Constant *> &IvarNames, GenerateIvarList(ArrayRef<llvm::Constant *> IvarNames,
const SmallVectorImpl<llvm::Constant *> &IvarTypes, ArrayRef<llvm::Constant *> IvarTypes,
const SmallVectorImpl<llvm::Constant *> &IvarOffsets) { ArrayRef<llvm::Constant *> IvarOffsets) {
if (IvarNames.size() == 0) if (IvarNames.size() == 0)
return NULLPtr; return NULLPtr;
// Get the method structure type. // Get the method structure type.
@ -1444,9 +1443,9 @@ llvm::Constant *CGObjCGNU::GenerateClassStructure(
return Class; return Class;
} }
llvm::Constant *CGObjCGNU::GenerateProtocolMethodList( llvm::Constant *CGObjCGNU::
const SmallVectorImpl<llvm::Constant *> &MethodNames, GenerateProtocolMethodList(ArrayRef<llvm::Constant *> MethodNames,
const SmallVectorImpl<llvm::Constant *> &MethodTypes) { ArrayRef<llvm::Constant *> MethodTypes) {
// Get the method structure type. // Get the method structure type.
llvm::StructType *ObjCMethodDescTy = llvm::StructType::get( llvm::StructType *ObjCMethodDescTy = llvm::StructType::get(
PtrToInt8Ty, // Really a selector, but the runtime does the casting for us. PtrToInt8Ty, // Really a selector, but the runtime does the casting for us.
@ -1473,8 +1472,7 @@ llvm::Constant *CGObjCGNU::GenerateProtocolMethodList(
} }
// Create the protocol list structure used in classes, categories and so on // Create the protocol list structure used in classes, categories and so on
llvm::Constant *CGObjCGNU::GenerateProtocolList( llvm::Constant *CGObjCGNU::GenerateProtocolList(ArrayRef<std::string>Protocols){
const SmallVectorImpl<std::string> &Protocols) {
llvm::ArrayType *ProtocolArrayTy = llvm::ArrayType::get(PtrToInt8Ty, llvm::ArrayType *ProtocolArrayTy = llvm::ArrayType::get(PtrToInt8Ty,
Protocols.size()); Protocols.size());
llvm::StructType *ProtocolListTy = llvm::StructType::get( llvm::StructType *ProtocolListTy = llvm::StructType::get(
@ -1771,7 +1769,7 @@ void CGObjCGNU::GenerateProtocolHolderCategory(void) {
/// significant bit being assumed to come first in the bitfield. Therefore, a /// significant bit being assumed to come first in the bitfield. Therefore, a
/// bitfield with the 64th bit set will be (int64_t)&{ 2, [0, 1<<31] }, while a /// bitfield with the 64th bit set will be (int64_t)&{ 2, [0, 1<<31] }, while a
/// bitfield / with the 63rd bit set will be 1<<64. /// bitfield / with the 63rd bit set will be 1<<64.
llvm::Constant *CGObjCGNU::MakeBitField(llvm::SmallVectorImpl<bool> &bits) { llvm::Constant *CGObjCGNU::MakeBitField(ArrayRef<bool> bits) {
int bitCount = bits.size(); int bitCount = bits.size();
int ptrBits = int ptrBits =
(TheModule.getPointerSize() == llvm::Module::Pointer32) ? 32 : 64; (TheModule.getPointerSize() == llvm::Module::Pointer32) ? 32 : 64;

View File

@ -831,7 +831,7 @@ protected:
void BuildAggrIvarLayout(const ObjCImplementationDecl *OI, void BuildAggrIvarLayout(const ObjCImplementationDecl *OI,
const llvm::StructLayout *Layout, const llvm::StructLayout *Layout,
const RecordDecl *RD, const RecordDecl *RD,
const SmallVectorImpl<const FieldDecl*> &RecFields, ArrayRef<const FieldDecl*> RecFields,
unsigned int BytePos, bool ForStrongLayout, unsigned int BytePos, bool ForStrongLayout,
bool &HasUnion); bool &HasUnion);
@ -3768,7 +3768,7 @@ void CGObjCCommonMac::BuildAggrIvarRecordLayout(const RecordType *RT,
void CGObjCCommonMac::BuildAggrIvarLayout(const ObjCImplementationDecl *OI, void CGObjCCommonMac::BuildAggrIvarLayout(const ObjCImplementationDecl *OI,
const llvm::StructLayout *Layout, const llvm::StructLayout *Layout,
const RecordDecl *RD, const RecordDecl *RD,
const SmallVectorImpl<const FieldDecl*> &RecFields, ArrayRef<const FieldDecl*> RecFields,
unsigned int BytePos, bool ForStrongLayout, unsigned int BytePos, bool ForStrongLayout,
bool &HasUnion) { bool &HasUnion) {
bool IsUnion = (RD && RD->isUnion()); bool IsUnion = (RD && RD->isUnion());

View File

@ -2226,7 +2226,7 @@ public:
llvm::Value *EmitNeonShiftVector(llvm::Value *V, llvm::Type *Ty, llvm::Value *EmitNeonShiftVector(llvm::Value *V, llvm::Type *Ty,
bool negateForRightShift); bool negateForRightShift);
llvm::Value *BuildVector(const SmallVectorImpl<llvm::Value*> &Ops); llvm::Value *BuildVector(ArrayRef<llvm::Value*> Ops);
llvm::Value *EmitX86BuiltinExpr(unsigned BuiltinID, const CallExpr *E); llvm::Value *EmitX86BuiltinExpr(unsigned BuiltinID, const CallExpr *E);
llvm::Value *EmitHexagonBuiltinExpr(unsigned BuiltinID, const CallExpr *E); llvm::Value *EmitHexagonBuiltinExpr(unsigned BuiltinID, const CallExpr *E);
llvm::Value *EmitPPCBuiltinExpr(unsigned BuiltinID, const CallExpr *E); llvm::Value *EmitPPCBuiltinExpr(unsigned BuiltinID, const CallExpr *E);