草庐IT

Kotlin-扩展(Extension)的能力边界在哪?

全部标签

c - Ruby c 扩展 : How can I catch all exceptions, 包括不是 StandardErrors 的东西?

在ruby中,begin#...rescue#...end不会捕获不是StandardError子类的异常。在C中,rb_rescue(x,Qnil,y,Qnil);VALUEx(void){/*...*/returnQnil;}VALUEy(void){/*...*/returnQnil;}会做同样的事情。我如何从ruby​​C扩展中rescueException=>e(而不仅仅是rescue=>e)? 最佳答案 Ruby需要更多文档。我不得不进入ruby​​源代码,这是我发现的:VALUErb_rescue(VALUE(*b_p

c - 如何在 Ruby 1.9 C 扩展中将 Block 转换为 Proc?

我正在编写一个Ruby1.9C扩展,我想在ruby​​中执行以下操作:notifier=Notifier.newnotifier.on'click'doputs"clicked!"end现在的问题是,在C方法上,我只“接收”了一个block,据我所知,它甚至不是一个参数:我只能用rb_yield.所以我的问题是:在Ruby1.9C扩展上有没有办法将block转换为proc或其他东西,这样我就可以将它存储在我的模块中,并在以后需要/需要它们时调用它?就像一个异步回调!我已经用Procs/lambdas实现了这个,但是不直接使用block语法太丑了。 最佳答案

ruby - ||= 条件赋值运算符的官方扩展

我想强调的是,我正在寻找||=运算符被Ruby1.9.3解释器扩展的实际方式,而不是它出现的方式根据其行为进行扩展。我真正希望的是能够理解实际解释器源代码的人,遗憾的是我可能无法胜任这项任务。我发现似乎可以检查此问题的唯一资源已过时:“Ashort-circuit(||=)edgecase”。我上面提到的资源似乎暗示x||=y到x=x||的“官方”扩展y在1.9之前的解释器版本中要么不准确要么有错误。无论如何,指示的边缘情况似乎已被消除。上面的资源声称x||x=y或x或x=y“更准确”。然而,这些都不正确,因为当x是一个以前未声明的全局变量时它们不起作用:[11:04:18][****

ruby - 使用扩展 ActiveSupport::Concern

我正在研究CodeSchool的RubyBits,我做了一个我只是不理解的练习:“确保AtariLibrary类只包含LibraryUtils模块,并让ActiveSupport::Concern负责加载它的依赖项。然后,重构LibraryUtils上的self.included方法以使用包含的方法。”moduleLibraryLoaderextendActiveSupport::ConcernmoduleClassMethodsdefload_game_listendendendmoduleLibraryUtilsdefself.included(base)base.load_gam

c - (U) Ruby 扩展 : rb_gc_mark() and instance variables

我正在编写定义类的ruby​​扩展。如果我使用Data_Wrap_Struct()来实现我对rb_define_alloc_func()的回调,我是否需要手动标记和释放实例变量?还是仍然为我处理? 最佳答案 Ruby的GC将收集在您的Ruby对象的实例变量中引用的所有Ruby对象。您不必也不应该自己释放Ruby实例变量(即在您的扩展中使用rb_iv_set()/rb_iv_get()访问的任何对象)。但是,如果包装的Cstruct引用Ruby对象,那么您必须在传递给Data_Wrap_Struct()的mark回调中标记这些对象。(

ruby-on-rails - 如何从应用程序/模块扩展 ActiveRecord?

我有几个不同的acts_as_...自定义类方法,我想在我的应用程序中使用。我希望这些方法的代码位于app/modules目录中的文件中。我一直无法让它工作。例如,我有一个文件:app/modules/acts_as_lockablemoduleActsAsLockabledefacts_as_lockablebefore_create:set_lockincludeInstanceMethodsendmoduleInstanceMethodsprotecteddefset_locknow=Time.now.to_sself.lock=Digest::SHA1.hexdigest(no

ruby - 如何从模块中定义的类扩展 ruby​​ 类?

我有以下文件:file.rbrequire_relative'foo/bar'baz=Foo::Stuff::Baz.new#dostufffoo/bar.rbrequire_relative'stuff/baz'moduleFooclassBardefinitialize#dostuffendendendfoo/stuff/baz.rbmoduleFoomoduleStuffclassBaz我收到以下错误:`':uninitializedconstantFoo::Stuff::Bar(NameError)我这里有什么地方做错了吗?这在Ruby中甚至可能吗?以防万一,我这样做只是因为我

c - 我如何在 Ruby 的 C 扩展 API 上检索 'standalone' 符号

我想从C函数返回多个值,恕我直言,散列是一个不错的选择。我首先使用rb_intern('A_KEY')创建key,但扩展崩溃了。现在,我正在使用rb_str_new2,但我更喜欢符号。如何创建一个新符号,并在不引用类或方法的情况下使用它? 最佳答案 您需要使用ID2SYM宏将从rb_intern获得的标识符转换为ruby​​符号。尝试改变rb_intern('A_KEY')到ID2SYM(rb_intern('A_KEY')) 关于c-我如何在Ruby的C扩展API上检索'standal

千耘农机导航的“星地一体”能力究竟是什么?

伴随农业机械化和智能化的发展,越来越多的人开始使用农机自动驾驶系统助力耕作,千耘农机导航的“星地一体”能力可有效解决信号受限的问题,实现作业提效。究竟什么是“星地一体”,又是如何解决智能化农机作业的痛点的?下面为大家揭秘。农机效率通常受限于通信网络目前虽然我国通讯网络的人口覆盖率达到99%,但地面移动通讯网络覆盖率仍小于国土面积的40%,而很多农田所在区域恰是山区、戈壁滩等偏远地区。两省交界地也会出现通信信号不稳定的状况;而国内大部分农机自动驾驶系统非常依赖通信网络,当通信网络弱的时候会出现系统掉线的现象,必须得携带小基站才能正常使用,极为繁琐。Q:什么是千耘农机导航“星地一体”能力?A:是星

ruby-on-rails - 何时使用关联扩展与命名范围?

粗略地看一下,它们似乎只是解决同一组问题的两种不同方法,除了命名作用域是可链接的,而关联扩展不是。谁能进一步解释或提供一个比命名范围更适合关联扩展的示例? 最佳答案 关联扩展对于创建用于创建、更新等(不一定是查找)的自定义方法非常有用。因为您可以访问proxy_owner、proxy_reflection、proxy_target,所以您可以很好地了解这种关系。查看Rails文档的关联扩展部分:http://api.rubyonrails.org/classes/ActiveRecord/Associations/ClassMeth