mirror of
https://github.com/middleman/middleman.git
synced 2022-11-09 12:20:27 -05:00
minor rdoc tweaks
This commit is contained in:
parent
7e845647ea
commit
8874e97608
4 changed files with 63 additions and 60 deletions
1
Rakefile
1
Rakefile
|
@ -62,6 +62,7 @@ Rake::RDocTask.new do |rdoc|
|
|||
rdoc.title = "middleman #{version}"
|
||||
rdoc.rdoc_files.include('README*')
|
||||
rdoc.rdoc_files.include('lib/**/*.rb')
|
||||
rdoc.rdoc_files.exclude('lib/middleman/features/sprockets+ruby19.rb')
|
||||
end
|
||||
|
||||
desc "Build and publish documentation using GitHub Pages."
|
||||
|
|
|
@ -4,12 +4,6 @@ require 'rubygems' unless ENV['NO_RUBYGEMS']
|
|||
# We're riding on Sinatra, so let's include it
|
||||
require 'sinatra/base'
|
||||
|
||||
# Rack helper for adding mime-types during local preview
|
||||
def mime(ext, type)
|
||||
ext = ".#{ext}" unless ext.to_s[0] == ?.
|
||||
Rack::Mime::MIME_TYPES[ext.to_s] = type
|
||||
end
|
||||
|
||||
module Middleman
|
||||
class Base < Sinatra::Base
|
||||
set :app_file, __FILE__
|
||||
|
@ -45,6 +39,12 @@ module Middleman
|
|||
enable :cache_buster
|
||||
end
|
||||
|
||||
# Rack helper for adding mime-types during local preview
|
||||
def mime(ext, type)
|
||||
ext = ".#{ext}" unless ext.to_s[0] == ?.
|
||||
Rack::Mime::MIME_TYPES[ext.to_s] = type
|
||||
end
|
||||
|
||||
# Convenience function to discover if a tempalte exists for the requested renderer (haml, sass, etc)
|
||||
def template_exists?(path, renderer=nil)
|
||||
template_path = path.dup
|
||||
|
|
|
@ -2,62 +2,64 @@ require 'haml'
|
|||
|
||||
module Middleman
|
||||
module Haml
|
||||
def self.included(base)
|
||||
base.supported_formats << "haml"
|
||||
base.helpers Middleman::HamlHelpers
|
||||
end
|
||||
module Renderer
|
||||
def self.included(base)
|
||||
base.supported_formats << "haml"
|
||||
base.helpers Middleman::Haml::Helpers
|
||||
end
|
||||
|
||||
def render_path(path)
|
||||
if template_exists?(path, :haml)
|
||||
result = nil
|
||||
begin
|
||||
result = haml(path.to_sym, :layout => File.extname(path) != ".xml")
|
||||
rescue ::Haml::Error => e
|
||||
result = "Haml Error: #{e}"
|
||||
result << "<pre>Backtrace: #{e.backtrace.join("\n")}</pre>"
|
||||
def render_path(path)
|
||||
if template_exists?(path, :haml)
|
||||
result = nil
|
||||
begin
|
||||
result = haml(path.to_sym, :layout => File.extname(path) != ".xml")
|
||||
rescue ::Haml::Error => e
|
||||
result = "Haml Error: #{e}"
|
||||
result << "<pre>Backtrace: #{e.backtrace.join("\n")}</pre>"
|
||||
end
|
||||
result
|
||||
else
|
||||
super
|
||||
end
|
||||
result
|
||||
else
|
||||
super
|
||||
end
|
||||
end
|
||||
end
|
||||
|
||||
module HamlHelpers
|
||||
def haml_partial(name, options = {})
|
||||
item_name = name.to_sym
|
||||
counter_name = "#{name}_counter".to_sym
|
||||
if collection = options.delete(:collection)
|
||||
collection.enum_for(:each_with_index).collect do |item,index|
|
||||
haml_partial name, options.merge(:locals => {item_name => item, counter_name => index+1})
|
||||
end.join
|
||||
elsif object = options.delete(:object)
|
||||
haml_partial name, options.merge(:locals => {item_name => object, counter_name => nil})
|
||||
else
|
||||
haml "_#{name}".to_sym, options.merge(:layout => false)
|
||||
end
|
||||
end
|
||||
end
|
||||
|
||||
module Table
|
||||
include ::Haml::Filters::Base
|
||||
|
||||
def render(text)
|
||||
output = '<div class="table"><table cellspacing="0" cellpadding="0">'
|
||||
line_num = 0
|
||||
text.each_line do |line|
|
||||
line_num += 1
|
||||
next if line.strip.empty?
|
||||
output << %Q{<tr class="#{(line_num % 2 == 0) ? "even" : "odd" }#{(line_num == 1) ? " first" : "" }">}
|
||||
|
||||
columns = line.split("|").map { |p| p.strip }
|
||||
columns.each_with_index do |col, i|
|
||||
output << %Q{<td class="col#{i+1}">#{col}</td>}
|
||||
module Helpers
|
||||
def haml_partial(name, options = {})
|
||||
item_name = name.to_sym
|
||||
counter_name = "#{name}_counter".to_sym
|
||||
if collection = options.delete(:collection)
|
||||
collection.enum_for(:each_with_index).collect do |item,index|
|
||||
haml_partial name, options.merge(:locals => {item_name => item, counter_name => index+1})
|
||||
end.join
|
||||
elsif object = options.delete(:object)
|
||||
haml_partial name, options.merge(:locals => {item_name => object, counter_name => nil})
|
||||
else
|
||||
haml "_#{name}".to_sym, options.merge(:layout => false)
|
||||
end
|
||||
|
||||
output << "</tr>"
|
||||
end
|
||||
output + "</table></div>"
|
||||
end
|
||||
|
||||
module Table
|
||||
include ::Haml::Filters::Base
|
||||
|
||||
def render(text)
|
||||
output = '<div class="table"><table cellspacing="0" cellpadding="0">'
|
||||
line_num = 0
|
||||
text.each_line do |line|
|
||||
line_num += 1
|
||||
next if line.strip.empty?
|
||||
output << %Q{<tr class="#{(line_num % 2 == 0) ? "even" : "odd" }#{(line_num == 1) ? " first" : "" }">}
|
||||
|
||||
columns = line.split("|").map { |p| p.strip }
|
||||
columns.each_with_index do |col, i|
|
||||
output << %Q{<td class="col#{i+1}">#{col}</td>}
|
||||
end
|
||||
|
||||
output << "</tr>"
|
||||
end
|
||||
output + "</table></div>"
|
||||
end
|
||||
end
|
||||
end
|
||||
|
||||
|
@ -125,6 +127,6 @@ END
|
|||
end
|
||||
|
||||
class Middleman::Base
|
||||
include Middleman::Haml
|
||||
include Middleman::Haml::Renderer
|
||||
include Middleman::Sass
|
||||
end
|
|
@ -12,20 +12,20 @@ module Middleman
|
|||
END
|
||||
end
|
||||
end
|
||||
end
|
||||
|
||||
module Compressor
|
||||
def render_path(path)
|
||||
if template_exists?(path, :js)
|
||||
compressor = YUI::JavaScriptCompressor.new(:munge => true)
|
||||
compressor.compress(super)
|
||||
else
|
||||
super
|
||||
module StaticJavascript
|
||||
def render_path(path)
|
||||
if template_exists?(path, :js)
|
||||
compressor = YUI::JavaScriptCompressor.new(:munge => true)
|
||||
compressor.compress(super)
|
||||
else
|
||||
super
|
||||
end
|
||||
end
|
||||
end
|
||||
end
|
||||
|
||||
class Base
|
||||
include Middleman::Compressor
|
||||
include Middleman::Minified::StaticJavascript
|
||||
end
|
||||
end
|
Loading…
Reference in a new issue