diff options
author | Chris Lattner <sabre@nondot.org> | 2002-11-07 19:33:50 +0000 |
---|---|---|
committer | Chris Lattner <sabre@nondot.org> | 2002-11-07 19:33:50 +0000 |
commit | a4479cd94615f84fe87533081e521669113557c7 (patch) | |
tree | 850f0bb1837ce9783ee18ff34b853e89e36fc9e1 /lib/ExecutionEngine/Interpreter/ExternalFunctions.cpp | |
parent | ab2dea568729ac68af0fec982756ca8d491f913b (diff) |
Implement freopen for burg
git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@4606 91177308-0d34-0410-b5e6-96231b3b80d8
Diffstat (limited to 'lib/ExecutionEngine/Interpreter/ExternalFunctions.cpp')
-rw-r--r-- | lib/ExecutionEngine/Interpreter/ExternalFunctions.cpp | 13 |
1 files changed, 11 insertions, 2 deletions
diff --git a/lib/ExecutionEngine/Interpreter/ExternalFunctions.cpp b/lib/ExecutionEngine/Interpreter/ExternalFunctions.cpp index b8f7786f6a..cb85a23474 100644 --- a/lib/ExecutionEngine/Interpreter/ExternalFunctions.cpp +++ b/lib/ExecutionEngine/Interpreter/ExternalFunctions.cpp @@ -531,11 +531,20 @@ GenericValue lle_X_fgets(FunctionType *M, const vector<GenericValue> &Args) { return GV; } +// FILE *freopen(const char *path, const char *mode, FILE *stream); +GenericValue lle_X_freopen(FunctionType *M, const vector<GenericValue> &Args) { + assert(Args.size() == 3); + GenericValue GV; + GV.PointerVal = (PointerTy)freopen((char*)Args[0].PointerVal, + (char*)Args[1].PointerVal, + getFILE(Args[2].PointerVal)); + return GV; +} + // int fflush(FILE *stream); GenericValue lle_X_fflush(FunctionType *M, const vector<GenericValue> &Args) { assert(Args.size() == 1); GenericValue GV; - GV.IntVal = fflush(getFILE(Args[0].PointerVal)); return GV; } @@ -544,7 +553,6 @@ GenericValue lle_X_fflush(FunctionType *M, const vector<GenericValue> &Args) { GenericValue lle_X_getc(FunctionType *M, const vector<GenericValue> &Args) { assert(Args.size() == 1); GenericValue GV; - GV.IntVal = getc(getFILE(Args[0].PointerVal)); return GV; } @@ -632,4 +640,5 @@ void Interpreter::initializeExternalMethods() { FuncNames["lle_X_fputc"] = lle_X_fputc; FuncNames["lle_X_ungetc"] = lle_X_ungetc; FuncNames["lle_X_fprintf"] = lle_X_fprintf; + FuncNames["lle_X_freopen"] = lle_X_freopen; } |