middleman/lib/middleman.rb

189 lines
6.3 KiB
Ruby
Raw Normal View History

2011-07-26 21:05:13 -07:00
# Setup our load paths
libdir = File.dirname(__FILE__)
$LOAD_PATH.unshift(libdir) unless $LOAD_PATH.include?(libdir)
2011-02-10 23:14:33 -08:00
# Top-level Middleman object
2010-03-02 22:00:46 -08:00
module Middleman
2011-02-10 23:14:33 -08:00
# Auto-load modules on-demand
2011-11-07 22:34:02 -08:00
autoload :Base, "middleman/base"
2011-11-19 18:53:18 -08:00
autoload :Cache, "middleman/cache"
2011-11-07 22:34:02 -08:00
autoload :Builder, "middleman/builder"
autoload :CLI, "middleman/cli"
autoload :Templates, "middleman/templates"
autoload :Guard, "middleman/guard"
2011-02-10 23:14:33 -08:00
# Custom Renderers
module Renderers
autoload :Haml, "middleman/renderers/haml"
autoload :Sass, "middleman/renderers/sass"
autoload :Markdown, "middleman/renderers/markdown"
2011-10-27 09:24:48 -07:00
autoload :ERb, "middleman/renderers/erb"
autoload :Liquid, "middleman/renderers/liquid"
end
module Sitemap
autoload :Store, "middleman/sitemap/store"
autoload :Page, "middleman/sitemap/page"
autoload :Template, "middleman/sitemap/template"
end
2011-11-23 21:59:53 -08:00
module CoreExtensions
2011-11-08 15:38:15 -08:00
# File Change Notifier
2011-11-07 22:34:02 -08:00
autoload :FileWatcher, "middleman/core_extensions/file_watcher"
2011-11-08 15:38:15 -08:00
# In-memory Sitemap
autoload :Sitemap, "middleman/core_extensions/sitemap"
2011-11-07 22:34:02 -08:00
# Add Builder callbacks
autoload :Builder, "middleman/core_extensions/builder"
# Custom Feature API
autoload :Extensions, "middleman/core_extensions/extensions"
2011-07-06 10:40:17 -07:00
# Asset Path Pipeline
autoload :Assets, "middleman/core_extensions/assets"
# DefaultHelpers are the built-in dynamic template helpers.
autoload :DefaultHelpers, "middleman/core_extensions/default_helpers"
# Data looks at the data/ folder for YAML files and makes them available
# to dynamic requests.
autoload :Data, "middleman/core_extensions/data"
# Parse YAML from templates
autoload :FrontMatter, "middleman/core_extensions/front_matter"
# Extended version of Padrino's rendering
autoload :Rendering, "middleman/core_extensions/rendering"
# Compass framework for Sass
autoload :Compass, "middleman/core_extensions/compass"
# Sprockets 2
autoload :Sprockets, "middleman/core_extensions/sprockets"
2011-07-06 10:46:06 -07:00
# Pass custom options to views
autoload :Routing, "middleman/core_extensions/routing"
end
module Extensions
# RelativeAssets allow any asset path in dynamic templates to be either
# relative to the root of the project or use an absolute URL.
autoload :RelativeAssets, "middleman/extensions/relative_assets"
2011-07-10 13:55:40 -07:00
# AssetHost allows you to setup multiple domains to host your static
# assets. Calls to asset paths in dynamic templates will then rotate
# through each of the asset servers to better spread the load.
autoload :AssetHost, "middleman/extensions/asset_host"
# CacheBuster adds a query string to assets in dynamic templates to avoid
# browser caches failing to update to your new content.
autoload :CacheBuster, "middleman/extensions/cache_buster"
2011-07-10 13:55:40 -07:00
# AutomaticImageSizes inspects the images used in your dynamic templates
# and automatically adds width and height attributes to their HTML
# elements.
autoload :AutomaticImageSizes, "middleman/extensions/automatic_image_sizes"
# MinifyCss uses the YUI compressor to shrink CSS files
autoload :MinifyCss, "middleman/extensions/minify_css"
# MinifyJavascript uses the YUI compressor to shrink JS files
autoload :MinifyJavascript, "middleman/extensions/minify_javascript"
2011-07-10 13:55:40 -07:00
# Lorem provides a handful of helpful prototyping methods to generate
# words, paragraphs, fake images, names and email addresses.
autoload :Lorem, "middleman/extensions/lorem"
2011-07-13 18:45:15 -07:00
# Automatically convert filename.html files into filename/index.html
autoload :DirectoryIndexes, "middleman/extensions/directory_indexes"
2011-11-08 00:00:33 -08:00
# Organize the sitemap as a tree
autoload :SitemapTree, "middleman/extensions/sitemap_tree"
end
2011-11-23 21:59:53 -08:00
# Where to look in gems for extensions to auto-register
EXTENSION_FILE = File.join("lib", "middleman_extension.rb")
2011-11-23 21:59:53 -08:00
2011-11-20 21:21:19 -08:00
class << self
2011-11-23 21:59:53 -08:00
# Automatically load extensions from available RubyGems
# which contain the EXTENSION_FILE
#
# @private
2011-11-20 21:21:19 -08:00
def load_extensions_in_path
extensions = rubygems_latest_specs.select do |spec|
spec_has_file?(spec, EXTENSION_FILE)
end
2011-08-18 17:33:45 -07:00
2011-11-20 21:21:19 -08:00
extensions.each do |spec|
require spec.name
end
2011-08-18 17:33:45 -07:00
end
2011-11-23 21:59:53 -08:00
# Backwards compatible means of finding all the latest gemspecs
# available on the system
#
# @private
# @return [Array] Array of latest Gem::Specification
2011-11-20 21:21:19 -08:00
def rubygems_latest_specs
# If newer Rubygems
if ::Gem::Specification.respond_to? :latest_specs
::Gem::Specification.latest_specs
else
::Gem.source_index.latest_specs
end
2011-08-29 11:53:11 -07:00
end
2011-11-23 21:59:53 -08:00
# Where a given Gem::Specification has a specific file. Used
# to discover extensions and Sprockets-supporting gems.
#
# @private
# @param [Gem::Specification]
# @param [String] Path to look for
# @return [Boolean] Whether the file exists
2011-11-20 21:21:19 -08:00
def spec_has_file?(spec, path)
full_path = File.join(spec.full_gem_path, path)
File.exists?(full_path)
end
2011-08-29 11:53:11 -07:00
2011-11-23 21:59:53 -08:00
# Create a new Class which is based on Middleman::Base
# Used to create a safe sandbox into which extensions and
# configuration can be included later without impacting
# other classes and instances.
#
# @return [Class]
2011-11-20 21:21:19 -08:00
def server(&block)
Class.new(Middleman::Base)
end
2011-08-09 14:37:55 -07:00
2011-11-23 21:59:53 -08:00
# Creates a new Rack::Server
#
# @param [Hash] options to pass to Rack::Server.new
# @return [Rack::Server]
2011-11-20 21:21:19 -08:00
def start_server(options={})
opts = {
:Port => options[:port] || 4567,
2011-11-23 22:05:53 -08:00
:Host => options[:host] || "0.0.0.0",
2011-11-20 21:21:19 -08:00
:AccessLog => []
}
2011-08-09 14:37:55 -07:00
2011-11-27 22:04:19 -08:00
app_class = options[:app] ||= ::Middleman.server.inst
2011-11-20 21:21:19 -08:00
opts[:app] = app_class
opts[:server] = 'thin'
2011-11-11 12:31:28 -08:00
2011-11-20 21:21:19 -08:00
# require "thin"
# ::Thin::Logging.silent = true if options[:debug] != "true"
2011-08-09 14:55:48 -07:00
2011-11-20 21:21:19 -08:00
server = ::Rack::Server.new(opts)
server.start
server
end
2011-08-09 14:37:55 -07:00
end
2010-08-06 09:59:38 -07:00
end
2011-11-23 21:59:53 -08:00
# Make the VERSION string available
require "middleman/version"
2011-11-23 21:59:53 -08:00
# Automatically discover extensions in RubyGems
2011-11-07 17:58:07 -08:00
Middleman.load_extensions_in_path