mirror of
				https://github.com/pocketpy/pocketpy
				synced 2025-10-25 05:50:17 +00:00 
			
		
		
		
	This commit is contained in:
		
							parent
							
								
									657e9b4313
								
							
						
					
					
						commit
						dd27071b22
					
				| @ -43,10 +43,10 @@ | |||||||
| #define DEBUG_NO_AUTO_GC			0 | #define DEBUG_NO_AUTO_GC			0 | ||||||
| #define DEBUG_GC_STATS				0 | #define DEBUG_GC_STATS				0 | ||||||
| 
 | 
 | ||||||
| #if (defined(__ANDROID__) && __ANDROID_API__ <= 22) || defined(__EMSCRIPTEN__) | #if (defined(__ANDROID__) && __ANDROID_API__ <= 22) | ||||||
| #define PK_ENABLE_FILEIO 			0 | #define PK_ENABLE_OS 			0 | ||||||
| #else | #else | ||||||
| #define PK_ENABLE_FILEIO 			1 | #define PK_ENABLE_OS 			1 | ||||||
| #endif | #endif | ||||||
| 
 | 
 | ||||||
| // This is the maximum number of arguments in a function declaration
 | // This is the maximum number of arguments in a function declaration
 | ||||||
|  | |||||||
							
								
								
									
										2
									
								
								src/io.h
									
									
									
									
									
								
							
							
						
						
									
										2
									
								
								src/io.h
									
									
									
									
									
								
							| @ -4,7 +4,7 @@ | |||||||
| #include "cffi.h" | #include "cffi.h" | ||||||
| #include "common.h" | #include "common.h" | ||||||
| 
 | 
 | ||||||
| #if PK_ENABLE_FILEIO | #if PK_ENABLE_OS | ||||||
| 
 | 
 | ||||||
| #include <fstream> | #include <fstream> | ||||||
| #include <filesystem> | #include <filesystem> | ||||||
|  | |||||||
| @ -6,7 +6,7 @@ | |||||||
| #ifndef __EMSCRIPTEN__ | #ifndef __EMSCRIPTEN__ | ||||||
| 
 | 
 | ||||||
| int main(int argc, char** argv){ | int main(int argc, char** argv){ | ||||||
|     pkpy::VM* vm = pkpy_new_vm(true); |     pkpy::VM* vm = pkpy_new_vm(true, true); | ||||||
|     vm->bind_builtin_func<0>("input", [](pkpy::VM* vm, pkpy::ArgsView args){ |     vm->bind_builtin_func<0>("input", [](pkpy::VM* vm, pkpy::ArgsView args){ | ||||||
|         return VAR(pkpy::getline()); |         return VAR(pkpy::getline()); | ||||||
|     }); |     }); | ||||||
|  | |||||||
| @ -828,12 +828,15 @@ inline void VM::post_init(){ | |||||||
|     add_module_math(this); |     add_module_math(this); | ||||||
|     add_module_re(this); |     add_module_re(this); | ||||||
|     add_module_dis(this); |     add_module_dis(this); | ||||||
|     add_module_io(this); |  | ||||||
|     add_module_os(this); |  | ||||||
|     add_module_c(this); |     add_module_c(this); | ||||||
|     add_module_gc(this); |     add_module_gc(this); | ||||||
|     add_module_random(this); |     add_module_random(this); | ||||||
| 
 | 
 | ||||||
|  |     if(enable_os){ | ||||||
|  |         add_module_io(this); | ||||||
|  |         add_module_os(this); | ||||||
|  |     } | ||||||
|  | 
 | ||||||
|     for(const char* name: {"this", "functools", "collections", "heapq", "bisect"}){ |     for(const char* name: {"this", "functools", "collections", "heapq", "bisect"}){ | ||||||
|         _lazy_modules[name] = kPythonLibs[name]; |         _lazy_modules[name] = kPythonLibs[name]; | ||||||
|     } |     } | ||||||
| @ -970,8 +973,8 @@ extern "C" { | |||||||
| 
 | 
 | ||||||
|     __EXPORT |     __EXPORT | ||||||
|     /// Create a virtual machine.
 |     /// Create a virtual machine.
 | ||||||
|     pkpy::VM* pkpy_new_vm(bool use_stdio){ |     pkpy::VM* pkpy_new_vm(bool use_stdio, bool enable_os){ | ||||||
|         return PKPY_ALLOCATE(pkpy::VM, use_stdio); |         return PKPY_ALLOCATE(pkpy::VM, use_stdio, enable_os); | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|     __EXPORT |     __EXPORT | ||||||
|  | |||||||
							
								
								
									
										4
									
								
								src/vm.h
									
									
									
									
									
								
							
							
						
						
									
										4
									
								
								src/vm.h
									
									
									
									
									
								
							| @ -104,7 +104,9 @@ public: | |||||||
|     Type tp_slice, tp_range, tp_module; |     Type tp_slice, tp_range, tp_module; | ||||||
|     Type tp_super, tp_exception, tp_bytes; |     Type tp_super, tp_exception, tp_bytes; | ||||||
| 
 | 
 | ||||||
|     VM(bool use_stdio) : heap(this){ |     const bool enable_os; | ||||||
|  | 
 | ||||||
|  |     VM(bool use_stdio, bool enable_os) : heap(this), enable_os(enable_os) { | ||||||
|         this->vm = this; |         this->vm = this; | ||||||
|         this->_stdout = use_stdio ? &std::cout : &_stdout_buffer; |         this->_stdout = use_stdio ? &std::cout : &_stdout_buffer; | ||||||
|         this->_stderr = use_stdio ? &std::cerr : &_stderr_buffer; |         this->_stderr = use_stdio ? &std::cerr : &_stderr_buffer; | ||||||
|  | |||||||
		Loading…
	
	
			
			x
			
			
		
	
		Reference in New Issue
	
	Block a user