From cd388e075c363d80f9bba050bbc77d7a1a1e0e07 Mon Sep 17 00:00:00 2001
From: =?UTF-8?q?Jos=C3=A9=20Valim?= <jose.valim@gmail.com>
Date: Sat, 4 Jul 2009 10:32:10 +0200
Subject: Search for generators on vendorized plugins and gems.

---
 railties/lib/generators.rb                                     | 10 ++++++++--
 .../stubby/generators/stubby_generator/stubby_generator.rb     |  4 ----
 .../vendor/gems/mspec/lib/generators/mspec_generator.rb        |  2 ++
 railties/test/generators_test.rb                               |  8 +++++++-
 4 files changed, 17 insertions(+), 7 deletions(-)
 delete mode 100644 railties/test/fixtures/plugins/default/stubby/generators/stubby_generator/stubby_generator.rb
 create mode 100644 railties/test/fixtures/vendor/gems/mspec/lib/generators/mspec_generator.rb

(limited to 'railties')

diff --git a/railties/lib/generators.rb b/railties/lib/generators.rb
index d513a3f6c7..83f1847598 100644
--- a/railties/lib/generators.rb
+++ b/railties/lib/generators.rb
@@ -20,13 +20,19 @@ module Rails
     # Generators load paths. First search on generators in the RAILS_ROOT, then
     # look for them in rails generators.
     #
-    # TODO Add plugins, gems and frozen gems to load path.
+    # TODO Right now, only plugin and frozen gems generators are loaded. Gems
+    # loaded by rubygems are not available since Rails dependencies system is
+    # being reworked.
     #
     def self.load_path
       @@load_path ||= begin
         paths = []
         paths << File.expand_path(File.join(File.dirname(__FILE__), "generators"))
-        paths << File.join(RAILS_ROOT, "lib", "generators") if defined?(RAILS_ROOT)
+        if defined?(RAILS_ROOT)
+          paths += Dir[File.join(RAILS_ROOT, "vendor", "gems", "*", "lib", "generators")]
+          paths += Dir[File.join(RAILS_ROOT, "vendor", "plugins", "*", "lib", "generators")]
+          paths << File.join(RAILS_ROOT, "lib", "generators")
+        end
         paths
       end
     end
diff --git a/railties/test/fixtures/plugins/default/stubby/generators/stubby_generator/stubby_generator.rb b/railties/test/fixtures/plugins/default/stubby/generators/stubby_generator/stubby_generator.rb
deleted file mode 100644
index 8fda8197d1..0000000000
--- a/railties/test/fixtures/plugins/default/stubby/generators/stubby_generator/stubby_generator.rb
+++ /dev/null
@@ -1,4 +0,0 @@
-class StubbyGenerator < Rails::Generator::Base
-  def manifest
-  end
-end
diff --git a/railties/test/fixtures/vendor/gems/mspec/lib/generators/mspec_generator.rb b/railties/test/fixtures/vendor/gems/mspec/lib/generators/mspec_generator.rb
new file mode 100644
index 0000000000..191bdbf2fc
--- /dev/null
+++ b/railties/test/fixtures/vendor/gems/mspec/lib/generators/mspec_generator.rb
@@ -0,0 +1,2 @@
+class MspecGenerator < Rails::Generators::NamedBase
+end
diff --git a/railties/test/generators_test.rb b/railties/test/generators_test.rb
index c49081e5cc..c7195f753d 100644
--- a/railties/test/generators_test.rb
+++ b/railties/test/generators_test.rb
@@ -63,6 +63,12 @@ class GeneratorsTest < GeneratorsTestCase
     assert_equal "rails:generators:javascripts", klass.namespace
   end
 
+  def test_find_by_namespace_lookup_to_vendor_folders
+    klass = Rails::Generators.find_by_namespace(:mspec)
+    assert klass
+    assert_equal "mspec", klass.namespace
+  end
+
   def test_builtin_generators
     assert Rails::Generators.builtin.include? %w(rails model)
   end
@@ -75,7 +81,7 @@ class GeneratorsTest < GeneratorsTestCase
 
   def test_rails_generators_with_others_information
     output = capture(:stdout){ Rails::Generators.help }.split("\n").last
-    assert_equal "Others: active_record:fixjour, fixjour, rails:javascripts.", output
+    assert_equal "Others: active_record:fixjour, fixjour, mspec, rails:javascripts.", output
   end
 
   def test_no_color_sets_proper_shell
-- 
cgit v1.2.3