2010-05-26 03:23:47 -04:00
require " rubygems "
2011-05-30 00:30:16 -04:00
require " bundler/setup "
2010-05-26 03:23:47 -04:00
2011-06-22 12:29:23 -04:00
## -- Rsync Deploy config -- ##
# Be sure your public key is listed in your server's ~/.ssh/authorized_keys file
2011-06-29 14:01:06 -04:00
ssh_user = " user@domain.com "
document_root = " ~/website.com/ "
deploy_default = " rsync "
# This will be configured for you when you run config_deploy
deploy_branch = " gh-pages "
2011-06-22 12:29:23 -04:00
## -- Misc Configs, you probably have no reason to changes these -- ##
2011-06-21 16:11:07 -04:00
public_dir = " public " # compiled site directory
source_dir = " source " # source file directory
deploy_dir = " _deploy " # deploy directory (for Github pages deployment)
stash_dir = " _stash " # directory to stash posts for speedy generation
posts_dir = " _posts " # directory for blog files
2011-06-29 14:01:06 -04:00
themes_dir = " .themes " # directory for blog files
2010-03-10 13:23:30 -05:00
post_format = " markdown " # file format for new posts when using the post rake task
2009-11-24 17:53:24 -05:00
2009-11-01 00:17:29 -04:00
2011-06-07 10:45:01 -04: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'
2011-07-11 11:17:15 -04:00
puts " # # Copying " + theme + " theme into ./ #{ source_dir } ./sass and ./plugins "
2011-07-11 11:55:56 -04:00
mkdir_p source_dir
cp_r " #{ themes_dir } / #{ theme } /source/. " , source_dir
mkdir_p " sass "
cp_r " #{ themes_dir } / #{ theme } /sass/. " , " sass "
mkdir_p " plugins "
cp_r " #{ themes_dir } / #{ theme } /plugins/. " , " plugins "
mkdir_p " #{ source_dir } / #{ posts_dir } "
mkdir_p public_dir
2011-06-07 10:45:01 -04:00
end
2011-06-11 07:56:04 -04:00
#######################
# Working with Jekyll #
#######################
2010-03-10 13:23:30 -05:00
2011-06-22 23:44:02 -04:00
desc " Generate jekyll site "
task :generate do
puts " # # Generating Site with Jekyll "
system " jekyll "
end
2011-06-11 07:56:04 -04: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 09:34:32 -05:00
end
2011-06-11 07:56:04 -04: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-05 22:30:03 -05:00
end
2009-12-07 11:55:13 -05:00
# usage rake post[my-new-post] or rake post['my new post'] or rake post (defaults to "new-post")
2011-06-27 22:47:40 -04:00
desc " Begin a new post in #{ source_dir } / #{ posts_dir } "
2009-12-07 11:55:13 -05:00
task :post , :filename do | t , args |
2011-04-17 23:49:30 -04:00
require './_plugins/titlecase.rb'
2009-12-07 11:55:13 -05:00
args . with_defaults ( :filename = > 'new-post' )
2011-06-21 16:11:07 -04:00
open ( " #{ source_dir } /_posts/ #{ Time . now . strftime ( '%Y-%m-%d' ) } - #{ args . filename . downcase . gsub ( / [ _] / , '-' ) } . #{ post_format } " , 'w' ) do | post |
system " mkdir -p #{ source_dir } / #{ posts_dir } " ;
2009-12-07 11:55:13 -05:00
post . puts " --- "
2011-06-17 22:24:48 -04:00
post . puts " title: #{ args . filename . gsub ( / [-_] / , ' ' ) . titlecase } "
2011-04-17 23:49:30 -04:00
post . puts " date: #{ Time . now . strftime ( '%Y-%m-%d %H:%M' ) } "
post . puts " layout: post "
2011-06-27 15:59:21 -04:00
post . puts " categories: [] "
2009-12-07 11:55:13 -05:00
post . puts " --- "
end
end
2010-01-23 15:47:43 -05: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 |
2011-06-21 16:11:07 -04:00
stash_dir = " #{ source_dir } / #{ stash_dir } "
2010-01-23 15:47:43 -05:00
FileUtils . mkdir ( stash_dir ) unless File . exist? ( stash_dir )
2011-06-21 16:11:07 -04:00
Dir . glob ( " #{ source_dir } / #{ posts_dir } /*.* " ) do | post |
2010-01-23 15:47:43 -05:00
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
2011-06-21 16:11:07 -04:00
FileUtils . mv Dir . glob ( " #{ source_dir } / #{ stash_dir } /*.* " ) , " #{ source_dir } / #{ posts_dir } / "
2010-01-23 15:47:43 -05:00
end
2011-06-17 22:24:48 -04:00
desc " Clean out caches: _code_cache, _gist_cache, .sass-cache "
task :clean do
system " rm -rf _code_cache/** _gist_cache/** .sass-cache/** "
end
2011-06-11 07:56:04 -04:00
##############
# Deploying #
##############
2011-06-29 14:01:06 -04:00
desc " Default deploy task "
task :deploy = > " #{ deploy_default } " do
end
2011-06-11 07:56:04 -04:00
desc " Deploy website via rsync "
2011-06-29 14:01:06 -04:00
task :rsync do
2011-06-07 10:45:01 -04:00
puts " # # Deploying website via Rsync "
2011-06-21 16:11:07 -04:00
ok_failed system ( " rsync -avz --delete #{ public_dir } / #{ ssh_user } : #{ document_root } " )
2009-10-18 20:07:36 -04:00
end
2011-06-21 16:11:07 -04:00
desc " deploy public directory to github pages "
2011-06-22 23:44:02 -04:00
task :push do
2011-06-21 16:11:07 -04:00
puts " # # Deploying branch to Github Pages "
( Dir [ " #{ deploy_dir } /* " ] ) . each { | f | rm_rf ( f ) }
system " cp -R #{ public_dir } / #{ deploy_dir } "
puts " \n # # copying #{ public_dir } to #{ deploy_dir } "
cd " #{ deploy_dir } " do
system " git add . "
system " git add -u "
puts " \n # # Commiting: Site updated at #{ Time . now . utc } "
message = " Site updated at #{ Time . now . utc } "
system " git commit -m ' #{ message } ' "
puts " \n # # Pushing generated #{ deploy_dir } website "
2011-06-29 14:01:06 -04:00
system " git push origin #{ deploy_branch } "
2011-06-21 16:11:07 -04:00
puts " \n # # Github Pages deploy complete "
end
2009-11-24 17:40:47 -05:00
end
2011-06-22 23:44:02 -04:00
desc " setup _deploy folder and deploy branch "
2011-06-29 14:01:06 -04:00
task :config_deploy , :branch do | t , args |
2011-06-27 22:47:40 -04:00
puts " !! Please provide a deploy branch, eg. rake init_deploy[gh-pages] !! " unless args . branch
puts " # # Creating a clean #{ args . branch } branch in ./ #{ deploy_dir } for Github pages deployment "
2011-06-27 18:17:15 -04:00
cd " #{ deploy_dir } " do
2011-06-22 23:44:02 -04:00
system " git symbolic-ref HEAD refs/heads/ #{ args . branch } "
system " rm .git/index "
system " git clean -fdx "
2011-06-27 22:47:40 -04:00
system " echo 'My Octopress Page is coming soon …' > index.html "
2011-06-22 23:44:02 -04:00
system " git add . "
2011-06-29 14:01:06 -04:00
system " git commit -m 'Octopress init' "
rakefile = IO . read ( __FILE__ )
rakefile . sub! ( / deploy_branch( \ s*)=( \ s*)(["'])[ \ w-]*["'] / , " deploy_branch \\ 1= \\ 2 \\ 3 #{ args . branch } \\ 3 " )
rakefile . sub! ( / deploy_default( \ s*)=( \ s*)(["'])[ \ w-]*["'] / , " deploy_default \\ 1= \\ 2 \\ 3push \\ 3 " )
File . open ( __FILE__ , 'w' ) do | f |
f . write rakefile
end
2011-06-22 23:44:02 -04:00
end
2011-07-11 11:17:15 -04:00
puts " # # Deployment configured. Now you can deploy to the #{ args . branch } branch with `rake deploy` # # "
2011-06-22 23:44:02 -04:00
end
2009-10-18 20:07:36 -04:00
2011-06-22 23:44:02 -04:00
def ok_failed ( condition )
if ( condition )
puts " OK "
else
puts " FAILED "
end
end
2009-10-18 20:07:36 -04:00
2011-06-11 07:56:04 -04: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 01:10:59 -04:00
end