`
up2u0609
  • 浏览: 16574 次
社区版块
存档分类
最新评论

[警报解除]gem升级警报:使用rails3.1的同学不要着急升级sprockets

阅读更多
  
此警报已接触,请直接升级到rails3.1.0.rc5 和 sprockets.2.0.0.beta.13



  sprockets-2.0.0.beta.10以后版本的一个微小改动会让r3.1的assets pipeline无法找到assets资源。
   sprockets目前的版本是2.0.0.beta.12,一个多月前发布的2.0.0.beta.11版本已经出现同样问题,所幸在那个版本发布后不久就被从gem库中移除(也许就是因为这个问题),但刚刚发布的2.0.0.beta.12依然没有做出针对性的修复。
   这个引发问题的改动很简单,但是我自己对于这个问题的修复很矛盾。这个问题的原因是一个看起来相当有道理的变化,故事说起来有点长,简单的举个例子来说明:
 
   原因是由于一个数组赋值的语句发生了一点微小的变化:
   在sprockets-2.0.0.beta.10是这么作的:
  #需求是把b数组拼接到a数组里
   a = [ 1 , 2 , 3 ]
   b = [ 4 , 5 , 6 ]
  #在sprockets-2.0.0.beta.10是这么实现的
   a.concat b  #=> a = [ 1 , 2 , 3 , 4 , 5 , 6 ]
 


  从sprockets-2.0.0.beta.11以后版本是这么作的:
  #需求是把b数组拼接到a数组里
   a = [ 1 , 2 , 3 ]
   b = [ 4 , 5 , 6 ]
  #在sprockets-2.0.0.beta.11以后是这么实现的
   a.dup.concat b  #=> 毫无疑问: a = [ 1 , 2 , 3 ]
 


想确认的同学可以在console下反复输入几次以下代码:
  Rails.application.assets.paths.id

在sprockets-2.0.0.beta.10下每次返回的结果都是一样的,在sprockets-2.0.0.beta.11以后每次结果都不一样,就是因为这个paths方法里多了个dup。

   对于这个问题我决定不自己动手修复,一方面sprocket没有什么错,为一个array作getter,出于数据安全的考虑,用dup是可以理解的;另一方面,rails本身也确实没有什么更好的办法来接触这个对象。在哪头改好像都不太合适,干脆等他们自己掰吃明白的吧。
0
0
分享到:
评论

相关推荐

Global site tag (gtag.js) - Google Analytics