diff options
author | Ted Kremenek <kremenek@apple.com> | 2008-10-06 23:49:24 +0000 |
---|---|---|
committer | Ted Kremenek <kremenek@apple.com> | 2008-10-06 23:49:24 +0000 |
commit | 655374859994cfca049b83390b89558ce27c1555 (patch) | |
tree | d31c27e2fb4f9f3fa397174383a373b0e3e311a3 /clang/lib/AST/DeclGroup.cpp | |
parent | 40aafce00db63ea7e82f9afed0bab44a0c485378 (diff) | |
download | bcm5719-llvm-655374859994cfca049b83390b89558ce27c1555.tar.gz bcm5719-llvm-655374859994cfca049b83390b89558ce27c1555.zip |
Added prototype serialization code for DeclGroup.
llvm-svn: 57222
Diffstat (limited to 'clang/lib/AST/DeclGroup.cpp')
-rw-r--r-- | clang/lib/AST/DeclGroup.cpp | 62 |
1 files changed, 62 insertions, 0 deletions
diff --git a/clang/lib/AST/DeclGroup.cpp b/clang/lib/AST/DeclGroup.cpp index 34b37dada5c..bd79fafc8f3 100644 --- a/clang/lib/AST/DeclGroup.cpp +++ b/clang/lib/AST/DeclGroup.cpp @@ -15,6 +15,8 @@ #include "clang/AST/Decl.h" #include "clang/AST/ASTContext.h" #include "llvm/Support/Allocator.h" +#include "llvm/Bitcode/Serialize.h" +#include "llvm/Bitcode/Deserialize.h" using namespace clang; @@ -26,6 +28,24 @@ DeclGroup* DeclGroup::Create(ASTContext& C, unsigned numdecls, Decl** decls) { return static_cast<DeclGroup*>(mem); } +/// Emit - Serialize a DeclGroup to Bitcode. +void DeclGroup::Emit(llvm::Serializer& S) const { + S.EmitInt(NumDecls); + S.BatchEmitOwnedPtrs(NumDecls, &(*this)[0]); +} + +/// Read - Deserialize a DeclGroup from Bitcode. +DeclGroup* DeclGroup::Create(llvm::Deserializer& D, ASTContext& C) { + unsigned NumDecls = (unsigned) D.ReadInt(); + unsigned size = sizeof(DeclGroup) + sizeof(Decl*) * NumDecls; + unsigned alignment = llvm::AlignOf<DeclGroup>::Alignment; + DeclGroup* DG = (DeclGroup*) C.getAllocator().Allocate(size, alignment); + new (DG) DeclGroup(); + DG->NumDecls = NumDecls; + D.BatchReadOwnedPtrs(NumDecls, &(*DG)[0], C); + return DG; +} + DeclGroup::DeclGroup(unsigned numdecls, Decl** decls) { assert (numdecls > 0); assert (decls); @@ -58,3 +78,45 @@ void DeclGroupOwningRef::Destroy(ASTContext& C) { D = 0; } + +void DeclGroupRef::Emit(llvm::Serializer& S) const { + if (getKind() == DeclKind) { + S.EmitBool(false); + S.EmitPtr(D); + } + else { + S.EmitBool(true); + S.EmitPtr(reinterpret_cast<DeclGroup*>(reinterpret_cast<uintptr_t>(D) + & ~Mask)); + } +} + +DeclGroupRef DeclGroupRef::ReadVal(llvm::Deserializer& D) { + if (D.ReadBool()) + return DeclGroupRef(D.ReadPtr<Decl>()); + + return DeclGroupRef(D.ReadPtr<DeclGroup>()); +} + +void DeclGroupOwningRef::Emit(llvm::Serializer& S) const { + if (getKind() == DeclKind) { + S.EmitBool(false); + S.EmitOwnedPtr(D); + } + else { + S.EmitBool(true); + S.EmitOwnedPtr(reinterpret_cast<DeclGroup*>(reinterpret_cast<uintptr_t>(D) + & ~Mask)); + } +} + +DeclGroupOwningRef DeclGroupOwningRef::ReadVal(llvm::Deserializer& D, + ASTContext& C) { + if (D.ReadBool()) { + DeclGroupOwningRef DG(D.ReadOwnedPtr<Decl>(C)); + return DG; + } + + DeclGroupOwningRef DG(D.ReadOwnedPtr<DeclGroup>(C)); + return DG; +} |