more code docs
This commit is contained in:
parent
2b3354472c
commit
8e66929a3f
|
@ -1,30 +1,44 @@
|
||||||
#!/usr/bin/env ruby
|
#!/usr/bin/env ruby
|
||||||
|
|
||||||
require "rubygems"
|
# Add our lib/ directory to the path
|
||||||
require "pathname"
|
|
||||||
|
|
||||||
libdir = File.expand_path(File.join(File.dirname(File.dirname(__FILE__)), "lib"))
|
libdir = File.expand_path(File.join(File.dirname(File.dirname(__FILE__)), "lib"))
|
||||||
$LOAD_PATH.unshift(libdir) unless $LOAD_PATH.include?(libdir)
|
$LOAD_PATH.unshift(libdir) unless $LOAD_PATH.include?(libdir)
|
||||||
|
|
||||||
ARGV << "server" if ARGV.length < 1
|
# Setup RubyGems
|
||||||
|
require "rubygems"
|
||||||
|
|
||||||
|
# Core Pathname library used for traversal
|
||||||
|
require "pathname"
|
||||||
|
|
||||||
|
# Recursive method to find config.rb
|
||||||
def locate_middleman_root!(cwd = Pathname.new(Dir.pwd))
|
def locate_middleman_root!(cwd = Pathname.new(Dir.pwd))
|
||||||
return cwd.to_s if File.exists?(File.join(cwd, 'config.rb'))
|
return cwd.to_s if File.exists?(File.join(cwd, 'config.rb'))
|
||||||
return false if cwd.root?
|
return false if cwd.root?
|
||||||
locate_middleman_root!(cwd.parent)
|
locate_middleman_root!(cwd.parent)
|
||||||
end
|
end
|
||||||
|
|
||||||
|
# Only look for config.rb if MM_ROOT isn't set
|
||||||
if !ENV["MM_ROOT"] && found_path = locate_middleman_root!
|
if !ENV["MM_ROOT"] && found_path = locate_middleman_root!
|
||||||
ENV["MM_ROOT"] = found_path
|
ENV["MM_ROOT"] = found_path
|
||||||
end
|
end
|
||||||
|
|
||||||
|
# If we've found the root, try to setup Bundler
|
||||||
if ENV["MM_ROOT"]
|
if ENV["MM_ROOT"]
|
||||||
|
|
||||||
# Set up gems listed in the Gemfile.
|
# Set up gems listed in the Gemfile.
|
||||||
ENV['BUNDLE_GEMFILE'] ||= File.expand_path('Gemfile', ENV["MM_ROOT"])
|
ENV['BUNDLE_GEMFILE'] ||= File.expand_path('Gemfile', ENV["MM_ROOT"])
|
||||||
require 'bundler/setup' if File.exists?(ENV['BUNDLE_GEMFILE'])
|
require 'bundler/setup' if File.exists?(ENV['BUNDLE_GEMFILE'])
|
||||||
end
|
end
|
||||||
|
|
||||||
|
# Default command is server
|
||||||
|
ARGV << "server" if ARGV.length < 1
|
||||||
|
|
||||||
|
# Require Middleman
|
||||||
require 'middleman'
|
require 'middleman'
|
||||||
|
|
||||||
|
# Change directory to the root
|
||||||
Dir.chdir(ENV["MM_ROOT"] || Dir.pwd) do
|
Dir.chdir(ENV["MM_ROOT"] || Dir.pwd) do
|
||||||
|
|
||||||
|
# Start the CLI
|
||||||
Middleman::Cli::Base.start
|
Middleman::Cli::Base.start
|
||||||
end
|
end
|
|
@ -1,16 +1,23 @@
|
||||||
|
# Require thor since that's what the who CLI is built around
|
||||||
require 'thor'
|
require 'thor'
|
||||||
require "thor/group"
|
require "thor/group"
|
||||||
|
|
||||||
# CLI Module
|
# CLI Module
|
||||||
module Middleman::Cli
|
module Middleman::Cli
|
||||||
|
|
||||||
|
# The base task from which everything else etends
|
||||||
class Base < Thor
|
class Base < Thor
|
||||||
|
|
||||||
desc "version", "Show version"
|
desc "version", "Show version"
|
||||||
def version
|
def version
|
||||||
require 'middleman/version'
|
require 'middleman/version'
|
||||||
say "Middleman #{Middleman::VERSION}"
|
say "Middleman #{Middleman::VERSION}"
|
||||||
end
|
end
|
||||||
|
|
||||||
|
# Override the Thor help method to find help for subtasks
|
||||||
|
# @param [Symbol, String, nil] meth
|
||||||
|
# @param [Boolean] subcommand
|
||||||
|
# @return [void]
|
||||||
def help(meth = nil, subcommand = false)
|
def help(meth = nil, subcommand = false)
|
||||||
if meth && !self.respond_to?(meth)
|
if meth && !self.respond_to?(meth)
|
||||||
klass, task = Thor::Util.find_class_and_task_by_namespace("#{meth}:#{meth}")
|
klass, task = Thor::Util.find_class_and_task_by_namespace("#{meth}:#{meth}")
|
||||||
|
@ -28,6 +35,8 @@ module Middleman::Cli
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
|
# Intercept missing methods and search subtasks for them
|
||||||
|
# @param [Symbol] meth
|
||||||
def method_missing(meth, *args)
|
def method_missing(meth, *args)
|
||||||
meth = meth.to_s
|
meth = meth.to_s
|
||||||
|
|
||||||
|
@ -42,6 +51,7 @@ module Middleman::Cli
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
|
# Include the core CLI items
|
||||||
require "middleman/cli/init"
|
require "middleman/cli/init"
|
||||||
require "middleman/cli/server"
|
require "middleman/cli/server"
|
||||||
require "middleman/cli/build"
|
require "middleman/cli/build"
|
|
@ -1,9 +1,14 @@
|
||||||
|
# Use Rack::Test for inspecting a running server for output
|
||||||
require "rack"
|
require "rack"
|
||||||
require "rack/test"
|
require "rack/test"
|
||||||
|
|
||||||
|
# CLI Module
|
||||||
module Middleman::Cli
|
module Middleman::Cli
|
||||||
|
|
||||||
|
# The CLI Build class
|
||||||
class Build < Thor
|
class Build < Thor
|
||||||
include Thor::Actions
|
include Thor::Actions
|
||||||
|
|
||||||
check_unknown_options!
|
check_unknown_options!
|
||||||
|
|
||||||
namespace :build
|
namespace :build
|
||||||
|
@ -24,6 +29,9 @@ module Middleman::Cli
|
||||||
:aliases => "-g",
|
:aliases => "-g",
|
||||||
:default => nil,
|
:default => nil,
|
||||||
:desc => 'Build a subset of the project'
|
:desc => 'Build a subset of the project'
|
||||||
|
|
||||||
|
# Core build Thor command
|
||||||
|
# @return [void]
|
||||||
def build
|
def build
|
||||||
if !ENV["MM_ROOT"]
|
if !ENV["MM_ROOT"]
|
||||||
$stderr.puts "== Error: Could not find a Middleman project config, perhaps you are in the wrong folder?"
|
$stderr.puts "== Error: Could not find a Middleman project config, perhaps you are in the wrong folder?"
|
||||||
|
@ -40,22 +48,33 @@ module Middleman::Cli
|
||||||
opts[:glob] = options["glob"] if options.has_key?("glob")
|
opts[:glob] = options["glob"] if options.has_key?("glob")
|
||||||
opts[:clean] = options["clean"] if options.has_key?("clean")
|
opts[:clean] = options["clean"] if options.has_key?("clean")
|
||||||
|
|
||||||
action GlobAction.new(self, self.class.shared_instance, opts)
|
action GlobAction.new(self, opts)
|
||||||
|
|
||||||
self.class.shared_instance.run_hook :after_build, self
|
self.class.shared_instance.run_hook :after_build, self
|
||||||
end
|
end
|
||||||
|
|
||||||
|
# Static methods
|
||||||
class << self
|
class << self
|
||||||
|
|
||||||
|
# Middleman::Base singleton
|
||||||
|
#
|
||||||
|
# @return [Middleman::Base]
|
||||||
def shared_instance
|
def shared_instance
|
||||||
@_shared_instance ||= ::Middleman.server.inst do
|
@_shared_instance ||= ::Middleman.server.inst do
|
||||||
set :environment, :build
|
set :environment, :build
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
|
# Middleman::Base class singleton
|
||||||
|
#
|
||||||
|
# @return [Middleman::Base]
|
||||||
def shared_server
|
def shared_server
|
||||||
@_shared_server ||= shared_instance.class
|
@_shared_server ||= shared_instance.class
|
||||||
end
|
end
|
||||||
|
|
||||||
|
# Rack::Test::Session singleton
|
||||||
|
#
|
||||||
|
# @return [Rack::Test::Session]
|
||||||
def shared_rack
|
def shared_rack
|
||||||
@_shared_rack ||= begin
|
@_shared_rack ||= begin
|
||||||
mock = ::Rack::MockSession.new(shared_server.to_rack_app)
|
mock = ::Rack::MockSession.new(shared_server.to_rack_app)
|
||||||
|
@ -66,62 +85,64 @@ module Middleman::Cli
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
|
# Set the root path to the Middleman::Base's root
|
||||||
source_root(shared_instance.root)
|
source_root(shared_instance.root)
|
||||||
|
# Render a template to a file.
|
||||||
# @private
|
#
|
||||||
module ThorActions
|
# @param [String] source
|
||||||
# Render a template to a file.
|
# @param [String] destination
|
||||||
# @return [String] the actual destination file path that was created
|
# @param [Hash] config
|
||||||
def tilt_template(source, *args, &block)
|
# @return [String] the actual destination file path that was created
|
||||||
config = args.last.is_a?(Hash) ? args.pop : {}
|
desc "private method", :hide => true
|
||||||
destination = args.first || source
|
def tilt_template(source, destination, config={})
|
||||||
|
build_dir = self.class.shared_instance.build_dir
|
||||||
|
request_path = destination.sub(/^#{build_dir}/, "")
|
||||||
|
config[:force] = true
|
||||||
|
|
||||||
request_path = destination.sub(/^#{self.class.shared_instance.build_dir}/, "")
|
begin
|
||||||
|
destination, request_path = self.class.shared_instance.reroute_builder(destination, request_path)
|
||||||
|
|
||||||
begin
|
response = self.class.shared_rack.get(request_path.gsub(/\s/, "%20"))
|
||||||
destination, request_path = self.class.shared_instance.reroute_builder(destination, request_path)
|
|
||||||
|
|
||||||
response = self.class.shared_rack.get(request_path.gsub(/\s/, "%20"))
|
create_file(destination, response.body, config)
|
||||||
|
|
||||||
create_file(destination, response.body, config)
|
destination
|
||||||
|
rescue
|
||||||
destination
|
say_status :error, destination, :red
|
||||||
rescue
|
abort
|
||||||
say_status :error, destination, :red
|
|
||||||
abort
|
|
||||||
end
|
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
include ThorActions
|
|
||||||
end
|
end
|
||||||
|
|
||||||
# @private
|
# A Thor Action, modular code, which does the majority of the work.
|
||||||
class GlobAction < ::Thor::Actions::EmptyDirectory
|
class GlobAction < ::Thor::Actions::EmptyDirectory
|
||||||
attr_reader :source
|
attr_reader :source
|
||||||
|
|
||||||
def initialize(base, app, config={}, &block)
|
# Setup the action
|
||||||
@app = app
|
#
|
||||||
|
# @param [Middleman::Cli::Build] base
|
||||||
|
# @param [Hash] config
|
||||||
|
def initialize(base, config={})
|
||||||
|
@app = base.class.shared_instance
|
||||||
source = @app.source
|
source = @app.source
|
||||||
@destination = @app.build_dir
|
@destination = @app.build_dir
|
||||||
|
|
||||||
@source = File.expand_path(base.find_in_source_paths(source.to_s))
|
@source = File.expand_path(base.find_in_source_paths(source.to_s))
|
||||||
|
|
||||||
super(base, destination, config)
|
super(base, @destination, config)
|
||||||
end
|
end
|
||||||
|
|
||||||
|
# Execute the action
|
||||||
|
# @return [void]
|
||||||
def invoke!
|
def invoke!
|
||||||
queue_current_paths if cleaning?
|
queue_current_paths if cleaning?
|
||||||
execute!
|
execute!
|
||||||
clean! if cleaning?
|
clean! if cleaning?
|
||||||
end
|
end
|
||||||
|
|
||||||
def revoke!
|
|
||||||
execute!
|
|
||||||
end
|
|
||||||
|
|
||||||
protected
|
protected
|
||||||
|
# Remove files which were not built in this cycle
|
||||||
|
# @return [void]
|
||||||
def clean!
|
def clean!
|
||||||
files = @cleaning_queue.select { |q| File.file? q }
|
files = @cleaning_queue.select { |q| File.file? q }
|
||||||
directories = @cleaning_queue.select { |q| File.directory? q }
|
directories = @cleaning_queue.select { |q| File.directory? q }
|
||||||
|
@ -137,14 +158,22 @@ module Middleman::Cli
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
|
# Whether we should clean the build
|
||||||
|
# @return [Boolean]
|
||||||
def cleaning?
|
def cleaning?
|
||||||
@config.has_key?(:clean) && @config[:clean]
|
@config.has_key?(:clean) && @config[:clean]
|
||||||
end
|
end
|
||||||
|
|
||||||
|
# Whether the given directory is empty
|
||||||
|
# @param [String] directory
|
||||||
|
# @return [Boolean]
|
||||||
def directory_empty?(directory)
|
def directory_empty?(directory)
|
||||||
Dir[File.join(directory, "*")].empty?
|
Dir[File.join(directory, "*")].empty?
|
||||||
end
|
end
|
||||||
|
|
||||||
|
# Get a list of all the paths in the destination folder and save them
|
||||||
|
# for comparison against the files we build in this cycle
|
||||||
|
# @return [void]
|
||||||
def queue_current_paths
|
def queue_current_paths
|
||||||
@cleaning_queue = []
|
@cleaning_queue = []
|
||||||
Find.find(@destination) do |path|
|
Find.find(@destination) do |path|
|
||||||
|
@ -155,9 +184,15 @@ module Middleman::Cli
|
||||||
end if File.exist?(@destination)
|
end if File.exist?(@destination)
|
||||||
end
|
end
|
||||||
|
|
||||||
|
# Actually build the app
|
||||||
|
# @return [void]
|
||||||
def execute!
|
def execute!
|
||||||
|
# Sort order, images, fonts, js/css and finally everything else.
|
||||||
sort_order = %w(.png .jpeg .jpg .gif .bmp .svg .svgz .ico .woff .otf .ttf .eot .js .css)
|
sort_order = %w(.png .jpeg .jpg .gif .bmp .svg .svgz .ico .woff .otf .ttf .eot .js .css)
|
||||||
|
|
||||||
|
# Sort paths to be built by the above order. This is primarily so Compass can
|
||||||
|
# find files in the build folder when it needs to generate sprites for the
|
||||||
|
# css files
|
||||||
paths = @app.sitemap.all_paths.sort do |a, b|
|
paths = @app.sitemap.all_paths.sort do |a, b|
|
||||||
a_ext = File.extname(a)
|
a_ext = File.extname(a)
|
||||||
b_ext = File.extname(b)
|
b_ext = File.extname(b)
|
||||||
|
@ -168,29 +203,27 @@ module Middleman::Cli
|
||||||
a_idx <=> b_idx
|
a_idx <=> b_idx
|
||||||
end
|
end
|
||||||
|
|
||||||
|
# Loop over all the paths and build them.
|
||||||
paths.each do |path|
|
paths.each do |path|
|
||||||
file_source = path
|
file_source = path
|
||||||
file_destination = File.join(given_destination, file_source.gsub(source, '.'))
|
file_destination = File.join(given_destination, file_source.gsub(source, '.'))
|
||||||
file_destination.gsub!('/./', '/')
|
file_destination.gsub!('/./', '/')
|
||||||
|
|
||||||
if @app.sitemap.generic?(file_source)
|
if @app.sitemap.proxied?(file_source)
|
||||||
# no-op
|
|
||||||
elsif @app.sitemap.proxied?(file_source)
|
|
||||||
file_source = @app.sitemap.page(file_source).proxied_to
|
file_source = @app.sitemap.page(file_source).proxied_to
|
||||||
elsif @app.sitemap.ignored?(file_source)
|
elsif @app.sitemap.ignored?(file_source)
|
||||||
next
|
next
|
||||||
end
|
end
|
||||||
|
|
||||||
|
next if @config[:glob] && !File.fnmatch(@config[:glob], file_source)
|
||||||
|
|
||||||
if @config[:glob]
|
file_destination = base.tilt_template(file_source, file_destination)
|
||||||
next unless File.fnmatch(@config[:glob], file_source)
|
|
||||||
end
|
|
||||||
|
|
||||||
file_destination = base.tilt_template(file_source, file_destination, { :force => true })
|
|
||||||
|
|
||||||
@cleaning_queue.delete(file_destination) if cleaning?
|
@cleaning_queue.delete(file_destination) if cleaning?
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
|
# Alias "b" to "build"
|
||||||
Base.map({ "b" => "build" })
|
Base.map({ "b" => "build" })
|
||||||
end
|
end
|
|
@ -1,4 +1,7 @@
|
||||||
|
# CLI Module
|
||||||
module Middleman::Cli
|
module Middleman::Cli
|
||||||
|
|
||||||
|
# A thor task for creating new projects
|
||||||
class Init < Thor
|
class Init < Thor
|
||||||
check_unknown_options!
|
check_unknown_options!
|
||||||
|
|
||||||
|
@ -6,7 +9,6 @@ module Middleman::Cli
|
||||||
|
|
||||||
desc "init NAME [options]", "Create new project NAME"
|
desc "init NAME [options]", "Create new project NAME"
|
||||||
available_templates = ::Middleman::Templates.registered.keys.join(", ")
|
available_templates = ::Middleman::Templates.registered.keys.join(", ")
|
||||||
# argument :name
|
|
||||||
method_option "template",
|
method_option "template",
|
||||||
:aliases => "-T",
|
:aliases => "-T",
|
||||||
:default => "default",
|
:default => "default",
|
||||||
|
@ -28,6 +30,8 @@ module Middleman::Cli
|
||||||
:type => :boolean,
|
:type => :boolean,
|
||||||
:default => false,
|
:default => false,
|
||||||
:desc => 'Create a Gemfile and use Bundler to manage gems'
|
:desc => 'Create a Gemfile and use Bundler to manage gems'
|
||||||
|
# The init task
|
||||||
|
# @param [String] name
|
||||||
def init(name)
|
def init(name)
|
||||||
key = options[:template].to_sym
|
key = options[:template].to_sym
|
||||||
unless ::Middleman::Templates.registered.has_key?(key)
|
unless ::Middleman::Templates.registered.has_key?(key)
|
||||||
|
@ -39,6 +43,7 @@ module Middleman::Cli
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
|
# Map "i", "new" and "n" to "init"
|
||||||
Base.map({
|
Base.map({
|
||||||
"i" => "init",
|
"i" => "init",
|
||||||
"new" => "init",
|
"new" => "init",
|
||||||
|
|
|
@ -1,4 +1,7 @@
|
||||||
|
# CLI Module
|
||||||
module Middleman::Cli
|
module Middleman::Cli
|
||||||
|
|
||||||
|
# Server thor task
|
||||||
class Server < Thor
|
class Server < Thor
|
||||||
check_unknown_options!
|
check_unknown_options!
|
||||||
|
|
||||||
|
@ -22,6 +25,8 @@ module Middleman::Cli
|
||||||
:type => :boolean,
|
:type => :boolean,
|
||||||
:default => false,
|
:default => false,
|
||||||
:desc => 'Print debug messages'
|
:desc => 'Print debug messages'
|
||||||
|
|
||||||
|
# Start the server
|
||||||
def server
|
def server
|
||||||
if !ENV["MM_ROOT"]
|
if !ENV["MM_ROOT"]
|
||||||
puts "== Warning: Could not find a Middleman project config.rb"
|
puts "== Warning: Could not find a Middleman project config.rb"
|
||||||
|
@ -42,5 +47,6 @@ module Middleman::Cli
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
|
# Map "s" to "server"
|
||||||
Base.map({ "s" => "server" })
|
Base.map({ "s" => "server" })
|
||||||
end
|
end
|
|
@ -8,7 +8,12 @@ require "net/http"
|
||||||
# Support forking on Windows
|
# Support forking on Windows
|
||||||
require "win32/process" if Middleman::WINDOWS
|
require "win32/process" if Middleman::WINDOWS
|
||||||
|
|
||||||
|
# The Guard namespace
|
||||||
module Middleman::Guard
|
module Middleman::Guard
|
||||||
|
|
||||||
|
# Start guard
|
||||||
|
# @param [Hash] options
|
||||||
|
# @return [void]
|
||||||
def self.start(options={})
|
def self.start(options={})
|
||||||
# Forward CLI options to Guard
|
# Forward CLI options to Guard
|
||||||
options_hash = options.map { |k,v| ", :#{k} => '#{v}'" }.join
|
options_hash = options.map { |k,v| ", :#{k} => '#{v}'" }.join
|
||||||
|
@ -28,6 +33,7 @@ end
|
||||||
|
|
||||||
# @private
|
# @private
|
||||||
module Guard
|
module Guard
|
||||||
|
|
||||||
# Monkeypatch Guard into being quiet
|
# Monkeypatch Guard into being quiet
|
||||||
module UI
|
module UI
|
||||||
class << self
|
class << self
|
||||||
|
@ -37,17 +43,23 @@ module Guard
|
||||||
|
|
||||||
# Guards must be in the Guard module to be picked up
|
# Guards must be in the Guard module to be picked up
|
||||||
class Middleman < Guard
|
class Middleman < Guard
|
||||||
|
|
||||||
# Save the options for later
|
# Save the options for later
|
||||||
def initialize(watchers = [], options = {})
|
def initialize(watchers = [], options = {})
|
||||||
super
|
super
|
||||||
|
|
||||||
|
# Save options
|
||||||
@options = options
|
@options = options
|
||||||
end
|
end
|
||||||
|
|
||||||
# Start Middleman in a fork
|
# Start Middleman in a fork
|
||||||
|
# @return [void]
|
||||||
def start
|
def start
|
||||||
@server_job = fork { bootup }
|
@server_job = fork { bootup }
|
||||||
end
|
end
|
||||||
|
|
||||||
|
# Start an instance of Middleman::Base
|
||||||
|
# @return [void]
|
||||||
def bootup
|
def bootup
|
||||||
env = (@options[:environment] || "development").to_sym
|
env = (@options[:environment] || "development").to_sym
|
||||||
is_logging = @options.has_key?(:debug) && (@options[:debug] == "true")
|
is_logging = @options.has_key?(:debug) && (@options[:debug] == "true")
|
||||||
|
@ -66,6 +78,7 @@ module Guard
|
||||||
end
|
end
|
||||||
|
|
||||||
# Stop the forked Middleman
|
# Stop the forked Middleman
|
||||||
|
# @return [void]
|
||||||
def stop
|
def stop
|
||||||
puts "== The Middleman is shutting down"
|
puts "== The Middleman is shutting down"
|
||||||
Process.kill(::Middleman::WINDOWS ? :KILL : :TERM, @server_job)
|
Process.kill(::Middleman::WINDOWS ? :KILL : :TERM, @server_job)
|
||||||
|
@ -74,6 +87,7 @@ module Guard
|
||||||
end
|
end
|
||||||
|
|
||||||
# Simply stop, then start
|
# Simply stop, then start
|
||||||
|
# @return [void]
|
||||||
def reload
|
def reload
|
||||||
stop
|
stop
|
||||||
start
|
start
|
||||||
|
@ -81,6 +95,7 @@ module Guard
|
||||||
|
|
||||||
# What to do on file change
|
# What to do on file change
|
||||||
# @param [Array<String>] paths Array of paths that changed
|
# @param [Array<String>] paths Array of paths that changed
|
||||||
|
# @return [void]
|
||||||
def run_on_change(paths)
|
def run_on_change(paths)
|
||||||
# See if the changed file is config.rb or lib/*.rb
|
# See if the changed file is config.rb or lib/*.rb
|
||||||
return reload if needs_to_reload?(paths)
|
return reload if needs_to_reload?(paths)
|
||||||
|
@ -91,6 +106,7 @@ module Guard
|
||||||
|
|
||||||
# What to do on file deletion
|
# What to do on file deletion
|
||||||
# @param [Array<String>] paths Array of paths that were removed
|
# @param [Array<String>] paths Array of paths that were removed
|
||||||
|
# @return [void]
|
||||||
def run_on_deletion(paths)
|
def run_on_deletion(paths)
|
||||||
# See if the changed file is config.rb or lib/*.rb
|
# See if the changed file is config.rb or lib/*.rb
|
||||||
return reload if needs_to_reload?(paths)
|
return reload if needs_to_reload?(paths)
|
||||||
|
@ -99,6 +115,8 @@ module Guard
|
||||||
paths.each { |path| tell_server(:delete => path) }
|
paths.each { |path| tell_server(:delete => path) }
|
||||||
end
|
end
|
||||||
|
|
||||||
|
# What command is sent to kill instances
|
||||||
|
# @return [Symbol, Fixnum]
|
||||||
def self.kill_command
|
def self.kill_command
|
||||||
::Middleman::WINDOWS ? 1 : :INT
|
::Middleman::WINDOWS ? 1 : :INT
|
||||||
end
|
end
|
||||||
|
@ -115,6 +133,7 @@ module Guard
|
||||||
|
|
||||||
# Send a message to the running server
|
# Send a message to the running server
|
||||||
# @param [Hash] params Keys to be hashed and sent to server
|
# @param [Hash] params Keys to be hashed and sent to server
|
||||||
|
# @return [void]
|
||||||
def tell_server(params={})
|
def tell_server(params={})
|
||||||
uri = URI.parse("http://#{@options[:host]}:#{@options[:port]}/__middleman__")
|
uri = URI.parse("http://#{@options[:host]}:#{@options[:port]}/__middleman__")
|
||||||
Net::HTTP.post_form(uri, {}.merge(params))
|
Net::HTTP.post_form(uri, {}.merge(params))
|
||||||
|
|
Loading…
Reference in a new issue