How to retrieve the current method name so to output it to the logger file?

落爺英雄遲暮 提交于 2019-12-07 02:34:01

问题


I am using Ruby on Rails 3.2.2 and, in order to display warning messages for development purposes, I am using logger.warn in my code. I would like to retrieve the method name in which that logger.warn runs so to output that method name to the log file.

class ClassName < ActiveRecord::Base
  def method_name
    # Note: This code doesn't work. It is just a sample.
    logger.warn "I would like to retrieve and display the #{self.class.to_s}##{method_name}"
  end
end

In the log file I would like to see:

I would like to retrieve and display the ClassName#method_name

Is it possible? If so, how can I make that?


回答1:


class ClassName < ActiveRecord::Base
  def method_name
    logger.warn("I would like to retrieve and display the #{self.class}##{__method__}")
  end
end

this should do the job.



来源:https://stackoverflow.com/questions/10467625/how-to-retrieve-the-current-method-name-so-to-output-it-to-the-logger-file

标签
易学教程内所有资源均来自网络或用户发布的内容,如有违反法律规定的内容欢迎反馈
该文章没有解决你所遇到的问题?点击提问,说说你的问题,让更多的人一起探讨吧!