mirror of
https://github.com/CompeyDev/lune-packaging.git
synced 2025-01-09 20:29:10 +00:00
Fix _G
This commit is contained in:
parent
cd434cf68c
commit
a6ed00ad33
5 changed files with 27 additions and 2 deletions
|
@ -25,6 +25,8 @@ and this project adheres to [Semantic Versioning](https://semver.org/spec/v2.0.0
|
||||||
|
|
||||||
### Fixed
|
### Fixed
|
||||||
|
|
||||||
|
- Fixed `_G` not being a readable & writable table
|
||||||
|
- Fixed `_G` containing normal globals such as `print`, `math`, ...
|
||||||
- Fixed using instances as keys in tables
|
- Fixed using instances as keys in tables
|
||||||
|
|
||||||
## `0.6.5` - March 27th, 2023
|
## `0.6.5` - March 27th, 2023
|
||||||
|
|
|
@ -40,11 +40,10 @@ pub fn create(lua: &'static Lua, args: Vec<String>) -> LuaResult<()> {
|
||||||
("printinfo", lua.create_function(top_level::printinfo)?),
|
("printinfo", lua.create_function(top_level::printinfo)?),
|
||||||
];
|
];
|
||||||
|
|
||||||
// Set top-level globals and seal them
|
// Set top-level globals
|
||||||
for (name, global) in globals {
|
for (name, global) in globals {
|
||||||
lua_globals.set(name, global)?;
|
lua_globals.set(name, global)?;
|
||||||
}
|
}
|
||||||
lua_globals.set_readonly(true);
|
|
||||||
|
|
||||||
Ok(())
|
Ok(())
|
||||||
}
|
}
|
||||||
|
|
|
@ -81,6 +81,9 @@ pub fn create() -> LuaResult<&'static Lua> {
|
||||||
let table: LuaTable = globals.raw_get("table")?;
|
let table: LuaTable = globals.raw_get("table")?;
|
||||||
let string: LuaTable = globals.raw_get("string")?;
|
let string: LuaTable = globals.raw_get("string")?;
|
||||||
let coroutine: LuaTable = globals.get("coroutine")?;
|
let coroutine: LuaTable = globals.get("coroutine")?;
|
||||||
|
// Create a _G table that is separate from our built-in globals
|
||||||
|
let global_table = lua.create_table()?;
|
||||||
|
globals.set("_G", global_table)?;
|
||||||
// Store original lua global functions in the registry so we can use
|
// Store original lua global functions in the registry so we can use
|
||||||
// them later without passing them around and dealing with lifetimes
|
// them later without passing them around and dealing with lifetimes
|
||||||
lua.set_named_registry_value("print", globals.get::<_, LuaFunction>("print")?)?;
|
lua.set_named_registry_value("print", globals.get::<_, LuaFunction>("print")?)?;
|
||||||
|
|
|
@ -69,6 +69,7 @@ create_tests! {
|
||||||
require_nested: "require/tests/nested",
|
require_nested: "require/tests/nested",
|
||||||
require_parents: "require/tests/parents",
|
require_parents: "require/tests/parents",
|
||||||
require_siblings: "require/tests/siblings",
|
require_siblings: "require/tests/siblings",
|
||||||
|
global_g_table: "globals/_G",
|
||||||
// TODO: Uncomment this test, it is commented out right
|
// TODO: Uncomment this test, it is commented out right
|
||||||
// now to let CI pass so that we can make a new release
|
// now to let CI pass so that we can make a new release
|
||||||
// global_coroutine: "globals/coroutine",
|
// global_coroutine: "globals/coroutine",
|
||||||
|
|
20
tests/globals/_G.luau
Normal file
20
tests/globals/_G.luau
Normal file
|
@ -0,0 +1,20 @@
|
||||||
|
assert(_G ~= nil, "Missing _G")
|
||||||
|
|
||||||
|
assert(type(_G) == "table", "Invalid type for _G")
|
||||||
|
|
||||||
|
assert(_G.require == nil, "Built-in global value was found in _G")
|
||||||
|
assert(_G.print == nil, "Built-in global value was found in _G")
|
||||||
|
assert(_G.warn == nil, "Built-in global value was found in _G")
|
||||||
|
assert(_G.error == nil, "Built-in global value was found in _G")
|
||||||
|
assert(_G.coroutine == nil, "Built-in global value was found in _G")
|
||||||
|
assert(_G.typeof == nil, "Built-in global value was found in _G")
|
||||||
|
assert(_G.type == nil, "Built-in global value was found in _G")
|
||||||
|
|
||||||
|
assert(next(_G) == nil, "_G contained value but should be empty")
|
||||||
|
|
||||||
|
_G.Hello = "World"
|
||||||
|
assert(_G.Hello == "World", "Failed to set value in _G")
|
||||||
|
|
||||||
|
local bar = {}
|
||||||
|
_G.Foo = bar
|
||||||
|
assert(_G.Foo == bar, "Failed to set reference in _G")
|
Loading…
Reference in a new issue