Skip to content
Projects
Groups
Snippets
Help
Loading...
Help
Support
Keyboard shortcuts
?
Submit feedback
Sign in / Register
Toggle navigation
Y
ygopro-core
Project overview
Project overview
Details
Activity
Releases
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Locked Files
Issues
0
Issues
0
List
Boards
Labels
Service Desk
Milestones
Merge Requests
0
Merge Requests
0
CI / CD
CI / CD
Pipelines
Jobs
Schedules
Security & Compliance
Security & Compliance
Dependency List
License Compliance
Packages
Packages
List
Container Registry
Analytics
Analytics
CI / CD
Code Review
Insights
Issues
Repository
Value Stream
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Create a new issue
Jobs
Commits
Issue Boards
Open sidebar
nanahira
ygopro-core
Commits
49459757
Commit
49459757
authored
Sep 25, 2025
by
salix5
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
Add enable_unsafe_feature flag
parent
73108e70
Changes
2
Hide whitespace changes
Inline
Side-by-side
Showing
2 changed files
with
8 additions
and
2 deletions
+8
-2
interpreter.cpp
interpreter.cpp
+7
-2
interpreter.h
interpreter.h
+1
-0
No files found.
interpreter.cpp
View file @
49459757
...
...
@@ -14,7 +14,8 @@
#include "ocgapi.h"
#include "interpreter.h"
interpreter
::
interpreter
(
duel
*
pd
,
bool
enable_unsafe_libraries
)
:
coroutines
(
256
),
pduel
(
pd
)
{
interpreter
::
interpreter
(
duel
*
pd
,
bool
enable_unsafe_libraries
)
:
coroutines
(
256
),
pduel
(
pd
),
enable_unsafe_feature
(
enable_unsafe_libraries
)
{
lua_state
=
luaL_newstate
();
current_state
=
lua_state
;
std
::
memcpy
(
lua_getextraspace
(
lua_state
),
&
pd
,
LUA_EXTRASPACE
);
//set_duel_info
...
...
@@ -139,7 +140,11 @@ int32_t interpreter::load_script(const char* script_name) {
return
OPERATION_FAIL
;
++
no_action
;
luaL_checkstack
(
current_state
,
2
,
nullptr
);
int32_t
error
=
luaL_loadbufferx
(
current_state
,
(
const
char
*
)
buffer
,
len
,
script_name
,
"t"
)
||
lua_pcall
(
current_state
,
0
,
0
,
0
);
int32_t
error
=
0
;
if
(
enable_unsafe_feature
)
error
=
luaL_loadbuffer
(
current_state
,
(
const
char
*
)
buffer
,
len
,
script_name
)
||
lua_pcall
(
current_state
,
0
,
0
,
0
);
else
error
=
luaL_loadbufferx
(
current_state
,
(
const
char
*
)
buffer
,
len
,
script_name
,
"t"
)
||
lua_pcall
(
current_state
,
0
,
0
,
0
);
if
(
error
)
{
interpreter
::
sprintf
(
pduel
->
strbuffer
,
"%s"
,
lua_tostring
(
current_state
,
-
1
));
handle_message
(
pduel
,
1
);
...
...
interpreter.h
View file @
49459757
...
...
@@ -52,6 +52,7 @@ public:
coroutine_map
coroutines
;
int32_t
no_action
{};
int32_t
call_depth
{};
bool
enable_unsafe_feature
{};
explicit
interpreter
(
duel
*
pd
,
bool
enable_unsafe_libraries
);
~
interpreter
();
...
...
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment