diff --git a/docs/godot/bintr.md b/docs/godot/bintr.md index 2588d70..18d78eb 100644 --- a/docs/godot/bintr.md +++ b/docs/godot/bintr.md @@ -1,5 +1,5 @@ --- -sidebar_position: 8 +sidebar_position: 9 --- # Binary Translation diff --git a/docs/godot/cmake.md b/docs/godot/cmake.md index ec9680d..68e45e8 100644 --- a/docs/godot/cmake.md +++ b/docs/godot/cmake.md @@ -1,5 +1,5 @@ --- -sidebar_position: 10 +sidebar_position: 11 --- # CMake Projects diff --git a/docs/godot/cppapi.md b/docs/godot/cppapi.md index 7a1a19c..ae6efa8 100644 --- a/docs/godot/cppapi.md +++ b/docs/godot/cppapi.md @@ -1,5 +1,5 @@ --- -sidebar_position: 11 +sidebar_position: 12 --- # C++ API Reference diff --git a/docs/godot/cppexamples.md b/docs/godot/cppexamples.md index 3a021a6..9eb9241 100644 --- a/docs/godot/cppexamples.md +++ b/docs/godot/cppexamples.md @@ -1,5 +1,5 @@ --- -sidebar_position: 6 +sidebar_position: 7 --- # C++ Examples diff --git a/docs/godot/memory.md b/docs/godot/memory.md new file mode 100644 index 0000000..13b4b4a --- /dev/null +++ b/docs/godot/memory.md @@ -0,0 +1,147 @@ +--- +sidebar_position: 6 +--- + +# Memory + +Memory in the Sandbox works just as anyone would expect. If you store something in memory, it will be there when you come back. All language-native code will work just you expect, until the Sandbox is freed. + +An exception to this rule is temporary Variants and object references. The reason behind this is that they represent data with unclear lifetimes that may be passed to Godot. In order to avoid architectural blunders, the Sandbox has been designed to account for lifetimes in a brutal way from the start: + +It does so by keeping track of and terminating all Variants that are created during a function call. This also makes it possible to place a limit, if desirable. In order to use Variants not just during calls they have to be: + +- Created during initialization, or +- Stored into another (eg. Array, Dictionary, Callable), or +- Returned from the function + +Let's go through this example by example. + +## Variants with storage + +```cpp +struct MyStuff { + int a; + std::string b; + std::unordered_map c; +}; +static std::vector mystuff; +``` + +As shown above: Any interaction with mystuff works exactly like normal. All language-native code works normally. + +```cpp +struct MyStuff { + Variant a; + std::vector b; +}; +static std::vector mystuff; +``` + +Any interaction with mystuff is destined to fail. Variants created after initialization can only be remembered after the call if they are attached to something outside of the Sandbox or something created during initialization. + +```cpp +static Array array = Array::Create(); +``` + +As shown above: This Variant of type ARRAY is created during initialization. It's storage is *not temporary*. We can freely add Variants to it later. These Variants are copied and stored into the Array: + +```cpp +static Array array = Array::Create(); + +Variant function_call_after_init() { + array.push_back(Variant(1)); + array.push_back(String("")); + array.push_back(Dictionary::Create()); + return Nil; +} +``` + +As shown above: Because the Array has storage, we can assign temporary Variants to it and they will become copied into it, receiving storage too. + +The same rule applies to Dictionary. Strings are immutable and creating a new String in order to assign it to a global String _will not work_: + +```cpp +static String str = "123"; + +Variant function_call_after_init() { + str = "456"; + // After returning, the new string evaporates. + return Nil; +} +``` + +As shown above, the Variant of type STRING is permanent, but overwriting it with a new temporary string will not work after the call ends. + +The rule is that temporary Variants evaporate after the call ends, as they don't have "real" storage. + +```cpp +static String str1 = "123"; +static String str2 = "456"; + +Variant function_call_after_init() { + static Array array = Array::Create(); + str1 = str2; + return Nil; +} +``` + +Assigning one global to another works. The array is created the first time the function gets called which is after initialization, and it is freed after the call. + +## Variants without storage + +Often you will end up using Variants during a function call. In that case, everything works like expected. Return values also always work like expected. + +```cpp +Variant function_call_after_init() { + String str1 = "123"; + String str2 = "456"; + + return str1 + str2; +} +``` + +This function returns `"123456"` back to the caller. + +The temporary strings `str1` and `str2` evaporate after the call ends. + +```cpp +Variant function_call_after_init() { + Dictionary d = Dictionary::Create(); + d[123] = 456; + d["123"] = "456"; + + return d; +} +``` + +As shown above: The function returns a Dictionary with 2 elements back to the caller. + + +## Making permanent Variants + +You can store a Variant permanently during a call by making it permanent: + +```cpp +static Variant pv; + +Variant function_call_after_init() { + Dictionary d = Dictionary::Create(); + d[123] = 456; + d["123"] = "456"; + + // First turn into Variant + Variant v(d); + pv = v.make_permanent(); + + return pv; +} +``` + +Making it permanent will allocate a slot in the permanent Variant group used by initialization. The Variant will be moved into that slot, and `v` will be updated to reflect the new underlying id. It returns a reference to its (updated) self. After that we can safely assign it to a global. + +```py +var s = Sandbox.new() +s.references_max = 100 +``` + +There are a finite amount of permanent slots, controlled by you. Keep in mind that sometimes you don't know what a program does, as you didn't write it. Making storage explicit is intentional. diff --git a/docs/godot/modding.md b/docs/godot/modding.md index 26ec1ad..3419558 100644 --- a/docs/godot/modding.md +++ b/docs/godot/modding.md @@ -1,5 +1,5 @@ --- -sidebar_position: 9 +sidebar_position: 10 --- # Modding and APIs diff --git a/docs/godot/sugar.md b/docs/godot/sugar.md index 9402f6f..61fde19 100644 --- a/docs/godot/sugar.md +++ b/docs/godot/sugar.md @@ -1,5 +1,5 @@ --- -sidebar_position: 7 +sidebar_position: 8 --- # Adding sugar