草庐IT

WIFI模块ESP-01S调试(AP和STA模式)

全部标签

ruby - 何时在模块的方法中使用 self

我的模块定义如下:moduleRG::Statsdefself.sum(a,args={})a.inject(0){|accum,i|accum+i}endend要使用这个方法,我只需要包含这个定义的文件,这样我就可以:RG::Stats.sum(array)还有RG::Stats.method(:sum)但是,如果我需要使用RG::Stats.instance_methods了解方法列表,我会得到一个空数组。这是因为我使用了self。如果我省略self,则RG::Stats.instance_methods会给出方法列表,但我无法再访问它们。问题是:如何在模块的方法定义中使用self

ruby - 所有 ruby​​ 文件都应该有一个与文件夹结构相匹配的模块结构吗?

是否所有文件都在具有文件夹结构(类似于java包)的模块中的ruby​​约定?例如,如果我的文件结构如下所示库/人/工具此处的文件是否具有如下模块结构:modulePeoplemoduleUtils#somefunctionalityforPeople::Utilsendend我问的原因是因为我一直在阅读一些Rails代码,并且似乎有几个文件在这样的文件结构中,但没有任何模块声明。我猜这是为了让您可以使用效用函数而不必包含People::Utils。ruby是否有关于何时应该使用模块以及何时不应该使用模块的约定? 最佳答案 这是Ra

ruby-on-rails - 具有相同名称的类和模块 - 如何选择一个或另一个?

我遇到过以下情况:有ModuleA::ModuleB::ClassC.do_something在do_something的定义中我需要使用来自应用程序的模型defdo_something...data=Order.all...end但是也存在一个模块ModuleA::Order所以我得到一个错误undefinedmethod`all'forModuleA::Order:Module我通过做找到了解决方案defdo_something...data=Kernel.const_get('Order').all...end返回模型。我的问题是:最好的方法是什么?有没有更清洁的解决方案?(尽管

ruby-on-rails - 在模块中声明一个类

测量工作代码(在一个名为Surveyor的模块中,不少),试图理解它。我遇到了这个包含模块中的类的部分。这与包含模块相同吗?如果不是,这样做的好处是什么?谢谢。(奖励积分:为什么我们要将self附加到类中,这不是已经暗示了吗?)moduleSurveyorclassCommonRAND_CHARS=[('a'..'z'),('A'..'Z'),(0..9)].map{|r|r.to_a}.flatten.joinOPERATORS=%w(==!===~)class]*>)|\n|\t/su,'')#Removehtmltagscol_text.downcase!#Removecapit

ruby-on-rails - 如何使用 ruby​​ 调试器获取堆栈跟踪?

我正在尝试在Rails应用程序中使用ruby​​调试器。为了显示堆栈跟踪,我需要在(rdb:1)提示符下键入什么命令?我试过backtrace,但它只列出了最顶层的框架。 最佳答案 http://apidock.com/ruby/Kernel/callercaller(0)#Returnsthestacktrace,omitting0initialentry. 关于ruby-on-rails-如何使用ruby​​调试器获取堆栈跟踪?,我们在StackOverflow上找到一个类似的问题:

ruby - 扩展模块和类变量访问?

我无法理解为什么在以下示例中访问模​​block的类变量失败:moduleM@@xyz=123endM.class_variables#[:@@xyz]M.class_variable_get:@@xyz#123,sofarsogoodclassCextendMendC.singleton_class.class_variables#[:@@xyz]C.singleton_class.class_variable_get:@@xyz#NameError:#uninitializedclassvariable@@xyzinClass谁能解释为什么类变量@@xyz在C的单例类中突然无法访问

ruby - YARD:记录由包含的模块添加的类方法

我正在使用YARD为我的ruby​​gem编写文档.在我的gem中,我有一些代码遵循这种常见的ruby​​模式,其中一个模块包含在一个类中,并且该模块不仅添加了实例方法,还添加了类方法:moduleMoodefself.included(klass)klass.extendClassMethodsendmoduleClassMethodsdefhelloputs"hello"endendendclassFooincludeMooendFoo.hello#=>classmethodruns,printing"hello"默认情况下,YARD将为Foo类生成如下所示的文档:我认为此文档不充

ruby-on-rails - 我怎样才能更好地在 RSpec 中进行调试?

我是测试新手,在调试时遇到了问题,就像我通常在模型或Controller中遇到的那样。我已经从工厂创建了一个用户(使用FactoryGirl,如果有区别的话),我很确定创建方法失败是因为保存时的验证。但是,我很想知道如何调试在测试期间实例化的模型。我试过:user.inspectputsuserraiseuser.to_yaml(后者有效,但停止执行其余测试,并且不显示验证错误——它仅证明我尝试实例化的模型存在或不存在。)除了将模型提升为错误外,在测试期间没有调试输出,我唯一能做的另一件事就是跟踪我的测试数据库的日志,看看那里发生了什么,但它看起来很笨拙最好。你会建议什么方法来完成我所

ruby - 如何在 Sinatra 中制作模块化助手

我想在一个模块中创建一个方法(出于分组原因),它可以作为module.method调用,如下所示:helpersdomoduleUserSessiondeflogged_in?notsession[:email].nil?enddeflogout!session[:email]=nilendendend但是当我尝试使用UserSession.logged_in?调用它时,它说logged_in不是UserSession的方法undefinedmethod`logged_in?'forUserSession:Module当我将方法移动为UserSession的方法时:helpersdom

ruby - 如何选择要在 Ruby 中动态包含的模块版本?

我正在编写一个使用fileutils的小型Rub​​y命令行应用程序来自文件操作的标准库。根据用户调用应用程序的方式,我想包括FileUtils,FileUtils::DryRun或FileUtils::Verbose.自include虽然是私有(private)的,但我无法将选择逻辑放入对象的initialize中方法。(这是我的第一个想法,从那时起我就可以将有关用户选择的信息作为参数传递给new。)我想出了两个似乎可行的选项,但我对其中任何一个都不满意:根据用户的选择在应用程序的命名空间中设置一个全局变量,然后在类中执行条件包含:classWorkercaseApp::OPTION