Commit 62b4e7c4 authored by POLYMER's avatar POLYMER

fix

parent 8fb77dc7
...@@ -21,7 +21,7 @@ function s.initial_effect(c) ...@@ -21,7 +21,7 @@ function s.initial_effect(c)
e2:SetType(EFFECT_TYPE_SINGLE+EFFECT_TYPE_TRIGGER_O) e2:SetType(EFFECT_TYPE_SINGLE+EFFECT_TYPE_TRIGGER_O)
e2:SetProperty(EFFECT_FLAG_DELAY) e2:SetProperty(EFFECT_FLAG_DELAY)
e2:SetCode(EVENT_TO_GRAVE) e2:SetCode(EVENT_TO_GRAVE)
e2:SetCountLimit(1,id+100) e2:SetCountLimit(1,id)
e2:SetCondition(s.thcon) e2:SetCondition(s.thcon)
e2:SetTarget(s.thtg) e2:SetTarget(s.thtg)
e2:SetOperation(s.thop) e2:SetOperation(s.thop)
...@@ -34,7 +34,7 @@ function s.initial_effect(c) ...@@ -34,7 +34,7 @@ function s.initial_effect(c)
e3:SetType(EFFECT_TYPE_SINGLE+EFFECT_TYPE_TRIGGER_O) e3:SetType(EFFECT_TYPE_SINGLE+EFFECT_TYPE_TRIGGER_O)
e3:SetProperty(EFFECT_FLAG_DELAY) e3:SetProperty(EFFECT_FLAG_DELAY)
e3:SetCode(EVENT_REMOVE) e3:SetCode(EVENT_REMOVE)
e3:SetCountLimit(1,id+200) e3:SetCountLimit(1,id)
e3:SetCondition(s.rmcon) e3:SetCondition(s.rmcon)
e3:SetTarget(s.rmtg) e3:SetTarget(s.rmtg)
e3:SetOperation(s.rmop) e3:SetOperation(s.rmop)
......
...@@ -43,7 +43,6 @@ end ...@@ -43,7 +43,6 @@ end
function s.negcost(e,tp,eg,ep,ev,re,r,rp,chk) function s.negcost(e,tp,eg,ep,ev,re,r,rp,chk)
local type=bit.band(re:GetActiveType(),0x7) local type=bit.band(re:GetActiveType(),0x7)
if chk==0 then return Duel.IsExistingMatchingCard(s.cfilter,tp,LOCATION_HAND+LOCATION_ONFIELD,0,1,nil,type) end if chk==0 then return Duel.IsExistingMatchingCard(s.cfilter,tp,LOCATION_HAND+LOCATION_ONFIELD,0,1,nil,type) end
Duel.DiscardHand(tp,s.cfilter,1,1,REASON_COST+REASON_DISCARD,nil,type)
Duel.Hint(HINT_SELECTMSG,tp,HINTMSG_OPERATECARD) Duel.Hint(HINT_SELECTMSG,tp,HINTMSG_OPERATECARD)
local g=Duel.SelectMatchingCard(tp,s.cfilter,tp,LOCATION_HAND+LOCATION_ONFIELD,0,1,1,nil,type) local g=Duel.SelectMatchingCard(tp,s.cfilter,tp,LOCATION_HAND+LOCATION_ONFIELD,0,1,1,nil,type)
local tc=g:GetFirst() local tc=g:GetFirst()
......
...@@ -33,6 +33,9 @@ s.Findesiecle=true ...@@ -33,6 +33,9 @@ s.Findesiecle=true
function s.rfilter(c,tp,chk) function s.rfilter(c,tp,chk)
return _G["c"..c:GetCode()] and _G["c"..c:GetCode()].Findesiecle and c:IsControler(tp) and c:IsFaceup() return _G["c"..c:GetCode()] and _G["c"..c:GetCode()].Findesiecle and c:IsControler(tp) and c:IsFaceup()
end end
function s.cfilter(c)
return c:IsFacedown() or not c:IsRace(0x10)
end
function s.cost(e,tp,eg,ep,ev,re,r,rp,chk) function s.cost(e,tp,eg,ep,ev,re,r,rp,chk)
if chk==0 then return Duel.CheckReleaseGroup(tp,s.rfilter,1,nil,tp) end if chk==0 then return Duel.CheckReleaseGroup(tp,s.rfilter,1,nil,tp) end
Duel.Hint(HINT_SELECTMSG,tp,HINTMSG_RELEASE) Duel.Hint(HINT_SELECTMSG,tp,HINTMSG_RELEASE)
...@@ -40,7 +43,7 @@ function s.cost(e,tp,eg,ep,ev,re,r,rp,chk) ...@@ -40,7 +43,7 @@ function s.cost(e,tp,eg,ep,ev,re,r,rp,chk)
Duel.Release(g,REASON_COST) Duel.Release(g,REASON_COST)
end end
function s.discon(e,tp,eg,ep,ev,re,r,rp) function s.discon(e,tp,eg,ep,ev,re,r,rp)
return rp==1-tp and Duel.IsChainDisablable(ev) return rp==1-tp and Duel.IsChainDisablable(ev) and not Duel.IsExistingMatchingCard(s.cfilter,tp,LOCATION_MZONE,0,1,nil)
end end
function s.distg(e,tp,eg,ep,ev,re,r,rp,chk) function s.distg(e,tp,eg,ep,ev,re,r,rp,chk)
if chk==0 then return true end if chk==0 then return true end
...@@ -58,10 +61,11 @@ function s.disop(e,tp,eg,ep,ev,re,r,rp) ...@@ -58,10 +61,11 @@ function s.disop(e,tp,eg,ep,ev,re,r,rp)
ec:CancelToGrave() ec:CancelToGrave()
Duel.Destroy(ec,REASON_RULE) Duel.Destroy(ec,REASON_RULE)
if Duel.SSet(tp,ec)~=0 and ec:IsLocation(LOCATION_SZONE) then if Duel.SSet(tp,ec)~=0 and ec:IsLocation(LOCATION_SZONE) then
Duel.RegisterFlagEffect(ec,id,RESET_EVENT+RESETS_STANDARD,0,1) ec:RegisterFlagEffect(id,RESET_EVENT+RESETS_STANDARD,0,1)
e1=Effect.CreateEffect(c) e1=Effect.CreateEffect(c)
e1:SetType(EFFECT_TYPE_FIELD+EFFECT_TYPE_CONTINUOUS) e1:SetType(EFFECT_TYPE_FIELD+EFFECT_TYPE_CONTINUOUS)
e1:SetCode(EVENT_CHAINING) e1:SetCode(EVENT_CHAINING)
e1:SetLabelObject(ec)
e1:SetCondition(s.negcon) e1:SetCondition(s.negcon)
e1:SetOperation(s.negop) e1:SetOperation(s.negop)
Duel.RegisterEffect(e1,tp) Duel.RegisterEffect(e1,tp)
...@@ -70,7 +74,13 @@ function s.disop(e,tp,eg,ep,ev,re,r,rp) ...@@ -70,7 +74,13 @@ function s.disop(e,tp,eg,ep,ev,re,r,rp)
end end
end end
function s.negcon(e,tp,eg,ep,ev,re,r,rp) function s.negcon(e,tp,eg,ep,ev,re,r,rp)
return Duel.GetFlagEffect(tp,id)~=0 and re:IsHasType(EFFECT_TYPE_ACTIVATE) local tc=e:GetLabelObject()
if tc:GetFlagEffect(id)~=0 and re:IsHasType(EFFECT_TYPE_ACTIVATE) then
return true
else
e:Reset()
return false
end
end end
function s.negop(e,tp,eg,ep,ev,re,r,rp) function s.negop(e,tp,eg,ep,ev,re,r,rp)
Duel.Hint(HINT_CARD,0,91300062) Duel.Hint(HINT_CARD,0,91300062)
......
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