diff options
Diffstat (limited to 'actionpack/lib/action_dispatch/routing')
| -rw-r--r-- | actionpack/lib/action_dispatch/routing/polymorphic_routes.rb | 18 | ||||
| -rw-r--r-- | actionpack/lib/action_dispatch/routing/route_set.rb | 45 | ||||
| -rw-r--r-- | actionpack/lib/action_dispatch/routing/url_for.rb | 6 | 
3 files changed, 35 insertions, 34 deletions
| diff --git a/actionpack/lib/action_dispatch/routing/polymorphic_routes.rb b/actionpack/lib/action_dispatch/routing/polymorphic_routes.rb index f2ce175cac..9934f5547a 100644 --- a/actionpack/lib/action_dispatch/routing/polymorphic_routes.rb +++ b/actionpack/lib/action_dispatch/routing/polymorphic_routes.rb @@ -247,14 +247,12 @@ module ActionDispatch            args  = []            model = record.to_model -          name = if model.persisted? -                   args << model -                   model.model_name.singular_route_key -                 else -                   @key_strategy.call model.model_name -                 end - -          named_route = "#{prefix}#{name}_#{suffix}" +          named_route = if model.persisted? +                          args << model +                          get_method_for_string model.model_name.singular_route_key +                        else +                          get_method_for_class model +                        end            [named_route, args]          end @@ -309,11 +307,11 @@ module ActionDispatch          def get_method_for_class(klass)            name   = @key_strategy.call klass.model_name -          prefix + "#{name}_#{suffix}" +          get_method_for_string name          end          def get_method_for_string(str) -          prefix + "#{str}_#{suffix}" +          "#{prefix}#{str}_#{suffix}"          end          [nil, 'new', 'edit'].each do |action| diff --git a/actionpack/lib/action_dispatch/routing/route_set.rb b/actionpack/lib/action_dispatch/routing/route_set.rb index ce04f0b08a..6d964c2cbf 100644 --- a/actionpack/lib/action_dispatch/routing/route_set.rb +++ b/actionpack/lib/action_dispatch/routing/route_set.rb @@ -20,6 +20,8 @@ module ActionDispatch        # alias inspect to to_s.        alias inspect to_s +      mattr_accessor :relative_url_root +        class Dispatcher < Routing::Endpoint          def initialize(defaults)            @defaults = defaults @@ -199,12 +201,9 @@ module ActionDispatch              private              def optimized_helper(args) -              params = parameterize_args(args) -              missing_keys = missing_keys(params) - -              unless missing_keys.empty? -                raise_generation_error(params, missing_keys) -              end +              params = parameterize_args(args) { |k| +                raise_generation_error(args) +              }                @route.format params              end @@ -215,16 +214,21 @@ module ActionDispatch              def parameterize_args(args)                params = {} -              @required_parts.zip(args.map(&:to_param)) { |k,v| params[k] = v } +              @arg_size.times { |i| +                key = @required_parts[i] +                value = args[i].to_param +                yield key if value.nil? || value.empty? +                params[key] = value +              }                params              end -            def missing_keys(args) -              args.select{ |part, arg| arg.nil? || arg.empty? }.keys -            end - -            def raise_generation_error(args, missing_keys) -              constraints = Hash[@route.requirements.merge(args).sort] +            def raise_generation_error(args) +              missing_keys = [] +              params = parameterize_args(args) { |missing_key| +                missing_keys << missing_key +              } +              constraints = Hash[@route.requirements.merge(params).sort]                message = "No route matches #{constraints.inspect}"                message << " missing required keys: #{missing_keys.sort.inspect}" @@ -307,7 +311,8 @@ module ActionDispatch        attr_accessor :formatter, :set, :named_routes, :default_scope, :router        attr_accessor :disable_clear_and_finalize, :resources_path_names -      attr_accessor :default_url_options, :request_class +      attr_accessor :default_url_options +      attr_reader :env_key        alias :routes :set @@ -315,22 +320,26 @@ module ActionDispatch          { :new => 'new', :edit => 'edit' }        end -      def initialize(request_class = ActionDispatch::Request) +      def initialize          self.named_routes = NamedRouteCollection.new          self.resources_path_names = self.class.default_resources_path_names          self.default_url_options = {} -        self.request_class = request_class          @append                     = []          @prepend                    = []          @disable_clear_and_finalize = false          @finalized                  = false +        @env_key                    = "ROUTES_#{object_id}_SCRIPT_NAME".freeze          @set    = Journey::Routes.new          @router = Journey::Router.new @set          @formatter = Journey::Formatter.new @set        end +      def request_class +        ActionDispatch::Request +      end +        def draw(&block)          clear! unless @disable_clear_and_finalize          eval_block(block) @@ -539,7 +548,7 @@ module ActionDispatch          conditions.keep_if do |k, _|            k == :action || k == :controller || k == :required_defaults || -            @request_class.public_method_defined?(k) || path_values.include?(k) +            request_class.public_method_defined?(k) || path_values.include?(k)          end        end        private :build_conditions @@ -693,7 +702,7 @@ module ActionDispatch        end        def find_script_name(options) -        options.delete(:script_name) || '' +        options.delete(:script_name) || relative_url_root || ''        end        def path_for(options, route_name = nil) diff --git a/actionpack/lib/action_dispatch/routing/url_for.rb b/actionpack/lib/action_dispatch/routing/url_for.rb index dca86858cc..eb554ec383 100644 --- a/actionpack/lib/action_dispatch/routing/url_for.rb +++ b/actionpack/lib/action_dispatch/routing/url_for.rb @@ -184,12 +184,6 @@ module ActionDispatch        def _routes_context          self        end - -      private - -        def _generate_paths_by_default -          true -        end      end    end  end | 
