Changes in directory llvm/lib/ExecutionEngine/Interpreter:
ExternalFunctions.cpp updated: 1.97 -> 1.98 --- Log message: We only need one putchar which gives it a shot at getting matched by its users. --- Diffs of the changes: (+4 -17) ExternalFunctions.cpp | 21 ++++----------------- 1 files changed, 4 insertions(+), 17 deletions(-) Index: llvm/lib/ExecutionEngine/Interpreter/ExternalFunctions.cpp diff -u llvm/lib/ExecutionEngine/Interpreter/ExternalFunctions.cpp:1.97 llvm/lib/ExecutionEngine/Interpreter/ExternalFunctions.cpp:1.98 --- llvm/lib/ExecutionEngine/Interpreter/ExternalFunctions.cpp:1.97 Fri Mar 30 11:41:50 2007 +++ llvm/lib/ExecutionEngine/Interpreter/ExternalFunctions.cpp Sat Apr 21 12:11:45 2007 @@ -112,20 +112,8 @@ // extern "C" { // Don't add C++ manglings to llvm mangling :) -// void putchar(sbyte) -GenericValue lle_VB_putchar(FunctionType *FT, const vector<GenericValue> &Args){ - cout << ((char)Args[0].IntVal.getZExtValue()); - return GenericValue(); -} - -// int putchar(int) -GenericValue lle_ii_putchar(FunctionType *FT, const vector<GenericValue> &Args){ - cout << ((char)Args[0].IntVal.getZExtValue()) << std::flush; - return Args[0]; -} - // void putchar(ubyte) -GenericValue lle_Vb_putchar(FunctionType *FT, const vector<GenericValue> &Args){ +GenericValue lle_X_putchar(FunctionType *FT, const vector<GenericValue> &Args){ cout << ((char)Args[0].IntVal.getZExtValue()) << std::flush; return Args[0]; } @@ -354,13 +342,14 @@ break; } } + return GV; } // int printf(sbyte *, ...) - a very rough implementation to make output useful. GenericValue lle_X_printf(FunctionType *FT, const vector<GenericValue> &Args) { char Buffer[10000]; vector<GenericValue> NewArgs; - NewArgs.push_back(PTOGV(Buffer)); + NewArgs.push_back(PTOGV((void*)&Buffer[0])); NewArgs.insert(NewArgs.end(), Args.begin(), Args.end()); GenericValue GV = lle_X_sprintf(FT, NewArgs); cout << Buffer; @@ -704,9 +693,7 @@ void Interpreter::initializeExternalFunctions() { - FuncNames["lle_Vb_putchar"] = lle_Vb_putchar; - FuncNames["lle_ii_putchar"] = lle_ii_putchar; - FuncNames["lle_VB_putchar"] = lle_VB_putchar; + FuncNames["lle_X_putchar"] = lle_X_putchar; FuncNames["lle_X_exit"] = lle_X_exit; FuncNames["lle_X_abort"] = lle_X_abort; FuncNames["lle_X_malloc"] = lle_X_malloc; _______________________________________________ llvm-commits mailing list llvm-commits@cs.uiuc.edu http://lists.cs.uiuc.edu/mailman/listinfo/llvm-commits