重建一个集市仓库,同时只保留一些分支机构(Recreating a bazaar repository while only retaining a few of the branches)
(编辑:删除了我的问题,留下了让我困惑的问题的链接,因为这里的一些评论中有一些有用的东西)
这里的问题让我困惑,但实际上已经完全回答了。 该问题询问了如何使用原始存储库的少数分支构建新的存储库。
(EDIT: Removed my question, leaving a link to the question that confused me, because there's some useful stuff in some of the comments here)
The question here confused me, but was actually answered fully. That question asked how to build a new repository with only a few of the branches of the original repository.
原文:https://stackoverflow.com/questions/19773652
最满意答案
从您的日志中,您可以看到您在某些内容上调用方法状态为零。
7月28日19:14:21域app / web.1:NoMethodError(未定义方法
state' for nil:NilClass): Jul 28 19:14:21 domain app/web.1: app/models/user.rb:75:in
类似的'7月28日19:14:21域应用程序/ web.1:app / models / user.rb:75:在'类似'在您编辑的答案中,您可以看到罪魁祸首。 你在这个else语句中返回nil。
def location if Location.by_zip_code(self.zip_code.to_s).any? # you can return all here if you want more than one # for testing just returning the first one return Location.by_zip_code(self.zip_code.to_s).first else return nil end end
但你不要在这里检查nil(c.location.state)
def similar arr = User.where(:gender => self.gender).where.not(:id => self.id) arr.select{|c| c.location.state == self.location.state } end
像我下面的东西可能会有所作为
def similar arr = User.where(:gender => self.gender).where.not(:id => self.id) arr.select{ |c| if !c.location.nil? return c.location.state == self.location.state else return false end } end
对于问题的其他部分,您可能会在Location模型中出现错误。 没有看到代码我无法帮助你,但上述内容将帮助您的代码优雅地失败。
From your logs you can see that you're calling the method state on something thats nil.
Jul 28 19:14:21 domain app/web.1: NoMethodError (undefined method
state' for nil:NilClass): Jul 28 19:14:21 domain app/web.1: app/models/user.rb:75:in
block in similar' Jul 28 19:14:21 domain app/web.1: app/models/user.rb:75:in `similar'In your edited answer you can see the culprit. You return nil in this else statement.
def location if Location.by_zip_code(self.zip_code.to_s).any? # you can return all here if you want more than one # for testing just returning the first one return Location.by_zip_code(self.zip_code.to_s).first else return nil end end
But you don't check for nil here (c.location.state)
def similar arr = User.where(:gender => self.gender).where.not(:id => self.id) arr.select{|c| c.location.state == self.location.state } end
Something like what I have below might do the trick
def similar arr = User.where(:gender => self.gender).where.not(:id => self.id) arr.select{ |c| if !c.location.nil? return c.location.state == self.location.state else return false end } end
For the other part of the problem, you could potentially have errors in your Location model. Without seeing that code I can't help you but the above will help your code to fail gracefully.
相关问答
更多-
我已经解决了这个问题。这是因为视图文件有问题。当你想把它放在index.html.erb中时,你不能在模型之前放@。 I've solve this problem.It is because the view file has an issue.When you want to put it in the index.html.erb,you can't put @ before the model.
-
发生这种情况是因为@nearbylocations是nil ,因为它期望一个Array 你可以通过使用避免这种情况 <% for masterlocation in @nearbylocations %>
- <%= masterlocation.nickname %>
<% end if @nearbylocations %> 我还注意到你在重定向后被声明为实例变量。 理想的情况下 redirect_to '/' @nearbylocations = Masterlocatio ... -
正如我在上面的评论中已经写过的那样:它最终对我有用而没有奇怪的语法和无法解释的错误 - 我能想到的唯一解释是我在测试期间弄乱了一些东西。 As I already written in comments above: It finally worked for me without strange syntax and unexplained errors - only explanation I can come up with is that I messed up something during t ...
-
你的session[:page]是nil 。 如果nil只需设置默认值: def pullTenRecords session[:page] ||= 0 ... Your session[:page] is nil. Just set default value if it nil: def pullTenRecords session[:page] ||= 0 ...
-
Ruby未定义的方法`+'为nil:NilClass(NoMethodError)(Ruby undefined method `+' for nil:NilClass (NoMethodError))[2022-05-14]
将@size的声明移动到初始化方法中: def initialize(data = nil, nextNode = nil) @data = data @nextNode = nextNode @size = 0 end Move the declaration for @size into the initialize method: def initialize(data = nil, nextNode = nil) @data = data @nextNode = nextNod ... -
当你看到undefined method '[]' for nil:NilClass它意味着: 嘿! 你有一个值nil然后是[...] ,但是没有这个方法。 在这种情况下,你的问题是match(...)有时不能匹配你想要的文本,返回nil ,然后你不能要求[1] 。 一些避免这种情况的直接方法是: match = t.cmd('actual command').match(/Calls:\s(\d{1,})/) res = match && match[1].to_i # or res = match[1 ...
-
从您的日志中,您可以看到您在某些内容上调用方法状态为零。 7月28日19:14:21域app / web.1:NoMethodError(未定义方法state' for nil:NilClass): Jul 28 19:14:21 domain app/web.1: app/models/user.rb:75:in类似的'7月28日19:14:21域应用程序/ web.1:app / models / user.rb:75:在'类似' 在您编辑的答案中,您可以看到罪魁祸首。 你在这个else语句中返回nil ...
-
我有完全相同的错误,解决方案是将上传器连接到我的模型中的现有字段。 对于您的示例,修复将是从更改 class Upload < ActiveRecord::Base attr_accessible :title, :data_file, :caption mount_uploader :upload, DataFileUploader validates :title, :data_file, :presence => true end 至 class Upload < ActiveReco ...
-
范围0..no_of_players包含在内。 您可能想要使用独家版本(注意三个点): 0...no_of_players 要么: 0..no_of_players-1 Range 0..no_of_players is inclusive. You probably want to use exclusive version (note three dots): 0...no_of_players or: 0..no_of_players-1
-
只调用each ,而不是each_with_index导致问题 应该是program.description.split(' ').each_with_index do |word, index| calling just each, not each_with_index causes the problem should be program.description.split(' ').each_with_index do |word, index|