Skip to content

Commit c0df48f

Browse files
committed
Take lua_Destructor in lua_newuserdatadtor (with lua_State argument).
mlua needs access to Lua state in userdata destructor to set a flag to prevent further access to Lua VM ops in destructor.
1 parent c517432 commit c0df48f

File tree

5 files changed

+16
-12
lines changed

5 files changed

+16
-12
lines changed

CLI/src/Repl.cpp

Lines changed: 1 addition & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -169,7 +169,7 @@ static void* createCliRequireContext(lua_State* L)
169169
void* ctx = lua_newuserdatadtor(
170170
L,
171171
sizeof(ReplRequirer),
172-
[](void* ptr)
172+
[](lua_State*, void* ptr)
173173
{
174174
static_cast<ReplRequirer*>(ptr)->~ReplRequirer();
175175
}

VM/include/lua.h

Lines changed: 7 additions & 3 deletions
Original file line numberDiff line numberDiff line change
@@ -54,6 +54,12 @@ typedef int (*lua_Continuation)(lua_State* L, int status);
5454

5555
typedef void* (*lua_Alloc)(void* ud, void* ptr, size_t osize, size_t nsize);
5656

57+
/*
58+
** prototype for userdata destructor
59+
*/
60+
61+
typedef void (*lua_Destructor)(lua_State* L, void* userdata);
62+
5763
// non-return type
5864
#define l_noret void LUA_NORETURN
5965

@@ -189,7 +195,7 @@ LUA_API int lua_pushthread(lua_State* L);
189195
LUA_API void lua_pushlightuserdatatagged(lua_State* L, void* p, int tag);
190196
LUA_API void* lua_newuserdatatagged(lua_State* L, size_t sz, int tag);
191197
LUA_API void* lua_newuserdatataggedwithmetatable(lua_State* L, size_t sz, int tag); // metatable fetched with lua_getuserdatametatable
192-
LUA_API void* lua_newuserdatadtor(lua_State* L, size_t sz, void (*dtor)(void*));
198+
LUA_API void* lua_newuserdatadtor(lua_State* L, size_t sz, lua_Destructor dtor);
193199

194200
LUA_API void* lua_newbuffer(lua_State* L, size_t sz);
195201

@@ -319,8 +325,6 @@ LUA_API double lua_clock();
319325

320326
LUA_API void lua_setuserdatatag(lua_State* L, int idx, int tag);
321327

322-
typedef void (*lua_Destructor)(lua_State* L, void* userdata);
323-
324328
LUA_API void lua_setuserdatadtor(lua_State* L, int tag, lua_Destructor dtor);
325329
LUA_API lua_Destructor lua_getuserdatadtor(lua_State* L, int tag);
326330

VM/src/lapi.cpp

Lines changed: 1 addition & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -1326,7 +1326,7 @@ void* lua_newuserdatataggedwithmetatable(lua_State* L, size_t sz, int tag)
13261326
return u->data;
13271327
}
13281328

1329-
void* lua_newuserdatadtor(lua_State* L, size_t sz, void (*dtor)(void*))
1329+
void* lua_newuserdatadtor(lua_State* L, size_t sz, lua_Destructor dtor)
13301330
{
13311331
luaC_checkGC(L);
13321332
luaC_threadbarrier(L);

VM/src/ludata.cpp

Lines changed: 2 additions & 2 deletions
Original file line numberDiff line numberDiff line change
@@ -32,10 +32,10 @@ void luaU_freeudata(lua_State* L, Udata* u, lua_Page* page)
3232
}
3333
else if (u->tag == UTAG_IDTOR)
3434
{
35-
void (*dtor)(void*) = nullptr;
35+
lua_Destructor dtor = nullptr;
3636
memcpy(&dtor, &u->data + u->len - sizeof(dtor), sizeof(dtor));
3737
if (dtor)
38-
dtor(u->data);
38+
dtor(L, u->data);
3939
}
4040

4141

tests/Conformance.test.cpp

Lines changed: 5 additions & 5 deletions
Original file line numberDiff line numberDiff line change
@@ -1488,15 +1488,15 @@ TEST_CASE("Reference")
14881488
lua_newuserdatadtor(
14891489
L,
14901490
0,
1491-
[](void*)
1491+
[](lua_State*, void* data)
14921492
{
14931493
dtorhits++;
14941494
}
14951495
);
14961496
lua_newuserdatadtor(
14971497
L,
14981498
0,
1499-
[](void*)
1499+
[](lua_State*, void* data)
15001500
{
15011501
dtorhits++;
15021502
}
@@ -1534,7 +1534,7 @@ TEST_CASE("NewUserdataOverflow")
15341534
[](lua_State* L1)
15351535
{
15361536
// The following userdata request might cause an overflow.
1537-
lua_newuserdatadtor(L1, SIZE_MAX, [](void* d) {});
1537+
lua_newuserdatadtor(L1, SIZE_MAX, [](lua_State*, void* d) {});
15381538
// The overflow might segfault in the following call.
15391539
lua_getmetatable(L1, -1);
15401540
return 0;
@@ -2442,7 +2442,7 @@ TEST_CASE("UserdataApi")
24422442
void* ud3 = lua_newuserdatadtor(
24432443
L,
24442444
4,
2445-
[](void* data)
2445+
[](lua_State*, void* data)
24462446
{
24472447
dtorhits += *(int*)data;
24482448
}
@@ -2451,7 +2451,7 @@ TEST_CASE("UserdataApi")
24512451
void* ud4 = lua_newuserdatadtor(
24522452
L,
24532453
1,
2454-
[](void* data)
2454+
[](lua_State*, void* data)
24552455
{
24562456
dtorhits += *(char*)data;
24572457
}

0 commit comments

Comments
 (0)