mirror of
				https://github.com/pocketpy/pocketpy
				synced 2025-10-25 05:50:17 +00:00 
			
		
		
		
	
		
			
				
	
	
		
			154 lines
		
	
	
		
			5.2 KiB
		
	
	
	
		
			Markdown
		
	
	
	
	
	
			
		
		
	
	
			154 lines
		
	
	
		
			5.2 KiB
		
	
	
	
		
			Markdown
		
	
	
	
	
	
| ---
 | |
| label: Virtual machine
 | |
| icon: dot
 | |
| order: 20
 | |
| ---
 | |
| 
 | |
| The `VM` class provides a sandboxed Python environment and a set of APIs for interacting with it.
 | |
| Using the namespace `PocketPython` before any operations.
 | |
| 
 | |
| ```csharp
 | |
| using PocketPython;
 | |
| ```
 | |
| 
 | |
| ### Construction
 | |
| 
 | |
| + `VM()`
 | |
| 
 | |
|     Create a new Python virtual machine.
 | |
| 
 | |
| ### Code Execution
 | |
| 
 | |
| + `CodeObject Compile(string source, string filename, CompileMode mode)`
 | |
| 
 | |
|     Compile Python source code into a `CodeObject` that can be executed later.
 | |
|     The `filename` parameter is used for error reporting, you can set it to `main.py` if you don't need it.
 | |
|     The `mode` parameter specifies the compile mode, see [CompileMode](../quick-start/exec/#compile-mode) for details.
 | |
| 
 | |
| + `object Exec(CodeObject co, PyModule mod = null)`
 | |
| 
 | |
|     Execute a `CodeObject` in the given module.
 | |
|     The `mod` parameter specifies the module in which the code will be executed.
 | |
|     If it is `null`, the code will be executed in the main module.
 | |
| 
 | |
| + `object Exec(string source, string filename, CompileMode mode = CompileMode.EXEC_MODE, PyModule mod = null)`
 | |
| 
 | |
|     Compile and execute Python source code in the given module. It is equivalent to `Exec(Compile(source, filename, mode), mod)`.
 | |
| 
 | |
| + `object Eval(string source, PyModule mod = null)`
 | |
| 
 | |
|     Evaluate an expression in the given module.
 | |
| 
 | |
| + `object Call(object callable, object[] args, Dictionary<string, object> kwargs)`
 | |
| 
 | |
|     Call a Python callable object with the given arguments and keyword arguments. It is equivalent to `callable(*args, **kwargs)` in Python.
 | |
| 
 | |
| + `object CallMethod(object obj, string name, params object[] args)`
 | |
| 
 | |
|     Call a method of a Python object with the given arguments. It is equivalent to `obj.name(*args)` in Python.
 | |
| 
 | |
| 
 | |
| ### Attribute Access
 | |
| 
 | |
| + `object GetAttr(object obj, string name, bool throwErr = true)`
 | |
| 
 | |
|     Get an attribute of a Python object. It is equivalent to `obj.name` in Python.
 | |
|     If `throwErr` is `true`, it will throw an exception if the attribute does not exist.
 | |
|     Otherwise, it will return `null`.
 | |
| 
 | |
| + `NoneType SetAttr(object obj, string name, object value)`
 | |
| 
 | |
|     Set an attribute of a Python object. It is equivalent to `obj.name = value` in Python.
 | |
| 
 | |
| + `bool HasAttr(object obj, string name)`
 | |
| 
 | |
|     Check if a Python object has the given attribute. It is equivalent to `hasattr(obj, name)` in Python.
 | |
| 
 | |
| ### Module Access
 | |
| 
 | |
| + `Dictionary<string, PyModule> modules`
 | |
| 
 | |
|     A dictionary that maps module names to `PyModule` objects.
 | |
|     You can use it to access the modules that have been imported.
 | |
| 
 | |
| + `Dictionary<string, string> lazyModules`
 | |
| 
 | |
|     A dictionary stores all unimported modules. You can add Python source into this dictionary.
 | |
|     It will be initialized and moved to `modules` when it is first imported.
 | |
| 
 | |
| + `PyModule NewModule(string name)`
 | |
| 
 | |
|     Create a new module with the given name at runtime. The module will be added to `modules` automatically.
 | |
| 
 | |
| + `PyModule PyImport(string name)`
 | |
| 
 | |
|     Import a Python module. It is equivalent to `import name` in Python. It first checks if the module has been imported, if not, it will try to load the module from `lazyModules`.
 | |
| 
 | |
| 
 | |
| ### Type Conversion
 | |
| 
 | |
| + `T PyCast<T>(object obj)`
 | |
| 
 | |
|     Convert a Python object to a C# object. It is equivalent to `obj as T` in C#.
 | |
|     Raise `TypeError` if the conversion fails.
 | |
| 
 | |
| + `bool IsInstance(object obj, PyTypeObject type)`
 | |
| 
 | |
|     Check if a Python object is an instance of the given type. It is equivalent to `isinstance(obj, type)` in Python.
 | |
| 
 | |
| + `void CheckType<T>(object t)`
 | |
| 
 | |
|     Check if `t is T`. Raise `TypeError` if the check fails.
 | |
| 
 | |
| + `bool PyEquals(object lhs, object rhs)`
 | |
| 
 | |
|     Check if two Python objects are equal. It is equivalent to `lhs == rhs` in Python. This is different from `==` or `object.ReferenceEquals` in C#. You should always use this method to compare Python objects.
 | |
| 
 | |
| + `object PyIter(object obj)`
 | |
| 
 | |
|     Get an iterator of a Python object. It is equivalent to `iter(obj)` in Python.
 | |
| 
 | |
| + `object PyNext(object obj)`
 | |
| 
 | |
|     Get the next element of a Python iterator. It is equivalent to `next(obj)` in Python.
 | |
| 
 | |
| + `bool PyBool(object obj)`
 | |
| 
 | |
|     Convert a Python object to a boolean value. It is equivalent to `bool(obj)` in Python.
 | |
| 
 | |
| + `string PyStr(object obj)`
 | |
| 
 | |
|     Convert a Python object to a string. It is equivalent to `str(obj)` in Python.
 | |
| 
 | |
| + `string PyRepr(object obj)`
 | |
| 
 | |
|     Convert a Python object to a string representation. It is equivalent to `repr(obj)` in Python.
 | |
| 
 | |
| + `int PyHash(object obj)`
 | |
| 
 | |
|     Get the hash value of a Python object. It is equivalent to `hash(obj)` in Python.
 | |
| 
 | |
| + `List<object> PyList(object obj)`
 | |
| 
 | |
|     Convert an `Iterable` Python object to a list. It is equivalent to `list(obj)` in Python.
 | |
| 
 | |
| ### Callbacks
 | |
| 
 | |
| + `System.Action<string> stdout = Debug.Log`
 | |
| 
 | |
|     A callback that will be called when the Python code invokes `print` function.
 | |
|     By default, it will print the message to Unity console.
 | |
| 
 | |
| + `System.Action<string> stderr = null`
 | |
| 
 | |
|     A callback that will be called when the Python code emits an error message.
 | |
|     By default, an Exception will be raised.
 | |
|     You can set it to `Debug.LogError` for printing to the Unity Console.
 | |
| 
 | |
| ### Debug Flag
 | |
| 
 | |
| + `bool debug = false`
 | |
| 
 | |
|     A flag that controls whether to print debug messages to Unity console.
 | |
|     You can set it to `true` to enable debug messages, or `false` to disable them.
 |