aboutsummaryrefslogtreecommitdiff
path: root/Rakefile
diff options
context:
space:
mode:
Diffstat (limited to 'Rakefile')
-rw-r--r--Rakefile129
1 files changed, 35 insertions, 94 deletions
diff --git a/Rakefile b/Rakefile
index c6fca785..634f6d48 100644
--- a/Rakefile
+++ b/Rakefile
@@ -2,11 +2,8 @@ require "rubygems"
require "bundler"
Bundler.setup
-require 'source/_helpers'
-
-site_url = "http://yoursite.com" # deployed site url for sitemap.xml generator
port = "4000" # preview project port eg. http://localhost:4000
-site = "site" # compiled site directory
+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
@@ -19,6 +16,7 @@ document_root = "~/document_root/" # for rsync deployment
## -- 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 below to :push_github
# If you're not using this, you can remove it
source_branch = "source" # this compiles to your deploy branch
deploy_branch = "master" # For user pages, use "master" for project pages use "gh-pages"
@@ -32,13 +30,13 @@ def ok_failed(condition)
end
end
-## if you're deploying with github, change the default deploy to deploy_github
-desc "default deploy task"
-task :deploy => [:deploy_rsync] do
+## if you're deploying with github, change the default deploy to push_github
+desc "default push task"
+task :push => [:push_rsync] do
end
desc "Generate and deploy task"
-task :generate_deploy => [:integrate, :generate, :clean_debug, :deploy] do
+task :deploy => [:integrate, :generate, :clean_debug, :push] do
end
desc "generate website in output directory"
@@ -49,10 +47,13 @@ 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"
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_%H-%M')}-#{args.filename.downcase.gsub(/[ _]/, '-')}.#{post_format}", 'w') do |post|
+ open("#{source}/_posts/#{Time.now.strftime('%Y-%m-%d')}-#{args.filename.downcase.gsub(/[ _]/, '-')}.#{post_format}", 'w') do |post|
post.puts "---"
post.puts "title: \"#{args.filename.gsub(/[-_]/, ' ').titlecase}\""
+ post.puts "date: #{Time.now.strftime('%Y-%m-%d %H:%M')}"
+ post.puts "layout: post"
post.puts "---"
end
end
@@ -98,124 +99,64 @@ end
desc "Generate site files only"
task :generate_site => [:clean, :generate_style] do
puts "\n\n>>> Generating site files <<<"
- system "jekyll --pygments"
- system "mv #{site}/atom.html #{site}/atom.xml"
-end
-
-def rebuild_site(relative)
- puts "\n\n>>> Change Detected to: #{relative} <<<"
- IO.popen('rake generate_site'){|io| print(io.readpartial(512)) until io.eof?}
- puts '>>> Update Complete <<<'
-end
-
-def rebuild_style(relative)
- puts "\n\n>>> Change Detected to: #{relative} <<<"
- IO.popen('rake generate_style'){|io| print(io.readpartial(512)) until io.eof?}
- puts '>>> Update Complete <<<'
+ system "jekyll"
end
desc "Watch the site and regenerate when it changes"
task :watch do
- require 'fssm'
- puts ">>> Watching for Changes <<<"
- FSSM.monitor do
- path "#{File.dirname(__FILE__)}/#{source}" do
- update {|base, relative| rebuild_site(relative)}
- delete {|base, relative| rebuild_site(relative)}
- create {|base, relative| rebuild_site(relative)}
- end
- path "#{File.dirname(__FILE__)}/stylesheets" do
- glob '**/*.sass'
- update {|base, relative| rebuild_style(relative)}
- delete {|base, relative| rebuild_style(relative)}
- create {|base, relative| rebuild_style(relative)}
- end
- end
+ system "trap 'kill $jekyllPid $guardPid' Exit; guard & guardPid=$!; jekyll --auto & jekyllPid=$!; wait"
end
desc "generate and deploy website via rsync"
-multitask :deploy_rsync do
- puts ">>> Deploying website to #{site_url} <<<"
+multitask :push_rsync do
+ puts ">>> Deploying website via Rsync <<<"
ok_failed system("rsync -avz --delete #{site}/ #{ssh_user}:#{document_root}")
end
-desc "generate and deploy website to github user pages"
-multitask :deploy_github do
+desc "deploy website to github user 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| rm_rf(f) }
Dir["#{site}/*"].each {|f| mv(f, ".")}
- rm_rf(site)
- puts "\n>>> Moving generated site files <<<\n"
+ 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 to #{deploy_branch} branch <<<\n"
+ 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
-desc "start up an instance of serve on the output files"
-task :start_serve => :stop_serve do
- cd "#{site}" do
- print "Starting serve..."
- system("serve #{port} > /dev/null 2>&1 &")
- sleep 1
- pid = `ps auxw | awk '/bin\\/serve\\ #{port}/ { print $2 }'`.strip
- ok_failed !pid.empty?
- system "open http://localhost:#{port}" unless pid.empty?
- end
+desc "start up a web server on the output files"
+task :start_server => :stop_server do
+ print "Starting serve..."
+ system("serve #{site} #{port} > /dev/null 2>&1 &")
+ sleep 1
+ pid = `ps auxw | awk '/bin\\/serve #{site} #{port}/ { print $2 }'`.strip
+ ok_failed !pid.empty?
+ system "open http://localhost:#{port}" unless pid.empty?
end
-desc "stop all instances of serve"
-task :stop_serve do
- pid = `ps auxw | awk '/bin\\/serve\\ #{port}/ { print $2 }'`.strip
+desc "stop the web server"
+task :stop_server do
+ pid = `ps auxw | awk '/bin\\/serve #{site} #{port}/ { print $2 }'`.strip
if pid.empty?
- puts "Serve is not running"
+ puts "Adsf is not running"
else
- print "Stoping serve..."
+ print "Stoping adsf..."
ok_failed system("kill -9 #{pid}")
end
end
desc "preview the site in a web browser"
-task :preview => [:generate, :start_serve, :watch]
-
-desc "Build an XML sitemap of all html files."
-task :sitemap do
- html_files = FileList.new("#{site}/**/*.html").map{|f| f[("#{site}".size)..-1]}.map do |f|
- if f.ends_with?("index.html")
- f[0..(-("index.html".size + 1))]
- else
- f
- end
- end.sort_by{|f| f.size}
- open("#{site}/sitemap.xml", 'w') do |sitemap|
- sitemap.puts %Q{<?xml version="1.0" encoding="UTF-8"?>}
- sitemap.puts %Q{<urlset xmlns="http://www.sitemaps.org/schemas/sitemap/0.9">}
- html_files.each do |f|
- priority = case f
- when %r{^/$}
- 1.0
- when %r{^/articles}
- 0.9
- else
- 0.8
- end
- sitemap.puts %Q{ <url>}
- sitemap.puts %Q{ <loc>#{site_url}#{f}</loc>}
- sitemap.puts %Q{ <lastmod>#{Time.now.strftime('%Y-%m-%d')}</lastmod>}
- sitemap.puts %Q{ <changefreq>weekly</changefreq>}
- sitemap.puts %Q{ <priority>#{priority}</priority>}
- sitemap.puts %Q{ </url>}
- end
- sitemap.puts %Q{</urlset>}
- puts "Created #{site}/sitemap.xml"
- end
+task :preview do
+ system "trap 'kill $servePid $jekyllPid $guardPid' Exit; serve #{site} #{port} > /dev/null 2>&1 & servePid=$!; jekyll --auto & jekyllPid=$!; guard & guardPid=$!; compass compile; open http://localhost:#{port}; wait"
end