草庐IT

iphone - 在编译器中为 NSLog 设置一个标志不显示

全部标签

ruby - 一个网络服务器上有多个 Ruby 版本?

理想使用rvm,如果能够在一个网络服务器上拥有多个Rubies,并且通过某种服务器配置,能够在每个项目的基础上将Ruby版本分配给不同的Rails/Sinatra/等应用程序,那将是非常棒的。我从rvm的文档中了解到,Passenger一次只能使用一个Ruby。:(妥协否则,至少能够想出一种方法将项目分配给Ruby1.8或Ruby1.9解释器会很好。我读过使用Nginx作为反向代理允许在同一个盒子上运行Apache和Nginx。那么是否有可能让Apache+Passenger使用一个Ruby,而Nginx+Passenger使用另一个?也许在Nginx中使用Passenger以外的东西

ruby - Resque:每个队列一个 worker

我目前有一个Rails3.0项目,使用Ruby1.9.2和Resque。我的应用程序有多个工作类和多个队列,它们是动态创建的(在运行时)。此外,有多个worker已启动,可以自由地在任何队列上工作,因为在启动时没有任何现有队列,并且无法预测它们:$COUNT=3QUEUE=*rakeresque:workers根据project的id创建队列:@queue="project_#{project.id}".to_sym对于给定的队列,他们的作业必须按顺序处理,一次处理一个。我的问题是,通过拥有多个工作人员,可以并行处理多个作业。有没有办法设置每个队列的最大worker数(为1)?有没有办

ruby-on-rails - 当加载根命名空间中的另一个同名类时,Rails 类加载会跳过命名空间类

我有两个命名空间,每个都有自己的Controller和演示器类:成员::DocumentsController成员::DocumentPresenterguest::DocumentsControllerGuest::DocumentPresenter两个演示者都继承自::DocumentPresenter。Controller在没有指定命名空间的情况下访问各自的演示者,例如:classGuest::DocumentsController这通常会在同一个命名空间中调用演示者。但是有时在开发环境中我看到正在使用base::DocumentPresenter。我怀疑原因是base::Doc

ruby - 在随后的 bundle 安装中跳过 native 扩展重新编译

由于安装nokogirigem(1.6.0)需要时间,我的生产部署需要额外几分钟。我知道这是因为安装gem会触发native扩展编译。请注意,我已经打包我的包并将其checkinDVCSbundlepackage如果没有其他任何变化,是否有一种方法可以避免重新编译native扩展,从而加快部署速度?更新:我使用OpscodeChef进行部署(具体来说是chef-solo)环境是:Ubuntu12.04LTS64位ruby193-p448 最佳答案 我找到了一种方法来做到这一点。解释如下:Bundler,默认情况下将gems安装到环境

Ruby JSON.parse 返回一个数组

我正在尝试通过RESTfulAPI解析从Twitter收到的JSON字符串作为响应。我想使用JSONgem,但遇到了问题。根据文档,JSON解析器似乎返回了一个Hash,这正是我想要的。然而,当我实际执行JSON.parse(twitter_result.body)时,它返回一个数组。如何让JSON解析器返回哈希?这是我正在使用的解析器:http://www.ruby-doc.org/stdlib-1.9.3/libdoc/json/rdoc/JSON.html#method-i-parse“漂亮”的JSON输出示例:[{"created_at":"SunDec0813:00:52+0

ruby-on-rails - 我如何解析一个 Excel 文件,它会给我提供与视觉上完全一样的数据?

我正在使用Rails5(Ruby2.4)。我想阅读.xls文档,我想将数据转换为CSV格式,就像它出现在Excel文件中一样。有人推荐我使用Roo,所以我有book=Roo::Spreadsheet.open(file_location)sheet=book.sheet(0)text=sheet.to_csvarr_of_arrs=CSV.parse(text)但是,返回的内容与我在电子表格中看到的内容不同。例如,电子表格中的一个单元格有16:45.81当我从上面获取CSV数据时,返回的是"0.011641319444444444"如何解析Excel文档并准确获取我所看到的内容?我不在

ruby - 使用 C API 编译 Ruby

如果我拿一个ruby代码puts"HelloWorld!"并使用Ruby的CAPI重写#include"ruby.h"intmain(){ruby_init();rb_funcall(Qnil,rb_intern("puts"),1,rb_str_new2("HelloWorld!"));ruby_finalize();return0;}然后编译,这是编译Ruby代码的方式吗?如果我创建一个程序,使用Ripper来解析Ruby代码并将其重写为C,我可以称它为“Ruby编译器”吗?有一些ruby​​代码不能用这种方式在Ruby中重写吗?以前有人试过写这种“编译器”吗?

ruby - 如何用 ruby​​ 1.9.2 编译 vim

我尝试重新编译支持ruby​​的vim,因为我注意到vim仍在使用1.8.7(这是SnowLeopard上的默认ruby​​版本)。Ruby1.9.2通过rvm安装。编译时./configure--enable-rubyinterp--enable-gui=no--disable-nls--enable-cscope--prefix=/Users/madhatter我从make中得到以下错误:ld:librarynotfoundfor-lruby.1.9.1collect2:ldreturned1exitstatusmake[1]:***[vim]Error1make:***[firs

ruby - 在另一个模块中包含一个模块

moduleA;defa;end;endmoduleB;defb;end;endclassC;includeA;endmoduleA;includeB;endclassD;includeA;endC.new.b#undefinedmethoderrorD.new.b#nilC.ancestors#[C,A,Object...]D.ancestors#[D,A,B,Object...]如何将模块B包含在A中,以便已经包含模块A的类也可以从模块B获取方法? 最佳答案 如前所述,Ruby不是这样工作的-当一个类包含一个模块时,它不会保留对

ruby - 如何多次运行同一个类?

我有一个puppet模块,它部署一个JAR文件并编写一些属性文件(通过使用ERB模板)。最近我们向应用程序添加了“模式”功能,这意味着应用程序可以根据list中输入的值以不同的模式运行。我的层次结构如下:设置*配置**文件*安装意思是安装程序调用配置类和安装类。安装类根据模式部署相关RPM文件配置类检查模式,并为每个模式调用具有特定模式和目录参数的文件类,这种结构的原因是属性的值取决于实际模式。技术问题是,如果我在list中有多种模式(这是我的目标),我需要调用文件类两次:ifgrep($modesArray,$online_str)==[$online_str]{class{'top