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
xiaoye
ygopro-core
Commits
02547161
Commit
02547161
authored
Mar 16, 2021
by
nanahira
Browse files
Options
Browse Files
Download
Plain Diff
Merge branch 'master' of github.com:Fluorohydride/ygopro-core
parents
6cfabcae
b75bb919
Changes
5
Hide whitespace changes
Inline
Side-by-side
Showing
5 changed files
with
176 additions
and
45 deletions
+176
-45
card.cpp
card.cpp
+35
-16
effect.h
effect.h
+1
-1
libcard.cpp
libcard.cpp
+11
-0
operations.cpp
operations.cpp
+128
-28
scriptlib.h
scriptlib.h
+1
-0
No files found.
card.cpp
View file @
02547161
...
@@ -2030,6 +2030,9 @@ void card::reset(uint32 id, uint32 reset_type) {
...
@@ -2030,6 +2030,9 @@ void card::reset(uint32 id, uint32 reset_type) {
for
(;
pr
.
first
!=
pr
.
second
;
++
pr
.
first
)
for
(;
pr
.
first
!=
pr
.
second
;
++
pr
.
first
)
pr
.
first
->
second
->
value
=
pr
.
first
->
second
->
value
&
0xffff
;
pr
.
first
->
second
->
value
=
pr
.
first
->
second
->
value
&
0xffff
;
}
}
if
(
id
&
RESET_TOFIELD
)
{
pre_equip_target
=
0
;
}
if
(
id
&
RESET_DISABLE
)
{
if
(
id
&
RESET_DISABLE
)
{
for
(
auto
cmit
=
counters
.
begin
();
cmit
!=
counters
.
end
();)
{
for
(
auto
cmit
=
counters
.
begin
();
cmit
!=
counters
.
end
();)
{
auto
rm
=
cmit
++
;
auto
rm
=
cmit
++
;
...
@@ -3159,7 +3162,6 @@ int32 card::is_can_be_summoned(uint8 playerid, uint8 ignore_count, effect* peffe
...
@@ -3159,7 +3162,6 @@ int32 card::is_can_be_summoned(uint8 playerid, uint8 ignore_count, effect* peffe
}
}
int32
card
::
get_summon_tribute_count
()
{
int32
card
::
get_summon_tribute_count
()
{
int32
min
=
0
,
max
=
0
;
int32
min
=
0
,
max
=
0
;
int32
minul
=
0
,
maxul
=
0
;
int32
level
=
get_level
();
int32
level
=
get_level
();
if
(
level
<
5
)
if
(
level
<
5
)
return
0
;
return
0
;
...
@@ -3167,22 +3169,26 @@ int32 card::get_summon_tribute_count() {
...
@@ -3167,22 +3169,26 @@ int32 card::get_summon_tribute_count() {
min
=
max
=
1
;
min
=
max
=
1
;
else
else
min
=
max
=
2
;
min
=
max
=
2
;
std
::
vector
<
int32
>
duplicate
;
effect_set
eset
;
effect_set
eset
;
filter_effect
(
EFFECT_DECREASE_TRIBUTE
,
&
eset
);
filter_effect
(
EFFECT_DECREASE_TRIBUTE
,
&
eset
);
for
(
int32
i
=
0
;
i
<
eset
.
size
();
++
i
)
{
for
(
int32
i
=
0
;
i
<
eset
.
size
();
++
i
)
{
int32
dec
=
eset
[
i
]
->
get_value
(
this
);
if
(
eset
[
i
]
->
is_flag
(
EFFECT_FLAG_COUNT_LIMIT
)
&&
eset
[
i
]
->
count_limit
==
0
)
if
(
!
eset
[
i
]
->
is_flag
(
EFFECT_FLAG_COUNT_LIMIT
))
{
continue
;
if
(
minul
<
(
dec
&
0xffff
))
std
::
vector
<
int32
>
retval
;
minul
=
dec
&
0xffff
;
eset
[
i
]
->
get_value
(
this
,
0
,
&
retval
);
if
(
maxul
<
(
dec
>>
16
))
int32
dec
=
retval
.
size
()
>
0
?
retval
[
0
]
:
0
;
maxul
=
dec
>>
16
;
int32
effect_code
=
retval
.
size
()
>
1
?
retval
[
1
]
:
0
;
}
else
if
(
eset
[
i
]
->
count_limit
>
0
)
{
if
(
effect_code
>
0
)
{
min
-=
dec
&
0xffff
;
auto
it
=
std
::
find
(
duplicate
.
begin
(),
duplicate
.
end
(),
effect_code
);
max
-=
dec
>>
16
;
if
(
it
==
duplicate
.
end
())
}
duplicate
.
push_back
(
effect_code
);
}
else
min
-=
minul
;
continue
;
max
-=
maxul
;
}
min
-=
dec
&
0xffff
;
max
-=
dec
>>
16
;
}
if
(
min
<
0
)
min
=
0
;
if
(
min
<
0
)
min
=
0
;
if
(
max
<
min
)
max
=
min
;
if
(
max
<
min
)
max
=
min
;
return
min
+
(
max
<<
16
);
return
min
+
(
max
<<
16
);
...
@@ -3196,10 +3202,23 @@ int32 card::get_set_tribute_count() {
...
@@ -3196,10 +3202,23 @@ int32 card::get_set_tribute_count() {
min
=
max
=
1
;
min
=
max
=
1
;
else
else
min
=
max
=
2
;
min
=
max
=
2
;
std
::
vector
<
int32
>
duplicate
;
effect_set
eset
;
effect_set
eset
;
filter_effect
(
EFFECT_DECREASE_TRIBUTE_SET
,
&
eset
);
filter_effect
(
EFFECT_DECREASE_TRIBUTE_SET
,
&
eset
);
if
(
eset
.
size
())
{
for
(
int32
i
=
0
;
i
<
eset
.
size
();
++
i
)
{
int32
dec
=
eset
.
get_last
()
->
get_value
(
this
);
if
(
eset
[
i
]
->
is_flag
(
EFFECT_FLAG_COUNT_LIMIT
)
&&
eset
[
i
]
->
count_limit
==
0
)
continue
;
std
::
vector
<
int32
>
retval
;
eset
[
i
]
->
get_value
(
this
,
0
,
&
retval
);
int32
dec
=
retval
.
size
()
>
0
?
retval
[
0
]
:
0
;
int32
effect_code
=
retval
.
size
()
>
1
?
retval
[
1
]
:
0
;
if
(
effect_code
>
0
)
{
auto
it
=
std
::
find
(
duplicate
.
begin
(),
duplicate
.
end
(),
effect_code
);
if
(
it
==
duplicate
.
end
())
duplicate
.
push_back
(
effect_code
);
else
continue
;
}
min
-=
dec
&
0xffff
;
min
-=
dec
&
0xffff
;
max
-=
dec
>>
16
;
max
-=
dec
>>
16
;
}
}
...
...
effect.h
View file @
02547161
...
@@ -213,7 +213,7 @@ enum effect_flag : uint32 {
...
@@ -213,7 +213,7 @@ enum effect_flag : uint32 {
EFFECT_FLAG_IMMEDIATELY_APPLY
=
0x80000000
,
EFFECT_FLAG_IMMEDIATELY_APPLY
=
0x80000000
,
};
};
enum
effect_flag2
:
uint32
{
enum
effect_flag2
:
uint32
{
// EFFECT_FLAG2_NAGA
= 0x0001,
EFFECT_FLAG2_MILLENNIUM_RESTRICT
=
0x0001
,
EFFECT_FLAG2_COF
=
0x0002
,
EFFECT_FLAG2_COF
=
0x0002
,
EFFECT_FLAG2_SPOSITCH
=
0x0100
,
// flag2 from 0x0100 are koishipro use
EFFECT_FLAG2_SPOSITCH
=
0x0100
,
// flag2 from 0x0100 are koishipro use
EFFECT_FLAG2_AVAILABLE_BD
=
0x0200
,
EFFECT_FLAG2_AVAILABLE_BD
=
0x0200
,
...
...
libcard.cpp
View file @
02547161
...
@@ -506,6 +506,16 @@ int32 scriptlib::card_get_origin_rscale(lua_State *L) {
...
@@ -506,6 +506,16 @@ int32 scriptlib::card_get_origin_rscale(lua_State *L) {
lua_pushinteger
(
L
,
pcard
->
data
.
rscale
);
lua_pushinteger
(
L
,
pcard
->
data
.
rscale
);
return
1
;
return
1
;
}
}
int32
scriptlib
::
card_get_current_scale
(
lua_State
*
L
)
{
check_param_count
(
L
,
1
);
check_param
(
L
,
PARAM_TYPE_CARD
,
1
);
card
*
pcard
=
*
(
card
**
)
lua_touserdata
(
L
,
1
);
if
(
pcard
->
current
.
pzone
&&
pcard
->
current
.
sequence
==
(
pcard
->
pduel
->
game_field
->
core
.
duel_rule
>=
4
?
0
:
6
))
lua_pushinteger
(
L
,
pcard
->
get_lscale
());
else
lua_pushinteger
(
L
,
pcard
->
get_rscale
());
return
1
;
}
int32
scriptlib
::
card_is_link_marker
(
lua_State
*
L
)
{
int32
scriptlib
::
card_is_link_marker
(
lua_State
*
L
)
{
check_param_count
(
L
,
2
);
check_param_count
(
L
,
2
);
check_param
(
L
,
PARAM_TYPE_CARD
,
1
);
check_param
(
L
,
PARAM_TYPE_CARD
,
1
);
...
@@ -3372,6 +3382,7 @@ static const struct luaL_Reg cardlib[] = {
...
@@ -3372,6 +3382,7 @@ static const struct luaL_Reg cardlib[] = {
{
"GetOriginalLeftScale"
,
scriptlib
::
card_get_origin_lscale
},
{
"GetOriginalLeftScale"
,
scriptlib
::
card_get_origin_lscale
},
{
"GetRightScale"
,
scriptlib
::
card_get_rscale
},
{
"GetRightScale"
,
scriptlib
::
card_get_rscale
},
{
"GetOriginalRightScale"
,
scriptlib
::
card_get_origin_rscale
},
{
"GetOriginalRightScale"
,
scriptlib
::
card_get_origin_rscale
},
{
"GetCurrentScale"
,
scriptlib
::
card_get_current_scale
},
{
"IsLinkMarker"
,
scriptlib
::
card_is_link_marker
},
{
"IsLinkMarker"
,
scriptlib
::
card_is_link_marker
},
{
"GetLinkedGroup"
,
scriptlib
::
card_get_linked_group
},
{
"GetLinkedGroup"
,
scriptlib
::
card_get_linked_group
},
{
"GetLinkedGroupCount"
,
scriptlib
::
card_get_linked_group_count
},
{
"GetLinkedGroupCount"
,
scriptlib
::
card_get_linked_group_count
},
...
...
operations.cpp
View file @
02547161
...
@@ -1791,47 +1791,70 @@ int32 field::summon(uint16 step, uint8 sumplayer, card* target, effect* proc, ui
...
@@ -1791,47 +1791,70 @@ int32 field::summon(uint16 step, uint8 sumplayer, card* target, effect* proc, ui
if
(
tributes
)
if
(
tributes
)
min
-=
(
int32
)
tributes
->
size
();
min
-=
(
int32
)
tributes
->
size
();
if
(
min
>
0
)
{
if
(
min
>
0
)
{
std
::
vector
<
int32
>
duplicate
;
effect_set
eset
;
effect_set
eset
;
target
->
filter_effect
(
EFFECT_DECREASE_TRIBUTE
,
&
eset
);
target
->
filter_effect
(
EFFECT_DECREASE_TRIBUTE
,
&
eset
);
int32 minul = 0;
effect* pdec = 0;
for
(
int32
i
=
0
;
i
<
eset
.
size
();
++
i
)
{
for
(
int32
i
=
0
;
i
<
eset
.
size
();
++
i
)
{
if(!eset[i]->is_flag(EFFECT_FLAG_COUNT_LIMIT)) {
if
(
eset
[
i
]
->
is_flag
(
EFFECT_FLAG_COUNT_LIMIT
))
int32 dec = eset[i]->get_value(target);
continue
;
if(minul < (dec & 0xffff)) {
std
::
vector
<
int32
>
retval
;
minul = dec & 0xffff;
eset
[
i
]
->
get_value
(
target
,
0
,
&
retval
);
pdec = eset[i];
int32
dec
=
retval
.
size
()
>
0
?
retval
[
0
]
:
0
;
}
int32
effect_code
=
retval
.
size
()
>
1
?
retval
[
1
]
:
0
;
if
(
effect_code
>
0
)
{
auto
it
=
std
::
find
(
duplicate
.
begin
(),
duplicate
.
end
(),
effect_code
);
if
(
it
==
duplicate
.
end
())
duplicate
.
push_back
(
effect_code
);
else
continue
;
}
}
}
min
-=
dec
&
0xffff
;
if(pdec) {
min -= minul;
pduel
->
write_buffer8
(
MSG_HINT
);
pduel
->
write_buffer8
(
MSG_HINT
);
pduel
->
write_buffer8
(
HINT_CARD
);
pduel
->
write_buffer8
(
HINT_CARD
);
pduel
->
write_buffer8
(
0
);
pduel
->
write_buffer8
(
0
);
pduel->write_buffer32(
pdec
->handler->data.code);
pduel
->
write_buffer32
(
eset
[
i
]
->
handler
->
data
.
code
);
}
}
for
(
int32
i
=
0
;
i
<
eset
.
size
()
&&
min
>
0
;
++
i
)
{
for
(
int32
i
=
0
;
i
<
eset
.
size
()
&&
min
>
0
;
++
i
)
{
if(eset[i]->is_flag(EFFECT_FLAG_COUNT_LIMIT) && eset[i]->count_limit > 0 && eset[i]->target) {
if
(
!
eset
[
i
]
->
is_flag
(
EFFECT_FLAG_COUNT_LIMIT
)
||
eset
[
i
]
->
count_limit
==
0
||
!
eset
[
i
]
->
target
)
int32 dec = eset[i]->get_value(target);
continue
;
min -= dec & 0xffff;
std
::
vector
<
int32
>
retval
;
eset[i]->dec_count();
eset
[
i
]
->
get_value
(
target
,
0
,
&
retval
);
pduel->write_buffer8(MSG_HINT);
int32
dec
=
retval
.
size
()
>
0
?
retval
[
0
]
:
0
;
pduel->write_buffer8(HINT_CARD);
int32
effect_code
=
retval
.
size
()
>
1
?
retval
[
1
]
:
0
;
pduel->write_buffer8(0);
if
(
effect_code
>
0
)
{
pduel->write_buffer32(eset[i]->handler->data.code);
auto
it
=
std
::
find
(
duplicate
.
begin
(),
duplicate
.
end
(),
effect_code
);
if
(
it
==
duplicate
.
end
())
duplicate
.
push_back
(
effect_code
);
else
continue
;
}
}
min
-=
dec
&
0xffff
;
eset
[
i
]
->
dec_count
();
pduel
->
write_buffer8
(
MSG_HINT
);
pduel
->
write_buffer8
(
HINT_CARD
);
pduel
->
write_buffer8
(
0
);
pduel
->
write_buffer32
(
eset
[
i
]
->
handler
->
data
.
code
);
}
}
for
(
int32
i
=
0
;
i
<
eset
.
size
()
&&
min
>
0
;
++
i
)
{
for
(
int32
i
=
0
;
i
<
eset
.
size
()
&&
min
>
0
;
++
i
)
{
if(eset[i]->is_flag(EFFECT_FLAG_COUNT_LIMIT) && eset[i]->count_limit > 0 && !eset[i]->target) {
if
(
!
eset
[
i
]
->
is_flag
(
EFFECT_FLAG_COUNT_LIMIT
)
||
eset
[
i
]
->
count_limit
==
0
||
eset
[
i
]
->
target
)
int32 dec = eset[i]->get_value(target);
continue
;
min -= dec & 0xffff;
std
::
vector
<
int32
>
retval
;
eset[i]->dec_count();
eset
[
i
]
->
get_value
(
target
,
0
,
&
retval
);
pduel->write_buffer8(MSG_HINT);
int32
dec
=
retval
.
size
()
>
0
?
retval
[
0
]
:
0
;
pduel->write_buffer8(HINT_CARD);
int32
effect_code
=
retval
.
size
()
>
1
?
retval
[
1
]
:
0
;
pduel->write_buffer8(0);
if
(
effect_code
>
0
)
{
pduel->write_buffer32(eset[i]->handler->data.code);
auto
it
=
std
::
find
(
duplicate
.
begin
(),
duplicate
.
end
(),
effect_code
);
if
(
it
==
duplicate
.
end
())
duplicate
.
push_back
(
effect_code
);
else
continue
;
}
}
min
-=
dec
&
0xffff
;
eset
[
i
]
->
dec_count
();
pduel
->
write_buffer8
(
MSG_HINT
);
pduel
->
write_buffer8
(
HINT_CARD
);
pduel
->
write_buffer8
(
0
);
pduel
->
write_buffer32
(
eset
[
i
]
->
handler
->
data
.
code
);
}
}
}
}
if
(
tributes
)
{
if
(
tributes
)
{
...
@@ -2327,6 +2350,83 @@ int32 field::mset(uint16 step, uint8 setplayer, card* target, effect* proc, uint
...
@@ -2327,6 +2350,83 @@ int32 field::mset(uint16 step, uint8 setplayer, card* target, effect* proc, uint
}
}
case
5
:
{
case
5
:
{
card_set
*
tributes
=
(
card_set
*
)
proc
;
card_set
*
tributes
=
(
card_set
*
)
proc
;
int32
min
=
0
;
int32
level
=
target
->
get_level
();
if
(
level
<
5
)
min
=
0
;
else
if
(
level
<
7
)
min
=
1
;
else
min
=
2
;
if
(
tributes
)
min
-=
(
int32
)
tributes
->
size
();
if
(
min
>
0
)
{
std
::
vector
<
int32
>
duplicate
;
effect_set
eset
;
target
->
filter_effect
(
EFFECT_DECREASE_TRIBUTE_SET
,
&
eset
);
for
(
int32
i
=
0
;
i
<
eset
.
size
();
++
i
)
{
if
(
eset
[
i
]
->
is_flag
(
EFFECT_FLAG_COUNT_LIMIT
))
continue
;
std
::
vector
<
int32
>
retval
;
eset
[
i
]
->
get_value
(
target
,
0
,
&
retval
);
int32
dec
=
retval
.
size
()
>
0
?
retval
[
0
]
:
0
;
int32
effect_code
=
retval
.
size
()
>
1
?
retval
[
1
]
:
0
;
if
(
effect_code
>
0
)
{
auto
it
=
std
::
find
(
duplicate
.
begin
(),
duplicate
.
end
(),
effect_code
);
if
(
it
==
duplicate
.
end
())
duplicate
.
push_back
(
effect_code
);
else
continue
;
}
min
-=
dec
&
0xffff
;
pduel
->
write_buffer8
(
MSG_HINT
);
pduel
->
write_buffer8
(
HINT_CARD
);
pduel
->
write_buffer8
(
0
);
pduel
->
write_buffer32
(
eset
[
i
]
->
handler
->
data
.
code
);
}
for
(
int32
i
=
0
;
i
<
eset
.
size
()
&&
min
>
0
;
++
i
)
{
if
(
!
eset
[
i
]
->
is_flag
(
EFFECT_FLAG_COUNT_LIMIT
)
||
eset
[
i
]
->
count_limit
==
0
||
!
eset
[
i
]
->
target
)
continue
;
std
::
vector
<
int32
>
retval
;
eset
[
i
]
->
get_value
(
target
,
0
,
&
retval
);
int32
dec
=
retval
.
size
()
>
0
?
retval
[
0
]
:
0
;
int32
effect_code
=
retval
.
size
()
>
1
?
retval
[
1
]
:
0
;
if
(
effect_code
>
0
)
{
auto
it
=
std
::
find
(
duplicate
.
begin
(),
duplicate
.
end
(),
effect_code
);
if
(
it
==
duplicate
.
end
())
duplicate
.
push_back
(
effect_code
);
else
continue
;
}
min
-=
dec
&
0xffff
;
eset
[
i
]
->
dec_count
();
pduel
->
write_buffer8
(
MSG_HINT
);
pduel
->
write_buffer8
(
HINT_CARD
);
pduel
->
write_buffer8
(
0
);
pduel
->
write_buffer32
(
eset
[
i
]
->
handler
->
data
.
code
);
}
for
(
int32
i
=
0
;
i
<
eset
.
size
()
&&
min
>
0
;
++
i
)
{
if
(
!
eset
[
i
]
->
is_flag
(
EFFECT_FLAG_COUNT_LIMIT
)
||
eset
[
i
]
->
count_limit
==
0
||
eset
[
i
]
->
target
)
continue
;
std
::
vector
<
int32
>
retval
;
eset
[
i
]
->
get_value
(
target
,
0
,
&
retval
);
int32
dec
=
retval
.
size
()
>
0
?
retval
[
0
]
:
0
;
int32
effect_code
=
retval
.
size
()
>
1
?
retval
[
1
]
:
0
;
if
(
effect_code
>
0
)
{
auto
it
=
std
::
find
(
duplicate
.
begin
(),
duplicate
.
end
(),
effect_code
);
if
(
it
==
duplicate
.
end
())
duplicate
.
push_back
(
effect_code
);
else
continue
;
}
min
-=
dec
&
0xffff
;
eset
[
i
]
->
dec_count
();
pduel
->
write_buffer8
(
MSG_HINT
);
pduel
->
write_buffer8
(
HINT_CARD
);
pduel
->
write_buffer8
(
0
);
pduel
->
write_buffer32
(
eset
[
i
]
->
handler
->
data
.
code
);
}
}
if
(
tributes
)
{
if
(
tributes
)
{
for
(
auto
&
pcard
:
*
tributes
)
for
(
auto
&
pcard
:
*
tributes
)
pcard
->
current
.
reason_card
=
target
;
pcard
->
current
.
reason_card
=
target
;
...
...
scriptlib.h
View file @
02547161
...
@@ -69,6 +69,7 @@ public:
...
@@ -69,6 +69,7 @@ public:
static
int32
card_get_origin_lscale
(
lua_State
*
L
);
static
int32
card_get_origin_lscale
(
lua_State
*
L
);
static
int32
card_get_rscale
(
lua_State
*
L
);
static
int32
card_get_rscale
(
lua_State
*
L
);
static
int32
card_get_origin_rscale
(
lua_State
*
L
);
static
int32
card_get_origin_rscale
(
lua_State
*
L
);
static
int32
card_get_current_scale
(
lua_State
*
L
);
static
int32
card_is_link_marker
(
lua_State
*
L
);
static
int32
card_is_link_marker
(
lua_State
*
L
);
static
int32
card_get_linked_group
(
lua_State
*
L
);
static
int32
card_get_linked_group
(
lua_State
*
L
);
static
int32
card_get_linked_group_count
(
lua_State
*
L
);
static
int32
card_get_linked_group_count
(
lua_State
*
L
);
...
...
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