Commit 17ce4263 authored by Kevin Modzelewski's avatar Kevin Modzelewski

try to copy the logic flow from Py_Main

parent 8119000a
...@@ -354,7 +354,55 @@ extern "C" void PyErr_Display(PyObject* exception, PyObject* value, PyObject* tb ...@@ -354,7 +354,55 @@ extern "C" void PyErr_Display(PyObject* exception, PyObject* value, PyObject* tb
} }
static void handle_system_exit(void) noexcept { static void handle_system_exit(void) noexcept {
Py_FatalError("unimplemented"); PyObject* exception, *value, *tb;
int exitcode = 0;
if (Py_InspectFlag)
/* Don't exit if -i flag was given. This flag is set to 0
* when entering interactive mode for inspecting. */
return;
PyErr_Fetch(&exception, &value, &tb);
if (Py_FlushLine())
PyErr_Clear();
fflush(stdout);
if (value == NULL || value == Py_None)
goto done;
if (PyExceptionInstance_Check(value)) {
/* The error code should be in the `code' attribute. */
PyObject* code = PyObject_GetAttrString(value, "code");
if (code) {
Py_DECREF(value);
value = code;
if (value == Py_None)
goto done;
}
/* If we failed to dig out the 'code' attribute,
just let the else clause below print the error. */
}
if (PyInt_Check(value))
exitcode = (int)PyInt_AsLong(value);
else {
PyObject* sys_stderr = PySys_GetObject("stderr");
if (sys_stderr != NULL && sys_stderr != Py_None) {
PyFile_WriteObject(value, sys_stderr, Py_PRINT_RAW);
} else {
PyObject_Print(value, stderr, Py_PRINT_RAW);
fflush(stderr);
}
PySys_WriteStderr("\n");
exitcode = 1;
}
done:
/* Restore and clear the exception info, in order to properly decref
* the exception, value, and traceback. If we just exit instead,
* these leak, which confuses PYTHONDUMPREFS output, and may prevent
* some finalizers from running.
*/
PyErr_Restore(exception, value, tb);
PyErr_Clear();
Py_Exit(exitcode);
/* NOTREACHED */
} }
extern "C" void PyErr_PrintEx(int set_sys_last_vars) noexcept { extern "C" void PyErr_PrintEx(int set_sys_last_vars) noexcept {
......
...@@ -82,6 +82,7 @@ bool BOOLS_AS_I64 = ENABLE_FRAME_INTROSPECTION; ...@@ -82,6 +82,7 @@ bool BOOLS_AS_I64 = ENABLE_FRAME_INTROSPECTION;
extern "C" { extern "C" {
int Py_FrozenFlag = 1; int Py_FrozenFlag = 1;
int Py_IgnoreEnvironmentFlag = 0; int Py_IgnoreEnvironmentFlag = 0;
int Py_InspectFlag = 0;
int Py_NoSiteFlag = 0; int Py_NoSiteFlag = 0;
int Py_OptimizeFlag = 0; int Py_OptimizeFlag = 0;
int Py_VerboseFlag = 0; int Py_VerboseFlag = 0;
......
...@@ -31,6 +31,7 @@ ...@@ -31,6 +31,7 @@
#include "osdefs.h" #include "osdefs.h"
#include "capi/types.h"
#include "codegen/entry.h" #include "codegen/entry.h"
#include "codegen/irgen/hooks.h" #include "codegen/irgen/hooks.h"
#include "codegen/parser.h" #include "codegen/parser.h"
...@@ -54,42 +55,7 @@ namespace pyston { ...@@ -54,42 +55,7 @@ namespace pyston {
extern void setEncodingAndErrors(); extern void setEncodingAndErrors();
// returns true iff we got a request to exit, i.e. SystemExit, placing the
// return code in `*retcode`. does not touch `*retcode* if it returns false.
static bool handle_toplevel_exn(const ExcInfo& e, int* retcode) {
if (e.matches(SystemExit)) {
Box* value = e.value;
if (value && PyExceptionInstance_Check(value)) {
Box* code = getattr(value, "code");
if (code)
value = code;
}
if (!value || value == None)
*retcode = 0;
else if (isSubclass(value->cls, int_cls))
*retcode = static_cast<BoxedInt*>(value)->n;
else {
*retcode = 1;
PyObject* sys_stderr = PySys_GetObject("stderr");
if (sys_stderr != NULL && sys_stderr != Py_None) {
PyFile_WriteObject(value, sys_stderr, Py_PRINT_RAW);
} else {
PyObject_Print(value, stderr, Py_PRINT_RAW);
fflush(stderr);
}
PySys_WriteStderr("\n");
}
return true;
}
e.printExcAndTraceback();
return false;
}
static bool force_repl = false;
static bool unbuffered = false; static bool unbuffered = false;
static const char* argv0; static const char* argv0;
...@@ -186,7 +152,7 @@ int handleArg(char code) { ...@@ -186,7 +152,7 @@ int handleArg(char code) {
else if (code == 'I') else if (code == 'I')
FORCE_INTERPRETER = true; FORCE_INTERPRETER = true;
else if (code == 'i') else if (code == 'i')
force_repl = true; Py_InspectFlag = true;
else if (code == 'n') { else if (code == 'n') {
ENABLE_INTERPRETER = false; ENABLE_INTERPRETER = false;
} else if (code == 'p') { } else if (code == 'p') {
...@@ -268,7 +234,7 @@ static int main(int argc, char** argv) { ...@@ -268,7 +234,7 @@ static int main(int argc, char** argv) {
timespec before_ts, after_ts; timespec before_ts, after_ts;
Timer main_time; Timer main_time;
int rtncode; int rtncode = 0;
{ {
STAT_TIMER2(t0, "us_timer_main_toplevel", main_time.getStartTime()); STAT_TIMER2(t0, "us_timer_main_toplevel", main_time.getStartTime());
...@@ -395,61 +361,53 @@ static int main(int argc, char** argv) { ...@@ -395,61 +361,53 @@ static int main(int argc, char** argv) {
main_module = createModule("__main__", "<string>"); main_module = createModule("__main__", "<string>");
AST_Module* m = parse_string(command); AST_Module* m = parse_string(command);
compileAndRunModule(m, main_module); compileAndRunModule(m, main_module);
rtncode = 0;
} catch (ExcInfo e) { } catch (ExcInfo e) {
if (!force_repl) { setCAPIException(e);
int retcode = 1; PyErr_Print();
(void)handle_toplevel_exn(e, &retcode); rtncode = 1;
Stats::dump(false);
return retcode;
}
} }
} else if (module != NULL) { } else if (module != NULL) {
// TODO: CPython uses the same main module for all code paths // TODO: CPython uses the same main module for all code paths
main_module = createModule("__main__", "<string>"); main_module = createModule("__main__", "<string>");
bool sts = (RunModule(module, 1) != 0); rtncode = (RunModule(module, 1) != 0);
printf("TODO check this\n"); } else {
if (!force_repl) { rtncode = 0;
if (sts) if (fn != NULL) {
return 1; llvm::SmallString<128> path;
return 0;
} if (!llvm::sys::path::is_absolute(fn)) {
} char cwd_buf[1026];
char* cwd = getcwd(cwd_buf, sizeof(cwd_buf));
if (fn != NULL) { assert(cwd);
llvm::SmallString<128> path; path = cwd;
}
if (!llvm::sys::path::is_absolute(fn)) {
char cwd_buf[1026];
char* cwd = getcwd(cwd_buf, sizeof(cwd_buf));
assert(cwd);
path = cwd;
}
llvm::sys::path::append(path, fn); llvm::sys::path::append(path, fn);
llvm::sys::path::remove_filename(path); llvm::sys::path::remove_filename(path);
char* real_path char* real_path
= realpath(path.str().str().c_str(), NULL); // inefficient way of null-terminating the string = realpath(path.str().str().c_str(), NULL); // inefficient way of null-terminating the string
prependToSysPath(real_path); prependToSysPath(real_path);
free(real_path); free(real_path);
main_module = createModule("__main__", fn); main_module = createModule("__main__", fn);
try { try {
AST_Module* ast = caching_parse_file(fn); AST_Module* ast = caching_parse_file(fn);
compileAndRunModule(ast, main_module); compileAndRunModule(ast, main_module);
} catch (ExcInfo e) { } catch (ExcInfo e) {
int retcode = 1; setCAPIException(e);
(void)handle_toplevel_exn(e, &retcode); PyErr_Print();
if (!force_repl) { rtncode = 1;
Stats::dump(false);
return retcode;
} }
} }
} }
if (force_repl || !(command || fn)) { if (Py_InspectFlag || !(command || fn || module)) {
printf("Pyston v%d.%d (rev " STRINGIFY(GITREV) ")", PYSTON_VERSION_MAJOR, PYSTON_VERSION_MINOR); printf("Pyston v%d.%d (rev " STRINGIFY(GITREV) ")", PYSTON_VERSION_MAJOR, PYSTON_VERSION_MINOR);
printf(", targeting Python %d.%d.%d\n", PYTHON_VERSION_MAJOR, PYTHON_VERSION_MINOR, PYTHON_VERSION_MICRO); printf(", targeting Python %d.%d.%d\n", PYTHON_VERSION_MAJOR, PYTHON_VERSION_MINOR, PYTHON_VERSION_MICRO);
Py_InspectFlag = 0;
if (!main_module) { if (!main_module) {
main_module = createModule("__main__", "<stdin>"); main_module = createModule("__main__", "<stdin>");
} else { } else {
...@@ -488,11 +446,8 @@ static int main(int argc, char** argv) { ...@@ -488,11 +446,8 @@ static int main(int argc, char** argv) {
compileAndRunModule(m, main_module); compileAndRunModule(m, main_module);
} catch (ExcInfo e) { } catch (ExcInfo e) {
int retcode = 0xdeadbeef; // should never be seen setCAPIException(e);
if (handle_toplevel_exn(e, &retcode)) { PyErr_Print();
Stats::dump(false);
return retcode;
}
} }
} }
} }
...@@ -506,7 +461,7 @@ static int main(int argc, char** argv) { ...@@ -506,7 +461,7 @@ static int main(int argc, char** argv) {
_t.split("joinRuntime"); _t.split("joinRuntime");
rtncode = joinRuntime(); joinRuntime();
_t.split("finishing up"); _t.split("finishing up");
uint64_t main_time_ended_at; uint64_t main_time_ended_at;
......
...@@ -685,6 +685,13 @@ void checkAndThrowCAPIException() { ...@@ -685,6 +685,13 @@ void checkAndThrowCAPIException() {
} }
} }
extern "C" void Py_Exit(int sts) noexcept {
// Py_Finalize();
Stats::dump(false);
exit(sts);
}
extern "C" void PyErr_Restore(PyObject* type, PyObject* value, PyObject* traceback) noexcept { extern "C" void PyErr_Restore(PyObject* type, PyObject* value, PyObject* traceback) noexcept {
cur_thread_state.curexc_type = type; cur_thread_state.curexc_type = type;
cur_thread_state.curexc_value = value; cur_thread_state.curexc_value = value;
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment