mirror of
https://github.com/ZDoom/raze-gles.git
synced 2025-01-27 09:20:51 +00:00
Lunatic: fix some must-fail tests and module()s without require'end_gamevars'.
git-svn-id: https://svn.eduke32.com/eduke32@3965 1a8010ca-5511-0410-912e-c29ae57300e0
This commit is contained in:
parent
3835019c70
commit
ac3a6a1bd2
3 changed files with 27 additions and 19 deletions
|
@ -1824,7 +1824,7 @@ local function our_require(modname, ...)
|
||||||
|
|
||||||
local gvmodi = module_gvlocali[modname]
|
local gvmodi = module_gvlocali[modname]
|
||||||
|
|
||||||
if (gvmodi and gvmodi[2]>=gvmodi[1]) then
|
if (gvmodi and gvmodi[2] and gvmodi[2]>=gvmodi[1]) then
|
||||||
if (coroutine.status(modthread)=="suspended") then
|
if (coroutine.status(modthread)=="suspended") then
|
||||||
-- Save off the suspended thread so that we may get its locals later on.
|
-- Save off the suspended thread so that we may get its locals later on.
|
||||||
-- It is never resumed, but only ever used for debug.getlocal().
|
-- It is never resumed, but only ever used for debug.getlocal().
|
||||||
|
|
|
@ -107,13 +107,32 @@ checkfail('print(gv.sprite[0])', "access forbidden")
|
||||||
-- set metatable forbidden
|
-- set metatable forbidden
|
||||||
checkfail('setmetatable(sprite, {})', "attempt to read undeclared variable 'setmetatable'")
|
checkfail('setmetatable(sprite, {})', "attempt to read undeclared variable 'setmetatable'")
|
||||||
|
|
||||||
-- OOB write access.
|
gameevent
|
||||||
-- Note that indexing ("reading") sector fails, even if the user wants to
|
{
|
||||||
-- assign to a sector member. Potentially confusing error message.
|
"ENTERLEVEL",
|
||||||
checkfail('sector[-1].ceilingpal = 4', "out-of-bounds sector[] read access")
|
|
||||||
|
|
||||||
-- wallnum member is read-only
|
function()
|
||||||
checkfail('sector[0].wallnum = 0', "attempt to write to constant location") -- this comes from LJ/FFI
|
-- OOB write access.
|
||||||
|
-- Note that indexing ("reading") sector fails, even if the user wants to
|
||||||
|
-- assign to a sector member. Potentially confusing error message.
|
||||||
|
checkfail('sector[-1].ceilingpal = 4', "out-of-bounds sector[] read access")
|
||||||
|
|
||||||
|
-- wallnum member is read-only
|
||||||
|
checkfail('sector[0].wallnum = 0', "attempt to write to constant location") -- this comes from LJ/FFI
|
||||||
|
|
||||||
|
-- direct sector write access forbidden
|
||||||
|
checkfail('sector[4] = sector[6]', "cannot write directly to sector[]")
|
||||||
|
|
||||||
|
-- creating new keys forbidden... handled by LuaJIT
|
||||||
|
checkfail('wall[4].QWE = 123', "has no member named 'QWE'")
|
||||||
|
|
||||||
|
-- no pointer arithmetic!
|
||||||
|
checkfail('local spr = sprite[0]; local x=spr+1', "attempt to perform arithmetic on")
|
||||||
|
|
||||||
|
-- actor[].t_data[] is not accessible for now
|
||||||
|
checkfail('local i = actor[0].t_data[15]', "has no member named 't_data'")
|
||||||
|
end
|
||||||
|
}
|
||||||
|
|
||||||
-- gv.numsectors is read-only
|
-- gv.numsectors is read-only
|
||||||
checkfail('gv.numsectors = 4', "attempt to write to constant location")
|
checkfail('gv.numsectors = 4', "attempt to write to constant location")
|
||||||
|
@ -121,18 +140,12 @@ checkfail('gv.numsectors = 4', "attempt to write to constant location")
|
||||||
-- cannot create new fields in 'gv'
|
-- cannot create new fields in 'gv'
|
||||||
checkfail('gv.QWE = 4', "write access forbidden")
|
checkfail('gv.QWE = 4', "write access forbidden")
|
||||||
|
|
||||||
-- direct sector write access forbidden
|
|
||||||
checkfail('sector[4] = sector[6]', "cannot write directly to sector[]")
|
|
||||||
|
|
||||||
-- that would be horrible...
|
-- that would be horrible...
|
||||||
checkfail('sprite._nextspritesect[4] = -666', "cannot write directly to nextspritesect[]")
|
checkfail('sprite._nextspritesect[4] = -666', "cannot write directly to nextspritesect[]")
|
||||||
|
|
||||||
-- we're indexing a plain array!
|
-- we're indexing a plain array!
|
||||||
checkfail('print(sprite._nextspritesect[4].whatfield)', "attempt to index a number value")
|
checkfail('print(sprite._nextspritesect[4].whatfield)', "attempt to index a number value")
|
||||||
|
|
||||||
-- creating new keys forbidden... handled by LuaJIT
|
|
||||||
checkfail('wall[4].QWE = 123', "has no member named 'QWE'")
|
|
||||||
|
|
||||||
-- our 'require' has only safe stuff
|
-- our 'require' has only safe stuff
|
||||||
--checkfail("require('os')")
|
--checkfail("require('os')")
|
||||||
|
|
||||||
|
@ -162,12 +175,6 @@ checkfail('gv.luaJIT_setmode(nil, 0, 0)', "missing declaration for symbol 'luaJI
|
||||||
checkfail('gv.luaJIT_BC_con_lang', "attempt to call a nil value")
|
checkfail('gv.luaJIT_BC_con_lang', "attempt to call a nil value")
|
||||||
checkfail('gv.gethiticks = nil', "attempt to write to constant location")
|
checkfail('gv.gethiticks = nil', "attempt to write to constant location")
|
||||||
|
|
||||||
-- actor[].t_data[] is not accessible for now
|
|
||||||
checkfail('local i = actor[0].t_data[15]', "has no member named 't_data'")
|
|
||||||
|
|
||||||
-- no pointer arithmetic!
|
|
||||||
checkfail('local spr = sprite[0]; local x=spr+1', "attempt to perform arithmetic on")
|
|
||||||
|
|
||||||
checkfail('gameactor{1680, 0}', "must provide a function with last numeric arg or .func")
|
checkfail('gameactor{1680, 0}', "must provide a function with last numeric arg or .func")
|
||||||
|
|
||||||
checkfail("do local bt=require'test.test_bitar'; bt.QWE=1; end", "modifying module table forbidden")
|
checkfail("do local bt=require'test.test_bitar'; bt.QWE=1; end", "modifying module table forbidden")
|
||||||
|
|
|
@ -2,6 +2,7 @@
|
||||||
|
|
||||||
-- Usage: luajit bittest.lua <number or "x"> [-ffi] [-bchk]
|
-- Usage: luajit bittest.lua <number or "x"> [-ffi] [-bchk]
|
||||||
|
|
||||||
|
local require = require
|
||||||
local string = require "string"
|
local string = require "string"
|
||||||
local math = require "math"
|
local math = require "math"
|
||||||
|
|
||||||
|
|
Loading…
Reference in a new issue