aboutsummaryrefslogtreecommitdiff
path: root/Rakefile
diff options
context:
space:
mode:
authorBrandon Mathis <brandon@imathis.com>2011-06-21 16:11:07 -0400
committerBrandon Mathis <brandon@imathis.com>2011-06-21 16:11:07 -0400
commitb9b9eb09c1b3e2fbb309adfe7ebbe236f6d5c9e4 (patch)
tree687d43da333827f626990173fa7ffb307eebf121 /Rakefile
parent5d61b463580584755bc6a45ac3212b3b08409dda (diff)
downloadmy_new_personal_website-b9b9eb09c1b3e2fbb309adfe7ebbe236f6d5c9e4.tar.xz
my_new_personal_website-b9b9eb09c1b3e2fbb309adfe7ebbe236f6d5c9e4.zip
improved rake tasks for deployment, updated .gitignore
Diffstat (limited to 'Rakefile')
-rw-r--r--Rakefile71
1 files changed, 31 insertions, 40 deletions
diff --git a/Rakefile b/Rakefile
index 8ad79319..a7d570de 100644
--- a/Rakefile
+++ b/Rakefile
@@ -1,10 +1,11 @@
require "rubygems"
require "bundler/setup"
-site = "public" # compiled site directory
-source = "source" # source file directory
-stash = "_stash" # directory to stash posts for speedy generation
-posts = "_posts" # directory for blog files
+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
post_format = "markdown" # file format for new posts when using the post rake task
## -- Rsync Deploy config -- ##
@@ -12,23 +13,16 @@ post_format = "markdown" # file format for new posts when using the post rake t
ssh_user = "mathisweb@imathis.com"
document_root = "~/dev.octopress.org/"
-## -- Github Pages deploy config -- ##
-# Read http://pages.github.com for guidance
-# You can deploy to github pages with `rake push_github` or change the default push task to :push_github
-source_branch = "source" # this compiles to your deploy branch
-deploy_branch = "master" # For user pages, use "master" for project pages use "gh-pages"
-
-
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"
- system "mkdir -p #{source}; cp -R themes/"+theme+"/source/ #{source}/"
+ system "mkdir -p #{source_dir}; cp -R themes/"+theme+"/source/ #{source_dir}/"
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}"
+ system "mkdir -p #{source_dir}/#{posts_dir}";
+ puts "## Layouts, images, and javascritps from the #{theme} theme have been installed into ./#{source_dir}"
puts "## Sass stylesheet sources from the #{theme} theme have been installed into ./sass"
puts "## Plugins from the #{theme} theme have been installed into ./_plugins"
end
@@ -48,12 +42,12 @@ task :preview do
end
# 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"
+desc "Begin a new post in #{source_dir}/_posts"
task :post, :filename do |t, args|
require './_plugins/titlecase.rb'
args.with_defaults(:filename => 'new-post')
- open("#{source}/_posts/#{Time.now.strftime('%Y-%m-%d')}-#{args.filename.downcase.gsub(/[ _]/, '-')}.#{post_format}", 'w') do |post|
- system "mkdir -p #{source}/#{posts}";
+ 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}";
post.puts "---"
post.puts "title: #{args.filename.gsub(/[-_]/, ' ').titlecase}"
post.puts "date: #{Time.now.strftime('%Y-%m-%d %H:%M')}"
@@ -65,16 +59,16 @@ end
# 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}"
+ stash_dir = "#{source_dir}/#{stash_dir}"
FileUtils.mkdir(stash_dir) unless File.exist?(stash_dir)
- Dir.glob("#{source}/#{posts}/*.*") do |post|
+ Dir.glob("#{source_dir}/#{posts_dir}/*.*") 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}/"
+ FileUtils.mv Dir.glob("#{source_dir}/#{stash_dir}/*.*"), "#{source_dir}/#{posts_dir}/"
end
desc "Clean out caches: _code_cache, _gist_cache, .sass-cache"
@@ -112,29 +106,25 @@ end
desc "Deploy website via rsync"
task :push_rsync do
puts "## Deploying website via Rsync"
- ok_failed system("rsync -avz --delete #{site}/ #{ssh_user}:#{document_root}")
+ ok_failed system("rsync -avz --delete #{public_dir}/ #{ssh_user}:#{document_root}")
end
-desc "deploy website to github pages"
+desc "deploy public directory to github pages"
multitask :push_github do
- puts "## Deploying #{deploy_branch} branch to Github Pages "
- require 'git'
- repo = Git.open('.')
- puts "\n## Checking out #{deploy_branch} branch \n"
- repo.branch("#{deploy_branch}").checkout
- (Dir["*"] - ["#{site}"]).each { |f| rm_rf(f) }
- Dir["#{site}/*"].each {|f| mv(f, ".")}
- rm_rf("#{site}")
- puts "\n## Moving generated /#{site} files \n"
- Dir["**/*"].each {|f| repo.add(f) }
- repo.status.deleted.each {|f, s| repo.remove(f)}
- puts "\n## Commiting: Site updated at #{Time.now.utc} \n"
- message = ENV["MESSAGE"] || "Site updated at #{Time.now.utc}"
- repo.commit(message)
- puts "\n## Pushing generated /#{site} files to #{deploy_branch} branch\n"
- repo.push
- puts "\n## Github Pages deploy complete\n"
- repo.branch("#{source_branch}").checkout
+ 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"
+ system "git push"
+ puts "\n## Github Pages deploy complete"
+ end
end
@@ -144,3 +134,4 @@ task :list do
puts "Tasks: #{(Rake::Task.tasks - [Rake::Task[:list]]).to_sentence}"
puts "(type rake -T for more detail)\n\n"
end
+