什么是rubocop中的阴影外部局部变量,我该如何解决这个问题?

时间:2015-11-16 14:25:57

标签: ruby-on-rails rubocop

我在rails上运行rubocop,它给了我以下信息。

W: Shadowing outer local variable - user.
  where(provider: auth.provider, uid: auth.uid).first_or_create do |user|
                                                                    ^^^^

这是代码。

def self.from_omniauth(auth)
user = User.where(email: auth.info.email).first

if user
  return user
else
  where(provider: auth.provider, uid: auth.uid).first_or_create do |user|
    user.fullname = auth.info.name
    user.provider = auth.provider
    user.uid = auth.uid
    user.email = auth.info.email
    user.image = auth.info.image
    user.password = Devise.friendly_token[0, 20]
  end
end

1 个答案:

答案 0 :(得分:8)

这意味着作为块参数提供的user将覆盖此处定义的user变量user = User.where(email: auth.info.email).first

要克服它,您需要更改其中一个变量的名称。 有什么谎言:

result = User.where...
return result if result    

或者:

where(provider: auth.provider, uid: auth.uid).first_or_create do |u|
  u.fullname = auth.info.name
  ...
end

更多信息:https://github.com/bbatsov/ruby-style-guide#no-shadowing