2011-01-20 2 views
0

Я видел некоторый код, который делает метод класса такое, что вы можете написатьМетод вызова Ruby для всех последующих вызовов def?

class_method :instance_method, 

instance_method для псевдонима и вызывать его из в методе обертки каждый раз, когда он вызывается. Есть ли способ позвонить class_method и применить его ко всем следующим вызовам определения (например, как работает private)?

ответ

1

Я не совсем понимаю ваш вопрос. В будущем, пожалуйста, укажите, что именно вы пытаетесь сделать, желательно в форме исполняемого testuite, чтобы мы могли проверить сами ли наши ответы действительно ответ на ваш вопрос.

Возможно, вы говорите о чем-то подобном?

module MethodHook 
    private 

    def class_method(m=nil) 
    return if @__recursing__ # prevent infinite recursion 
    return @__class_method__ = true unless m 

    @__recursing__ = true 

    old_m = instance_method(m) 
    define_method(m) do |*args, &block| 
     puts "before #{m}(#{args.join(', ')})" # wrap wrap wrap 
     old_m.bind(self).(*args, &block) 
     puts "after #{m}" # more wrapping 
    end 

    @__recursing__ = nil 
    end 

    def method_added(m) 
    class_method(m) if @__class_method__ 
    super 
    end 
end 

Использование так:

class Foo 
    extend MethodHook 

    def unwrapped 
    puts __method__ 
    end 

    class_method 

    def wrapped 
    puts __method__ 
    end 
end 

f = Foo.new 

f.unwrapped 
# unwrapped 

f.wrapped 
# before wrapped() 
# wrapped 
# after wrapped 

class Foo 
    class_method(:unwrapped) 
end 

f.unwrapped 
# before unwrapped() 
# wrapped 
# after unwrapped 
+0

К сожалению о смутном вопросе, но вы определенно есть суть того, что я просил. спасибо –

Смежные вопросы