草庐IT

宿主机Qt交叉编译环境

全部标签

ruby - 我如何将 Ripper 的 AST 重新编译回 Ruby 代码?

Ripper是Ruby1.9附带的解析库。它将Ruby代码转换为AST,如下所示:ppRipper.sexp("deffoo;yield:a;return1end")#=>[:program,[[:def,[:@ident,"foo",[1,4]],[:params,nil,nil,nil,nil,nil],[:bodystmt,[[:yield,[:args_add_block,[[:symbol_literal,[:symbol,[:@ident,"a",[1,16]]]]],false]],[:return,[:args_add_block,[[:@int,"1",[1,26]]

ruby-on-rails - 在调用 Rake 任务时设置多个环境变量

我可以像这样调用一个Rake任务并设置一个环境变量:$ONE=1raketemp:both但是如何设置两个环境变量呢?这行不通:$ONE=1TWO=2raketemp:both这行得通,但读起来很困惑:$ONE=1raketemp:bothTWO=2如何在调用rake之前传递多个环境? 最佳答案 同意@Ernest;它应该工作。这是一个示例...示例rake任务以回显变量:task:echo_envdoputs"VAR1:#{ENV['VAR1']}"puts"VAR2:#{ENV['VAR2']}"end执行任务:VAR1=fir

ruby-on-rails - 将 Heroku 环境变量传输到 Docker 实例

我在Heroku上构建了一个必须在Docker容器内运行的RoR应用程序。为此,我使用officialDockerfile.因为它在Heroku中很常见,所以我需要一些附加组件才能使这个应用程序完全运行。在生产中,变量DATABASE_URL在我的应用程序中可用。但是,如果我尝试其他一些使用环境变量(在我的例子中是Mailtrap)的加载项,变量不会在运行时复制到实例中。所以我的问题很简单:如何让docker实例在Heroku上执行时知道环境变量?您可能会问,我已经知道我们可以在docker-compose.yml中指定一个environment指令。我想避免这种情况,以便能够通过项目

ruby-on-rails - Websocket-rails 不适用于 Nginx 和 Unicorn 的生产环境

我有带有gemwebsocket-rails0.7的Rails3.2应用程序。在开发机上,一切正常在生产环境中,我使用Nginx/1.6作为代理服务器,Unicorn作为http服务器。Thin用于独立模式(在https://github.com/websocket-rails/websocket-rails/wiki/Standalone-Server-Mode之后)。nginx配置:location/websocket{proxy_passhttp://localhost:3001/websocket;proxy_http_version1.1;proxy_set_headerUp

ruby-on-rails - rake spec 不使用 rails 环境

我正在尝试在刚刚升级到Rails2.3.2的Rails项目中使用rspec。我在应用程序中安装了rspec1.2.6和rspec-rails1.2.6作为插件。我的问题是规范无法访问我的应用程序类或任何Rails标准库。首先,我必须使用来自RAILS_ROOT的完整路径来指定我想要测试的模型类,但现在当它加载类时,我得到以下信息/app/models/person.rb:1:uninitializedconstantActiveRecord(NameError)from./spec/models/person_spec.rb:1:in`require'from./spec/models

ruby - 编译 Ruby 内联 C 代码 - 解决错误

我正在尝试获取此Ruby内联C代码http://pastie.org/2825882上类。该代码在vanillaC中运行,但在这里我收到错误和警告。是什么导致了这个错误?./backtrack_inline.rb:67:error:lvaluerequiredasunary'&'operand另外,为什么会出现以下错误?./backtrack_inline.rb:73:error:toofewargumentstofunction'backtrack'检查生成的C代码(http://pastie.org/2826036)我没有发现参数有任何问题。但我也收到以下警告:./backtrac

ruby-on-rails - 对于诸如libyaml之类的已编译库,Ruby(或RVM)在文件系统中搜索哪些位置以加载或解析它们?

操作系统:CentOS6.2x86_64很抱歉缩进太古怪了。这是我的第一篇SO帖子,我是新来设置服务器的。不过,我正在学习,并将详细说明我尝试解决此问题所采取的步骤以及寻求帮助的地方。我是一位有抱负的年轻Web开发人员,并且我在其他人配置的服务器上工作,因此,这对我来说是全新的。我正在准备我最近购买的用于运行Rails应用程序的linode。我遵循了此处http://blog.blenderbox.com/2011/01/07/installing-rvm-ruby-rails-passenger-nginx-on-centos/提供的初始安装指南,并更改了步骤:sudobash反射(

ruby-on-rails - 子域 + ActionView::Template::Error(缺少要链接的主机!)

我已经解决了标题中描述的错误的众多解决方案。ActionView::Template::Error(缺少要链接的主机!请提供:host参数,设置default_url_options[:host],或将:only_path设置为true):但是,该项目还修改了url_for函数以使用子域,如本railscast所示:http://railscasts.com/episodes/221-subdomains-in-rails-3因此,这个错误的传统答案,例如在我的环境设置中设置变量似乎不是解决方案。这里有一些其他的提示:这是一个全新的设置,我刚刚克隆了一个项目并安装了ruby​​、rai

ruby-on-rails - "Private"Rake 任务与 Rails 环境

我知道我可以使用以下命令调用子任务列表并让每个子任务都利用我项目的Rails环境:task:main_task=>[:sub_task1,:sub_task2]doendtask:sub_task1=>:environmentdoModel1.some_class_methodendtask:sub_task2=>:environmentdoModel2.some_class_methodend我的问题是:main_task中是否有任何方法可以传递:environment,这样我就不必在每个子任务中显式地放置它?有没有办法让子任务被认为是“私有(private)的”?也就是说,我不希望

ruby-on-rails - Unicorn.rb 配置取决于环境

我在config/unicorn.rb中有一行看起来像这样:working_directory"/SomePath/Web\Development/Rails/learning"但是在生产环境中,需要不同的路径。我想尽可能多地保留源代码控制(还没有放弃任何东西)。有没有办法根据环境设置working_directory? 最佳答案 您尝试如何访问RAILS_ENV或RACK_ENV?它应该通过“ENV”就像...ENV['RAILS_ENV']……或者……ENV['RACK_ENV']当您将“-E”标志传递给unicorn时,一个或