require File.join(File.dirname(__FILE__), 'vendor/gems/environment') require 'nanoc3/tasks' $: << "lib" desc "watch for changes and recompile" task :watch do require 'fssm' require 'nanoc3' require 'nanoc3/cli' Dir['lib/commands/*.rb'].map{|d| d[4..-1]}.sort.each { |f| require f } Dir['lib/data_sources/*.rb'].map{|d| d[4..-1]}.sort.each { |f| require f } Nanoc3::NotificationCenter.on(:compilation_started) do |rep| puts "Compiling: #{rep.path}" end rebuild_site = lambda do |base, relative| if relative puts ">>> Change Detected to #{relative} <<<" else puts ">>> Compiling <<<" end start = Time.now # Nanoc3::CLI::Base.new.run(["co"]) site = Nanoc3::Site.new('.') site.load_data begin site.compiler.run puts ">>> Done in #{((Time.now - start)*10000).round.to_f / 10}ms <<<" `growlnotify -m "Compilation Complete" --image misc/success-icon.png; exit 0` rescue Exception => e puts ">>> ERROR: #{e.message} <<<" puts e.backtrace.join("\n") `growlnotify -m "Compilation Error!" --image misc/error-icon.png; exit 0` end end rebuild_site.call(nil,nil) puts ">>> Watching for Changes <<<" puts "Run: ./bin/serve .." monitor = FSSM::Monitor.new monitor.path("#{File.dirname(__FILE__)}/content", '**/*') do update(&rebuild_site) delete(&rebuild_site) create(&rebuild_site) end monitor.path("#{File.dirname(__FILE__)}/lib", '**/*') do update(&rebuild_site) delete(&rebuild_site) create(&rebuild_site) end monitor.path("#{File.dirname(__FILE__)}/layouts", '**/*') do update(&rebuild_site) delete(&rebuild_site) create(&rebuild_site) end monitor.path("#{File.dirname(__FILE__)}/assets", '**/*') do update(&rebuild_site) delete(&rebuild_site) create(&rebuild_site) end monitor.run end