草庐IT

http远程调用

全部标签

ruby - 为什么 Rake 不能连续调用多个任务?

我有一个Rake任务,我在下面进行了简化。我在Windows上使用Ruby1.9。也许您想猜测调用下面的Rake任务“list_all_levels”的结果?应该是:"Hellolevel1""Hellolevel2""Hellolevel3"但由于我不知道的原因,它只打印“Hellolevel1”然后停止。也就是说,它总是只调用第一个任务。如果我更改第一行以传递参数“42”,它将打印“Hellolevel42”然后停止。我想知道为什么它不调用任务3次并打印所有3行?有什么方法可以让它按照我的预期工作吗?task:list_all_levels=>[]doRake::Task[:lis

ruby-on-rails - 从子类中的重载方法调用基类方法

也许我只是没有使用正确的Ruby术语(如果我是,请纠正我),但谷歌在这方面没有帮助我。我拥有的是一个扩展另一个类(称为BaseStoreController)的类(称为OrderController)。在BaseStoreController中,我定义了一个before_filter用于我的整个站点,除了我的OrderController。在这种非常特殊的情况下,我需要定义一个自定义的before_filter,它需要执行一些额外的逻辑,然后调用在我的BaseStoreController中定义的before_filter。我不知道该怎么做。这是我尝试过的方法,但“super”关键字似

Unity3D不同脚本函数或参数之间调用

脚本通讯假如,我们有两个脚本:Main.cs,SliderControl.cs。现在希望从SliderControl.cs调用Main.cs内的函数或参数。(一)、被调用脚本函数为static类型,调用时直接用类名.参数publicclassMain:MonoBehaviour{publicstaticintindex=0;}//在SliderControl.cs中调用indexintpara=Main.index;(二)、GameObject.Find(“脚本所挂载在的物体的名字”)找到游戏对象,再通过GetComponent().函数名()调用脚本中的函数,只能调用public类型函数pu

ruby - 为 Ruby 模块中的每个方法调用执行代码

我正在用Ruby1.9.2编写一个模块,它定义了几个方法。当调用这些方法中的任何一个时,我希望它们中的每一个都先执行特定的语句。moduleMyModuledefgo_forthare-usedstatement#codeparticulartothismethodfollows...enddefand_multiplyare-usedstatement#thensomethingcompletelydifferent...endend但我想避免在每个方法中显式地放置那个重用语句代码。有办法吗?(如果重要的话,重用语句将让每个方法在调用时打印自己的名称。它将通过puts__method

ruby - 检查 Ruby HTTP 响应是否成功

如何正确检查来自Net::HTTP::Get(例如)的响应是否“成功”(即2xx返回码)?令人遗憾的是,文档似乎对这个简单的问题保持沉默。我有:response=Net::HTTP.new(host,port).requestmy_get_request#detailsnotimportant经过一系列谷歌搜索和近乎随机的输入,我终于确定这是可行的:response.class这真的是规范的方式吗? 最佳答案 对于Net::HTTP,是的,检查响应对象的类是这样做的方法。使用kind_of?(也称为is_a?)更清晰一些(但在功能上

Ruby 在调用方法之前检查是否为 nil

我在Ruby中有一个字符串,我在其上调用strip方法来删​​除前导和尾随空格。例如s="12345"s.strip但是,如果字符串为emptynil,我会收到以下错误。NoMethodError:undefinedmethod`strip'fornil:NilClass我使用的是Ruby1.9,那么在调用strip方法之前检查值是否为nil的最简单方法是什么?更新:我在数组中的一个元素上试过这个但遇到了同样的问题:data[2][1][6].nil??data[2][1][6]:data[2][1][6].split(":")[1].strip 最佳答案

ruby-on-rails - 为什么 Ruby on Rails 使用 http ://0. 0.0.0 :3000 instead of http://localhost:3000?

当我尝试按照官方“入门”RubyonRails教程进行操作时,很快就出错了。基本上它说:…navigatetohttp://localhost:3000.YoushouldseeRails’defaultinformationpage.但是当我按照说明操作时,我得到了=>Rails2.3.4applicationstartingonhttp://0.0.0.0:3000在尝试了这两个地址之后,我知道它们指向同一件事,但是有人可以向我解释为什么RubyonRails使用http://0.0.0.0:3000而不是http://localhost:3000?有没有办法让WEBrick服务器

ruby-on-rails - 您如何查看 ruby​​ 中的调用堆栈示例?

我正在研究不同的优化技术,我发现了这篇文章AnalyzingCodeforEfficiency?相信对调用堆栈进行采样比使用分析器更有效的人。基本思想是,如果您查看调用堆栈,您会看到您的应用程序最有可能花费大部分时间的地方,然后在那里进行优化。这当然很有趣,而且他显然是这方面的专家,但我不知道如何在ruby中查看调用堆栈。在调试器中,我可以说“信息堆栈”,但似乎只显示一行。编辑:我看到MikeDunlavey的评论:“我只想指出,如果你在调试器下运行,手动中断它,并显示调用堆栈......”我只是不确定如何手动中断它并隐藏调用堆栈。 最佳答案

ruby - 您如何检查 Capistrano 中是否存在文件(在远程服务器上)?

像我在Googleverse中看到的许多其他人一样,我成为了File.exists?陷阱的受害者,它当然会检查您的本地文件系统,而不是您要部署到的服务器。我发现了一个使用shellhack的结果,例如:if[[-d#{shared_path}/images]];then...但这对我来说不太合适,除非它被很好地包装在Ruby方法中。有没有人优雅地解决了这个问题? 最佳答案 在Capistrano3中,您可以:onroles(:all)doiftest("[-f/path/to/my/file]")#thefileexistselse

ruby-on-rails - 用于在多行上链接调用的 Ruby 约定

这是什么约定?我使用以下样式,但不确定它是否是首选样式,因为如果我在末尾漏掉一个点,我可能会在不知不觉中遇到很多问题。query=reservations_scope.for_company(current_company).joins{property.development}.group{property.development.id}.group{property.development.name}.group{property.number}.group{created_at}.group{price}.group{reservation_path}.group{company