Answers:
在几乎所有情况下,依靠库或元编程进行过时都是过分的。只需在rdoc中添加注释并调用该Kernel#warn
方法即可。例如:
class Foo
# <b>DEPRECATED:</b> Please use <tt>useful</tt> instead.
def useless
warn "[DEPRECATION] `useless` is deprecated. Please use `useful` instead."
useful
end
def useful
# ...
end
end
# @deprecated Please use {#useful} instead
最后,如果您坚持使用tomdoc,请使您的评论如下所示:
# Deprecated: Please use `useful` instead
不推荐使用:表示不推荐使用该方法,并将在以后的版本中将其删除。您应该使用它来记录那些公开的方法,但是在下一个主要版本中将被删除。
同样,不要忘记在将来的某个版本(并正确存储)中删除不推荐使用的方法。不要犯与Java库相同的错误。
Ruby标准库有一个带有警告逻辑的模块:https : //ruby-doc.org/stdlib/libdoc/rubygems/rdoc/Gem/Deprecate.html。我倾向于使用它以“标准”方式维护我的弃用消息:
# my_file.rb
class MyFile
extend Gem::Deprecate
def no_more
close
end
deprecate :no_more, :close, 2015, 5
def close
# new logic here
end
end
MyFile.new.no_more
# => NOTE: MyFile#no_more is deprecated; use close instead. It will be removed on or after 2015-05-01.
# => MyFile#no_more called from my_file.rb:16.
请注意,使用这种方法,您将获得有关呼叫发生位置的免费信息。
0
数字文字的前导使其变为八进制,因此应将其删除。
deprecate :initialize, UseThisClassInstead, 2017, 5
使用ActiveSupport:
class Player < ActiveRecord::Base
def to_s
ActiveSupport::Deprecation.warn('Use presenter instead')
partner_uid
end
end
默认情况下,警告在生产环境中处于关闭状态
您也可以这样使用ActiveSupport::Deprecation
(在4.0+版本中可用):
require 'active_support/deprecation'
require 'active_support/core_ext/module/deprecation'
class MyGem
def self.deprecator
ActiveSupport::Deprecation.new('2.0', 'MyGem')
end
def old_method
end
def new_method
end
deprecate old_method: :new_method, deprecator: deprecator
end
MyGem.new.old_method
# => DEPRECATION WARNING: old_method is deprecated and will be removed from MyGem 2.0 (use new_method instead). (called from <main> at file.rb:18)
您确实有libdeprecated-ruby
(2010-2012,2015年在rubygem上不再可用)
一个小型图书馆,旨在帮助开发人员使用不推荐使用的代码。
这个想法来自' D
'编程语言,开发人员可以在其中将某些代码标记为已弃用,然后允许/禁止执行已弃用的代码的功能。
require 'lib/deprecated.rb'
require 'test/unit'
# this class is used to test the deprecate functionality
class DummyClass
def monkey
return true
end
deprecate :monkey
end
# we want exceptions for testing here.
Deprecate.set_action(:throw)
class DeprecateTest < Test::Unit::TestCase
def test_set_action
assert_raise(DeprecatedError) { raise StandardError.new unless DummyClass.new.monkey }
Deprecate.set_action(proc { |msg| raise DeprecatedError.new("#{msg} is deprecated.") })
assert_raise(DeprecatedError) { raise StandardError.new unless DummyClass.new.monkey }
# set to warn and make sure our return values are getting through.
Deprecate.set_action(:warn)
assert_nothing_raised(DeprecatedError) { raise StandardError.new unless DummyClass.new.monkey }
end
end
您可以使用Class Macros模式并编写如下内容:
class Module
def deprecate(old_method, new_method)
define_method(old_method) do |*args, &block|
warn "Method #{old_method}() depricated. Use #{new_method}() instead"
send(new_method, *args, &block)
end
end
end
class Test
def my_new_method
p "My method"
end
deprecate :my_old_method, :my_method
end
我最终提出了一个轻量级的方法:
def deprecate(msg)
method = caller_locations(1, 1).first.label
source = caller(2, 1).first
warn "#{method} is deprecated: #{msg}\ncalled at #{source}"
end
然后要弃用方法,请在方法主体(或类的构造函数)中插入调用
def foo
deprecate 'prefer bar, will be removed in version 3'
...
end
它是声明性的,并提供带有相关信息的日志记录。我不太喜欢Ruby,因此可能需要进行一些调整/ YMMV。
我们可以使用内部宏方法。例:
class Foo
def get_a; puts "I'm an A" end
def get_b; puts "I'm an B" end
def get_c; puts "I'm an C" end
def self.deprecate(old_method, new_method)
define_method(old_method) do |*args, &block|
puts "Warning: #{old_method} is deprecated! Use #{new_method} instead"
send(new_method, *args, &block)
结束
弃用:a,:get_a弃用:b,:get_b弃用:c,:get_c结束
o = Foo.new p oa