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
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
MyCard
ygopro-core
Commits
f01ebeb6
Commit
f01ebeb6
authored
Apr 29, 2019
by
nanahira
Browse files
Options
Browse Files
Download
Plain Diff
Merge branch 'master' of github.com:Fluorohydride/ygopro-core
parents
eb18a5c6
4a9317bc
Changes
3
Hide whitespace changes
Inline
Side-by-side
Showing
3 changed files
with
26 additions
and
10 deletions
+26
-10
card.cpp
card.cpp
+18
-8
libcard.cpp
libcard.cpp
+6
-2
processor.cpp
processor.cpp
+2
-0
No files found.
card.cpp
View file @
f01ebeb6
...
@@ -2331,12 +2331,14 @@ int32 card::remove_counter(uint16 countertype, uint16 count) {
...
@@ -2331,12 +2331,14 @@ int32 card::remove_counter(uint16 countertype, uint16 count) {
}
}
int32
card
::
is_can_add_counter
(
uint8
playerid
,
uint16
countertype
,
uint16
count
,
uint8
singly
,
uint32
loc
)
{
int32
card
::
is_can_add_counter
(
uint8
playerid
,
uint16
countertype
,
uint16
count
,
uint8
singly
,
uint32
loc
)
{
effect_set
eset
;
effect_set
eset
;
if
(
!
pduel
->
game_field
->
is_player_can_place_counter
(
playerid
,
this
,
countertype
,
count
))
if
(
count
>
0
)
{
return
FALSE
;
if
(
!
pduel
->
game_field
->
is_player_can_place_counter
(
playerid
,
this
,
countertype
,
count
))
if
(
!
loc
&&
(
!
(
current
.
location
&
LOCATION_ONFIELD
)
||
!
is_position
(
POS_FACEUP
)))
return
FALSE
;
return
FALSE
;
if
(
!
loc
&&
(
!
(
current
.
location
&
LOCATION_ONFIELD
)
||
!
is_position
(
POS_FACEUP
)))
if
((
countertype
&
COUNTER_NEED_ENABLE
)
&&
is_status
(
STATUS_DISABLED
))
return
FALSE
;
return
FALSE
;
if
((
countertype
&
COUNTER_NEED_ENABLE
)
&&
is_status
(
STATUS_DISABLED
))
return
FALSE
;
}
uint32
check
=
countertype
&
COUNTER_WITHOUT_PERMIT
;
uint32
check
=
countertype
&
COUNTER_WITHOUT_PERMIT
;
if
(
!
check
)
{
if
(
!
check
)
{
filter_effect
(
EFFECT_COUNTER_PERMIT
+
(
countertype
&
0xffff
),
&
eset
);
filter_effect
(
EFFECT_COUNTER_PERMIT
+
(
countertype
&
0xffff
),
&
eset
);
...
@@ -2344,8 +2346,16 @@ int32 card::is_can_add_counter(uint8 playerid, uint16 countertype, uint16 count,
...
@@ -2344,8 +2346,16 @@ int32 card::is_can_add_counter(uint8 playerid, uint16 countertype, uint16 count,
uint32
prange
=
eset
[
i
]
->
get_value
();
uint32
prange
=
eset
[
i
]
->
get_value
();
if
(
loc
)
if
(
loc
)
check
=
loc
&
prange
;
check
=
loc
&
prange
;
else
else
if
(
current
.
location
&
LOCATION_ONFIELD
)
{
check
=
current
.
is_location
(
prange
)
&&
is_position
(
POS_FACEUP
);
uint32
filter
=
TRUE
;
if
(
eset
[
i
]
->
target
)
{
pduel
->
lua
->
add_param
(
eset
[
i
],
PARAM_TYPE_EFFECT
);
pduel
->
lua
->
add_param
(
this
,
PARAM_TYPE_CARD
);
filter
=
pduel
->
lua
->
check_condition
(
eset
[
i
]
->
target
,
2
);
}
check
=
current
.
is_location
(
prange
)
&&
is_position
(
POS_FACEUP
)
&&
filter
;
}
else
check
=
TRUE
;
if
(
check
)
if
(
check
)
break
;
break
;
}
}
...
...
libcard.cpp
View file @
f01ebeb6
...
@@ -2713,6 +2713,8 @@ int32 scriptlib::card_enable_counter_permit(lua_State *L) {
...
@@ -2713,6 +2713,8 @@ int32 scriptlib::card_enable_counter_permit(lua_State *L) {
peffect
->
type
=
EFFECT_TYPE_SINGLE
;
peffect
->
type
=
EFFECT_TYPE_SINGLE
;
peffect
->
code
=
EFFECT_COUNTER_PERMIT
|
countertype
;
peffect
->
code
=
EFFECT_COUNTER_PERMIT
|
countertype
;
peffect
->
value
=
prange
;
peffect
->
value
=
prange
;
if
(
lua_gettop
(
L
)
>
3
&&
lua_isfunction
(
L
,
4
))
peffect
->
target
=
interpreter
::
get_function_handle
(
L
,
4
);
pcard
->
add_effect
(
peffect
);
pcard
->
add_effect
(
peffect
);
return
0
;
return
0
;
}
}
...
@@ -2744,11 +2746,13 @@ int32 scriptlib::card_is_can_turn_set(lua_State *L) {
...
@@ -2744,11 +2746,13 @@ int32 scriptlib::card_is_can_turn_set(lua_State *L) {
return
1
;
return
1
;
}
}
int32
scriptlib
::
card_is_can_add_counter
(
lua_State
*
L
)
{
int32
scriptlib
::
card_is_can_add_counter
(
lua_State
*
L
)
{
check_param_count
(
L
,
3
);
check_param_count
(
L
,
2
);
check_param
(
L
,
PARAM_TYPE_CARD
,
1
);
check_param
(
L
,
PARAM_TYPE_CARD
,
1
);
card
*
pcard
=
*
(
card
**
)
lua_touserdata
(
L
,
1
);
card
*
pcard
=
*
(
card
**
)
lua_touserdata
(
L
,
1
);
uint32
countertype
=
lua_tointeger
(
L
,
2
);
uint32
countertype
=
lua_tointeger
(
L
,
2
);
uint32
count
=
lua_tointeger
(
L
,
3
);
uint32
count
=
0
;
if
(
lua_gettop
(
L
)
>
2
)
count
=
lua_tointeger
(
L
,
3
);
uint8
singly
=
FALSE
;
uint8
singly
=
FALSE
;
if
(
lua_gettop
(
L
)
>
3
)
if
(
lua_gettop
(
L
)
>
3
)
singly
=
lua_toboolean
(
L
,
4
);
singly
=
lua_toboolean
(
L
,
4
);
...
...
processor.cpp
View file @
f01ebeb6
...
@@ -1351,6 +1351,7 @@ int32 field::check_hint_timing(effect* peffect) {
...
@@ -1351,6 +1351,7 @@ int32 field::check_hint_timing(effect* peffect) {
else
else
return
(
peffect
->
hint_timing
[
0
]
&
core
.
hint_timing
[
1
])
||
(
peffect
->
hint_timing
[
1
]
&
core
.
hint_timing
[
0
]);
return
(
peffect
->
hint_timing
[
0
]
&
core
.
hint_timing
[
1
])
||
(
peffect
->
hint_timing
[
1
]
&
core
.
hint_timing
[
0
]);
}
}
// core.spe_effect[p]: # of optional trigger effects, activate/quick effect with hints
int32
field
::
process_phase_event
(
int16
step
,
int32
phase
)
{
int32
field
::
process_phase_event
(
int16
step
,
int32
phase
)
{
switch
(
step
)
{
switch
(
step
)
{
case
0
:
{
case
0
:
{
...
@@ -1645,6 +1646,7 @@ int32 field::process_phase_event(int16 step, int32 phase) {
...
@@ -1645,6 +1646,7 @@ int32 field::process_phase_event(int16 step, int32 phase) {
}
}
return
TRUE
;
return
TRUE
;
}
}
// core.tmp_chains: used in step 8 (obsolete ignition effect ruling)
int32
field
::
process_point_event
(
int16
step
,
int32
skip_trigger
,
int32
skip_freechain
,
int32
skip_new
)
{
int32
field
::
process_point_event
(
int16
step
,
int32
skip_trigger
,
int32
skip_freechain
,
int32
skip_new
)
{
switch
(
step
)
{
switch
(
step
)
{
case
0
:
{
case
0
:
{
...
...
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