minor rdoc tweaks

This commit is contained in:
tdreyno 2009-10-06 16:51:34 -07:00
parent 7e845647ea
commit 8874e97608
4 changed files with 63 additions and 60 deletions

View file

@ -62,6 +62,7 @@ Rake::RDocTask.new do |rdoc|
rdoc.title = "middleman #{version}" rdoc.title = "middleman #{version}"
rdoc.rdoc_files.include('README*') rdoc.rdoc_files.include('README*')
rdoc.rdoc_files.include('lib/**/*.rb') rdoc.rdoc_files.include('lib/**/*.rb')
rdoc.rdoc_files.exclude('lib/middleman/features/sprockets+ruby19.rb')
end end
desc "Build and publish documentation using GitHub Pages." desc "Build and publish documentation using GitHub Pages."

View file

@ -4,12 +4,6 @@ require 'rubygems' unless ENV['NO_RUBYGEMS']
# We're riding on Sinatra, so let's include it # We're riding on Sinatra, so let's include it
require 'sinatra/base' 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 module Middleman
class Base < Sinatra::Base class Base < Sinatra::Base
set :app_file, __FILE__ set :app_file, __FILE__
@ -45,6 +39,12 @@ module Middleman
enable :cache_buster enable :cache_buster
end 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) # Convenience function to discover if a tempalte exists for the requested renderer (haml, sass, etc)
def template_exists?(path, renderer=nil) def template_exists?(path, renderer=nil)
template_path = path.dup template_path = path.dup

View file

@ -2,62 +2,64 @@ require 'haml'
module Middleman module Middleman
module Haml module Haml
def self.included(base) module Renderer
base.supported_formats << "haml" def self.included(base)
base.helpers Middleman::HamlHelpers base.supported_formats << "haml"
end base.helpers Middleman::Haml::Helpers
end
def render_path(path) def render_path(path)
if template_exists?(path, :haml) if template_exists?(path, :haml)
result = nil result = nil
begin begin
result = haml(path.to_sym, :layout => File.extname(path) != ".xml") result = haml(path.to_sym, :layout => File.extname(path) != ".xml")
rescue ::Haml::Error => e rescue ::Haml::Error => e
result = "Haml Error: #{e}" result = "Haml Error: #{e}"
result << "<pre>Backtrace: #{e.backtrace.join("\n")}</pre>" result << "<pre>Backtrace: #{e.backtrace.join("\n")}</pre>"
end
result
else
super
end end
result
else
super
end end
end end
end
module HamlHelpers module Helpers
def haml_partial(name, options = {}) def haml_partial(name, options = {})
item_name = name.to_sym item_name = name.to_sym
counter_name = "#{name}_counter".to_sym counter_name = "#{name}_counter".to_sym
if collection = options.delete(:collection) if collection = options.delete(:collection)
collection.enum_for(:each_with_index).collect do |item,index| collection.enum_for(:each_with_index).collect do |item,index|
haml_partial name, options.merge(:locals => {item_name => item, counter_name => index+1}) haml_partial name, options.merge(:locals => {item_name => item, counter_name => index+1})
end.join end.join
elsif object = options.delete(:object) elsif object = options.delete(:object)
haml_partial name, options.merge(:locals => {item_name => object, counter_name => nil}) haml_partial name, options.merge(:locals => {item_name => object, counter_name => nil})
else else
haml "_#{name}".to_sym, options.merge(:layout => false) haml "_#{name}".to_sym, options.merge(:layout => false)
end
end end
end end
end
module Table module Table
include ::Haml::Filters::Base include ::Haml::Filters::Base
def render(text) def render(text)
output = '<div class="table"><table cellspacing="0" cellpadding="0">' output = '<div class="table"><table cellspacing="0" cellpadding="0">'
line_num = 0 line_num = 0
text.each_line do |line| text.each_line do |line|
line_num += 1 line_num += 1
next if line.strip.empty? next if line.strip.empty?
output << %Q{<tr class="#{(line_num % 2 == 0) ? "even" : "odd" }#{(line_num == 1) ? " first" : "" }">} output << %Q{<tr class="#{(line_num % 2 == 0) ? "even" : "odd" }#{(line_num == 1) ? " first" : "" }">}
columns = line.split("|").map { |p| p.strip } columns = line.split("|").map { |p| p.strip }
columns.each_with_index do |col, i| columns.each_with_index do |col, i|
output << %Q{<td class="col#{i+1}">#{col}</td>} output << %Q{<td class="col#{i+1}">#{col}</td>}
end
output << "</tr>"
end end
output + "</table></div>"
output << "</tr>"
end end
output + "</table></div>"
end end
end end
@ -125,6 +127,6 @@ END
end end
class Middleman::Base class Middleman::Base
include Middleman::Haml include Middleman::Haml::Renderer
include Middleman::Sass include Middleman::Sass
end end

View file

@ -12,20 +12,20 @@ module Middleman
END END
end end
end end
end
module Compressor module StaticJavascript
def render_path(path) def render_path(path)
if template_exists?(path, :js) if template_exists?(path, :js)
compressor = YUI::JavaScriptCompressor.new(:munge => true) compressor = YUI::JavaScriptCompressor.new(:munge => true)
compressor.compress(super) compressor.compress(super)
else else
super super
end
end end
end end
end end
class Base class Base
include Middleman::Compressor include Middleman::Minified::StaticJavascript
end end
end end