[Command Line] Ability to create a bare project with no stylesheets provided.
This commit is contained in:
parent
563c4cf43e
commit
853e97f2e4
@ -59,3 +59,17 @@ Feature: Command Line
|
|||||||
And I am told how to link to /stylesheets/print.css for media "print"
|
And I am told how to link to /stylesheets/print.css for media "print"
|
||||||
And I am told how to conditionally link "IE" to /stylesheets/ie.css for media "screen, projection"
|
And I am told how to conditionally link "IE" to /stylesheets/ie.css for media "screen, projection"
|
||||||
|
|
||||||
|
Scenario: Creating a bare project
|
||||||
|
When I run: compass create bare_project --bare
|
||||||
|
Then a directory bare_project/ is created
|
||||||
|
And a configuration file bare_project/config.rb is created
|
||||||
|
And a directory custom_project/src/ is created
|
||||||
|
And a directory custom_project/stylesheets/ is not created
|
||||||
|
And I am congratulated
|
||||||
|
And I am told where to place stylesheets
|
||||||
|
And how to compile them
|
||||||
|
|
||||||
|
Scenario: Creating a bare project with a framework
|
||||||
|
When I run: compass create bare_project --using blueprint --bare
|
||||||
|
Then an error message is printed out: A bare project cannot be created when a framework is specified.
|
||||||
|
And the command exits with a non-zero error code
|
||||||
|
@ -51,3 +51,25 @@ end
|
|||||||
Then /I am told how to conditionally link "([^"]+)" to ([^ ]+) for media "([^"]+)"/ do |condition, stylesheet, media|
|
Then /I am told how to conditionally link "([^"]+)" to ([^ ]+) for media "([^"]+)"/ do |condition, stylesheet, media|
|
||||||
@last_result.should =~ %r{<!--\[if #{condition}\]>\s+<link href="#{stylesheet}" media="#{media}" rel="stylesheet" type="text/css" />\s+<!\[endif\]-->}mi
|
@last_result.should =~ %r{<!--\[if #{condition}\]>\s+<link href="#{stylesheet}" media="#{media}" rel="stylesheet" type="text/css" />\s+<!\[endif\]-->}mi
|
||||||
end
|
end
|
||||||
|
|
||||||
|
Then /^an error message is printed out: (.+)$/ do |error_message|
|
||||||
|
@last_error.should =~ Regexp.new(Regexp.escape(error_message))
|
||||||
|
end
|
||||||
|
|
||||||
|
Then /^the command exits with a non\-zero error code$/ do
|
||||||
|
@last_exit_code.should_not == 0
|
||||||
|
end
|
||||||
|
|
||||||
|
|
||||||
|
Then /^I am congratulated$/ do
|
||||||
|
pending
|
||||||
|
end
|
||||||
|
|
||||||
|
Then /^I am told where to place stylesheets$/ do
|
||||||
|
pending
|
||||||
|
end
|
||||||
|
|
||||||
|
Then /^how to compile them$/ do
|
||||||
|
pending
|
||||||
|
end
|
||||||
|
|
||||||
|
@ -2,11 +2,13 @@ module Compass
|
|||||||
module Installers
|
module Installers
|
||||||
class Base
|
class Base
|
||||||
end
|
end
|
||||||
|
class ManifestInstaller < Base
|
||||||
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
module AppIntegration
|
module AppIntegration
|
||||||
module Rails
|
module Rails
|
||||||
class Installer < Compass::Installers::Base
|
class Installer < Compass::Installers::ManifestInstaller
|
||||||
|
|
||||||
def default_configuration
|
def default_configuration
|
||||||
Compass::Configuration::Data.new.extend(ConfigurationDefaults)
|
Compass::Configuration::Data.new.extend(ConfigurationDefaults)
|
||||||
|
@ -2,11 +2,13 @@ module Compass
|
|||||||
module Installers
|
module Installers
|
||||||
class Base
|
class Base
|
||||||
end
|
end
|
||||||
|
class ManifestInstaller < Base
|
||||||
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
module AppIntegration
|
module AppIntegration
|
||||||
module StandAlone
|
module StandAlone
|
||||||
class Installer < Compass::Installers::Base
|
class Installer < Compass::Installers::ManifestInstaller
|
||||||
|
|
||||||
def init
|
def init
|
||||||
directory targetize("")
|
directory targetize("")
|
||||||
|
@ -15,6 +15,10 @@ module Compass
|
|||||||
|
|
||||||
Options:
|
Options:
|
||||||
}.split("\n").map{|l| l.gsub(/^ */,'')}.join("\n")
|
}.split("\n").map{|l| l.gsub(/^ */,'')}.join("\n")
|
||||||
|
|
||||||
|
opts.on_tail("--bare", "Don't generate any Sass or CSS files.") do
|
||||||
|
self.options[:bare] = true
|
||||||
|
end
|
||||||
else
|
else
|
||||||
opts.banner = %Q{
|
opts.banner = %Q{
|
||||||
Usage: compass init project_type path/to/project [options]
|
Usage: compass init project_type path/to/project [options]
|
||||||
@ -68,6 +72,9 @@ module Compass
|
|||||||
parser = option_parser(arguments)
|
parser = option_parser(arguments)
|
||||||
parse_options!(parser, arguments)
|
parse_options!(parser, arguments)
|
||||||
parse_arguments!(parser, arguments)
|
parse_arguments!(parser, arguments)
|
||||||
|
if parser.options[:framework] && parser.options[:bare]
|
||||||
|
raise Compass::Error, "A bare project cannot be created when a framework is specified."
|
||||||
|
end
|
||||||
set_default_arguments(parser)
|
set_default_arguments(parser)
|
||||||
parser.options
|
parser.options
|
||||||
end
|
end
|
||||||
|
@ -16,8 +16,12 @@ module Compass
|
|||||||
end
|
end
|
||||||
|
|
||||||
def installer
|
def installer
|
||||||
project_type = options[:project_type] || Compass.configuration.project_type
|
installer_class = if options[:bare]
|
||||||
installer_class = "Compass::AppIntegration::#{camelize(project_type)}::Installer"
|
"Compass::Installers::BareInstaller"
|
||||||
|
else
|
||||||
|
project_type = options[:project_type] || Compass.configuration.project_type
|
||||||
|
"Compass::AppIntegration::#{camelize(project_type)}::Installer"
|
||||||
|
end
|
||||||
@installer = eval("#{installer_class}.new *installer_args")
|
@installer = eval("#{installer_class}.new *installer_args")
|
||||||
end
|
end
|
||||||
|
|
||||||
|
@ -3,6 +3,7 @@ require 'optparse'
|
|||||||
require 'compass/logger'
|
require 'compass/logger'
|
||||||
require 'compass/errors'
|
require 'compass/errors'
|
||||||
require 'compass/actions'
|
require 'compass/actions'
|
||||||
|
require 'compass/installers'
|
||||||
require 'compass/commands'
|
require 'compass/commands'
|
||||||
|
|
||||||
module Compass::Exec
|
module Compass::Exec
|
||||||
|
@ -1,3 +1,3 @@
|
|||||||
%w(manifest template_context base).each do |f|
|
%w(manifest template_context base manifest_installer bare_installer).each do |f|
|
||||||
require "compass/installers/#{f}"
|
require "compass/installers/#{f}"
|
||||||
end
|
end
|
||||||
|
13
lib/compass/installers/bare_installer.rb
Normal file
13
lib/compass/installers/bare_installer.rb
Normal file
@ -0,0 +1,13 @@
|
|||||||
|
module Compass
|
||||||
|
module Installers
|
||||||
|
|
||||||
|
class BareInstaller < Base
|
||||||
|
def prepare
|
||||||
|
|
||||||
|
end
|
||||||
|
def install
|
||||||
|
# directory
|
||||||
|
end
|
||||||
|
end
|
||||||
|
end
|
||||||
|
end
|
@ -7,21 +7,15 @@ module Compass
|
|||||||
|
|
||||||
attr_accessor :template_path, :target_path, :working_path
|
attr_accessor :template_path, :target_path, :working_path
|
||||||
attr_accessor :options
|
attr_accessor :options
|
||||||
attr_accessor :manifest
|
|
||||||
|
|
||||||
def initialize(template_path, target_path, options = {})
|
def initialize(template_path, target_path, options = {})
|
||||||
@template_path = template_path
|
@template_path = template_path
|
||||||
@target_path = target_path
|
@target_path = target_path
|
||||||
@working_path = Dir.getwd
|
@working_path = Dir.getwd
|
||||||
@options = options
|
@options = options
|
||||||
@manifest = Manifest.new(manifest_file, options) if template_path
|
|
||||||
self.logger = options[:logger]
|
self.logger = options[:logger]
|
||||||
end
|
end
|
||||||
|
|
||||||
def manifest_file
|
|
||||||
@manifest_file ||= File.join(template_path, "manifest.rb")
|
|
||||||
end
|
|
||||||
|
|
||||||
[:css_dir, :sass_dir, :images_dir, :javascripts_dir, :http_stylesheets_path].each do |dir|
|
[:css_dir, :sass_dir, :images_dir, :javascripts_dir, :http_stylesheets_path].each do |dir|
|
||||||
define_method dir do
|
define_method dir do
|
||||||
Compass.configuration.send(dir)
|
Compass.configuration.send(dir)
|
||||||
@ -31,23 +25,6 @@ module Compass
|
|||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
# Initializes the project to work with compass
|
|
||||||
def init
|
|
||||||
dirs = manifest.map do |entry|
|
|
||||||
loc = send("install_location_for_#{entry.type}", entry.to, entry.options)
|
|
||||||
File.dirname(loc)
|
|
||||||
end
|
|
||||||
|
|
||||||
if manifest.has_stylesheet?
|
|
||||||
dirs << sass_dir
|
|
||||||
dirs << css_dir
|
|
||||||
end
|
|
||||||
|
|
||||||
dirs.uniq.sort.each do |dir|
|
|
||||||
directory targetize(dir)
|
|
||||||
end
|
|
||||||
end
|
|
||||||
|
|
||||||
# Runs the installer.
|
# Runs the installer.
|
||||||
# Every installer must conform to the installation strategy of prepare, install, and then finalize.
|
# Every installer must conform to the installation strategy of prepare, install, and then finalize.
|
||||||
# A default implementation is provided for each step.
|
# A default implementation is provided for each step.
|
||||||
@ -62,20 +39,9 @@ module Compass
|
|||||||
def prepare
|
def prepare
|
||||||
end
|
end
|
||||||
|
|
||||||
def configure_option_with_default(opt)
|
# The install method override this to install
|
||||||
value = options[opt]
|
|
||||||
value ||= begin
|
|
||||||
default_method = "default_#{opt}".to_sym
|
|
||||||
send(default_method) if respond_to?(default_method)
|
|
||||||
end
|
|
||||||
send("#{opt}=", value)
|
|
||||||
end
|
|
||||||
|
|
||||||
# The default install method. Calls install_<type> methods in the order specified by the manifest.
|
|
||||||
def install
|
def install
|
||||||
manifest.each do |entry|
|
raise "Not Yet Implemented"
|
||||||
send("install_#{entry.type}", entry.from, entry.to, entry.options)
|
|
||||||
end
|
|
||||||
end
|
end
|
||||||
|
|
||||||
# The default finalize method -- it is a no-op.
|
# The default finalize method -- it is a no-op.
|
||||||
@ -165,22 +131,12 @@ module Compass
|
|||||||
strip_trailing_separator File.join(template_path, separate(path))
|
strip_trailing_separator File.join(template_path, separate(path))
|
||||||
end
|
end
|
||||||
|
|
||||||
|
# Emits an HTML fragment that can be used to link to the compiled css files
|
||||||
def stylesheet_links
|
def stylesheet_links
|
||||||
html = "<head>\n"
|
""
|
||||||
manifest.each_stylesheet do |stylesheet|
|
|
||||||
# Skip partials.
|
|
||||||
next if File.basename(stylesheet.from)[0..0] == "_"
|
|
||||||
media = if stylesheet.options[:media]
|
|
||||||
%Q{ media="#{stylesheet.options[:media]}"}
|
|
||||||
end
|
|
||||||
ss_line = %Q{ <link href="#{http_stylesheets_path}/#{stylesheet.to.sub(/\.sass$/,'.css')}"#{media} rel="stylesheet" type="text/css" />}
|
|
||||||
if stylesheet.options[:condition]
|
|
||||||
ss_line = " <!--[if #{stylesheet.options[:condition]}]>\n #{ss_line}\n <![endif]-->"
|
|
||||||
end
|
|
||||||
html << ss_line + "\n"
|
|
||||||
end
|
|
||||||
html << "</head>"
|
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
require 'compass/installers/bare_installer'
|
||||||
|
require 'compass/installers/manifest_installer'
|
||||||
|
59
lib/compass/installers/manifest_installer.rb
Normal file
59
lib/compass/installers/manifest_installer.rb
Normal file
@ -0,0 +1,59 @@
|
|||||||
|
module Compass
|
||||||
|
module Installers
|
||||||
|
|
||||||
|
class ManifestInstaller < Base
|
||||||
|
|
||||||
|
attr_accessor :manifest
|
||||||
|
|
||||||
|
def initialize(template_path, target_path, options = {})
|
||||||
|
super
|
||||||
|
@manifest = Manifest.new(manifest_file, options) if template_path
|
||||||
|
end
|
||||||
|
|
||||||
|
def manifest_file
|
||||||
|
@manifest_file ||= File.join(template_path, "manifest.rb")
|
||||||
|
end
|
||||||
|
|
||||||
|
# Initializes the project to work with compass
|
||||||
|
def init
|
||||||
|
dirs = manifest.map do |entry|
|
||||||
|
loc = send("install_location_for_#{entry.type}", entry.to, entry.options)
|
||||||
|
File.dirname(loc)
|
||||||
|
end
|
||||||
|
|
||||||
|
if manifest.has_stylesheet?
|
||||||
|
dirs << sass_dir
|
||||||
|
dirs << css_dir
|
||||||
|
end
|
||||||
|
|
||||||
|
dirs.uniq.sort.each do |dir|
|
||||||
|
directory targetize(dir)
|
||||||
|
end
|
||||||
|
end
|
||||||
|
|
||||||
|
# The default install method. Calls install_<type> methods in the order specified by the manifest.
|
||||||
|
def install
|
||||||
|
manifest.each do |entry|
|
||||||
|
send("install_#{entry.type}", entry.from, entry.to, entry.options)
|
||||||
|
end
|
||||||
|
end
|
||||||
|
|
||||||
|
def stylesheet_links
|
||||||
|
html = "<head>\n"
|
||||||
|
manifest.each_stylesheet do |stylesheet|
|
||||||
|
# Skip partials.
|
||||||
|
next if File.basename(stylesheet.from)[0..0] == "_"
|
||||||
|
media = if stylesheet.options[:media]
|
||||||
|
%Q{ media="#{stylesheet.options[:media]}"}
|
||||||
|
end
|
||||||
|
ss_line = %Q{ <link href="#{http_stylesheets_path}/#{stylesheet.to.sub(/\.sass$/,'.css')}"#{media} rel="stylesheet" type="text/css" />}
|
||||||
|
if stylesheet.options[:condition]
|
||||||
|
ss_line = " <!--[if #{stylesheet.options[:condition]}]>\n #{ss_line}\n <![endif]-->"
|
||||||
|
end
|
||||||
|
html << ss_line + "\n"
|
||||||
|
end
|
||||||
|
html << "</head>"
|
||||||
|
end
|
||||||
|
end
|
||||||
|
end
|
||||||
|
end
|
@ -35,8 +35,10 @@ module Compass::CommandLineHelper
|
|||||||
end
|
end
|
||||||
end
|
end
|
||||||
else
|
else
|
||||||
@last_result = capture_output do
|
@last_error = capture_warning do
|
||||||
execute *arguments
|
@last_result = capture_output do
|
||||||
|
@last_exit_code = execute *arguments
|
||||||
|
end
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
rescue Timeout::Error
|
rescue Timeout::Error
|
||||||
|
Loading…
Reference in New Issue
Block a user