2010-05-26 07:23:47 +00:00
require " rubygems "
2011-05-30 04:30:16 +00:00
require " bundler/setup "
2010-05-26 07:23:47 +00:00
2010-03-10 18:23:30 +00:00
port = " 4000 " # preview project port eg. http://localhost:4000
2011-04-18 03:49:30 +00:00
site = " public " # compiled site directory
2010-03-10 18:23:30 +00:00
source = " source " # source file directory
stash = " _stash " # directory to stash posts for speedy generation
posts = " _posts " # directory for blog files
post_format = " markdown " # file format for new posts when using the post rake task
2009-11-24 22:53:24 +00:00
## -- Rsync Deploy config -- ##
2011-06-11 11:56:04 +00:00
# Be sure your public key is listed in your server's ~/.ssh/authorized_keys file
2009-11-01 04:17:29 +00:00
ssh_user = " user@host.com " # for rsync deployment
document_root = " ~/document_root/ " # for rsync deployment
2009-11-24 22:53:24 +00:00
## -- Github Pages deploy config -- ##
2009-11-24 22:40:47 +00:00
# Read http://pages.github.com for guidance
2011-06-11 11:56:04 +00:00
# You can deploy to github pages with `rake push_github` or change the default push task to :push_github
2009-11-24 22:53:24 +00:00
source_branch = " source " # this compiles to your deploy branch
2009-12-13 16:36:59 +00:00
deploy_branch = " master " # For user pages, use "master" for project pages use "gh-pages"
2009-11-24 22:40:47 +00:00
2009-10-19 00:07:36 +00:00
2011-06-07 14:45:01 +00:00
desc " Initial setup for Octopress: copies the default theme into the path of Jekyll's generator. rake install defaults to rake install[classic] to install a different theme run rake install[some_theme_name] "
task :install , :theme do | t , args |
# copy theme into working Jekyll directories
theme = args . theme || 'classic'
puts " # # Copying " + theme + " theme to Jekyll paths "
2011-06-11 19:58:53 +00:00
system " mkdir -p #{ source } ; cp -R themes/ " + theme + " /source/ #{ source } / "
system " mkdir -p sass; cp -R themes/ " + theme + " /sass/ sass/ "
system " mkdir -p _plugins; cp -R themes/ " + theme + " /_plugins/ _plugins/ "
system " mkdir -p #{ source } /_posts " ;
puts " # # Layouts, images, and javascritps from the #{ theme } theme have been installed into ./ #{ source } "
puts " # # Sass stylesheet sources from the #{ theme } theme have been installed into ./sass "
puts " # # Plugins from the #{ theme } theme have been installed into ./_plugins "
2011-06-07 14:45:01 +00:00
end
2011-06-11 11:56:04 +00:00
#######################
# Working with Jekyll #
#######################
2010-03-10 18:23:30 +00:00
2011-06-11 11:56:04 +00:00
desc " Watch the site and regenerate when it changes "
task :watch do
system " trap 'kill $jekyllPid $compassPid' Exit; jekyll --auto & jekyllPid=$!; compass watch & compassPid=$!; wait "
2009-11-25 14:34:32 +00:00
end
2011-06-11 11:56:04 +00:00
desc " preview the site in a web browser "
task :preview do
system " trap 'kill $jekyllPid $compassPid' Exit; jekyll --auto --server & jekyllPid=$!; compass watch & compassPid=$!; wait "
2009-11-06 03:30:03 +00:00
end
2009-12-07 16:55:13 +00:00
# usage rake post[my-new-post] or rake post['my new post'] or rake post (defaults to "new-post")
desc " Begin a new post in #{ source } /_posts "
task :post , :filename do | t , args |
2011-04-18 03:49:30 +00:00
require './_plugins/titlecase.rb'
2009-12-07 16:55:13 +00:00
args . with_defaults ( :filename = > 'new-post' )
2011-04-18 03:49:30 +00:00
open ( " #{ source } /_posts/ #{ Time . now . strftime ( '%Y-%m-%d' ) } - #{ args . filename . downcase . gsub ( / [ _] / , '-' ) } . #{ post_format } " , 'w' ) do | post |
2009-12-07 16:55:13 +00:00
post . puts " --- "
post . puts " title: \" #{ args . filename . gsub ( / [-_] / , ' ' ) . titlecase } \" "
2011-04-18 03:49:30 +00:00
post . puts " date: #{ Time . now . strftime ( '%Y-%m-%d %H:%M' ) } "
post . puts " layout: post "
2009-12-07 16:55:13 +00:00
post . puts " --- "
end
end
2010-01-23 20:47:43 +00:00
# usage rake isolate[my-post]
desc " Move all other posts than the one currently being worked on to a temporary stash location (stash) so regenerating the site happens much quicker. "
task :isolate , :filename do | t , args |
stash_dir = " #{ source } / #{ stash } "
FileUtils . mkdir ( stash_dir ) unless File . exist? ( stash_dir )
Dir . glob ( " #{ source } / #{ posts } /*.* " ) do | post |
FileUtils . mv post , stash_dir unless post . include? ( args . filename )
end
end
desc " Move all stashed posts back into the posts directory, ready for site generation. "
task :integrate do
FileUtils . mv Dir . glob ( " #{ source } / #{ stash } /*.* " ) , " #{ source } / #{ posts } / "
end
2011-06-11 11:56:04 +00:00
##############
# Deploying #
##############
## if you're deploying with github, change the default deploy to push_github
desc " default push task "
task :push = > [ :push_rsync ] do
2009-10-19 00:07:36 +00:00
end
2011-06-11 11:56:04 +00:00
desc " Generate and deploy task "
multitask :deploy = > [ :integrate , :generate , :push ] do
end
desc " Generate jekyll site "
task :generate do
puts " # # Generating Site with Jekyll "
system " jekyll "
2009-10-31 17:52:56 +00:00
end
2011-06-11 11:56:04 +00:00
def ok_failed ( condition )
if ( condition )
puts " OK "
else
puts " FAILED "
end
end
desc " Deploy website via rsync "
task :push_rsync do
2011-06-07 14:45:01 +00:00
puts " # # Deploying website via Rsync "
2009-10-20 13:50:16 +00:00
ok_failed system ( " rsync -avz --delete #{ site } / #{ ssh_user } : #{ document_root } " )
2009-10-19 00:07:36 +00:00
end
2011-06-11 11:56:04 +00:00
desc " deploy website to github pages "
2011-04-18 03:49:30 +00:00
multitask :push_github do
2011-06-07 14:45:01 +00:00
puts " # # Deploying #{ deploy_branch } branch to Github Pages "
2009-11-24 22:40:47 +00:00
require 'git'
repo = Git . open ( '.' )
2011-06-07 14:45:01 +00:00
puts " \n # # Checking out #{ deploy_branch } branch \n "
2009-11-24 23:01:32 +00:00
repo . branch ( " #{ deploy_branch } " ) . checkout
2011-04-18 03:49:30 +00:00
( Dir [ " * " ] - [ " #{ site } " ] ) . each { | f | rm_rf ( f ) }
2009-11-24 22:40:47 +00:00
Dir [ " #{ site } /* " ] . each { | f | mv ( f , " . " ) }
2011-04-18 03:49:30 +00:00
rm_rf ( " #{ site } " )
2011-06-07 14:45:01 +00:00
puts " \n # # Moving generated / #{ site } files \n "
2009-11-24 22:40:47 +00:00
Dir [ " **/* " ] . each { | f | repo . add ( f ) }
repo . status . deleted . each { | f , s | repo . remove ( f ) }
2011-06-07 14:45:01 +00:00
puts " \n # # Commiting: Site updated at #{ Time . now . utc } \n "
2009-11-24 22:40:47 +00:00
message = ENV [ " MESSAGE " ] || " Site updated at #{ Time . now . utc } "
repo . commit ( message )
2011-06-07 14:45:01 +00:00
puts " \n # # Pushing generated / #{ site } files to #{ deploy_branch } branch \n "
2009-11-24 23:21:04 +00:00
repo . push
2011-06-07 14:45:01 +00:00
puts " \n # # Github Pages deploy complete \n "
2009-11-24 22:53:24 +00:00
repo . branch ( " #{ source_branch } " ) . checkout
2009-11-24 22:40:47 +00:00
end
2009-10-19 00:07:36 +00:00
2011-06-11 11:56:04 +00:00
desc " list tasks "
task :list do
puts " Tasks: #{ ( Rake :: Task . tasks - [ Rake :: Task [ :list ] ] ) . to_sentence } "
puts " (type rake -T for more detail) \n \n "
2010-08-03 05:10:59 +00:00
end