improved rake tasks for deployment, updated .gitignore
This commit is contained in:
parent
5d61b46358
commit
b9b9eb09c1
1
.gitignore
vendored
1
.gitignore
vendored
@ -4,6 +4,7 @@
|
|||||||
_gist_cache
|
_gist_cache
|
||||||
_code_cache
|
_code_cache
|
||||||
_assets
|
_assets
|
||||||
|
_deploy
|
||||||
public
|
public
|
||||||
source/_stash
|
source/_stash
|
||||||
vendor
|
vendor
|
||||||
|
71
Rakefile
71
Rakefile
@ -1,10 +1,11 @@
|
|||||||
require "rubygems"
|
require "rubygems"
|
||||||
require "bundler/setup"
|
require "bundler/setup"
|
||||||
|
|
||||||
site = "public" # compiled site directory
|
public_dir = "public" # compiled site directory
|
||||||
source = "source" # source file directory
|
source_dir = "source" # source file directory
|
||||||
stash = "_stash" # directory to stash posts for speedy generation
|
deploy_dir = "_deploy" # deploy directory (for Github pages deployment)
|
||||||
posts = "_posts" # directory for blog files
|
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
|
post_format = "markdown" # file format for new posts when using the post rake task
|
||||||
|
|
||||||
## -- Rsync Deploy config -- ##
|
## -- 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"
|
ssh_user = "mathisweb@imathis.com"
|
||||||
document_root = "~/dev.octopress.org/"
|
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]"
|
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|
|
task :install, :theme do |t, args|
|
||||||
# copy theme into working Jekyll directories
|
# copy theme into working Jekyll directories
|
||||||
theme = args.theme || 'classic'
|
theme = args.theme || 'classic'
|
||||||
puts "## Copying "+theme+" theme to Jekyll paths"
|
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 sass; cp -R themes/"+theme+"/sass/ sass/"
|
||||||
system "mkdir -p _plugins; cp -R themes/"+theme+"/_plugins/ _plugins/"
|
system "mkdir -p _plugins; cp -R themes/"+theme+"/_plugins/ _plugins/"
|
||||||
system "mkdir -p #{source}/#{posts}";
|
system "mkdir -p #{source_dir}/#{posts_dir}";
|
||||||
puts "## Layouts, images, and javascritps from the #{theme} theme have been installed into ./#{source}"
|
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 "## Sass stylesheet sources from the #{theme} theme have been installed into ./sass"
|
||||||
puts "## Plugins from the #{theme} theme have been installed into ./_plugins"
|
puts "## Plugins from the #{theme} theme have been installed into ./_plugins"
|
||||||
end
|
end
|
||||||
@ -48,12 +42,12 @@ task :preview do
|
|||||||
end
|
end
|
||||||
|
|
||||||
# usage rake post[my-new-post] or rake post['my new post'] or rake post (defaults to "new-post")
|
# 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|
|
task :post, :filename do |t, args|
|
||||||
require './_plugins/titlecase.rb'
|
require './_plugins/titlecase.rb'
|
||||||
args.with_defaults(:filename => 'new-post')
|
args.with_defaults(:filename => 'new-post')
|
||||||
open("#{source}/_posts/#{Time.now.strftime('%Y-%m-%d')}-#{args.filename.downcase.gsub(/[ _]/, '-')}.#{post_format}", 'w') do |post|
|
open("#{source_dir}/_posts/#{Time.now.strftime('%Y-%m-%d')}-#{args.filename.downcase.gsub(/[ _]/, '-')}.#{post_format}", 'w') do |post|
|
||||||
system "mkdir -p #{source}/#{posts}";
|
system "mkdir -p #{source_dir}/#{posts_dir}";
|
||||||
post.puts "---"
|
post.puts "---"
|
||||||
post.puts "title: #{args.filename.gsub(/[-_]/, ' ').titlecase}"
|
post.puts "title: #{args.filename.gsub(/[-_]/, ' ').titlecase}"
|
||||||
post.puts "date: #{Time.now.strftime('%Y-%m-%d %H:%M')}"
|
post.puts "date: #{Time.now.strftime('%Y-%m-%d %H:%M')}"
|
||||||
@ -65,16 +59,16 @@ end
|
|||||||
# usage rake isolate[my-post]
|
# 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."
|
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|
|
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)
|
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)
|
FileUtils.mv post, stash_dir unless post.include?(args.filename)
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
desc "Move all stashed posts back into the posts directory, ready for site generation."
|
desc "Move all stashed posts back into the posts directory, ready for site generation."
|
||||||
task :integrate do
|
task :integrate do
|
||||||
FileUtils.mv Dir.glob("#{source}/#{stash}/*.*"), "#{source}/#{posts}/"
|
FileUtils.mv Dir.glob("#{source_dir}/#{stash_dir}/*.*"), "#{source_dir}/#{posts_dir}/"
|
||||||
end
|
end
|
||||||
|
|
||||||
desc "Clean out caches: _code_cache, _gist_cache, .sass-cache"
|
desc "Clean out caches: _code_cache, _gist_cache, .sass-cache"
|
||||||
@ -112,29 +106,25 @@ end
|
|||||||
desc "Deploy website via rsync"
|
desc "Deploy website via rsync"
|
||||||
task :push_rsync do
|
task :push_rsync do
|
||||||
puts "## Deploying website via Rsync"
|
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
|
end
|
||||||
|
|
||||||
desc "deploy website to github pages"
|
desc "deploy public directory to github pages"
|
||||||
multitask :push_github do
|
multitask :push_github do
|
||||||
puts "## Deploying #{deploy_branch} branch to Github Pages "
|
puts "## Deploying branch to Github Pages "
|
||||||
require 'git'
|
(Dir["#{deploy_dir}/*"]).each { |f| rm_rf(f) }
|
||||||
repo = Git.open('.')
|
system "cp -R #{public_dir}/ #{deploy_dir}"
|
||||||
puts "\n## Checking out #{deploy_branch} branch \n"
|
puts "\n## copying #{public_dir} to #{deploy_dir}"
|
||||||
repo.branch("#{deploy_branch}").checkout
|
cd "#{deploy_dir}" do
|
||||||
(Dir["*"] - ["#{site}"]).each { |f| rm_rf(f) }
|
system "git add ."
|
||||||
Dir["#{site}/*"].each {|f| mv(f, ".")}
|
system "git add -u"
|
||||||
rm_rf("#{site}")
|
puts "\n## Commiting: Site updated at #{Time.now.utc}"
|
||||||
puts "\n## Moving generated /#{site} files \n"
|
message = "Site updated at #{Time.now.utc}"
|
||||||
Dir["**/*"].each {|f| repo.add(f) }
|
system "git commit -m '#{message}'"
|
||||||
repo.status.deleted.each {|f, s| repo.remove(f)}
|
puts "\n## Pushing generated #{deploy_dir} website"
|
||||||
puts "\n## Commiting: Site updated at #{Time.now.utc} \n"
|
system "git push"
|
||||||
message = ENV["MESSAGE"] || "Site updated at #{Time.now.utc}"
|
puts "\n## Github Pages deploy complete"
|
||||||
repo.commit(message)
|
end
|
||||||
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
|
|
||||||
end
|
end
|
||||||
|
|
||||||
|
|
||||||
@ -144,3 +134,4 @@ task :list do
|
|||||||
puts "Tasks: #{(Rake::Task.tasks - [Rake::Task[:list]]).to_sentence}"
|
puts "Tasks: #{(Rake::Task.tasks - [Rake::Task[:list]]).to_sentence}"
|
||||||
puts "(type rake -T for more detail)\n\n"
|
puts "(type rake -T for more detail)\n\n"
|
||||||
end
|
end
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user