diff options
author | José Valim <jose.valim@gmail.com> | 2009-07-04 18:13:27 +0200 |
---|---|---|
committer | José Valim <jose.valim@gmail.com> | 2009-07-04 20:17:32 +0200 |
commit | b277cf28e8a6f5636d0485ab8c04ea0660444440 (patch) | |
tree | e7b99a8e16308854a2b1dadbb50f0c69daf418b7 | |
parent | 35925a8995e4b3522e4a4e4e52a3a18c9c1cee52 (diff) | |
download | rails-b277cf28e8a6f5636d0485ab8c04ea0660444440.tar.gz rails-b277cf28e8a6f5636d0485ab8c04ea0660444440.tar.bz2 rails-b277cf28e8a6f5636d0485ab8c04ea0660444440.zip |
Allow scaffold controller to load action_orm files on demand.
-rw-r--r-- | railties/lib/generators.rb | 1 | ||||
-rw-r--r-- | railties/lib/generators/named_base.rb | 15 | ||||
-rw-r--r-- | railties/test/generators/scaffold_controller_generator_test.rb | 2 |
3 files changed, 14 insertions, 4 deletions
diff --git a/railties/lib/generators.rb b/railties/lib/generators.rb index 83f1847598..e7495e8036 100644 --- a/railties/lib/generators.rb +++ b/railties/lib/generators.rb @@ -12,7 +12,6 @@ require 'rails/version' unless defined?(Rails::VERSION) require 'generators/base' require 'generators/named_base' -require 'generators/active_record' # We will need ActionORM from ActiveRecord, but just it. module Rails module Generators diff --git a/railties/lib/generators/named_base.rb b/railties/lib/generators/named_base.rb index 8f44000729..0d399c876c 100644 --- a/railties/lib/generators/named_base.rb +++ b/railties/lib/generators/named_base.rb @@ -129,13 +129,24 @@ module Rails # def orm_class @orm_class ||= begin + # Raise an error if the class_option :orm was not defined. unless self.class.class_options[:orm] raise "You need to have :orm as class option to invoke orm_class and orm_instance" end action_orm = "#{options[:orm].to_s.classify}::Generators::ActionORM" - action_orm.constantize - rescue NameError => e + + # If the orm was not loaded, try to load it at "generators/orm", + # for example "generators/active_record" or "generators/sequel". + begin + klass = action_orm.constantize + rescue NameError + require "generators/#{options[:orm]}" + end + + # Try once again after loading the file with success. + klass ||= action_orm.constantize + rescue Exception => e raise Error, "Could not load #{action_orm}, skipping controller. Error: #{e.message}." end end diff --git a/railties/test/generators/scaffold_controller_generator_test.rb b/railties/test/generators/scaffold_controller_generator_test.rb index 46b37d0cde..1f0060d11e 100644 --- a/railties/test/generators/scaffold_controller_generator_test.rb +++ b/railties/test/generators/scaffold_controller_generator_test.rb @@ -100,7 +100,7 @@ class ScaffoldControllerGeneratorTest < GeneratorsTestCase def test_error_is_shown_if_orm_does_not_provide_interface error = capture(:stderr){ run_generator ["User", "--orm=unknown"] } assert_equal "Could not load Unknown::Generators::ActionORM, skipping controller. " << - "Error: uninitialized constant Unknown.\n", error + "Error: no such file to load -- generators/unknown.\n", error end protected |