Warning: file_get_contents(/data/phpspider/zhask/data//catemap/5/ruby/23.json): failed to open stream: No such file or directory in /data/phpspider/zhask/libs/function.php on line 167

Warning: Invalid argument supplied for foreach() in /data/phpspider/zhask/libs/tag.function.php on line 1116

Notice: Undefined index: in /data/phpspider/zhask/libs/function.php on line 180

Warning: array_chunk() expects parameter 1 to be array, null given in /data/phpspider/zhask/libs/function.php on line 181
Ruby on rails “文件”和“行”的作用是什么;1当您定义has\u rich\u text方法时?_Ruby On Rails_Ruby - Fatal编程技术网

Ruby on rails “文件”和“行”的作用是什么;1当您定义has\u rich\u text方法时?

Ruby on rails “文件”和“行”的作用是什么;1当您定义has\u rich\u text方法时?,ruby-on-rails,ruby,Ruby On Rails,Ruby,我在Rails中找到了以下代码,但无法理解\uuuuuu FILE\uuuuuu和\uuuuuuu行+1的角色。当你在class\u eval中定义一些方法时,有人能解释一下它们的用途吗 def has_rich_text(name) class_eval <<-CODE, __FILE__, __LINE__ + 1 def #{name} self.rich_text_#{name} ||= ActionText::RichText.new(name: "

我在Rails中找到了以下代码,但无法理解
\uuuuuu FILE\uuuuuu
\uuuuuuu行+1
的角色。当你在
class\u eval
中定义一些方法时,有人能解释一下它们的用途吗

def has_rich_text(name)
  class_eval <<-CODE, __FILE__, __LINE__ + 1
    def #{name}
      self.rich_text_#{name} ||= ActionText::RichText.new(name: "#{name}", record: self)
    end

    def #{name}=(body)
      self.#{name}.body = body
    end
  CODE

  has_one :"rich_text_#{name}", -> { where(name: name) }, class_name: "ActionText::RichText", as: :record, inverse_of: :record, dependent: :destroy

  scope :"with_rich_text_#{name}", -> { includes("rich_text_#{name}") }
  scope :"with_rich_text_#{name}_and_embeds", -> { includes("rich_text_#{name}": { embeds_attachments: :blob }) }

  after_save do
    public_send(name).save if public_send(name).changed?
  end
end
def有丰富的文本(名称)
类{eval{includes(“富文本{name}”)}
范围:“with_rich_text_#{name}和_embeddes”,->{includes(“rich_text#{name}”):{embeddes_attachments::blob}
保存后做什么
公用发送(名称)。是否保存公用发送(名称)。是否更改?
结束
结束
错误报告(回溯)会相应更改:

class Test
  def self.fun_ok(name)
    class_eval <<-CODE, __FILE__, __LINE__ + 1
      def #{name}; raise; end
    CODE
  end

  def self.fun_ko(name)
    class_eval <<-CODE
      def #{name}; raise; end
    CODE
  end
end
让我们测试一下:

begin
  Test.new.ok
rescue => e
  puts e.backtrace.inspect
end
#⇒ ["/tmp/foo.rb:4:in `ok'", "/tmp/foo.rb:19:in `<main>'"]

begin
  Test.new.ko
rescue => e
  puts e.backtrace.inspect
end
#⇒ ["(eval):1:in `ko'", "/tmp/foo.rb:25:in `<main>'"]
开始
测试,新的,好的
救援=>e
放e.backtrace.inspect
结束
#⇒[“/tmp/foo.rb:4:in‘ok’”,/tmp/foo.rb:19:in‘in’”]
开始
Test.new.ko
救援=>e
放e.backtrace.inspect
结束
#⇒ [“(eval):1:in`ko'”/tmp/foo.rb:25:in`']

正如您可能看到的,前一个回溯指向导致异常的源代码中的确切行(特别是:
“/tmp/foo.rb:4”
部分)。后一个回溯指向任何地方。

如果您能够解释一下在
模块#class_eval
的文档中您不清楚的内容,那将是非常有用的。这样,Ruby开发人员就可以改进文档,使未来的程序员不会遇到与您相同的问题。
begin
  Test.new.ok
rescue => e
  puts e.backtrace.inspect
end
#⇒ ["/tmp/foo.rb:4:in `ok'", "/tmp/foo.rb:19:in `<main>'"]

begin
  Test.new.ko
rescue => e
  puts e.backtrace.inspect
end
#⇒ ["(eval):1:in `ko'", "/tmp/foo.rb:25:in `<main>'"]