Skip to content

Commit

Permalink
Added helper(:all) as a way to include all helpers from app/helpers/*…
Browse files Browse the repository at this point in the history
…*/*.rb in ApplicationController [DHH]

git-svn-id: http://svn-commit.rubyonrails.org/rails/trunk@6221 5ecf4fe2-1ee6-0310-87b1-e25e094e27de
  • Loading branch information
dhh committed Feb 24, 2007
1 parent 351eea1 commit f95dfff
Show file tree
Hide file tree
Showing 4 changed files with 45 additions and 6 deletions.
2 changes: 2 additions & 0 deletions actionpack/CHANGELOG
@@ -1,5 +1,7 @@
*SVN*

* Added helper(:all) as a way to include all helpers from app/helpers/**/*.rb in ApplicationController [DHH]

* Integration tests: introduce methods for other HTTP methods. #6353 [caboose]

* Routing: better support for escaped values in route segments. #7544 [Chris
Expand Down
26 changes: 23 additions & 3 deletions actionpack/lib/action_controller/helpers.rb
@@ -1,5 +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
Expand Down Expand Up @@ -46,19 +48,28 @@ def add_template_helper(helper_module) #:nodoc:
end

# Declare a helper:
#
# helper :foo
# requires 'foo_helper' and includes FooHelper in the template class.
#
# helper FooHelper
# includes FooHelper in the template class.
#
# helper { def foo() "#{bar} is the very best" end }
# evaluates the block in the template class, adding method #foo.
#
# helper(:three, BlindHelper) { def mice() 'mice' end }
# does all three.
#
# helper :all
# includes all helpers from app/views/helpers/**/*.rb under RAILS_ROOT
def helper(*args, &block)
args.flatten.each do |arg|
case arg
when Module
add_template_helper(arg)
when :all
helper(all_application_helpers)
when String, Symbol
file_name = arg.to_s.underscore + '_helper'
class_name = file_name.camelize
Expand All @@ -73,14 +84,14 @@ def helper(*args, &block)

add_template_helper(class_name.constantize)
else
raise ArgumentError, 'helper expects String, Symbol, or Module argument'
raise ArgumentError, "helper expects String, Symbol, or Module argument (was: #{args.inspect})"
end
end

# 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
Expand All @@ -104,6 +115,7 @@ def helper_attr(*attrs)
attrs.flatten.each { |attr| helper_method(attr, "#{attr}=") }
end


private
def default_helper_module!
module_name = name.sub(/Controller$|$/, 'Helper')
Expand All @@ -120,6 +132,7 @@ def default_helper_module!

def inherited_with_helper(child)
inherited_without_helper(child)

begin
child.master_helper_module = Module.new
child.master_helper_module.send :include, master_helper_module
Expand All @@ -128,6 +141,13 @@ def inherited_with_helper(child)
raise unless e.is_missing?("helpers/#{child.controller_path}_helper")
end
end

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
end
end
end
end
end
21 changes: 19 additions & 2 deletions actionpack/test/controller/helper_test.rb
@@ -1,5 +1,7 @@
require File.dirname(__FILE__) + '/../abstract_unit'

silence_warnings { ActionController::Helpers::HELPERS_DIR = File.dirname(__FILE__) + '/../fixtures/helpers' }

class TestController < ActionController::Base
attr_accessor :delegate_attr
def delegate_method() end
Expand All @@ -15,7 +17,7 @@ def render_hello_world
def rescue_action(e) raise end
end

class PDFController < ActionController::Base
class PdfController < ActionController::Base
def test
render :inline => "test: <%= foobar %>"
end
Expand All @@ -24,6 +26,10 @@ def rescue_action(e) raise end
end
end

class ApplicationController < ActionController::Base
helper :all
end

module LocalAbcHelper
def a() end
def b() end
Expand Down Expand Up @@ -120,7 +126,18 @@ def test_helper_for_acronym_controller
response = ActionController::TestResponse.new
request.action = 'test'

assert_equal 'test: baz', Fun::PDFController.process(request, response).body
assert_equal 'test: baz', Fun::PdfController.process(request, response).body
end

def test_all_helpers
# abc_helper.rb
assert ApplicationController.master_helper_module.instance_methods.include?("bare_a")

# fun/games_helper.rb
assert ApplicationController.master_helper_module.instance_methods.include?("stratego")

# fun/pdf_helper.rb
assert ApplicationController.master_helper_module.instance_methods.include?("foobar")
end

private
Expand Down
2 changes: 1 addition & 1 deletion actionpack/test/fixtures/helpers/fun/pdf_helper.rb
@@ -1,3 +1,3 @@
module Fun::PDFHelper
module Fun::PdfHelper
def foobar() 'baz' end
end

0 comments on commit f95dfff

Please sign in to comment.