//===----------------------------------------------------------------------===//
#include "ASTConsumers.h"
+#include "clang/Basic/TargetInfo.h"
#include "clang/AST/AST.h"
#include "clang/AST/ASTConsumer.h"
#include "clang/AST/ASTContext.h"
#include "clang/AST/CFG.h"
+#include "clang.h"
#include "llvm/System/Path.h"
#include "llvm/Support/Streams.h"
#include "llvm/Support/MemoryBuffer.h"
class SerializationTest : public ASTConsumer {
ASTContext* Context;
+ Diagnostic &Diags;
std::list<Decl*> Decls;
enum { BasicMetadataBlock = 1,
DeclsBlock = 3 };
public:
- SerializationTest() : Context(NULL) {};
+ SerializationTest(Diagnostic &d) : Context(NULL), Diags(d) {};
~SerializationTest();
virtual void Initialize(ASTContext& context, unsigned) {
} // end anonymous namespace
-ASTConsumer* clang::CreateSerializationTest() {
- return new SerializationTest();
+ASTConsumer* clang::CreateSerializationTest(Diagnostic &Diags) {
+ return new SerializationTest(Diags);
}
static void WritePreamble(llvm::BitstreamWriter& Stream) {
llvm::cerr << "Faux-serializing: SourceManager.\n";
Sezr.EmitPtr(&Context->SourceMgr);
- // "Fake" emit the Target.
- llvm::cerr << "Faux-serializing: Target.\n";
+ // Emit the Target.
+ llvm::cerr << "Serializing: Target.\n";
Sezr.EmitPtr(&Context->Target);
+ Sezr.EmitCStr(Context->Target.getTargetTriple());
Sezr.ExitBlock();
llvm::cerr << "Faux-Deserializing: SourceManager.\n";
Dezr.RegisterPtr(&Context->SourceMgr);
- // "Fake" read the TargetInfo.
- llvm::cerr << "Faux-Deserializing: Target.\n";
- Dezr.RegisterPtr(&Context->Target);
-
+ { // Read the TargetInfo.
+ llvm::cerr << "Deserializing: Target.\n";
+ llvm::SerializedPtrID PtrID = Dezr.ReadPtrID();
+ char* triple = Dezr.ReadCStr(NULL,0,true);
+ std::vector<std::string> triples;
+ triples.push_back(triple);
+ delete [] triple;
+ Dezr.RegisterPtr(PtrID,CreateTargetInfo(triples,Diags));
+ }
+
// For Selectors, we must read the identifier table first because the
// SelectorTable depends on the identifiers being already deserialized.
- llvm::Deserializer::Location SelectorBlockLoc = Dezr.getCurrentBlockLocation();
+ llvm::Deserializer::Location SelectorBlockLoc =
+ Dezr.getCurrentBlockLocation();
+
Dezr.SkipBlock();
// Read the identifier table.