fix per-engine layout_engine, add tests
This commit is contained in:
parent
22c37f9b2b
commit
9eccf59aec
3 changed files with 46 additions and 20 deletions
|
@ -229,6 +229,9 @@ class Middleman::Base
|
||||||
@options = context.has_key?(:options) ? context[:options] : {}
|
@options = context.has_key?(:options) ? context[:options] : {}
|
||||||
@locals = context.has_key?(:locals) ? context[:locals] : {}
|
@locals = context.has_key?(:locals) ? context[:locals] : {}
|
||||||
|
|
||||||
|
engine_options = respond_to?(engine.to_sym) ? send(engine.to_sym) : {}
|
||||||
|
@options.merge!(engine_options)
|
||||||
|
|
||||||
provides_metadata.each do |callback, matcher|
|
provides_metadata.each do |callback, matcher|
|
||||||
next if !matcher.nil? && !path.match(matcher)
|
next if !matcher.nil? && !path.match(matcher)
|
||||||
instance_exec(path, &callback)
|
instance_exec(path, &callback)
|
||||||
|
@ -246,9 +249,9 @@ class Middleman::Base
|
||||||
instance_eval(&context[:block])
|
instance_eval(&context[:block])
|
||||||
end
|
end
|
||||||
|
|
||||||
# content_type mime_type(File.extname(@request_path))
|
content_type mime_type(File.extname(@request_path))
|
||||||
res.status = 200
|
res.status = 200
|
||||||
|
|
||||||
output = if local_layout
|
output = if local_layout
|
||||||
layout_engine = if options.has_key?(:layout_engine)
|
layout_engine = if options.has_key?(:layout_engine)
|
||||||
options[:layout_engine]
|
options[:layout_engine]
|
||||||
|
@ -324,20 +327,6 @@ public
|
||||||
self.class.map(map, &block)
|
self.class.map(map, &block)
|
||||||
end
|
end
|
||||||
|
|
||||||
# def compiled_templates_cache
|
|
||||||
# @_compiled_templates_cache ||= {}
|
|
||||||
# end
|
|
||||||
#
|
|
||||||
# def read_compiled_template(path, locals, options, &block)
|
|
||||||
# key = [path, locals, options]
|
|
||||||
#
|
|
||||||
# if !raw_templates_cache.has_key?(key)
|
|
||||||
# raw_templates_cache[key] = yield
|
|
||||||
# end
|
|
||||||
#
|
|
||||||
# raw_templates_cache[key]
|
|
||||||
# end
|
|
||||||
|
|
||||||
def full_path(path)
|
def full_path(path)
|
||||||
parts = path ? path.split('/') : []
|
parts = path ? path.split('/') : []
|
||||||
if parts.last.nil? || parts.last.split('.').length == 1
|
if parts.last.nil? || parts.last.split('.').length == 1
|
||||||
|
@ -395,10 +384,9 @@ public
|
||||||
end
|
end
|
||||||
|
|
||||||
def send_file(path)
|
def send_file(path)
|
||||||
|
matched_mime = mime_type(File.extname(path))
|
||||||
# matched_mime = mime_type(File.extname(request_path))
|
matched_mime = "application/octet-stream" if matched_mime.nil?
|
||||||
# matched_mime = "application/octet-stream" if matched_mime.nil?
|
content_type matched_mime
|
||||||
# content_type matched_mime
|
|
||||||
|
|
||||||
file = ::Rack::File.new nil
|
file = ::Rack::File.new nil
|
||||||
file.path = path
|
file.path = path
|
||||||
|
@ -412,4 +400,40 @@ public
|
||||||
template = ::Tilt.new(path, 1, options) { body }
|
template = ::Tilt.new(path, 1, options) { body }
|
||||||
template.render(self, locals, &block)
|
template.render(self, locals, &block)
|
||||||
end
|
end
|
||||||
|
|
||||||
|
def mime_type(type, value=nil)
|
||||||
|
return type if type.nil? || type.to_s.include?('/')
|
||||||
|
type = ".#{type}" unless type.to_s[0] == ?.
|
||||||
|
return ::Rack::Mime.mime_type(type, nil) unless value
|
||||||
|
::Rack::Mime::MIME_TYPES[type] = value
|
||||||
|
end
|
||||||
|
|
||||||
|
def content_type(type = nil, params={})
|
||||||
|
return res['Content-Type'] unless type
|
||||||
|
default = params.delete :default
|
||||||
|
mime_type = mime_type(type) || default
|
||||||
|
throw "Unknown media type: %p" % type if mime_type.nil?
|
||||||
|
mime_type = mime_type.dup
|
||||||
|
unless params.include? :charset
|
||||||
|
params[:charset] = params.delete('charset') || "utf-8"
|
||||||
|
end
|
||||||
|
params.delete :charset if mime_type.include? 'charset'
|
||||||
|
unless params.empty?
|
||||||
|
mime_type << (mime_type.include?(';') ? ', ' : ';')
|
||||||
|
mime_type << params.map { |kv| kv.join('=') }.join(', ')
|
||||||
|
end
|
||||||
|
res['Content-Type'] = mime_type
|
||||||
|
end
|
||||||
|
|
||||||
|
def helpers(*extensions, &block)
|
||||||
|
self.class.helpers(*extensions, &block)
|
||||||
|
end
|
||||||
|
|
||||||
|
def use(middleware, *args, &block)
|
||||||
|
self.class.use(middleware, *args, &block)
|
||||||
|
end
|
||||||
|
|
||||||
|
def map(map, &block)
|
||||||
|
self.class.map(map, &block)
|
||||||
|
end
|
||||||
end
|
end
|
|
@ -24,6 +24,7 @@ Gem::Specification.new do |s|
|
||||||
s.add_dependency("thin", ["~> 1.2.11"])
|
s.add_dependency("thin", ["~> 1.2.11"])
|
||||||
s.add_dependency("thor", ["~> 0.14.0"])
|
s.add_dependency("thor", ["~> 0.14.0"])
|
||||||
s.add_dependency("tilt", ["~> 1.3.1"])
|
s.add_dependency("tilt", ["~> 1.3.1"])
|
||||||
|
s.add_dependency("i18n", ["~> 0.6.0"])
|
||||||
s.add_dependency("rack-test", ["~> 0.6.1"])
|
s.add_dependency("rack-test", ["~> 0.6.1"])
|
||||||
s.add_dependency("uglifier", ["~> 1.1.0"])
|
s.add_dependency("uglifier", ["~> 1.1.0"])
|
||||||
s.add_dependency("haml", ["~> 3.1.0"])
|
s.add_dependency("haml", ["~> 3.1.0"])
|
||||||
|
|
|
@ -24,6 +24,7 @@ Gem::Specification.new do |s|
|
||||||
s.add_dependency("thin", ["~> 1.2.11"])
|
s.add_dependency("thin", ["~> 1.2.11"])
|
||||||
s.add_dependency("thor", ["~> 0.14.0"])
|
s.add_dependency("thor", ["~> 0.14.0"])
|
||||||
s.add_dependency("tilt", ["~> 1.3.1"])
|
s.add_dependency("tilt", ["~> 1.3.1"])
|
||||||
|
s.add_dependency("i18n", ["~> 0.6.0"])
|
||||||
s.add_dependency("rack-test", ["~> 0.6.1"])
|
s.add_dependency("rack-test", ["~> 0.6.1"])
|
||||||
s.add_dependency("uglifier", ["~> 1.1.0"])
|
s.add_dependency("uglifier", ["~> 1.1.0"])
|
||||||
s.add_dependency("haml", ["~> 3.1.0"])
|
s.add_dependency("haml", ["~> 3.1.0"])
|
||||||
|
|
Loading…
Reference in a new issue