aboutsummaryrefslogtreecommitdiff
path: root/lib/ExecutionEngine/Interpreter/ExternalFunctions.cpp
diff options
context:
space:
mode:
authorChris Lattner <sabre@nondot.org>2001-10-18 21:55:32 +0000
committerChris Lattner <sabre@nondot.org>2001-10-18 21:55:32 +0000
commitf8f2afb8cc5f080b291faad678e0a256ea44d15f (patch)
tree379ee6deb37bce643073e445144af18aea82d9ed /lib/ExecutionEngine/Interpreter/ExternalFunctions.cpp
parentb7e711838f8d6445f1ad7fa032515ad472060c84 (diff)
Enhancements to pass argc & argv to main if required
git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@909 91177308-0d34-0410-b5e6-96231b3b80d8
Diffstat (limited to 'lib/ExecutionEngine/Interpreter/ExternalFunctions.cpp')
-rw-r--r--lib/ExecutionEngine/Interpreter/ExternalFunctions.cpp10
1 files changed, 8 insertions, 2 deletions
diff --git a/lib/ExecutionEngine/Interpreter/ExternalFunctions.cpp b/lib/ExecutionEngine/Interpreter/ExternalFunctions.cpp
index 7be3336c58..bcd584a6b5 100644
--- a/lib/ExecutionEngine/Interpreter/ExternalFunctions.cpp
+++ b/lib/ExecutionEngine/Interpreter/ExternalFunctions.cpp
@@ -110,9 +110,10 @@ GenericValue lle_X_print(MethodType *M, const vector<GenericValue> &ArgVals) {
GenericValue lle_X_printVal(MethodType *M, const vector<GenericValue> &ArgVal) {
assert(ArgVal.size() == 1 && "generic print only takes one argument!");
- // Specialize print([ubyte {x N} ] *)
+ // Specialize print([ubyte {x N} ] *) and print(sbyte *)
if (PointerType *PTy = dyn_cast<PointerType>(M->getParamTypes()[0].get()))
- if (const ArrayType *ATy = dyn_cast<ArrayType>(PTy->getValueType())) {
+ if (PTy->getValueType() == Type::SByteTy ||
+ isa<ArrayType>(PTy->getValueType())) {
return lle_VP_printstr(M, ArgVal);
}
@@ -132,4 +133,9 @@ GenericValue lle_VB_putchar(MethodType *M, const vector<GenericValue> &Args) {
return GenericValue();
}
+// void "__main"()
+GenericValue lle_V___main(MethodType *M, const vector<GenericValue> &Args) {
+ return GenericValue();
+}
+
} // End extern "C"