mirror of
				https://github.com/pocketpy/pocketpy
				synced 2025-10-25 14:00:18 +00:00 
			
		
		
		
	
		
			
				
	
	
	
		
			2.4 KiB
		
	
	
	
	
	
	
	
			
		
		
	
	
			2.4 KiB
		
	
	
	
	
	
	
	
| icon | label | order | 
|---|---|---|
| dot | Execute Python code | 93 | 
Simple execution
Once you have a VM instance, you can execute python code by calling exec method.
PyObject* exec(Str source, Str filename, CompileMode mode, PyObject* _module=nullptr)
- source, the python source code to be executed
- filename, the filename of the source code. This is used for error reporting
- mode, the compile mode. See below for details
- module, the module where the code will be executed. If- nullptr, the code will be executed in the- __main__module
exec handles possible exceptions and returns a PyObject*.
If the execution is not successful, e.g. a syntax error or a runtime exception,
the return value will be nullptr.
There are also overloaded versions of exec and eval, which is useful for simple execution:
- PyObject* exec(Str source)
- PyObject* eval(Str source)
Compile mode
The mode parameter controls how the source code is compiled. There are 5 possible values:
- EXEC_MODE, this is the default mode. Just do normal execution.
- EVAL_MODE, this mode is used for evaluating a single expression. The- sourceshould be a single expression. It cannot contain any statements.
- REPL_MODE, this mode is used for REPL. It is similar to- EXEC_MODE, but generates- PRINT_EXPRopcode when necessary.
- CELL_MODE, this mode is designed for Jupyter like execution. It is similar to- EXEC_MODE, but generates- PRINT_EXPRopcode when necessary.
- JSON_MODE, this mode is used for JSON parsing. It is similar to- EVAL_MODE, but uses a lexing rule designed for JSON.
Fine-grained execution
In some cases, you may want to execute python code in a more fine-grained way. These two methods are provided for this purpose:
- CodeObject_ compile(Str source, Str filename, CompileMode mode, bool unknown_global_scope)
- PyObject* _exec(CodeObject_ co, PyObject* _module)
- compilecompiles the source code into a- CodeObject_instance. Leave- unknown_global_scopeto- falseif you don't know what it means.
- _execexecutes the- CodeObject_instance.
!!!
_exec does not handle exceptions, you need to use try..catch manually.
!!!
try{
    PyObject* result = vm->exec("123", "<eval>", EVAL_MODE);
    std::cout << py_cast<int>(vm, result);   // 123
}catch(Exception& e){
    // use e.summary() to get a summary of the exception
    std::cerr << e.summary() << std::endl;
}