Support for Framework Patterns.

A pattern is a folder in the framework's templates directory. It must
have a manifest file that tells compass what to install and where.
Unlike the project template, a pattern can be stamped out any number of
times.

It is best for pattern stylesheets to only provide example usage to get
the user started. All the core styles for the pattern should be
distributed as part of the framework's stylesheets as mixins to
facilitate easy upgrades and bug fixing on the part of the pattern's
maintainer.

Patterns can install stylesheets, images, javascripts, and arbitrary
files. The installer will put these assets into the correct locations
according to the project type (E.g. rails, stand-alone).

Example Usage:
compass --framework blueprint --pattern buttons
This commit is contained in:
Chris Eppstein 2009-04-03 01:06:23 -07:00
parent fbd6f55c56
commit e18ed8118b
7 changed files with 84 additions and 37 deletions

View File

@ -1,39 +1,18 @@
require 'fileutils' require 'fileutils'
require File.join(File.dirname(__FILE__), 'base') require File.join(File.dirname(__FILE__), 'stamp_pattern')
require File.join(File.dirname(__FILE__), 'update_project') require File.join(File.dirname(__FILE__), 'update_project')
require File.join(Compass.lib_directory, 'compass', 'installers') require File.join(Compass.lib_directory, 'compass', 'installers')
module Compass module Compass
module Commands module Commands
class CreateProject < ProjectBase class CreateProject < StampPattern
include Compass::Installers
attr_accessor :installer
def initialize(working_path, options) def initialize(working_path, options)
super(working_path, options) super(working_path, options.merge(:pattern => "project", :pattern_name => nil))
installer_args = [project_template_directory, project_directory, self.options]
@installer = case options[:project_type]
when :stand_alone
StandAloneInstaller.new *installer_args
when :rails
RailsInstaller.new *installer_args
else
raise "Unknown project type: #{project_type}"
end
end end
# all commands must implement perform def is_project_creation?
def perform true
installer.init
installer.run(:skip_finalization => true)
UpdateProject.new(working_path, options).perform if installer.compilation_required?
installer.finalize(:create => true)
end
def project_template_directory
File.join(framework.templates_directory, "project")
end end
end end

View File

@ -0,0 +1,45 @@
require 'fileutils'
require File.join(File.dirname(__FILE__), 'base')
require File.join(File.dirname(__FILE__), 'update_project')
require File.join(Compass.lib_directory, 'compass', 'installers')
module Compass
module Commands
class StampPattern < ProjectBase
include Compass::Installers
attr_accessor :installer
def initialize(working_path, options)
super(working_path, options)
installer_args = [template_directory(options[:pattern]), project_directory, self.options]
@installer = case options[:project_type]
when :stand_alone
StandAloneInstaller.new *installer_args
when :rails
RailsInstaller.new *installer_args
else
raise "Unknown project type: #{project_type}"
end
end
# all commands must implement perform
def perform
installer.init
installer.run(:skip_finalization => true)
UpdateProject.new(working_path, options).perform if installer.compilation_required?
installer.finalize(:create => is_project_creation?)
end
def is_project_creation?
false
end
def template_directory(pattern)
File.join(framework.templates_directory, pattern)
end
end
end
end

View File

@ -162,6 +162,15 @@ END
self.options[:command] = :validate_project self.options[:command] = :validate_project
end end
opts.on('-p', '--pattern PATTERN', 'Stamp out a pattern into the current project. Must be used in combination with -f.') do |pattern|
self.options[:command] = :stamp_pattern
self.options[:pattern] = pattern
end
opts.on('-n', '--pattern-name NAME', 'The name to use when stamping a pattern. Must be used in combination with -p.') do |name|
self.options[:pattern_name] = name
end
opts.on_tail("-?", "-h", "--help", "Show this message") do opts.on_tail("-?", "-h", "--help", "Show this message") do
puts opts puts opts
exit exit

View File

@ -26,6 +26,18 @@ module Compass
# Initializes the project to work with compass # Initializes the project to work with compass
def init def init
dirs = manifest.map do |entry|
File.dirname(send("install_location_for_#{entry.type}", entry.to))
end
if manifest.has_stylesheet?
dirs << sass_dir
dirs << css_dir
end
dirs.uniq.sort.each do |dir|
directory targetize(dir)
end
end end
# Runs the installer. # Runs the installer.
@ -81,6 +93,10 @@ module Compass
false false
end end
def pattern_name_as_dir
"#{options[:pattern_name]}/" if options[:pattern_name]
end
def self.installer(type, &locator) def self.installer(type, &locator)
locator ||= lambda{|to| to} locator ||= lambda{|to| to}
loc_method = "install_location_for_#{type}".to_sym loc_method = "install_location_for_#{type}".to_sym
@ -91,7 +107,7 @@ module Compass
end end
installer :stylesheet do |to| installer :stylesheet do |to|
"#{sass_dir}/#{to}" "#{sass_dir}/#{pattern_name_as_dir}#{to}"
end end
installer :image do |to| installer :image do |to|
@ -102,7 +118,9 @@ module Compass
"#{javascripts_dir}/#{to}" "#{javascripts_dir}/#{to}"
end end
installer :file installer :file do |to|
"#{pattern_name_as_dir}#{to}"
end
# returns an absolute path given a path relative to the current installation target. # returns an absolute path given a path relative to the current installation target.
# Paths can use unix style "/" and will be corrected for the current platform. # Paths can use unix style "/" and will be corrected for the current platform.

View File

@ -2,6 +2,7 @@ module Compass
module Installers module Installers
class Manifest class Manifest
include Enumerable
# A Manifest entry # A Manifest entry
class Entry < Struct.new(:type, :from, :options) class Entry < Struct.new(:type, :from, :options)

View File

@ -16,12 +16,11 @@ module Compass
def init def init
set_sass_dir unless sass_dir set_sass_dir unless sass_dir
set_css_dir unless css_dir set_css_dir unless css_dir
directory targetize(css_dir) super
directory targetize(sass_dir)
write_file targetize('config/initializers/compass.rb'), initializer_contents
end end
def prepare def prepare
write_file targetize('config/initializers/compass.rb'), initializer_contents
end end
def finalize(options = {}) def finalize(options = {})

View File

@ -14,13 +14,10 @@ module Compass
def init def init
directory targetize("") directory targetize("")
directory targetize(css_dir) super
directory targetize(sass_dir)
end end
def prepare def prepare
directory targetize(images_dir) if manifest.has_image?
directory targetize(javascripts_dir) if manifest.has_javascript?
end end
def default_css_dir def default_css_dir
@ -61,10 +58,9 @@ This can be done in one of the following ways:
compass -u path/to/project compass -u path/to/project
3. To monitor your project for changes and automatically recompile: 3. To monitor your project for changes and automatically recompile:
compass --watch [path/to/project] compass --watch [path/to/project]
NEXTSTEPS NEXTSTEPS
end end
puts "To import your new stylesheets add the following lines of HTML (or equivalent) to your webpage:" puts "\nTo import your new stylesheets add the following lines of HTML (or equivalent) to your webpage:"
puts stylesheet_links puts stylesheet_links
end end