mirror of
				https://github.com/pocketpy/pocketpy
				synced 2025-10-25 14:00:18 +00:00 
			
		
		
		
	some refactor
This commit is contained in:
		
							parent
							
								
									bb27112575
								
							
						
					
					
						commit
						99457e1797
					
				| @ -180,7 +180,6 @@ public: | |||||||
|     static constexpr Type tp_list=6, tp_tuple=7; |     static constexpr Type tp_list=6, tp_tuple=7; | ||||||
|     static constexpr Type tp_slice=8, tp_range=9, tp_module=10; |     static constexpr Type tp_slice=8, tp_range=9, tp_module=10; | ||||||
|     static constexpr Type tp_function=11, tp_native_func=12, tp_bound_method=13; |     static constexpr Type tp_function=11, tp_native_func=12, tp_bound_method=13; | ||||||
|      |  | ||||||
|     static constexpr Type tp_super=14, tp_exception=15, tp_bytes=16, tp_mappingproxy=17; |     static constexpr Type tp_super=14, tp_exception=15, tp_bytes=16, tp_mappingproxy=17; | ||||||
|     static constexpr Type tp_dict=18, tp_property=19, tp_star_wrapper=20; |     static constexpr Type tp_dict=18, tp_property=19, tp_star_wrapper=20; | ||||||
|     static constexpr Type tp_staticmethod=21, tp_classmethod=22; |     static constexpr Type tp_staticmethod=21, tp_classmethod=22; | ||||||
| @ -213,7 +212,7 @@ public: | |||||||
| 
 | 
 | ||||||
|     /********** utils **********/ |     /********** utils **********/ | ||||||
|     PyObject* new_module(Str name, Str package=""); |     PyObject* new_module(Str name, Str package=""); | ||||||
|     ArgsView _cast_array_view(PyObject* obj); |     ArgsView cast_array_view(PyObject* obj); | ||||||
|     void set_main_argv(int argc, char** argv); |     void set_main_argv(int argc, char** argv); | ||||||
|     i64 normalized_index(i64 index, int size); |     i64 normalized_index(i64 index, int size); | ||||||
|     Str disassemble(CodeObject_ co); |     Str disassemble(CodeObject_ co); | ||||||
| @ -244,16 +243,14 @@ public: | |||||||
| 
 | 
 | ||||||
|     template<typename... Args> |     template<typename... Args> | ||||||
|     PyObject* call(PyObject* callable, Args&&... args){ |     PyObject* call(PyObject* callable, Args&&... args){ | ||||||
|         PUSH(callable); |         PUSH(callable); PUSH(PY_NULL); | ||||||
|         PUSH(PY_NULL); |  | ||||||
|         __push_varargs(args...); |         __push_varargs(args...); | ||||||
|         return vectorcall(sizeof...(args)); |         return vectorcall(sizeof...(args)); | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|     template<typename... Args> |     template<typename... Args> | ||||||
|     PyObject* call_method(PyObject* self, PyObject* callable, Args&&... args){ |     PyObject* call_method(PyObject* self, PyObject* callable, Args&&... args){ | ||||||
|         PUSH(callable); |         PUSH(callable); PUSH(self); | ||||||
|         PUSH(self); |  | ||||||
|         __push_varargs(args...); |         __push_varargs(args...); | ||||||
|         return vectorcall(sizeof...(args)); |         return vectorcall(sizeof...(args)); | ||||||
|     } |     } | ||||||
| @ -335,6 +332,7 @@ public: | |||||||
|     void IOError(const Str& msg) { __builtin_error("IOError", msg); } |     void IOError(const Str& msg) { __builtin_error("IOError", msg); } | ||||||
|     void NotImplementedError(){ __builtin_error("NotImplementedError"); } |     void NotImplementedError(){ __builtin_error("NotImplementedError"); } | ||||||
|     void TypeError(const Str& msg){ __builtin_error("TypeError", msg); } |     void TypeError(const Str& msg){ __builtin_error("TypeError", msg); } | ||||||
|  |     void TypeError(Type expected, Type actual) { TypeError("expected " + _type_name(vm, expected).escape() + ", got " + _type_name(vm, actual).escape()); } | ||||||
|     void IndexError(const Str& msg){ __builtin_error("IndexError", msg); } |     void IndexError(const Str& msg){ __builtin_error("IndexError", msg); } | ||||||
|     void ValueError(const Str& msg){ __builtin_error("ValueError", msg); } |     void ValueError(const Str& msg){ __builtin_error("ValueError", msg); } | ||||||
|     void RuntimeError(const Str& msg){ __builtin_error("RuntimeError", msg); } |     void RuntimeError(const Str& msg){ __builtin_error("RuntimeError", msg); } | ||||||
| @ -346,42 +344,27 @@ public: | |||||||
|     void ImportError(const Str& msg){ __builtin_error("ImportError", msg); } |     void ImportError(const Str& msg){ __builtin_error("ImportError", msg); } | ||||||
|     void AssertionError(const Str& msg){ __builtin_error("AssertionError", msg); } |     void AssertionError(const Str& msg){ __builtin_error("AssertionError", msg); } | ||||||
|     void AssertionError(){ __builtin_error("AssertionError"); } |     void AssertionError(){ __builtin_error("AssertionError"); } | ||||||
| 
 |  | ||||||
|     void BinaryOptError(const char* op, PyObject* _0, PyObject* _1); |     void BinaryOptError(const char* op, PyObject* _0, PyObject* _1); | ||||||
|     void AttributeError(PyObject* obj, StrName name); |     void AttributeError(PyObject* obj, StrName name); | ||||||
|     void AttributeError(const Str& msg){ __builtin_error("AttributeError", msg); } |     void AttributeError(const Str& msg){ __builtin_error("AttributeError", msg); } | ||||||
| 
 | 
 | ||||||
|     /********** type **********/ |     /********** type **********/ | ||||||
|     PyObject* new_type_object(PyObject* mod, StrName name, Type base, bool subclass_enabled=true); |     PyObject* new_type_object(PyObject* mod, StrName name, Type base, bool subclass_enabled=true); | ||||||
|      |  | ||||||
|     const PyTypeInfo* _inst_type_info(PyObject* obj); |     const PyTypeInfo* _inst_type_info(PyObject* obj); | ||||||
|     bool isinstance(PyObject* obj, Type base); |     bool isinstance(PyObject* obj, Type base); | ||||||
|     bool issubclass(Type cls, Type base); |     bool issubclass(Type cls, Type base); | ||||||
| 
 |     void check_type(PyObject* obj, Type type){ if(!is_type(obj, type)) TypeError(type, _tp(obj)); } | ||||||
|     void check_type(PyObject* obj, Type type){ |     void check_compatible_type(PyObject* obj, Type type){ if(!isinstance(obj, type)) TypeError(type, _tp(obj)); } | ||||||
|         if(is_type(obj, type)) return; |     PyObject* _t(PyObject* obj){ return _all_types[_tp(obj)].obj; } | ||||||
|         TypeError("expected " + _type_name(vm, type).escape() + ", got " + _type_name(vm, _tp(obj)).escape()); |     PyObject* _t(Type t){ return _all_types[t.index].obj; } | ||||||
|     } |     Type _tp(PyObject* obj){ return is_small_int(obj) ? tp_int : obj->type; } | ||||||
| 
 |  | ||||||
|     void check_compatible_type(PyObject* obj, Type type){ |  | ||||||
|         if(isinstance(obj, type)) return; |  | ||||||
|         TypeError("expected " + _type_name(vm, type).escape() + ", got " + _type_name(vm, _tp(obj)).escape()); |  | ||||||
|     } |  | ||||||
| 
 |  | ||||||
|     PyObject* _t(Type t){ |  | ||||||
|         return _all_types[t.index].obj; |  | ||||||
|     } |  | ||||||
| 
 |  | ||||||
|     Type _tp(PyObject* obj){ |  | ||||||
|         if(!is_tagged(obj)) return obj->type; |  | ||||||
|         return tp_int; |  | ||||||
|     } |  | ||||||
| 
 |  | ||||||
|     PyObject* _t(PyObject* obj){ |  | ||||||
|         return _all_types[_tp(obj).index].obj; |  | ||||||
|     } |  | ||||||
| 
 | 
 | ||||||
|     /********** user type **********/ |     /********** user type **********/ | ||||||
|  |     template<typename T> | ||||||
|  |     Type _tp_user(){ return _find_type_in_cxx_typeid_map<T>(); } | ||||||
|  |     template<typename T> | ||||||
|  |     bool is_user_type(PyObject* obj){ return _tp(obj) == _tp_user<T>(); } | ||||||
|  | 
 | ||||||
|     template<typename T> |     template<typename T> | ||||||
|     PyObject* register_user_class(PyObject* mod, StrName name, bool subclass_enabled=false){ |     PyObject* register_user_class(PyObject* mod, StrName name, bool subclass_enabled=false){ | ||||||
|         PyObject* type = new_type_object(mod, name, 0, subclass_enabled); |         PyObject* type = new_type_object(mod, name, 0, subclass_enabled); | ||||||
| @ -396,16 +379,6 @@ public: | |||||||
|         return heap.gcnew<T>(_tp_user<T>(), std::forward<Args>(args)...); |         return heap.gcnew<T>(_tp_user<T>(), std::forward<Args>(args)...); | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|     template<typename T> |  | ||||||
|     Type _tp_user(){ |  | ||||||
|         return _find_type_in_cxx_typeid_map<T>(); |  | ||||||
|     } |  | ||||||
| 
 |  | ||||||
|     template<typename T> |  | ||||||
|     bool is_user_type(PyObject* obj){ |  | ||||||
|         return _tp(obj) == _tp_user<T>(); |  | ||||||
|     } |  | ||||||
| 
 |  | ||||||
|     template<typename T> |     template<typename T> | ||||||
|     Type _find_type_in_cxx_typeid_map(){ |     Type _find_type_in_cxx_typeid_map(){ | ||||||
|         auto it = _cxx_typeid_map.find(typeid(T)); |         auto it = _cxx_typeid_map.find(typeid(T)); | ||||||
| @ -421,9 +394,9 @@ public: | |||||||
|         return it->second; |         return it->second; | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|  |     /********** private **********/ | ||||||
|     virtual ~VM(); |     virtual ~VM(); | ||||||
| 
 | 
 | ||||||
|     /********** private **********/ |  | ||||||
| #if PK_DEBUG_CEVAL_STEP | #if PK_DEBUG_CEVAL_STEP | ||||||
|     void __log_s_data(const char* title = nullptr); |     void __log_s_data(const char* title = nullptr); | ||||||
| #endif | #endif | ||||||
|  | |||||||
| @ -178,7 +178,7 @@ struct Random{ | |||||||
| 
 | 
 | ||||||
|         vm->bind_method<1>(type, "choice", [](VM* vm, ArgsView args) { |         vm->bind_method<1>(type, "choice", [](VM* vm, ArgsView args) { | ||||||
|             Random& self = PK_OBJ_GET(Random, args[0]); |             Random& self = PK_OBJ_GET(Random, args[0]); | ||||||
|             ArgsView view = vm->_cast_array_view(args[1]); |             ArgsView view = vm->cast_array_view(args[1]); | ||||||
|             if(view.empty()) vm->IndexError("cannot choose from an empty sequence"); |             if(view.empty()) vm->IndexError("cannot choose from an empty sequence"); | ||||||
|             int index = self.gen.randint(0, view.size()-1); |             int index = self.gen.randint(0, view.size()-1); | ||||||
|             return view[index]; |             return view[index]; | ||||||
| @ -186,7 +186,7 @@ struct Random{ | |||||||
| 
 | 
 | ||||||
|         vm->bind(type, "choices(self, population, weights=None, k=1)", [](VM* vm, ArgsView args) { |         vm->bind(type, "choices(self, population, weights=None, k=1)", [](VM* vm, ArgsView args) { | ||||||
|             Random& self = PK_OBJ_GET(Random, args[0]); |             Random& self = PK_OBJ_GET(Random, args[0]); | ||||||
|             ArgsView view = vm->_cast_array_view(args[1]); |             ArgsView view = vm->cast_array_view(args[1]); | ||||||
|             PyObject** data = view.begin(); |             PyObject** data = view.begin(); | ||||||
|             int size = view.size(); |             int size = view.size(); | ||||||
|             if(size == 0) vm->IndexError("cannot choose from an empty sequence"); |             if(size == 0) vm->IndexError("cannot choose from an empty sequence"); | ||||||
| @ -194,7 +194,7 @@ struct Random{ | |||||||
|             if(args[2] == vm->None){ |             if(args[2] == vm->None){ | ||||||
|                 for(int i = 0; i < size; i++) cum_weights[i] = i + 1; |                 for(int i = 0; i < size; i++) cum_weights[i] = i + 1; | ||||||
|             }else{ |             }else{ | ||||||
|                 ArgsView weights = vm->_cast_array_view(args[2]); |                 ArgsView weights = vm->cast_array_view(args[2]); | ||||||
|                 if(weights.size() != size) vm->ValueError(_S("len(weights) != ", size)); |                 if(weights.size() != size) vm->ValueError(_S("len(weights) != ", size)); | ||||||
|                 cum_weights[0] = CAST(f64, weights[0]); |                 cum_weights[0] = CAST(f64, weights[0]); | ||||||
|                 for(int i = 1; i < size; i++){ |                 for(int i = 1; i < size; i++){ | ||||||
|  | |||||||
| @ -113,7 +113,7 @@ namespace pkpy{ | |||||||
|         return nullptr; |         return nullptr; | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|     ArgsView VM::_cast_array_view(PyObject* obj){ |     ArgsView VM::cast_array_view(PyObject* obj){ | ||||||
|         if(is_type(obj, VM::tp_list)){ |         if(is_type(obj, VM::tp_list)){ | ||||||
|             List& list = PK_OBJ_GET(List, obj); |             List& list = PK_OBJ_GET(List, obj); | ||||||
|             return ArgsView(list.begin(), list.end()); |             return ArgsView(list.begin(), list.end()); | ||||||
| @ -284,7 +284,7 @@ namespace pkpy{ | |||||||
|          |          | ||||||
|         ArgsView view(nullptr, nullptr); |         ArgsView view(nullptr, nullptr); | ||||||
|         if(args_tuple.size()==1){ |         if(args_tuple.size()==1){ | ||||||
|             view = _cast_array_view(args_tuple[0]); |             view = cast_array_view(args_tuple[0]); | ||||||
|         }else{ |         }else{ | ||||||
|             view = ArgsView(args_tuple); |             view = ArgsView(args_tuple); | ||||||
|         } |         } | ||||||
|  | |||||||
		Loading…
	
	
			
			x
			
			
		
	
		Reference in New Issue
	
	Block a user