草庐IT

debug-eval

全部标签

ruby-on-rails - 如何在 ruby​​ 1.9.3/Rails 3.2.1 中安装 ruby​​-debug

这个问题在这里已经有了答案:关闭10年前。PossibleDuplicate:Rails3.1andRuby1.9.3p125:ruby-debug19stillcrasheswith“Symbolnotfound:_ruby_threadptr_data_type”我已经完成了打印到控制台的工作——我想回到20世纪并开始使用调试器!!但是如何安装ruby​​-debug?当我尝试安装ruby​​-debug19gem时,ruby-debug.c的native编译失败。我查看了其他SO帖子,但还没有找到答案......我正在使用Ruby1.9.3-p0我正在使用Rails3.2(当然还

ruby - 为什么在生产中使用 Net::HTTP 的 set_debug_output 是危险的?

Net::HTTP库中有一个非常有用的方法可以调试HTTP请求。这是文档对此的描述:set_debug_output(output)WARNINGThismethodcausesserioussecurityhole.Neverusethismethodinproductioncode.Setanoutputstreamfordebugging.http://ruby-doc.org/stdlib/libdoc/net/http/rdoc/classes/Net/HTTP.html#M001371这里提到的安全漏洞是什么? 最佳答案

ruby - 猴子修补 vs class_eval?

classStringdefhello"world"endendString.class_eval{defworld"hello"end}"a".world=>"hello""b".hello=>"world"他们似乎在做同样的事情——向现有类添加一个方法。那有什么区别呢? 最佳答案 使用class_eval你可以做更多动态的事情:>>met="hello"#=>"hello">>String.class_eval"def#{met};'hello';end"#=>nil>>"foo".hello#=>"hello"

ruby - 我如何在 Emacs 中使用 ruby​​-debug?

我知道Emacs与gdb有某种集成(虽然我从未使用过它)以在调试程序时跳转文件。我想对Ruby程序做同样的事情。 最佳答案 正如erenon所说,使用ruby​​调试,它为emacs提供了一个库,让您可以像gdb一样使用它。通过在您的终端上发出此命令来安装rdebug(sudo是可选的,具体取决于您的系统):geminstallruby-debug然后你需要download来自ruby​​forge的ruby​​-debug-extra文件,并以标准方式安装它。sh./configuremakemaketest#optional,b

ruby - `class_eval` 字符串中的变量范围是什么?

我正在使用class_eval编写要在当前类的上下文中执行的代码。在下面的代码中,我想为属性值的变化添加一个计数器。classClassdefattr_count(attr_name)attr_name=attr_name.to_sattr_readerattr_name#createtheattribute'sgetterclass_eval%Q{@count=0def#{attr_name}=(attr_name)@attr_name=attr_name@count+=1enddef#{attr_name}@attr_nameend}endendclassFooattr_count

ruby - 'eval' 是与 Ruby 中的绑定(bind)对象交互的唯一方式吗?

我是Ruby的新手,到目前为止,弄清楚如何使用"binding"objects是我最大的痛点之一。如果我没有正确阅读文档,它们几乎是完全不透明的。要访问绑定(bind)对象内的范围,您必须有一串Ruby代码和eval它使用绑定(bind)。也许我只是来自不同学校的纯粹主义者,但一般来说,我对基于字符串的“eval”结构过敏。在一般情况下,给定一个绑定(bind)对象,有什么方法可以安全地执行以下任何操作:在绑定(bind)表示的上下文中列出范围内的标识符,或检索内容的哈希值。将绑定(bind)中局部变量的值设置为等于外部上下文中某个局部变量的值。理想情况下,这应该可以正常工作,即使值是

Ruby 单例方法 (class_eval, define_method) vs (instance_eval, define_method)

Ruby中的元编程很棒,因为我经常使用它来模拟基于原型(prototype)的编程,并快速编写一些问题的原型(prototype)解决方案来测试它们的可行性。所以我想知道下面这段代码是否有本质区别:(class和(class代码的两个版本都定义了一个单例方法,我还没有遇到任何迫使我选择(instance_eval,define_method)组合而不是(class_eval,define_method)组合来定义单例方法,我想知道两者之间是否存在一些本质区别。 最佳答案 define_method没有区别。但是当您使用def时会有所

ruby-on-rails - 无法安装 ruby​​-debug-base19x gem

当我尝试安装ruby​​-debug-base19xgem以使用RubyMineIDE调试我的应用程序时,我收到以下错误消息,有人可以帮助我吗?我使用的是MacOSX10.7.4/Users/danilobarsotti/.rvm/rubies/ruby-1.9.3-p194/bin/rubyextconf.rbcheckingforrb_method_entry_t.bodyinmethod.h...nocheckingforvm_core.h...no/Users/danilobarsotti/.rvm/gems/ruby-1.9.3-p194/gems/ruby_core_sou

ruby - 我如何使用 class_eval?

我不明白class_eval。classModuledefattr_(*syms)syms.eachdo|sym|class_eval%{def#{sym}=(val)@#{sym}=valend}endendend%是什么意思?class_eval有什么作用?(val)来自哪里? 最佳答案 简短的回答是:您可能希望避免像这样使用class_eval。这是对您的代码的解释:%{hello}只是在Ruby中编写字符串文字的另一种方式,无需担心在字符串中转义双引号或单引号:%{hello"world"}=="hello\"world\"

ruby - 'yield self' 和 instance_eval 一样吗?

如果用instance_eval:定义Foo有什么不同吗?..classFoodefinitialize(&block)instance_eval(&block)ifblock_given?endend。..或者使用“yieldself”:classFoodefinitializeyieldselfifblock_given?endend无论哪种情况,您都可以这样做:x=Foo.new{deffoo;'foo';end}x.foo所以“yieldself”意味着Foo.new之后的block总是在Foo类的上下文中求值。这是正确的吗? 最佳答案