在我的一个 Rails 应用程序中,ExecJS 没有显示咖啡脚本编译错误的行号。我的编译错误信息如下所示:

ExecJS::RuntimeError in Referrals#new

Showing ~/MyApp/app/views/layouts/application.html.erb where line #6 raised:

SyntaxError: unexpected IDENTIFIER
  (in ~/MyApp/assets/javascripts/utils.js.coffee)

请注意,咖啡脚本源没有行号(第 6 行用于 erb 文件)。

在我的另一个应用程序中,我仍在获取行号,语法错误如下所示:
ExecJS::ProgramError in Projects#show

Showing ~/OtherApp/app/views/layouts/application.html.erb where     line #17 raised:

Error: Parse error on line 6: Unexpected 'STRING'
(in ~/OtherApp/app/assets/javascripts/projects.js.coffee)

所以看起来区别在于 ExecJS::ProgramError 会给我行号,而 0x2518122231343141 不会。

任何人都知道如何取回行号?为什么我的应用程序在编译咖啡 Assets 时会创建 RuntimeErrors,而另一个应用程序会给出 ProgramErrors?我检查了 Rails,它们似乎匹配。

请注意,如果我修复了编译错误,应用程序运行良好(例如,咖啡文件实际上会被编译)——但是让这些行号指向编译错误会很好!。

编辑
我意识到无论是 ExecJS ExecJS::RuntimeError 还是 Runtimeerror 似乎都不重要——在第一个应用程序中,从来没有给出行号,而在第二个应用程序中,总是有。

最佳答案

我想通了——这是由于 coffee-script-source gem 版本。在给出行号的应用程序中,bundle show 给出了 1.4.0 的 coffee-script-source,而另一个应用程序的 coffee-script-source 版本为 1.6.1。

我没有注意到这一点,因为 coffee-rails gem 没有严格指定这种依赖关系(在我的两个 Gemfiles 中,我都使用 gem 'coffee-rails', '3.2' )。 要解决这个问题,只需明确指定 coffee-script-source gem 版本 :

gem 'coffee-rails', '3.2.2'
gem 'coffee-script-source', '1.5.0'

bundle update coffee-script-source

希望这可以帮助其他可能遇到这种差异的人。

关于ruby-on-rails - ExecJS 咖啡脚本未显示编译错误的行号(Rails Assets 管道),我们在Stack Overflow上找到一个类似的问题:https://stackoverflow.com/questions/16369614/

10-14 09:31