[英]Assignment Branch Condition size for update_status is too high. [<1, 18, 8> 19.72/17]
How can i fix this, when i try to condition if user.completed?当我尝试调整 if user.completed 时,我该如何解决这个问题? == false or add when "completed", i will has error == false 或在“完成”时添加,我会出错
def update_status
status_cont = params[:status_cont]
if user.completed? == false
case status_cont
when "waiting_email_confirm"
user.waiting_email_confirm!
when "email_confirmed"
user.email_confirmed!
when "ready_to_ship"
user.ready_to_ship!
when "shipped"
user.shipped!
when "canceled"
user.canceled!
when "completed"
user.completed!
end
end
end
There's a pattern in your case
that you can use to simplify the logic.您的case
中有一种模式可用于简化逻辑。 Something like this:像这样:
STATUS_CONTS = %w[canceled completed email_confirmed ready_to_ship shipped waiting_email_confirm]
private_constant :STATUS_CONTS
def update_status
return if !user.completed?
status_cont = params[:status_cont]
raise "Unknown status_cont #{status_cont}" if !status_cont.in?(STATUS_CONTS)
user.send("#{status_cont}!")
end
You'll probably want to handle unknown status_cont
values differently but I don't know how the surrounding flow works.您可能希望以不同方式处理未知的status_cont
值,但我不知道周围的流程是如何工作的。
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.