草庐IT

ios - UICollectionView 设置默认位置

全部标签

Ruby,哪个异常最适合处理未设置的环境变量?

我编写的脚本在启动时运行,需要设置环境变量,但是Ruby的Exceptions,是最好的?我使用了LoadError,我只是想尽可能具有描述性并遵循适当的约定。其次,除了检查环境变量的长度外,我找不到其他方法来查看是否设置了环境变量,但这似乎不太优雅。beginraiseLoadErrorifENV['FOO'].to_s.length==0system"openhttp://example.com/"+ENV['FOO']rescueException=>eputs"=>#{e}FOOenvironmentvariablenotset"end 最佳答案

ruby - 设置 rake-pipeline 以与 handlebars 和 Google App Engine 一起使用

这就是我正在尝试做的事情。我正在构建一个ember.js应用程序,其java后端在GAE上运行。我正在使用Handlebars,但我希望将它们分成单独的文件,而不是全部粘贴到index.html中。通过ember.jsirc,我打开了rake-pipeline连同minispade连同webfilters和自定义handlebarsfilter我开始构建Assets文件。我不知道Ruby或gem文件等。因此,我正在尝试找出能够即时编译我的coffeescript/handlebars文件的最佳方法,对它们进行minispade,但在开发模式下保持单个文件可访问,以便我可以调试它们。困难

ruby - 如何让 fish shell 默认使用 rvm ruby

我在MacOSX10.9.1上使用fishshell2.10。我想在我的终端中使用我使用RVM作为默认安装的Ruby,但我似乎无法完成这项工作。我已经尝试过rvmuse2.1.0--default但在打开一个新终端时我仍然得到以下信息:>whichruby/usr/bin/ruby运行rvm命令会加载ruby​​:>whichruby/usr/bin/ruby>rvm[...]>whichruby/Users/alex/.rvm/rubies/ruby-2.1.0/bin/ruby但每次我打开一个新终端时都必须这样做很烦人。 最佳答案

ruby-on-rails - 如何为有点独立的 Ruby 脚本设置 Rails 环境?

我的Rails应用程序中有一个Ruby脚本,用于从Twitter加载一些数据。将来我会让它成为一个自动后台进程,但现在我手动运行它,如下所示:ruby/lib/twitter/twitterLoad.rb为了使用Rails模型类等,我将以下内容作为脚本的第一行:require"#{File.dirname(__FILE__)}/../../config/environment.rb"默认使用开发环境。但是,我希望能够在某个时候选择生产环境。更新#1:RAILS_ENV常量正在environment.rb文件中设置。所以,我能够将ENV['RAILS_ENV']='production'

ruby - 在 ruby​​ 中使用带有默认值的选项散列作为参数的一种干净利落的方法是什么

假设我想要一个这样调用的方法:tiger=create_tiger(:num_stripes=>12,:max_speed=>43.2)tiger.num_stripes#willbe12有些选项有默认值:tiger=create_tiger(:max_speed=>43.2)tiger.num_stripes#willhavesomedefaultvalue在方法实现中实现默认行为的惯用ruby​​方法是什么? 最佳答案 deffoo(options={})options={...defaults...}.merge(option

ruby - 什么是 'rvm_codesign_identity' 以及如何设置它?

我正在使用rvm1.16.10(稳定版)在我执行rvminstall1.9.3--with-gcc=clang之后安装1.9.3后显示:'rvm_codesign_identity'未设置,请在~/.rvmrc中设置但是..什么是“rvm_codesign_identity”以及如何设置它?提前致谢。 最佳答案 https://github.com/wayneeseguin/rvm/issues/820https://github.com/wayneeseguin/rvm/issues/1210#issuecomment-92722

Ruby:如何获取可选 proc 参数的默认值

假设我有一个像这样的proc/lambda/block/method/etc:2.1.2:075>procedure=Proc.new{|a,b=2,*c,&d|42}=>#我知道我可以通过以下方式找出参数的名称:2.1.2:080>procedure.parameters=>[[:opt,:a],[:opt,:b],[:rest,:c],[:block,:d]]但是,如果给定的可选参数未给定,我该如何获取该可选参数的值呢?附言:是的。我知道这在here之前已经被问过/回答过,但之前的解决方案需要使用merbgem,这实际上有点误导。merb本身依赖于methoparagem(除非您使

ruby - 有没有办法在 Vim 中为 Ruby 设置良好的自动完成?

我一直在尝试为Ruby代码设置Vim自动完成功能,但没有成功。我的意思是“工作”,但我希望有更好的插件或配置可用。我已经设置了ruby​​complete插件,它做得不错,但与像RubyMine这样的IDE相比就差强人意了。一旦我安装它,它只是呼吸新鲜空气,看看我错过了什么。它非常了解语法、上下文,并且通常只显示相关的可能选项。也许我只是没有正确设置。不可能找到关于如何解决这个问题的教程、博客文章和好的文档(尤其是最新的文档)。有时您只是发现有不同的工具和设置,但没有太多关于如何操作的解释。是否有针对此类事物的社区标准?实现这一目标的最佳工具是什么?任何好的教程、资源、关于如何去做的线

ruby - 如何在 Ruby 中创建 IO 的自定义子类?

我如何创建自己的类来代替IO,例如为某些接受类似IO参数的代码重定向/捕获输入/输出?IO本身似乎耦合到OS文件描述符,我所知道的唯一一个模仿它而不对其进行子类化的类是StringIO,它似乎只是重新实现了整个接口(interface)。我认为该语言会提供一种直接的方法来执行此操作,但我找不到有关该主题的任何信息。是否有像Enumerable那样在一些基元之上实现接口(interface)的混合宏? 最佳答案 我怀疑我遗漏了什么,但假设情况并非如此......为什么子类化不是一种选择?你能不能只重写IO中需要表现不同的部分?clas

ruby - 如何防止将位置参数扩展为关键字参数?

我想要一个接受散列和可选关键字参数的方法。我尝试定义这样的方法:deffoo_of_thing_plus_amount(thing,amount:10)thing[:foo]+amountend当我使用关键字参数调用此方法时,它按预期工作:my_thing={foo:1,bar:2}foo_of_thing_plus_amount(my_thing,amount:20)#=>21然而,当我省略关键字参数时,散列被吃掉了:foo_of_thing_plus_amount(my_thing)#=>ArgumentError:unknownkeywords:foo,bar如何防止这种情况发生