Skip to content
Projects
Groups
Snippets
Help
Loading...
Help
Support
Keyboard shortcuts
?
Submit feedback
Sign in / Register
Toggle navigation
Y
ygopro-scripts-888
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
3
Merge Requests
3
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
MyCard
ygopro-scripts-888
Commits
fadb389d
Commit
fadb389d
authored
Jun 21, 2025
by
Vury Leo
Committed by
wind2009
Jun 21, 2025
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
Add 魔鍵 to new fusion
parent
85e64521
Changes
2
Hide whitespace changes
Inline
Side-by-side
Showing
2 changed files
with
107 additions
and
160 deletions
+107
-160
c51510279.lua
c51510279.lua
+32
-50
c99426088.lua
c99426088.lua
+75
-110
No files found.
c51510279.lua
View file @
fadb389d
--繋がれし魔鍵
function
c51510279
.
initial_effect
(
c
)
local
s
,
id
,
o
=
GetID
()
function
s
.
initial_effect
(
c
)
--- fusion effect
local
e0
=
FusionSpell
.
CreateSummonEffect
(
c
,{
fusfilter
=
s
.
fusfilter
,
matfilter
=
aux
.
NecroValleyFilter
(),
sumpos
=
POS_FACEUP_DEFENSE
})
--Activate
local
e1
=
Effect
.
CreateEffect
(
c
)
e1
:
SetCategory
(
CATEGORY_TOHAND
+
CATEGORY_SPECIAL_SUMMON
+
CATEGORY_FUSION_SUMMON
)
...
...
@@ -7,83 +14,58 @@ function c51510279.initial_effect(c)
e1
:
SetType
(
EFFECT_TYPE_ACTIVATE
)
e1
:
SetCode
(
EVENT_FREE_CHAIN
)
e1
:
SetHintTiming
(
0
,
TIMINGS_CHECK_MONSTER
+
TIMING_END_PHASE
)
e1
:
SetTarget
(
c51510279
.
target
)
e1
:
SetOperation
(
c51510279
.
activate
)
e1
:
SetTarget
(
s
.
target
)
e1
:
SetOperation
(
s
.
activate
)
e1
:
SetLabelObject
(
e0
)
c
:
RegisterEffect
(
e1
)
end
function
c51510279
.
thfilter
(
c
)
function
s
.
thfilter
(
c
)
return
(
c
:
IsType
(
TYPE_NORMAL
)
or
c
:
IsSetCard
(
0x165
)
and
c
:
IsType
(
TYPE_MONSTER
))
and
c
:
IsAbleToHand
()
end
function
c51510279
.
target
(
e
,
tp
,
eg
,
ep
,
ev
,
re
,
r
,
rp
,
chk
,
chkc
)
if
chkc
then
return
chkc
:
IsControler
(
tp
)
and
chkc
:
IsLocation
(
LOCATION_GRAVE
)
and
c51510279
.
thfilter
(
chkc
)
end
if
chk
==
0
then
return
Duel
.
IsExistingTarget
(
c51510279
.
thfilter
,
tp
,
LOCATION_GRAVE
,
0
,
1
,
nil
)
end
function
s
.
target
(
e
,
tp
,
eg
,
ep
,
ev
,
re
,
r
,
rp
,
chk
,
chkc
)
if
chkc
then
return
chkc
:
IsControler
(
tp
)
and
chkc
:
IsLocation
(
LOCATION_GRAVE
)
and
s
.
thfilter
(
chkc
)
end
if
chk
==
0
then
return
Duel
.
IsExistingTarget
(
s
.
thfilter
,
tp
,
LOCATION_GRAVE
,
0
,
1
,
nil
)
end
Duel
.
Hint
(
HINT_SELECTMSG
,
tp
,
HINTMSG_ATOHAND
)
local
g
=
Duel
.
SelectTarget
(
tp
,
c51510279
.
thfilter
,
tp
,
LOCATION_GRAVE
,
0
,
1
,
1
,
nil
)
local
g
=
Duel
.
SelectTarget
(
tp
,
s
.
thfilter
,
tp
,
LOCATION_GRAVE
,
0
,
1
,
1
,
nil
)
Duel
.
SetOperationInfo
(
0
,
CATEGORY_TOHAND
,
g
,
1
,
0
,
0
)
end
function
c51510279
.
ffilter1
(
c
,
e
)
return
not
c
:
IsImmuneToEffect
(
e
)
function
s
.
fusfilter
(
c
)
return
c
:
IsSetCard
(
0x165
)
end
function
c51510279
.
ffilter2
(
c
,
e
,
tp
,
m
,
f
,
chkf
)
return
c
:
IsType
(
TYPE_FUSION
)
and
c
:
IsSetCard
(
0x165
)
and
(
not
f
or
f
(
c
))
and
c
:
IsCanBeSpecialSummoned
(
e
,
SUMMON_TYPE_FUSION
,
tp
,
false
,
false
,
POS_FACEUP_DEFENSE
)
and
c
:
CheckFusionMaterial
(
m
,
nil
,
chkf
)
end
function
c51510279
.
rfilter
(
c
,
e
,
tp
)
function
s
.
rfilter
(
c
,
e
,
tp
)
return
c
:
IsSetCard
(
0x165
)
and
c
:
IsCanBeSpecialSummoned
(
e
,
SUMMON_TYPE_RITUAL
,
tp
,
false
,
true
,
POS_FACEUP_DEFENSE
)
end
function
c51510279
.
activate
(
e
,
tp
,
eg
,
ep
,
ev
,
re
,
r
,
rp
)
function
s
.
activate
(
e
,
tp
,
eg
,
ep
,
ev
,
re
,
r
,
rp
)
local
th
=
Duel
.
GetFirstTarget
()
if
not
th
:
IsRelateToEffect
(
e
)
or
Duel
.
SendtoHand
(
th
,
nil
,
REASON_EFFECT
)
==
0
or
not
th
:
IsLocation
(
LOCATION_HAND
)
then
return
end
local
chkf
=
tp
local
fmg1
=
Duel
.
GetFusionMaterial
(
tp
):
Filter
(
c51510279
.
ffilter1
,
nil
,
e
)
local
fsg1
=
Duel
.
GetMatchingGroup
(
c51510279
.
ffilter2
,
tp
,
LOCATION_EXTRA
,
0
,
nil
,
e
,
tp
,
fmg1
,
nil
,
chkf
)
local
fmg2
=
nil
local
fsg2
=
nil
local
ce
=
Duel
.
GetChainMaterial
(
tp
)
if
ce
~=
nil
then
local
fgroup
=
ce
:
GetTarget
()
fmg2
=
fgroup
(
ce
,
e
,
tp
)
local
mf
=
ce
:
GetValue
()
fsg2
=
Duel
.
GetMatchingGroup
(
c51510279
.
ffilter2
,
tp
,
LOCATION_EXTRA
,
0
,
nil
,
e
,
tp
,
fmg2
,
mf
,
chkf
)
end
local
fusion_effect
=
e
:
GetLabelObject
()
local
rmg1
=
Duel
.
GetRitualMaterial
(
tp
)
local
rsg
=
Duel
.
GetMatchingGroup
(
aux
.
RitualUltimateFilter
,
tp
,
LOCATION_HAND
,
0
,
nil
,
c51510279
.
rfilter
,
e
,
tp
,
rmg1
,
nil
,
Card
.
GetLevel
,
"Greater"
)
local
rsg
=
Duel
.
GetMatchingGroup
(
aux
.
RitualUltimateFilter
,
tp
,
LOCATION_HAND
,
0
,
nil
,
s
.
rfilter
,
e
,
tp
,
rmg1
,
nil
,
Card
.
GetLevel
,
"Greater"
)
local
off
=
1
local
ops
=
{}
local
opval
=
{}
ops
[
off
]
=
aux
.
Stringid
(
51510279
,
0
)
ops
[
off
]
=
aux
.
Stringid
(
id
,
0
)
opval
[
off
-
1
]
=
0
off
=
off
+
1
if
f
sg1
:
GetCount
()
>
0
or
(
fsg2
~=
nil
and
fsg2
:
GetCount
()
>
0
)
then
ops
[
off
]
=
aux
.
Stringid
(
51510279
,
1
)
if
f
usion_effect
:
GetTarget
()(
e
,
tp
,
eg
,
ep
,
ev
,
re
,
r
,
rp
,
0
)
then
ops
[
off
]
=
aux
.
Stringid
(
id
,
1
)
opval
[
off
-
1
]
=
1
off
=
off
+
1
end
if
rsg
:
GetCount
()
>
0
then
ops
[
off
]
=
aux
.
Stringid
(
51510279
,
2
)
ops
[
off
]
=
aux
.
Stringid
(
id
,
2
)
opval
[
off
-
1
]
=
2
off
=
off
+
1
end
local
op
=
Duel
.
SelectOption
(
tp
,
table.unpack
(
ops
))
if
opval
[
op
]
==
1
then
Duel
.
BreakEffect
()
local
sg
=
fsg1
:
Clone
()
if
fsg2
then
sg
:
Merge
(
fsg2
)
end
Duel
.
Hint
(
HINT_SELECTMSG
,
tp
,
HINTMSG_SPSUMMON
)
local
tc
=
sg
:
Select
(
tp
,
1
,
1
,
nil
):
GetFirst
()
fmg1
:
RemoveCard
(
tc
)
if
fsg1
:
IsContains
(
tc
)
and
(
fsg2
==
nil
or
not
fsg2
:
IsContains
(
tc
)
or
not
Duel
.
SelectYesNo
(
tp
,
ce
:
GetDescription
()))
then
local
mat1
=
Duel
.
SelectFusionMaterial
(
tp
,
tc
,
fmg1
,
nil
,
chkf
)
tc
:
SetMaterial
(
mat1
)
Duel
.
SendtoGrave
(
mat1
,
REASON_EFFECT
+
REASON_MATERIAL
+
REASON_FUSION
)
Duel
.
BreakEffect
()
Duel
.
SpecialSummon
(
tc
,
SUMMON_TYPE_FUSION
,
tp
,
tp
,
false
,
false
,
POS_FACEUP_DEFENSE
)
else
local
mat2
=
Duel
.
SelectFusionMaterial
(
tp
,
tc
,
fmg2
,
nil
,
chkf
)
local
fop
=
ce
:
GetOperation
()
fop
(
ce
,
e
,
tp
,
tc
,
mat2
)
end
tc
:
CompleteProcedure
()
fusion_effect
:
GetOperation
()(
e
,
tp
,
eg
,
ep
,
ev
,
re
,
r
,
rp
)
elseif
opval
[
op
]
==
2
then
::
rcancel
::
Duel
.
BreakEffect
()
...
...
c99426088.lua
View file @
fadb389d
--魔鍵-マフテア
function
c99426088
.
initial_effect
(
c
)
local
s
,
id
,
o
=
GetID
()
function
s
.
initial_effect
(
c
)
--Activate
local
e1
=
Effect
.
CreateEffect
(
c
)
e1
:
SetCategory
(
CATEGORY_SPECIAL_SUMMON
+
CATEGORY_FUSION_SUMMON
+
CATEGORY_DECKDES
)
e1
:
SetType
(
EFFECT_TYPE_ACTIVATE
)
e1
:
SetCode
(
EVENT_FREE_CHAIN
)
e1
:
SetTarget
(
c99426088
.
target
)
e1
:
SetOperation
(
c99426088
.
activate
)
e1
:
SetTarget
(
s
.
target
)
e1
:
SetOperation
(
s
.
activate
)
c
:
RegisterEffect
(
e1
)
end
function
c99426088
.
exconfilter
(
c
)
function
s
.
exconfilter
(
c
)
return
c
:
IsFaceup
()
and
c
:
IsType
(
TYPE_NORMAL
)
end
function
c99426088
.
excon
(
tp
)
return
Duel
.
IsExistingMatchingCard
(
c99426088
.
exconfilter
,
tp
,
LOCATION_MZONE
,
0
,
1
,
nil
)
function
s
.
excon
(
tp
)
return
Duel
.
IsExistingMatchingCard
(
s
.
exconfilter
,
tp
,
LOCATION_MZONE
,
0
,
1
,
nil
)
end
function
c99426088
.
ffilter1
(
c
,
e
)
return
not
c
:
IsImmuneToEffect
(
e
)
function
s
.
fusfilter
(
c
)
return
c
:
IsSetCard
(
0x165
)
end
function
c99426088
.
ffilter2
(
c
,
e
,
tp
,
m
,
f
,
chkf
)
return
c
:
IsType
(
TYPE_FUSION
)
and
c
:
IsSetCard
(
0x165
)
and
(
not
f
or
f
(
c
))
and
c
:
IsCanBeSpecialSummoned
(
e
,
SUMMON_TYPE_FUSION
,
tp
,
false
,
false
)
and
c
:
CheckFusionMaterial
(
m
,
nil
,
chkf
)
--- @type FUSION_SPELL_PRE_SELECT_MAT_LOCATION_FUNCTION
function
s
.
pre_select_mat_location
(
tc
,
tp
)
local
location
=
LOCATION_HAND
|
LOCATION_MZONE
--- Add Deck if controls a Normal Monster
if
Duel
.
IsExistingMatchingCard
(
function
(
c
)
return
c
:
IsFaceup
()
and
c
:
IsType
(
TYPE_NORMAL
)
end
,
tp
,
LOCATION_MZONE
,
0
,
1
,
nil
)
then
location
=
location
|
LOCATION_DECK
end
return
location
end
function
c99426088
.
fexfilter
(
c
)
return
c
:
IsType
(
TYPE_NORMAL
)
and
c
:
IsCanBeFusionMaterial
()
and
c
:
IsAbleToGrave
()
function
s
.
fusion_spell_matfilter
(
c
)
--- material from Deck must be Normal Monster
if
c
:
IsLocation
(
LOCATION_DECK
)
and
not
c
:
IsType
(
TYPE_NORMAL
)
then
return
false
end
return
true
end
function
c99426088
.
rfilter
(
c
,
e
,
tp
)
function
s
.
rfilter
(
c
,
e
,
tp
)
return
c
:
IsSetCard
(
0x165
)
end
function
c99426088
.
rexfilter
(
c
)
function
s
.
rexfilter
(
c
)
return
c
:
IsType
(
TYPE_NORMAL
)
and
c
:
IsLevelAbove
(
1
)
and
c
:
IsAbleToGrave
()
end
function
c99426088
.
frcheck
(
tp
,
sg
,
fc
)
function
s
.
rcheck
(
tp
,
sg
,
fc
)
return
sg
:
FilterCount
(
Card
.
IsLocation
,
nil
,
LOCATION_DECK
)
<=
1
end
function
c99426088
.
gcheck
(
sg
,
ec
)
function
s
.
gcheck
(
sg
,
ec
)
return
sg
:
FilterCount
(
Card
.
IsLocation
,
nil
,
LOCATION_DECK
)
<=
1
end
function
c99426088
.
target
(
e
,
tp
,
eg
,
ep
,
ev
,
re
,
r
,
rp
,
chk
)
function
s
.
target
(
e
,
tp
,
eg
,
ep
,
ev
,
re
,
r
,
rp
,
chk
)
if
chk
==
0
then
local
chkf
=
tp
local
fmg1
=
Duel
.
GetFusionMaterial
(
tp
)
if
c99426088
.
excon
(
tp
)
then
local
fmg2
=
Duel
.
GetMatchingGroup
(
c99426088
.
fexfilter
,
tp
,
LOCATION_DECK
,
0
,
nil
)
if
fmg2
:
GetCount
()
>
0
then
fmg1
:
Merge
(
fmg2
)
aux
.
FCheckAdditional
=
c99426088
.
frcheck
aux
.
GCheckAdditional
=
c99426088
.
gcheck
end
local
fusion_effect
=
FusionSpell
.
CreateSummonEffect
(
e
:
GetHandler
(),{
fusfilter
=
s
.
fusfilter
,
pre_select_mat_location
=
s
.
pre_select_mat_location
,
fusion_spell_matfilter
=
s
.
fusion_spell_matfilter
})
if
fusion_effect
:
GetTarget
()(
e
,
tp
,
eg
,
ep
,
ev
,
re
,
r
,
rp
,
0
)
then
return
true
end
local
res
=
Duel
.
IsExistingMatchingCard
(
c99426088
.
ffilter2
,
tp
,
LOCATION_EXTRA
,
0
,
1
,
nil
,
e
,
tp
,
fmg1
,
nil
,
chkf
)
aux
.
FCheckAdditional
=
nil
aux
.
GCheckAdditional
=
nil
if
not
res
then
local
ce
=
Duel
.
GetChainMaterial
(
tp
)
if
ce
~=
nil
then
local
fgroup
=
ce
:
GetTarget
()
local
fmg3
=
fgroup
(
ce
,
e
,
tp
)
local
mf
=
ce
:
GetValue
()
res
=
Duel
.
IsExistingMatchingCard
(
c99426088
.
ffilter2
,
tp
,
LOCATION_EXTRA
,
0
,
1
,
nil
,
e
,
tp
,
fmg3
,
mf
,
chkf
)
end
end
if
not
res
then
local
rmg1
=
Duel
.
GetRitualMaterial
(
tp
)
local
rmg2
if
c99426088
.
excon
(
tp
)
then
rmg2
=
Duel
.
GetMatchingGroup
(
c99426088
.
rexfilter
,
tp
,
LOCATION_DECK
,
0
,
nil
)
end
aux
.
RCheckAdditional
=
c99426088
.
frcheck
aux
.
RGCheckAdditional
=
c99426088
.
gcheck
res
=
Duel
.
IsExistingMatchingCard
(
aux
.
RitualUltimateFilter
,
tp
,
LOCATION_HAND
,
0
,
1
,
nil
,
c99426088
.
rfilter
,
e
,
tp
,
rmg1
,
rmg2
,
Card
.
GetLevel
,
"Greater"
)
aux
.
RCheckAdditional
=
nil
aux
.
RGCheckAdditional
=
nil
local
rmg1
=
Duel
.
GetRitualMaterial
(
tp
)
local
rmg2
if
s
.
excon
(
tp
)
then
rmg2
=
Duel
.
GetMatchingGroup
(
s
.
rexfilter
,
tp
,
LOCATION_DECK
,
0
,
nil
)
end
aux
.
RCheckAdditional
=
s
.
rcheck
aux
.
RGCheckAdditional
=
s
.
gcheck
local
res
=
Duel
.
IsExistingMatchingCard
(
aux
.
RitualUltimateFilter
,
tp
,
LOCATION_HAND
,
0
,
1
,
nil
,
s
.
rfilter
,
e
,
tp
,
rmg1
,
rmg2
,
Card
.
GetLevel
,
"Greater"
)
aux
.
RCheckAdditional
=
nil
aux
.
RGCheckAdditional
=
nil
return
res
end
Duel
.
SetOperationInfo
(
0
,
CATEGORY_SPECIAL_SUMMON
,
nil
,
1
,
tp
,
LOCATION_HAND
+
LOCATION_EXTRA
)
end
function
c99426088
.
activate
(
e
,
tp
,
eg
,
ep
,
ev
,
re
,
r
,
rp
)
local
chkf
=
tp
local
fmg1
=
Duel
.
GetFusionMaterial
(
tp
):
Filter
(
c99426088
.
ffilter1
,
nil
,
e
)
local
exmat
=
false
if
c99426088
.
excon
(
tp
)
then
local
fmg2
=
Duel
.
GetMatchingGroup
(
c99426088
.
fexfilter
,
tp
,
LOCATION_DECK
,
0
,
nil
)
if
fmg2
:
GetCount
()
>
0
then
fmg1
:
Merge
(
fmg2
)
exmat
=
true
end
end
if
exmat
then
aux
.
FCheckAdditional
=
c99426088
.
frcheck
aux
.
GCheckAdditional
=
c99426088
.
gcheck
end
local
fsg1
=
Duel
.
GetMatchingGroup
(
c99426088
.
ffilter2
,
tp
,
LOCATION_EXTRA
,
0
,
nil
,
e
,
tp
,
fmg1
,
nil
,
chkf
)
aux
.
FCheckAdditional
=
nil
aux
.
GCheckAdditional
=
nil
local
fmg3
=
nil
local
fsg2
=
nil
local
ce
=
Duel
.
GetChainMaterial
(
tp
)
if
ce
~=
nil
then
local
fgroup
=
ce
:
GetTarget
()
fmg3
=
fgroup
(
ce
,
e
,
tp
)
local
mf
=
ce
:
GetValue
()
fsg2
=
Duel
.
GetMatchingGroup
(
c99426088
.
ffilter2
,
tp
,
LOCATION_EXTRA
,
0
,
nil
,
e
,
tp
,
fmg3
,
mf
,
chkf
)
end
function
s
.
activate
(
e
,
tp
,
eg
,
ep
,
ev
,
re
,
r
,
rp
)
local
fusion_effect
=
FusionSpell
.
CreateSummonEffect
(
e
:
GetHandler
(),{
fusfilter
=
s
.
fusfilter
,
matfilter
=
aux
.
NecroValleyFilter
(),
pre_select_mat_location
=
s
.
pre_select_mat_location
,
fusion_spell_matfilter
=
s
.
fusion_spell_matfilter
})
local
can_fusion
=
fusion_effect
:
GetTarget
()(
e
,
tp
,
eg
,
ep
,
ev
,
re
,
r
,
rp
,
0
)
local
rmg1
=
Duel
.
GetRitualMaterial
(
tp
)
local
rmg2
if
c99426088
.
excon
(
tp
)
then
rmg2
=
Duel
.
GetMatchingGroup
(
c99426088
.
rexfilter
,
tp
,
LOCATION_DECK
,
0
,
nil
)
if
s
.
excon
(
tp
)
then
rmg2
=
Duel
.
GetMatchingGroup
(
s
.
rexfilter
,
tp
,
LOCATION_DECK
,
0
,
nil
)
end
aux
.
RCheckAdditional
=
c99426088
.
f
rcheck
aux
.
RGCheckAdditional
=
c99426088
.
gcheck
local
rsg
=
Duel
.
GetMatchingGroup
(
aux
.
RitualUltimateFilter
,
tp
,
LOCATION_HAND
,
0
,
nil
,
c99426088
.
rfilter
,
e
,
tp
,
rmg1
,
rmg2
,
Card
.
GetLevel
,
"Greater"
)
aux
.
RCheckAdditional
=
s
.
rcheck
aux
.
RGCheckAdditional
=
s
.
gcheck
local
rsg
=
Duel
.
GetMatchingGroup
(
aux
.
RitualUltimateFilter
,
tp
,
LOCATION_HAND
,
0
,
nil
,
s
.
rfilter
,
e
,
tp
,
rmg1
,
rmg2
,
Card
.
GetLevel
,
"Greater"
)
aux
.
RCheckAdditional
=
nil
aux
.
RGCheckAdditional
=
nil
local
off
=
1
local
ops
=
{}
local
opval
=
{}
if
fsg1
:
GetCount
()
>
0
or
(
fsg2
~=
nil
and
fsg2
:
GetCount
()
>
0
)
then
ops
[
off
]
=
aux
.
Stringid
(
99426088
,
0
)
if
can_fusion
then
ops
[
off
]
=
aux
.
Stringid
(
id
,
0
)
opval
[
off
-
1
]
=
1
off
=
off
+
1
end
if
rsg
:
GetCount
()
>
0
then
ops
[
off
]
=
aux
.
Stringid
(
99426088
,
1
)
ops
[
off
]
=
aux
.
Stringid
(
id
,
1
)
opval
[
off
-
1
]
=
2
off
=
off
+
1
end
if
off
==
1
then
return
end
local
op
=
Duel
.
SelectOption
(
tp
,
table.unpack
(
ops
))
if
opval
[
op
]
==
1
then
local
sg
=
fsg1
:
Clone
()
if
fsg2
then
sg
:
Merge
(
fsg2
)
end
Duel
.
Hint
(
HINT_SELECTMSG
,
tp
,
HINTMSG_SPSUMMON
)
local
tc
=
sg
:
Select
(
tp
,
1
,
1
,
nil
):
GetFirst
()
fmg1
:
RemoveCard
(
tc
)
if
fsg1
:
IsContains
(
tc
)
and
(
fsg2
==
nil
or
not
fsg2
:
IsContains
(
tc
)
or
not
Duel
.
SelectYesNo
(
tp
,
ce
:
GetDescription
()))
then
if
exmat
then
aux
.
FCheckAdditional
=
c99426088
.
frcheck
aux
.
GCheckAdditional
=
c99426088
.
gcheck
end
local
mat1
=
Duel
.
SelectFusionMaterial
(
tp
,
tc
,
fmg1
,
nil
,
chkf
)
aux
.
FCheckAdditional
=
nil
aux
.
GCheckAdditional
=
nil
tc
:
SetMaterial
(
mat1
)
Duel
.
SendtoGrave
(
mat1
,
REASON_EFFECT
+
REASON_MATERIAL
+
REASON_FUSION
)
Duel
.
BreakEffect
()
Duel
.
SpecialSummon
(
tc
,
SUMMON_TYPE_FUSION
,
tp
,
tp
,
false
,
false
,
POS_FACEUP
)
else
local
mat2
=
Duel
.
SelectFusionMaterial
(
tp
,
tc
,
fmg3
,
nil
,
chkf
)
local
fop
=
ce
:
GetOperation
()
fop
(
ce
,
e
,
tp
,
tc
,
mat2
)
end
tc
:
CompleteProcedure
()
fusion_effect
:
GetOperation
()(
e
,
tp
,
eg
,
ep
,
ev
,
re
,
r
,
rp
)
else
::
rcancel
::
Duel
.
Hint
(
HINT_SELECTMSG
,
tp
,
HINTMSG_SPSUMMON
)
local
tc
=
rsg
:
Select
(
tp
,
1
,
1
,
nil
):
GetFirst
()
aux
.
RCheckAdditional
=
c99426088
.
f
rcheck
aux
.
RGCheckAdditional
=
c99426088
.
gcheck
aux
.
RCheckAdditional
=
s
.
rcheck
aux
.
RGCheckAdditional
=
s
.
gcheck
local
rmg
=
rmg1
:
Filter
(
Card
.
IsCanBeRitualMaterial
,
tc
,
tc
)
if
rmg2
then
rmg
:
Merge
(
rmg2
)
end
if
tc
.
mat_filter
then
...
...
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