mirror of
https://github.com/pocketpy/pocketpy
synced 2025-10-23 04:50:17 +00:00
...
This commit is contained in:
parent
75a7a80630
commit
a1212fbf09
@ -130,7 +130,7 @@ template<> inline void gc_mark<Function>(Function& t){
|
|||||||
}
|
}
|
||||||
|
|
||||||
struct ValueStack {
|
struct ValueStack {
|
||||||
static const size_t MAX_SIZE = 32768;
|
static const size_t MAX_SIZE = 16384;
|
||||||
// We allocate 512 more bytes to keep `_sp` valid when `is_overflow() == true`.
|
// We allocate 512 more bytes to keep `_sp` valid when `is_overflow() == true`.
|
||||||
PyObject* _begin[MAX_SIZE + 512];
|
PyObject* _begin[MAX_SIZE + 512];
|
||||||
PyObject** _sp;
|
PyObject** _sp;
|
||||||
|
@ -590,6 +590,11 @@ inline void add_module_time(VM* vm){
|
|||||||
inline void add_module_sys(VM* vm){
|
inline void add_module_sys(VM* vm){
|
||||||
PyObject* mod = vm->new_module("sys");
|
PyObject* mod = vm->new_module("sys");
|
||||||
vm->setattr(mod, "version", VAR(PK_VERSION));
|
vm->setattr(mod, "version", VAR(PK_VERSION));
|
||||||
|
vm->bind_func<0>(mod, "getrecursionlimit", CPP_LAMBDA(VAR(vm->recursionlimit)));
|
||||||
|
vm->bind_func<1>(mod, "setrecursionlimit", [](VM* vm, ArgsView args) {
|
||||||
|
vm->recursionlimit = CAST(int, args[0]);
|
||||||
|
return vm->None;
|
||||||
|
});
|
||||||
}
|
}
|
||||||
|
|
||||||
inline void add_module_json(VM* vm){
|
inline void add_module_json(VM* vm){
|
||||||
|
8
src/vm.h
8
src/vm.h
@ -104,6 +104,8 @@ public:
|
|||||||
Type tp_slice, tp_range, tp_module;
|
Type tp_slice, tp_range, tp_module;
|
||||||
Type tp_super, tp_exception;
|
Type tp_super, tp_exception;
|
||||||
|
|
||||||
|
i64 recursionlimit = 1000;
|
||||||
|
|
||||||
VM(bool use_stdio) : heap(this){
|
VM(bool use_stdio) : heap(this){
|
||||||
this->vm = this;
|
this->vm = this;
|
||||||
this->_stdout = use_stdio ? &std::cout : &_stdout_buffer;
|
this->_stdout = use_stdio ? &std::cout : &_stdout_buffer;
|
||||||
@ -329,6 +331,7 @@ public:
|
|||||||
}
|
}
|
||||||
|
|
||||||
void StackOverflowError() { _error("StackOverflowError", ""); }
|
void StackOverflowError() { _error("StackOverflowError", ""); }
|
||||||
|
void RecursionError() { _error("RecursionError", "maximum recursion depth exceeded"); }
|
||||||
void IOError(const Str& msg) { _error("IOError", msg); }
|
void IOError(const Str& msg) { _error("IOError", msg); }
|
||||||
void NotImplementedError(){ _error("NotImplementedError", ""); }
|
void NotImplementedError(){ _error("NotImplementedError", ""); }
|
||||||
void TypeError(const Str& msg){ _error("TypeError", msg); }
|
void TypeError(const Str& msg){ _error("TypeError", msg); }
|
||||||
@ -863,6 +866,8 @@ inline PyObject* VM::_vectorcall(int ARGC, int KWARGC, bool op_call){
|
|||||||
|
|
||||||
inline PyObject* VM::_py_call(PyObject** sp_base, PyObject* callable, ArgsView args, ArgsView kwargs){
|
inline PyObject* VM::_py_call(PyObject** sp_base, PyObject* callable, ArgsView args, ArgsView kwargs){
|
||||||
// callable must be a `function` object
|
// callable must be a `function` object
|
||||||
|
if(callstack.size() >= recursionlimit) RecursionError();
|
||||||
|
|
||||||
const Function& fn = CAST(Function&, callable);
|
const Function& fn = CAST(Function&, callable);
|
||||||
const CodeObject* co = fn.decl->code.get();
|
const CodeObject* co = fn.decl->code.get();
|
||||||
FastLocals locals(co);
|
FastLocals locals(co);
|
||||||
@ -907,7 +912,8 @@ inline PyObject* VM::_py_call(PyObject** sp_base, PyObject* callable, ArgsView a
|
|||||||
}
|
}
|
||||||
PyObject* _module = fn._module != nullptr ? fn._module : top_frame()->_module;
|
PyObject* _module = fn._module != nullptr ? fn._module : top_frame()->_module;
|
||||||
|
|
||||||
// TODO: callable may be garbage collected
|
// TODO: callable may be garbage collected if it is a temporary object
|
||||||
|
// very unlikely to happen, but still possible
|
||||||
s_data.reset(sp_base);
|
s_data.reset(sp_base);
|
||||||
PyObject** curr_sp = s_data._sp;
|
PyObject** curr_sp = s_data._sp;
|
||||||
if(co->is_generator){
|
if(co->is_generator){
|
||||||
|
Loading…
x
Reference in New Issue
Block a user