From 521f1feb110e97b8015a84364f73303e1e6fd4f6 Mon Sep 17 00:00:00 2001 From: Misha Brukman Date: Thu, 18 Sep 2003 16:17:06 +0000 Subject: [PATCH] Minimal implementation of the abstract ModuleProvider interface. git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@8594 91177308-0d34-0410-b5e6-96231b3b80d8 --- lib/VMCore/ModuleProvider.cpp | 28 ++++++++++++++++++++++++++++ 1 file changed, 28 insertions(+) create mode 100644 lib/VMCore/ModuleProvider.cpp diff --git a/lib/VMCore/ModuleProvider.cpp b/lib/VMCore/ModuleProvider.cpp new file mode 100644 index 00000000000..52c30cd1311 --- /dev/null +++ b/lib/VMCore/ModuleProvider.cpp @@ -0,0 +1,28 @@ +//===-- ModuleProvider.cpp - Base implementation for module providers -----===// +// +// Minimal implementation of the abstract interface for providing a module. +// +//===----------------------------------------------------------------------===// + +#include "llvm/ModuleProvider.h" +#include "llvm/Module.h" + +/// ctor - always have a valid Module +/// +AbstractModuleProvider::AbstractModuleProvider() { + M = new Module(""); +} + +/// dtor - when we leave, we take our Module with us +/// +AbstractModuleProvider::~AbstractModuleProvider() { + delete M; +} + +/// materializeFunction - make sure the given function is fully read. +/// +void AbstractModuleProvider::materializeModule() { + for (Module::iterator i = M->begin(), e = M->end(); i != e; ++i) { + materializeFunction(i); + } +}