Commit 7f8a3ce1 authored by salix5's avatar salix5

Merge pull request #116 from DailyShana/patch-4

fix "after this card is activated"
parents a3c3c539 db429d7b
...@@ -19,8 +19,7 @@ function c11961740.activate(e,tp,eg,ep,ev,re,r,rp) ...@@ -19,8 +19,7 @@ function c11961740.activate(e,tp,eg,ep,ev,re,r,rp)
Duel.Hint(HINT_SELECTMSG,tp,HINTMSG_REMOVE) Duel.Hint(HINT_SELECTMSG,tp,HINTMSG_REMOVE)
local g=Duel.SelectMatchingCard(tp,Card.IsAbleToRemove,tp,LOCATION_DECK,0,1,1,nil) local g=Duel.SelectMatchingCard(tp,Card.IsAbleToRemove,tp,LOCATION_DECK,0,1,1,nil)
local tc=g:GetFirst() local tc=g:GetFirst()
if tc then if tc and Duel.Remove(tc,POS_FACEDOWN,REASON_EFFECT)~=0 and e:IsHasType(EFFECT_TYPE_ACTIVATE) then
Duel.Remove(tc,POS_FACEDOWN,REASON_EFFECT)
tc:RegisterFlagEffect(11961740,RESET_EVENT+0x1fe0000,0,1) tc:RegisterFlagEffect(11961740,RESET_EVENT+0x1fe0000,0,1)
c:CancelToGrave() c:CancelToGrave()
local e1=Effect.CreateEffect(c) local e1=Effect.CreateEffect(c)
......
...@@ -34,6 +34,7 @@ function c17194258.activate(e,tp,eg,ep,ev,re,r,rp) ...@@ -34,6 +34,7 @@ function c17194258.activate(e,tp,eg,ep,ev,re,r,rp)
local tc=g:GetFirst() local tc=g:GetFirst()
if tc and Duel.SendtoHand(tc,nil,REASON_EFFECT)~=0 and tc:IsLocation(LOCATION_HAND) then if tc and Duel.SendtoHand(tc,nil,REASON_EFFECT)~=0 and tc:IsLocation(LOCATION_HAND) then
Duel.ConfirmCards(1-tp,tc) Duel.ConfirmCards(1-tp,tc)
if not e:IsHasType(EFFECT_TYPE_ACTIVATE) then return end
local e1=Effect.CreateEffect(e:GetHandler()) local e1=Effect.CreateEffect(e:GetHandler())
e1:SetType(EFFECT_TYPE_FIELD) e1:SetType(EFFECT_TYPE_FIELD)
e1:SetCode(EFFECT_CANNOT_SUMMON) e1:SetCode(EFFECT_CANNOT_SUMMON)
......
...@@ -18,6 +18,7 @@ function c313513.cost(e,tp,eg,ep,ev,re,r,rp,chk) ...@@ -18,6 +18,7 @@ function c313513.cost(e,tp,eg,ep,ev,re,r,rp,chk)
Duel.Hint(HINT_SELECTMSG,tp,HINTMSG_TOGRAVE) Duel.Hint(HINT_SELECTMSG,tp,HINTMSG_TOGRAVE)
local g=Duel.SelectMatchingCard(tp,c313513.cfilter,tp,LOCATION_ONFIELD,0,3,3,nil) local g=Duel.SelectMatchingCard(tp,c313513.cfilter,tp,LOCATION_ONFIELD,0,3,3,nil)
Duel.SendtoGrave(g,REASON_COST) Duel.SendtoGrave(g,REASON_COST)
if not e:IsHasType(EFFECT_TYPE_ACTIVATE) then return end
local e1=Effect.CreateEffect(e:GetHandler()) local e1=Effect.CreateEffect(e:GetHandler())
e1:SetType(EFFECT_TYPE_FIELD) e1:SetType(EFFECT_TYPE_FIELD)
e1:SetCode(EFFECT_CANNOT_SUMMON) e1:SetCode(EFFECT_CANNOT_SUMMON)
......
...@@ -22,7 +22,7 @@ function c51790181.activate(e,tp,eg,ep,ev,re,r,rp) ...@@ -22,7 +22,7 @@ function c51790181.activate(e,tp,eg,ep,ev,re,r,rp)
local g=Duel.GetChainInfo(0,CHAININFO_TARGET_CARDS) local g=Duel.GetChainInfo(0,CHAININFO_TARGET_CARDS)
local sg=g:Filter(Card.IsRelateToEffect,nil,e) local sg=g:Filter(Card.IsRelateToEffect,nil,e)
Duel.SendtoDeck(sg,nil,2,REASON_EFFECT) Duel.SendtoDeck(sg,nil,2,REASON_EFFECT)
if e:GetHandler():IsRelateToEffect(e) then if e:GetHandler():IsRelateToEffect(e) and e:IsHasType(EFFECT_TYPE_ACTIVATE) then
Duel.Remove(e:GetHandler(),POS_FACEUP,REASON_EFFECT) Duel.Remove(e:GetHandler(),POS_FACEUP,REASON_EFFECT)
end end
end end
...@@ -6,7 +6,6 @@ function c72537897.initial_effect(c) ...@@ -6,7 +6,6 @@ function c72537897.initial_effect(c)
e1:SetType(EFFECT_TYPE_ACTIVATE) e1:SetType(EFFECT_TYPE_ACTIVATE)
e1:SetCode(EVENT_FREE_CHAIN) e1:SetCode(EVENT_FREE_CHAIN)
e1:SetCondition(c72537897.condition) e1:SetCondition(c72537897.condition)
e1:SetCost(c72537897.cost)
e1:SetTarget(c72537897.target) e1:SetTarget(c72537897.target)
e1:SetOperation(c72537897.activate) e1:SetOperation(c72537897.activate)
c:RegisterEffect(e1) c:RegisterEffect(e1)
...@@ -14,20 +13,6 @@ end ...@@ -14,20 +13,6 @@ end
function c72537897.condition(e,tp,eg,ep,ev,re,r,rp) function c72537897.condition(e,tp,eg,ep,ev,re,r,rp)
return Duel.GetFieldGroupCount(tp,LOCATION_MZONE,0)==0 return Duel.GetFieldGroupCount(tp,LOCATION_MZONE,0)==0
end end
function c72537897.cost(e,tp,eg,ep,ev,re,r,rp,chk)
if chk==0 then return true end
local e1=Effect.CreateEffect(e:GetHandler())
e1:SetType(EFFECT_TYPE_FIELD)
e1:SetProperty(EFFECT_FLAG_PLAYER_TARGET)
e1:SetCode(EFFECT_CANNOT_SPECIAL_SUMMON)
e1:SetTargetRange(1,0)
e1:SetTarget(c72537897.splimit)
e1:SetReset(RESET_PHASE+PHASE_END)
Duel.RegisterEffect(e1,tp)
end
function c72537897.splimit(e,c)
return c:GetRace()~=RACE_BEAST
end
function c72537897.spfilter(c,e,tp) function c72537897.spfilter(c,e,tp)
return c:IsRace(RACE_BEAST) and c:IsLevelBelow(2) and c:IsType(TYPE_EFFECT) and c:IsCanBeSpecialSummoned(e,0,tp,false,false) return c:IsRace(RACE_BEAST) and c:IsLevelBelow(2) and c:IsType(TYPE_EFFECT) and c:IsCanBeSpecialSummoned(e,0,tp,false,false)
end end
...@@ -38,6 +23,17 @@ function c72537897.target(e,tp,eg,ep,ev,re,r,rp,chk) ...@@ -38,6 +23,17 @@ function c72537897.target(e,tp,eg,ep,ev,re,r,rp,chk)
Duel.SetOperationInfo(0,CATEGORY_SPECIAL_SUMMON,nil,3,tp,LOCATION_DECK) Duel.SetOperationInfo(0,CATEGORY_SPECIAL_SUMMON,nil,3,tp,LOCATION_DECK)
end end
function c72537897.activate(e,tp,eg,ep,ev,re,r,rp) function c72537897.activate(e,tp,eg,ep,ev,re,r,rp)
local c=e:GetHandler()
if e:IsHasType(EFFECT_TYPE_ACTIVATE) then
local e1=Effect.CreateEffect(c)
e1:SetType(EFFECT_TYPE_FIELD)
e1:SetProperty(EFFECT_FLAG_PLAYER_TARGET)
e1:SetCode(EFFECT_CANNOT_SPECIAL_SUMMON)
e1:SetTargetRange(1,0)
e1:SetTarget(c72537897.splimit)
e1:SetReset(RESET_PHASE+PHASE_END)
Duel.RegisterEffect(e1,tp)
end
if Duel.GetLocationCount(tp,LOCATION_MZONE)<=2 then return end if Duel.GetLocationCount(tp,LOCATION_MZONE)<=2 then return end
local g=Duel.GetMatchingGroup(c72537897.spfilter,tp,LOCATION_DECK,0,nil,e,tp) local g=Duel.GetMatchingGroup(c72537897.spfilter,tp,LOCATION_DECK,0,nil,e,tp)
if g:GetClassCount(Card.GetCode)>=3 then if g:GetClassCount(Card.GetCode)>=3 then
...@@ -51,7 +47,6 @@ function c72537897.activate(e,tp,eg,ep,ev,re,r,rp) ...@@ -51,7 +47,6 @@ function c72537897.activate(e,tp,eg,ep,ev,re,r,rp)
local sg3=g:Select(tp,1,1,nil) local sg3=g:Select(tp,1,1,nil)
sg1:Merge(sg2) sg1:Merge(sg2)
sg1:Merge(sg3) sg1:Merge(sg3)
local c=e:GetHandler()
local fid=c:GetFieldID() local fid=c:GetFieldID()
local tc=sg1:GetFirst() local tc=sg1:GetFirst()
while tc do while tc do
...@@ -83,6 +78,9 @@ function c72537897.activate(e,tp,eg,ep,ev,re,r,rp) ...@@ -83,6 +78,9 @@ function c72537897.activate(e,tp,eg,ep,ev,re,r,rp)
Duel.SpecialSummonComplete() Duel.SpecialSummonComplete()
end end
end end
function c72537897.splimit(e,c)
return c:GetRace()~=RACE_BEAST
end
function c72537897.desfilter(c,fid) function c72537897.desfilter(c,fid)
return c:GetFlagEffectLabel(72537897)==fid return c:GetFlagEffectLabel(72537897)==fid
end end
......
...@@ -19,6 +19,7 @@ function c75500286.activate(e,tp,eg,ep,ev,re,r,rp) ...@@ -19,6 +19,7 @@ function c75500286.activate(e,tp,eg,ep,ev,re,r,rp)
local tg=g:GetFirst() local tg=g:GetFirst()
if tg==nil then return end if tg==nil then return end
Duel.Remove(tg,POS_FACEUP,REASON_EFFECT) Duel.Remove(tg,POS_FACEUP,REASON_EFFECT)
if not e:IsHasType(EFFECT_TYPE_ACTIVATE) then return end
local e1=Effect.CreateEffect(e:GetHandler()) local e1=Effect.CreateEffect(e:GetHandler())
e1:SetType(EFFECT_TYPE_FIELD+EFFECT_TYPE_CONTINUOUS) e1:SetType(EFFECT_TYPE_FIELD+EFFECT_TYPE_CONTINUOUS)
e1:SetRange(LOCATION_REMOVED) e1:SetRange(LOCATION_REMOVED)
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment