草庐IT

Metaprogramming

全部标签

ruby - 是否有可能缩小 ruby 常量查找

我有一个模块,其中包含名为String的类(以及其他类。)我需要按名称查找该类,如果没有这样的类,则优雅地回退。moduleMod1moduleStringendendMod1.const_get'String'#⇒Mod1::StringKernel.const_get'::Mod1::String'#⇒Mod1::String到目前为止,还不错。当我尝试查找不存在的类时,我预计会收到NameError,这很好。问题是如果在全局命名空间中存在一个具有给定名称的类,它将被返回:Mod1.const_get'Fixnum'#⇒Fixnum我明白其中的原因,但我的问题是:是否有现成的方法仅

ruby - 检测方法未被覆盖

比如说,我有以下2个类:classAdefa_methodendendclassB是否可以从B类(的一个实例)中检测到a_method方法仅在父类(superclass)中定义,因此不会在B中被覆盖?更新:解决方案虽然我已将Chuck的回答标记为“已接受”,但后来PaoloPerrota让我意识到该解决方案显然可以更简单,并且它可能也适用于早期版本的Ruby。检测“a_method”是否在B中被覆盖:B.instance_methods(false).include?("a_method")对于类方法,我们同样使用singleton_methods:B.singleton_method

Ruby 捕获 NoMethodError 并从发生异常的地方继续执行

在Ruby中,我想在另一个对象中捕获在一个对象上生成的NoMethodError,然后将一些值返回到引发异常的位置并继续执行。有没有现成的方法可以做到这一点?我想到的最好的是:classExceptionattr_accessor:continuationendclassOuterdefhelloputs"hello"endclassInnerdefworldputs"world"enddefmethod_missing(method,*args,&block)x=callccdo|cc|e=RuntimeError.exception(method)e.continuation=cc

ruby-on-rails - Constantize 引发未初始化的常量错误

我正在研究thisprettythornyproblem并决定我可以通过这样做动态创建一个继承自StandardError的类:something="JustForBelow"error_class="#{something}Error".constantizeerror_class=StandardError.new但我遇到了一个非常奇怪的错误(在我看来),它是:UninitializedconstantJustForBelowError我不是在那里初始化它吗?(本质上)当我尝试这个时出现同样的错误:StandardError.const_get"#{something}Error"

ruby - 给定一个 Ruby 元类,我如何获取它所附加的实例?

这是问题“GivenaninstanceofaRubyobject,howdoIgetitsmetaclass?”的反面您可以在默认的to_s输出中看到附加元类或单例类的对象的表示:s="hello"s_meta=class"#>"classC;endc_meta=class"#"是否有可能实现一个方法Class.attached来返回这个对象(如果接收者是一个普通类,则返回nil)?s_meta.attached#=>sc_meta.attached#=>CC.attached#=>nil 最佳答案 有一个丑陋的(但有效的)黑客,

ruby - 从外部 gem 扩充模型

我正在使用refinerycms在我们的站点让技术人员较少的更新内容。在gem中,它们有一个Page类,用于映射站点上的每个顶级页面。我想在此Page类上使用acts_as_taggablegem。现在我可以将acts_as_taggle声明直接添加到page.rb文件中,但是我必须维护一个单独的git存储库来跟踪我的版本和官方版本之间的差异。基于SO上的其他一些问题,我创建了一个初始化程序和扩展,如下所示:lib/page_extensions.rb:modulePantsmoduleExtensionsmodulePagemoduleClassMethodsdefadd_tagga

ruby - Ruby中Base的元类和Derived类的元类是什么关系?

在Ruby中,我们可以在单例方法中使用super来调用对应父类(superclass)的单例方法,如下面的代码所示。classBasedefself.class_methodputs"Baseclassmethod"endendclassDerived但是,我似乎不太明白Derived.class_method中对super的调用如何到达Base.class_method。我假设class_method是在他们的元类上定义的,这是否意味着他们的元类具有父/子关系?(我无法通过实验完全证实这一点)更新:我问这个问题是因为我记得在某处看到基类和派生类的元类之间存在某种关系(但我找不到它不再

ruby - 如何在运行时动态创建实例方法?

[ruby1.8]假设我有:dummy"string"doputs"thing"end现在,这是对一种方法的调用,该方法具有一个字符串和一个block作为输入参数。不错。现在假设我可以有很多类似的调用(不同的方法名称,相同的参数)。示例:otherdummy"string"doputs"thing"end现在因为它们做同样的事情,而且它们可能有数百个,所以我不想为所需类中的每个方法创建一个实例方法。我宁愿找到一种聪明的方法来根据一般规则在运行时动态定义方法。这可能吗?常用的技术有哪些?谢谢 最佳答案 我特别喜欢使用method_mi

ruby - 如何使用类似宏的元编程方法扩展 Ruby 模块?

考虑以下扩展(多年来由多个Rails插件推广的模式):moduleExtensiondefself.included(recipient)recipient.extendClassMethodsrecipient.send:include,InstanceMethodsendmoduleClassMethodsdefmacro_methodputs"Calledmacro_methodwithin#{self.name}"endendmoduleInstanceMethodsdefinstance_methodputs"Calledinstance_methodwithin#{self

ruby - 带 block 的动态类定义

所以我遇到了这种情况,我想以编程方式定义一堆类。我在下面使用的方法工作正常,除了我从这里继承的第3方类不喜欢该类是匿名定义的事实(基本上,它没有它需要的信息,即.在我有机会将匿名类设置为常量之前,在“继承”Hook中的类名)。['one','two','three'].eachdo|model|cls=Class.new(ThirdPartyClass)dodefine_method:modeldomodelendendThirdPartyClass.const_set(model.capitalize,cls)end我可以简单地使用eval并定义类似这样的类:['one','two'