123456789_123456789_123456789_123456789_123456789_

Module: AbstractController::Collector

Relationships & Source Files
Extension / Inclusion / Inheritance Descendants
Included In:
Defined in: actionpack/lib/abstract_controller/collector.rb

Class Method Summary

Dynamic Method Handling

This class handles dynamic methods through the method_missing method

#method_missing(symbol, &block) (protected)

[ GitHub ]

  
# File 'actionpack/lib/abstract_controller/collector.rb', line 25

def method_missing(symbol, &block)
  const_name = symbol.upcase

  unless Mime.const_defined?(const_name)
    raise NoMethodError, "To respond to a custom format, register it as a MIME type first: " \
      "http://guides.rubyonrails.org/action_controller_overview.html#restful-downloads. " \
      "If you meant to respond to a variant like :tablet or :phone, not a custom format, " \
      "be sure to nest your variant response within a format response: " \
      "format.html { |html| html.tablet { ... } }"
  end

  mime_constant = Mime.const_get(const_name)

  if Mime::SET.include?(mime_constant)
    AbstractController::Collector.generate_method_for_mime(mime_constant)
    send(symbol, &block)
  else
    super
  end
end

Class Method Details

.generate_method_for_mime(mime)

[ GitHub ]

  
# File 'actionpack/lib/abstract_controller/collector.rb', line 5

def self.generate_method_for_mime(mime)
  sym = mime.is_a?(Symbol) ? mime : mime.to_sym
  const = sym.upcase
  class_eval <<-RUBY, __FILE__, __LINE__ + 1
    def #{sym}(*args, &block)                # def html(*args, &block)
      custom(Mime::#{const}, *args, &block)  #   custom(Mime::HTML, *args, &block)
    end                                      # end
  RUBY
end