Commit 4245856d authored by Nemo Ma's avatar Nemo Ma

fix

parent 2914ffd2
...@@ -72,7 +72,7 @@ function cm.cfilter1(c) ...@@ -72,7 +72,7 @@ function cm.cfilter1(c)
end end
function cm.drcon(e,tp,eg,ep,ev,re,r,rp) function cm.drcon(e,tp,eg,ep,ev,re,r,rp)
local g=Duel.GetFieldGroup(tp,LOCATION_HAND,0) local g=Duel.GetFieldGroup(tp,LOCATION_HAND,0)
return g:FilterCount(cfilter1,nil)==g:GetCount() and g:GetClassCount(Card.GetCode)==g:GetCount() return g:FilterCount(cm.cfilter1,nil)==g:GetCount() and g:GetClassCount(Card.GetCode)==g:GetCount()
end end
function cm.drcost(e,tp,eg,ep,ev,re,r,rp,chk) function cm.drcost(e,tp,eg,ep,ev,re,r,rp,chk)
if chk==0 then return Duel.GetFieldGroupCount(tp,LOCATION_HAND,0)~=0 if chk==0 then return Duel.GetFieldGroupCount(tp,LOCATION_HAND,0)~=0
......
...@@ -26,7 +26,7 @@ function cm.cost(e,tp,eg,ep,ev,re,r,rp,chk) ...@@ -26,7 +26,7 @@ function cm.cost(e,tp,eg,ep,ev,re,r,rp,chk)
end end
local sg=tama.tamas_selectElementsMaterial(mg,el,tp) local sg=tama.tamas_selectElementsMaterial(mg,el,tp)
local ct=tama.tamas_getElementCount(tama.tamas_sumElements(sg),TAMA_ELEMENT_FIRE) local ct=tama.tamas_getElementCount(tama.tamas_sumElements(sg),TAMA_ELEMENT_FIRE)
local ct1=tama.tamas_getElementCount(tamas_sumElements(sg),TAMA_ELEMENT_EARTH)-0 local ct1=tama.tamas_getElementCount(tama.tamas_sumElements(sg),TAMA_ELEMENT_EARTH)-0
e:SetLabel(ct,ct1) e:SetLabel(ct,ct1)
Duel.SendtoDeck(sg,nil,2,REASON_COST) Duel.SendtoDeck(sg,nil,2,REASON_COST)
end end
......
...@@ -27,6 +27,10 @@ function cm.initial_effect(c) ...@@ -27,6 +27,10 @@ function cm.initial_effect(c)
e2:SetTarget(cm.sptg) e2:SetTarget(cm.sptg)
e2:SetOperation(cm.spop) e2:SetOperation(cm.spop)
c:RegisterEffect(e2) c:RegisterEffect(e2)
if not cm.Decla then
cm.Decla=true
cm.Declatable={}
end
end end
function cm.cost(e,tp,eg,ep,ev,re,r,rp,chk) function cm.cost(e,tp,eg,ep,ev,re,r,rp,chk)
local c=e:GetHandler() local c=e:GetHandler()
...@@ -54,6 +58,7 @@ end ...@@ -54,6 +58,7 @@ end
function cm.operation(e,tp,eg,ep,ev,re,r,rp) function cm.operation(e,tp,eg,ep,ev,re,r,rp)
local ac=Duel.GetChainInfo(0,CHAININFO_TARGET_PARAM) local ac=Duel.GetChainInfo(0,CHAININFO_TARGET_PARAM)
local c=e:GetHandler() local c=e:GetHandler()
cm.Declatable[#cm.Declatable+1]=ac
--damage --damage
local e2=Effect.CreateEffect(c) local e2=Effect.CreateEffect(c)
e2:SetType(EFFECT_TYPE_FIELD+EFFECT_TYPE_CONTINUOUS) e2:SetType(EFFECT_TYPE_FIELD+EFFECT_TYPE_CONTINUOUS)
...@@ -68,10 +73,20 @@ function cm.regop(e,tp,eg,ep,ev,re,r,rp) ...@@ -68,10 +73,20 @@ function cm.regop(e,tp,eg,ep,ev,re,r,rp)
end end
end end
function cm.rmfilter(c,code) function cm.rmfilter(c,code)
return c:IsAbleToRemoveAsCost() and c:IsCode(code) local code1,code2=c:GetOriginalCodeRule()
return c:IsAbleToRemoveAsCost() and (cm.include(code1,cm.Declatable) or cm.include(code2,cm.Declatable))
end
function cm.include(value,tab)
if not value then return false end
if tab==nil then return false end
for k,v in ipairs(tab) do
if v == value then
return true
end
end
return false
end end
function cm.effcost(e,tp,eg,ep,ev,re,r,rp,chk) function cm.effcost(e,tp,eg,ep,ev,re,r,rp,chk)
local code=e:GetLabelObject():GetLabel()
if chk==0 then return Duel.IsExistingMatchingCard(cm.rmfilter,tp,LOCATION_DECK,0,1,nil,code) and not e:GetHandler():IsControler(tp) end if chk==0 then return Duel.IsExistingMatchingCard(cm.rmfilter,tp,LOCATION_DECK,0,1,nil,code) and not e:GetHandler():IsControler(tp) end
Duel.Hint(HINT_SELECTMSG,tp,HINTMSG_REMOVE) Duel.Hint(HINT_SELECTMSG,tp,HINTMSG_REMOVE)
local rg=Duel.SelectMatchingCard(tp,cm.rmfilter,tp,LOCATION_DECK,0,1,1,nil,code) local rg=Duel.SelectMatchingCard(tp,cm.rmfilter,tp,LOCATION_DECK,0,1,1,nil,code)
......
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