Add docs task and setup gh pages

This commit is contained in:
tdreyno 2011-02-12 21:02:00 -08:00
parent e51d84b2ed
commit f08fa84852
2 changed files with 41 additions and 4 deletions

1
.gitignore vendored
View file

@ -6,3 +6,4 @@ pkg
.sassc
.tmp
Gemfile.lock
docs

View file

@ -7,10 +7,46 @@ Cucumber::Rake::Task.new(:cucumber, 'Run features that should pass') do |t|
t.cucumber_opts = "--color --tags ~@wip --strict --format #{ENV['CUCUMBER_FORMAT'] || 'pretty'}"
end
#$LOAD_PATH.unshift 'lib'
require 'rake/testtask'
require 'rake/clean'
task :test => :cucumber
namespace :build do
task :docs do
`rocco lib/*.rb --output=docs`
# Bring in Rocco tasks
require 'rocco/tasks'
Rocco::make 'docs/'
desc 'Build rocco docs'
task :docs => :rocco
directory 'docs/'
# Make index.html a copy of rocco.html
file 'docs/index.html' => 'docs/lib/middleman.html' do |f|
cp 'docs/lib/middleman.html', 'docs/index.html', :preserve => true
end
task :docs => 'docs/index.html'
CLEAN.include 'docs/index.html'
desc 'Update gh-pages branch'
task :pages => ['docs/.git', :docs] do
rev = `git rev-parse --short HEAD`.strip
Dir.chdir 'docs' do
sh "git add *.html"
sh "git commit -m 'rebuild pages from #{rev}'" do |ok,res|
if ok
verbose { puts "gh-pages updated" }
sh "git push -q o HEAD:gh-pages"
end
end
end
end
# Update the pages/ directory clone
file 'docs/.git' => ['docs/', '.git/refs/heads/gh-pages'] do |f|
sh "cd docs && git init -q && git remote add o ../.git" if !File.exist?(f.name)
sh "cd docs && git fetch -q o && git reset -q --hard o/gh-pages && touch ."
end
CLOBBER.include 'docs/.git'