summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorChris Lattner <sabre@nondot.org>2009-02-20 18:10:37 +0000
committerChris Lattner <sabre@nondot.org>2009-02-20 18:10:37 +0000
commited89b3ff2f02ee9cafb358ee66cf1a8192b5de59 (patch)
treef1cd097021b399e0cd5040391210b8190465604a
parentcdbb5e336d0f6072cc09ec744e1bcf0254c317ab (diff)
downloadbcm5719-llvm-ed89b3ff2f02ee9cafb358ee66cf1a8192b5de59.tar.gz
bcm5719-llvm-ed89b3ff2f02ee9cafb358ee66cf1a8192b5de59.zip
Change ObjCForwardProtocolDecl to use an ObjCList.
llvm-svn: 65131
-rw-r--r--clang/Driver/ASTConsumers.cpp8
-rw-r--r--clang/include/clang/AST/DeclObjC.h35
-rw-r--r--clang/lib/AST/DeclObjC.cpp17
3 files changed, 18 insertions, 42 deletions
diff --git a/clang/Driver/ASTConsumers.cpp b/clang/Driver/ASTConsumers.cpp
index 397170e60d2..f3bfc0b4345 100644
--- a/clang/Driver/ASTConsumers.cpp
+++ b/clang/Driver/ASTConsumers.cpp
@@ -97,10 +97,10 @@ void DeclPrinter:: PrintDecl(Decl *D) {
} else if (ObjCForwardProtocolDecl *OFPD =
dyn_cast<ObjCForwardProtocolDecl>(D)) {
Out << "@protocol ";
- for (unsigned i = 0, e = OFPD->getNumForwardDecls(); i != e; ++i) {
- const ObjCProtocolDecl *D = OFPD->getForwardProtocolDecl(i);
- if (i) Out << ", ";
- Out << D->getNameAsString();
+ for (ObjCForwardProtocolDecl::iterator I = OFPD->begin(), E = OFPD->end();
+ I != E; ++I) {
+ if (I != OFPD->begin()) Out << ", ";
+ Out << (*I)->getNameAsString();
}
Out << ";\n";
} else if (ObjCImplementationDecl *OID =
diff --git a/clang/include/clang/AST/DeclObjC.h b/clang/include/clang/AST/DeclObjC.h
index 10f59bcadfe..efd5242953d 100644
--- a/clang/include/clang/AST/DeclObjC.h
+++ b/clang/include/clang/AST/DeclObjC.h
@@ -658,44 +658,25 @@ public:
///
/// @protocol NSTextInput, NSChangeSpelling, NSDraggingInfo;
///
-/// FIXME: Should this be a transparent DeclContext?
class ObjCForwardProtocolDecl : public Decl {
- ObjCProtocolDecl **ReferencedProtocols;
- unsigned NumReferencedProtocols;
+ ObjCList<ObjCProtocolDecl> ReferencedProtocols;
ObjCForwardProtocolDecl(DeclContext *DC, SourceLocation L,
- ObjCProtocolDecl **Elts, unsigned nElts);
- virtual ~ObjCForwardProtocolDecl() {
- assert(ReferencedProtocols == 0 && "Destroy not called?");
- }
+ ObjCProtocolDecl *const *Elts, unsigned nElts);
+ virtual ~ObjCForwardProtocolDecl() {}
public:
static ObjCForwardProtocolDecl *Create(ASTContext &C, DeclContext *DC,
SourceLocation L,
- ObjCProtocolDecl **Elts, unsigned Num);
+ ObjCProtocolDecl *const *Elts,
+ unsigned Num);
/// Destroy - Call destructors and release memory.
virtual void Destroy(ASTContext& C);
-
- void setForwardProtocolDecl(unsigned idx, ObjCProtocolDecl *OID) {
- assert(idx < NumReferencedProtocols && "index out of range");
- ReferencedProtocols[idx] = OID;
- }
-
- unsigned getNumForwardDecls() const { return NumReferencedProtocols; }
-
- ObjCProtocolDecl *getForwardProtocolDecl(unsigned idx) {
- assert(idx < NumReferencedProtocols && "index out of range");
- return ReferencedProtocols[idx];
- }
- const ObjCProtocolDecl *getForwardProtocolDecl(unsigned idx) const {
- assert(idx < NumReferencedProtocols && "index out of range");
- return ReferencedProtocols[idx];
- }
- typedef ObjCProtocolDecl * const * iterator;
- iterator begin() const { return ReferencedProtocols; }
- iterator end() const { return ReferencedProtocols+NumReferencedProtocols; }
+ typedef ObjCList<ObjCProtocolDecl>::iterator iterator;
+ iterator begin() const { return ReferencedProtocols.begin(); }
+ iterator end() const { return ReferencedProtocols.end(); }
static bool classof(const Decl *D) {
return D->getKind() == ObjCForwardProtocol;
diff --git a/clang/lib/AST/DeclObjC.cpp b/clang/lib/AST/DeclObjC.cpp
index b0d36dbab8d..2ae7ccc8165 100644
--- a/clang/lib/AST/DeclObjC.cpp
+++ b/clang/lib/AST/DeclObjC.cpp
@@ -137,26 +137,21 @@ void ObjCClassDecl::Destroy(ASTContext &C) {
ObjCForwardProtocolDecl *
ObjCForwardProtocolDecl::Create(ASTContext &C, DeclContext *DC,
SourceLocation L,
- ObjCProtocolDecl **Elts, unsigned NumElts) {
+ ObjCProtocolDecl *const *Elts,
+ unsigned NumElts) {
return new (C) ObjCForwardProtocolDecl(DC, L, Elts, NumElts);
}
ObjCForwardProtocolDecl::
ObjCForwardProtocolDecl(DeclContext *DC, SourceLocation L,
- ObjCProtocolDecl **Elts, unsigned nElts)
+ ObjCProtocolDecl *const *Elts, unsigned nElts)
: Decl(ObjCForwardProtocol, DC, L) {
- NumReferencedProtocols = nElts;
- if (nElts) {
- ReferencedProtocols = new ObjCProtocolDecl*[nElts];
- memcpy(ReferencedProtocols, Elts, nElts*sizeof(ObjCProtocolDecl*));
- } else {
- ReferencedProtocols = 0;
- }
+ ReferencedProtocols.set(Elts, nElts);
}
void ObjCForwardProtocolDecl::Destroy(ASTContext &C) {
- delete [] ReferencedProtocols;
- ReferencedProtocols = 0;
+ ReferencedProtocols.clear();
+ Decl::Destroy(C);
}
ObjCCategoryDecl *ObjCCategoryDecl::Create(ASTContext &C, DeclContext *DC,
OpenPOWER on IntegriCloud