aboutsummaryrefslogtreecommitdiff
path: root/lib/ExecutionEngine/Interpreter/UserInput.cpp
diff options
context:
space:
mode:
Diffstat (limited to 'lib/ExecutionEngine/Interpreter/UserInput.cpp')
-rw-r--r--lib/ExecutionEngine/Interpreter/UserInput.cpp17
1 files changed, 14 insertions, 3 deletions
diff --git a/lib/ExecutionEngine/Interpreter/UserInput.cpp b/lib/ExecutionEngine/Interpreter/UserInput.cpp
index f579ef1a9b..2989ae95e8 100644
--- a/lib/ExecutionEngine/Interpreter/UserInput.cpp
+++ b/lib/ExecutionEngine/Interpreter/UserInput.cpp
@@ -8,6 +8,7 @@
#include "llvm/Bytecode/Reader.h"
#include "llvm/Assembly/Writer.h"
#include "llvm/DerivedTypes.h"
+#include "llvm/Transforms/Linker.h"
#include <algorithm>
enum CommandID {
@@ -129,15 +130,25 @@ void Interpreter::handleUserInput() {
// loadModule - Load a new module to execute...
//
void Interpreter::loadModule(const string &Filename) {
+ string ErrorMsg;
if (CurMod && !flushModule()) return; // Kill current execution
- CurMod = ParseBytecodeFile(Filename);
+ CurMod = ParseBytecodeFile(Filename, &ErrorMsg);
if (CurMod == 0) {
- cout << "Error parsing '" << Filename << "': No module loaded.\n";
+ cout << "Error parsing '" << Filename << "': No module loaded: "
+ << ErrorMsg << "\n";
return;
}
- // TODO: link in support library...
+ string RuntimeLib = getCurrentExecutablePath() + "/RuntimeLib.bc";
+ if (Module *SupportLib = ParseBytecodeFile(RuntimeLib, &ErrorMsg)) {
+ if (LinkModules(CurMod, SupportLib, &ErrorMsg))
+ cerr << "Error Linking runtime library into current module: "
+ << ErrorMsg << endl;
+ } else {
+ cerr << "Error loading runtime library '"+RuntimeLib+"': "
+ << ErrorMsg << "\n";
+ }
}