jjzjj

metaprogramming

全部标签

ruby - 动态添加 ruby​​ 类方法或实例方法

我对Ruby很陌生,所以还在学习中。我研究了很多关于如何动态添加方法,并且我成功地创建了实例方法,但在创建类方法时却没有成功。这就是我生成实例方法的方式:classBdefbefore_methodputs"beforemethod"enddefself.run(method)send:define_method,methoddobefore_methodputs"method#{method}"endendendclassA关于创建静态方法的最佳方法有什么想法吗?我的最终任务是寻找为类方法创建“之前”和“之后”任务的最佳方式。 最佳答案

ruby - 如何在 Ruby 中动态改变继承

我想在Ruby中为一个类动态指定父类。考虑这段代码:classAgentdefself.hook_up(calling_class,desired_parent_class)#DosomemagichereendendclassParentdefbarputs"bar"endendclassChilddeffooputs"foo"endAgent.hook_up(self,Parent)endChild.new.barParent和Child类定义均未指定父类,因此它们都继承自Object。我的第一个问题是:我需要在Agent.hook_up中做什么才能使Parent成为Child的父

ruby - 对于未定义的实例变量,Ruby 是否有 method_missing 等价物?

当我调用一个不存在的方法时,method_missing会告诉我该方法的名称。当我尝试访问一个尚未设置的变量时,该值只是nil。我正在尝试动态拦截对nil实例变量的访问,并根据所访问的变量的名称返回一个值。最接近的等价物是PHP的__get.Ruby中是否有任何等效功能? 最佳答案 我不相信这在Ruby中是可能的。推荐的方法是在模板中使用“user”方法而不是“@user”实例变量。这与您在外部处理Ruby对象的方式一致(''obj.user''是一种引用''@user''的方法,但实际上不是''@user''本身)。如果您需要任何

ruby-on-rails - Ruby 2.0 如何在包含模块后从模块中取消包含模块?

moduleXendmoduleYendmoduleZ#TODOincludeXreplacementofincludingY#TODOincludeYreplacementofincludingXend有没有办法解决ruby​​不包含uninclude关键字的问题?? 最佳答案 如果您真的需要这种功能,您可以使用refinements来实现.classFooendmoduleXdefxputs'x'endendmoduleYendmoduleRrefineFoodoincludeXincludeYendend#Inaseparat

Ruby 插件架构

我想要一个非常基本的小型基础程序示例,它读入两个插件并注册它们。这两个插件以相同的方式以不冲突的方式挂接到基础程序。就此而言,我对任何编程语言的元编程都很陌生,我不确定从哪里开始。 最佳答案 我已经研究这个问题一段时间了。我尝试了很多不同的方法来做这件事,并征求了很多人的建议。我仍然不确定我所拥有的是否是“正确的方法”,但它运作良好并且很容易做到。在我的例子中,我专门查看配置并引入配置插件,但原理是相同的,即使我的术语特定于cnfiguration。在非常基础的层面上,我有一个配置类,里面什么都没有——它是空的。我还有一个Confi

ruby - 在 ruby​​ 上,为什么 include 是私有(private)的而 extend 是公共(public)的?

在ruby上,为什么include是private,而Object#extend是public? 最佳答案 Object#extend必须是公开的,否则您将无法使用它。毕竟,它的目的是将模块混合到对象中,因此您通常会像obj.extend(Foo)那样调用它,这对于私有(private)方法是不可能的。Module#include通常只在模块体内使用,如下所示:classBarincludeFooend即它通常在没有接收者的情况下被调用,所以它不必公开。当然,它也必须是私有(private)的。我猜它之所以是私有(private)的

ruby - 是否有迭代编写新程序的程序?

大约一年来,我一直在考虑编写一个编写程序的程序。这主要是一个有趣的练习,可能会教会我一些新概念。我的灵感来自negentropy以及从困惑中出现秩序和新困惑无限连续出现的能力。更具体地说,该程序将从写入一个简短的随机字符串开始。如果字符串编译通过,程序会将其记录下来供以后比较。如果字符串没有编译,程序将尝试重写它直到它编译。随着更多的字符串(迷你“无用”程序)被记录下来,它们可以被解析以寻找相似之处并用于生成语法。然后可以利用此语法编写更多字符串,这些字符串比纯随机字符串具有更高的编译概率。这显然有点傻,但我认为尝试和发展这样的程序会很有趣。作为副产品,我得到了一堆独特的程序,我可以将

ruby-on-rails - rails : dynamically define class method based on parent class name within module/concern

我想根据包含此Mixin的类名在Mixin中动态生成一个类方法。这是我当前的代码:moduleMyModuleextendActiveSupport::Concern#defsome_methods#...#endmoduleClassMethods#HereiswhereI'mstuck...define_method"#{self.name.downcase}_status"do#dosomething...endendendclassMyClass但这给了我以下方法名称:MyClass.mymodule::classmethods_status在方法定义中获取基类名称是可行的(s

Ruby - 从符号转换为变量

如何将:obj转换回def中名为obj的变量?deffoo(bar)bar.some_method_callendfoo:obj更新:最终代码比这更复杂,但是......我喜欢说foo:obj代替fooobj我正在研究一些类似DSL的语法。这一变化会让事情变得更清晰。 最佳答案 在您的示例中,obj是什么类型的变量?如果它是调用foo的范围的局部变量,则无法从foo内部访问它,除非您将当前绑定(bind)作为第二个参数传递。如果你想访问实例变量@obj,很简单:deffoo(bar)instance_variable_get("@#

Ruby:有没有办法获取类的封闭模块常量?

我正在用Ruby进行一些元编程,我需要在模块内动态生成一个同级类。这样做时,我想在模块上调用const_set,但直到运行时我才知道要调用哪个模块常量。一个例子:给定的类Foo::Bar::BazFoo::Quox::Quack我希望能够调用这样的函数(这里过于简单):defgenerate_fromklassmod=klass.enclosing_module#当使用Baz调用时,我最终想要的是一个定义为的新类Foo::Bar::GeneratedClassName还有嘎嘎,我想要Foo::Quox::GeneratedClassName我知道的唯一方法是拆分klass.name,然