Я пытаюсь переопределить динамически генерируемый метод, добавив модуль.
В приведенном ниже примере ассоциация Ripple добавляет метод rows=
в таблицу. Я хочу вызвать этот метод, но потом сделаю еще кое-что.
Я создал модуль для переопределения метода, полагая, что row=
модуля сможет вызвать super
для использования существующего метода.
class Table
# Ripple association - creates rows= method
many :rows, :class_name => Table::Row
# Hacky first attempt to use the dynamically-created
# method and also do additional stuff - I would actually
# move this code elsewhere if it worked
module RowNormalizer
def rows=(*args)
rows = super
rows.map!(&:normalize_prior_year)
end
end
include RowNormalizer
end
Тем не менее, мой новый rows=
никогда не вызывается, о чем свидетельствует тот факт, что если я вызову исключение внутри него, ничего не произойдет.
Я знаю, что модуль включается, потому что, если я вставлю это в него, моё исключение поднимется.
included do
raise 'I got included, woo!'
end
Кроме того, если вместо rows=
модуль определяет somethingelse=
, этот метод может быть вызван.
Почему мой метод модуля не перекрывает динамически генерируемый?