From 8ec42df64166baa0cdf459b619c8e76937ab902f Mon Sep 17 00:00:00 2001 From: Ben Hollis Date: Sat, 15 Sep 2012 23:36:00 -0700 Subject: [PATCH] Correctly preview directory URLs with .s in them and show the request path on 404 pages. --- .../lib/middleman-core/application.rb | 31 ++++++++++++------- .../middleman-core/core_extensions/request.rb | 30 +++++++----------- .../middleman-core/core_extensions/routing.rb | 5 ++- 3 files changed, 36 insertions(+), 30 deletions(-) diff --git a/middleman-core/lib/middleman-core/application.rb b/middleman-core/lib/middleman-core/application.rb index 65bc4f0a..a3772cd3 100644 --- a/middleman-core/lib/middleman-core/application.rb +++ b/middleman-core/lib/middleman-core/application.rb @@ -183,11 +183,7 @@ module Middleman # Evaluate a passed block if given instance_exec(&block) if block_given? - # Build expanded source path once paths have been parsed - path = root.dup - source_path = ENV["MM_SOURCE"] || self.source - path = File.join(root, source_path) unless source_path.empty? - set :source_dir, path + set :source, ENV["MM_SOURCE"] if ENV["MM_SOURCE"] super end @@ -216,6 +212,13 @@ module Middleman self end + # The full path to the source directory + # + # @return [String] + def source_dir + File.join(root, source) + end + delegate :logger, :instrument, :to => ::Middleman::Util # Work around this bug: http://bugs.ruby-lang.org/issues/4521 @@ -232,12 +235,18 @@ module Middleman # @param [String] path Request path # @return [String] Path with index file if necessary def full_path(path) - cache.fetch(:full_path, path) do - parts = path ? path.split('/') : [] - if parts.last.nil? || parts.last.split('.').length == 1 - path = File.join(path, index_file) - end - "/" + path.sub(%r{^/}, '') + resource = sitemap.find_resource_by_destination_path(path) + + if !resource + # Try it with /index.html at the end + indexed_path = File.join(path.sub(%r{/$}, ''), index_file) + resource = sitemap.find_resource_by_destination_path(indexed_path) + end + + if resource + '/' + resource.destination_path + else + '/' + Middleman::Util.normalize_path(path) end end diff --git a/middleman-core/lib/middleman-core/core_extensions/request.rb b/middleman-core/lib/middleman-core/core_extensions/request.rb index 9f750e16..b88eef57 100644 --- a/middleman-core/lib/middleman-core/core_extensions/request.rb +++ b/middleman-core/lib/middleman-core/core_extensions/request.rb @@ -227,32 +227,26 @@ module Middleman start_time = Time.now @current_path = nil - # Normalize the path and add index if we're looking at a directory - original_path = URI.decode(env["PATH_INFO"].dup) - if original_path.respond_to? :force_encoding - original_path.force_encoding('UTF-8') + request_path = URI.decode(env["PATH_INFO"].dup) + if request_path.respond_to? :force_encoding + request_path.force_encoding('UTF-8') end - request_path = full_path(original_path) + request_path = full_path(request_path) # Run before callbacks run_hook :before - if original_path != request_path - # Get the resource object for this path - resource = sitemap.find_resource_by_destination_path(original_path) - end - - # Get the resource object for this full path - resource ||= sitemap.find_resource_by_destination_path(request_path) + # Get the resource object for this path + resource = sitemap.find_resource_by_destination_path(request_path) # Return 404 if not in sitemap - return not_found(res) unless resource && !resource.ignored? + return not_found(res, request_path) unless resource && !resource.ignored? + + current_path = resource.destination_path # If this path is a static file, send it immediately return send_file(resource.source_file, env, res) unless resource.template? - current_path = request_path.dup - # Set a HTTP content type based on the request's extensions content_type(res, resource.mime_type) @@ -272,7 +266,7 @@ module Middleman end # End the request - logger.debug "== Finishing Request: #{request_path} (#{(Time.now - start_time).round(2)}s)" + logger.debug "== Finishing Request: #{current_path} (#{(Time.now - start_time).round(2)}s)" halt res.finish end @@ -289,9 +283,9 @@ module Middleman end # Halt request and return 404 - def not_found(res) + def not_found(res, path) res.status == 404 - res.write "

File Not Found

#{@request_path}

" + res.write "

File Not Found

#{path}

" res.finish end diff --git a/middleman-core/lib/middleman-core/core_extensions/routing.rb b/middleman-core/lib/middleman-core/core_extensions/routing.rb index e78d0361..db7c6e61 100644 --- a/middleman-core/lib/middleman-core/core_extensions/routing.rb +++ b/middleman-core/lib/middleman-core/core_extensions/routing.rb @@ -64,7 +64,10 @@ module Middleman end # Normalized path - url = full_path(url) + url = '/' + Middleman::Util.normalize_path(url) + if url.end_with?('/') || File.directory?(File.join(source_dir, url)) + url = File.join(url, index_file) + end # Setup proxy if opts.has_key?(:proxy)