diff options
author | Jeremy Kemper <jeremy@bitsweat.net> | 2007-05-29 22:06:13 +0000 |
---|---|---|
committer | Jeremy Kemper <jeremy@bitsweat.net> | 2007-05-29 22:06:13 +0000 |
commit | 186ac4cdaa911a9af659a29f2179a19b99dea13b (patch) | |
tree | 00c8337c6707951409d636788ddc05b59c26cb06 /actionpack/lib/action_controller | |
parent | 34a5a896e1a55aebb0ae4b99de525c85b9eda2ed (diff) | |
download | rails-186ac4cdaa911a9af659a29f2179a19b99dea13b.tar.gz rails-186ac4cdaa911a9af659a29f2179a19b99dea13b.tar.bz2 rails-186ac4cdaa911a9af659a29f2179a19b99dea13b.zip |
Don't choke on nested helpers.
git-svn-id: http://svn-commit.rubyonrails.org/rails/trunk@6899 5ecf4fe2-1ee6-0310-87b1-e25e094e27de
Diffstat (limited to 'actionpack/lib/action_controller')
-rw-r--r-- | actionpack/lib/action_controller/helpers.rb | 35 |
1 files changed, 17 insertions, 18 deletions
diff --git a/actionpack/lib/action_controller/helpers.rb b/actionpack/lib/action_controller/helpers.rb index ab5b945b4d..af5b2fc64c 100644 --- a/actionpack/lib/action_controller/helpers.rb +++ b/actionpack/lib/action_controller/helpers.rb @@ -1,7 +1,7 @@ module ActionController #:nodoc: module Helpers #:nodoc: HELPERS_DIR = (defined?(RAILS_ROOT) ? "#{RAILS_ROOT}/app/helpers" : "app/helpers") - + def self.included(base) # Initialize the base module to aggregate its helpers. base.class_inheritable_accessor :master_helper_module @@ -19,29 +19,29 @@ module ActionController #:nodoc: end # The template helpers serve to relieve the templates from including the same inline code again and again. It's a - # set of standardized methods for working with forms (FormHelper), dates (DateHelper), texts (TextHelper), and + # set of standardized methods for working with forms (FormHelper), dates (DateHelper), texts (TextHelper), and # Active Records (ActiveRecordHelper) that's available to all templates by default. # # It's also really easy to make your own helpers and it's much encouraged to keep the template files free - # from complicated logic. It's even encouraged to bundle common compositions of methods from other helpers + # from complicated logic. It's even encouraged to bundle common compositions of methods from other helpers # (often the common helpers) as they're used by the specific application. - # + # # module MyHelper # def hello_world() "hello world" end # end - # + # # MyHelper can now be included in a controller, like this: - # + # # class MyController < ActionController::Base # helper :my_helper # end - # + # # ...and, same as above, used in any template rendered from MyController, like this: - # + # # Let's hear what the helper has to say: <tt><%= hello_world %></tt> module ClassMethods # Makes all the (instance) methods in the helper module available to templates rendered through this controller. - # See ActionView::Helpers (link:classes/ActionView/Helpers.html) for more about making your own helper modules + # See ActionView::Helpers (link:classes/ActionView/Helpers.html) for more about making your own helper modules # available to the templates. def add_template_helper(helper_module) #:nodoc: master_helper_module.send(:include, helper_module) @@ -73,7 +73,7 @@ module ActionController #:nodoc: when String, Symbol file_name = arg.to_s.underscore + '_helper' class_name = file_name.camelize - + begin require_dependency(file_name) rescue LoadError => load_error @@ -91,7 +91,7 @@ module ActionController #:nodoc: # Evaluate block in template class if given. master_helper_module.module_eval(&block) if block_given? end - + # Declare a controller method as a helper. For example, # helper_method :link_to # def link_to(name, options) ... end @@ -116,7 +116,7 @@ module ActionController #:nodoc: end - private + private def default_helper_module! module_name = name.sub(/Controller$|$/, 'Helper') module_path = module_name.split('::').map { |m| m.underscore }.join('/') @@ -141,13 +141,12 @@ module ActionController #:nodoc: raise unless e.is_missing?("helpers/#{child.controller_path}_helper") end end - + + # Extract helper names from files in app/helpers/**/*.rb def all_application_helpers - Dir["#{HELPERS_DIR}/**/*.rb"].collect do |file| - # Helper file without excess path, "_helper" suffix, and_extension - file[((File.dirname(HELPERS_DIR) + "/helpers/").size)..-("_helper".size + 4)] - end + extract = /^#{Regexp.quote(HELPERS_DIR)}\/?(.*)_helper.rb$/ + Dir["#{HELPERS_DIR}/**/*_helper.rb"].map { |file| file.sub extract, '\1' } end end end -end
\ No newline at end of file +end |