A command to unpack an extension from the system location.

This commit is contained in:
Chris Eppstein 2010-08-29 11:30:58 -07:00
parent 13055f4731
commit 8ad10dc467
4 changed files with 133 additions and 9 deletions

View File

@ -6,6 +6,6 @@ require 'compass/commands/registry'
%w(base generate_grid_background help list_frameworks project_base %w(base generate_grid_background help list_frameworks project_base
update_project watch_project create_project imports installer_command update_project watch_project create_project imports installer_command
print_version project_stats stamp_pattern validate_project print_version project_stats stamp_pattern validate_project
write_configuration interactive).each do |lib| write_configuration interactive unpack_extension).each do |lib|
require "compass/commands/#{lib}" require "compass/commands/#{lib}"
end end

View File

@ -24,7 +24,7 @@ module Compass
def configure! def configure!
add_project_configuration add_project_configuration
Compass.add_configuration(options, "command_line") Compass.add_configuration(options, "command_line")
Compass.discover_extensions! Compass.discover_extensions! unless skip_extension_discovery?
end end
def add_project_configuration def add_project_configuration
@ -88,6 +88,10 @@ module Compass
path.index(File::SEPARATOR) == 0 path.index(File::SEPARATOR) == 0
end end
def skip_extension_discovery?
false
end
end end
end end
end end

View File

@ -0,0 +1,117 @@
require 'compass/commands/project_base'
require 'fileutils'
module Compass
module Commands
module ExtensionOptionsParser
def set_options(opts)
opts.banner = %Q{
Usage: compass unpack EXTENSION
Description:
Copy an extension into your extensions folder for easy access to the source code.
This makes it easier to peruse the source in unfamiliar projects. It is not recommended
that you change other extensions' source -- this makes it hard to take updates from
the original author. The following extensions are available:
FRAMEWORKS
Options:
}.strip.split("\n").map{|l| l.gsub(/^ {0,10}/,'')}.join("\n")
opts.banner.gsub!(/FRAMEWORKS/,Compass::Frameworks.pretty_print(true))
super
end
end
class UnpackExtension < ProjectBase
register :unpack
def initialize(working_path, options)
super
assert_project_directory_exists!
end
def perform
framework = Compass::Frameworks[options[:framework]]
files = Dir["#{framework.path}/**/*"]
extension_dir = File.join(Compass.configuration.extensions_path, framework.name)
FileUtils.rm_rf extension_dir
FileUtils.mkdir_p extension_dir
write_file File.join(extension_dir, "DO_NOT_MODIFY"), readme(framework)
files.each do |f|
next if File.directory?(f)
ending = f[(framework.path.size+1)..-1]
destination = File.join(extension_dir, ending)
FileUtils.mkdir_p(File.dirname(destination))
copy f, destination
end
puts "\nYou have unpacked \"#{framework.name}\""
puts
puts readme(framework)
end
def readme(framework)
%Q{| This is a copy of the "#{framework.name}" extension.
|
| It now overrides the original which was found here:
|
| #{framework.path}
|
| Unpacking an extension is useful when you need to easily peruse the
| extension's source. You might find yourself tempted to change the
| stylesheets here. If you do this, you'll find it harder to take
| updates from the original author. Sometimes this seems like a good
| idea at the time, but in a few months, you'll probably regret it.
|
| In the future, if you take an update of this framework, you'll need to run
|
| compass unpack #{framework.name}
|
| again or remove this unpacked extension.
|}.gsub(/^\s*\| ?/,"")
end
def skip_extension_discovery?
true
end
class << self
def option_parser(arguments)
parser = Compass::Exec::CommandOptionParser.new(arguments)
parser.extend(Compass::Exec::GlobalOptionsParser)
parser.extend(Compass::Exec::ProjectOptionsParser)
parser.extend(ExtensionOptionsParser)
end
def usage
option_parser([]).to_s
end
def description(command)
"Copy an extension into your extensions folder."
end
def parse!(arguments)
parser = option_parser(arguments)
parser.parse!
parse_arguments!(parser, arguments)
parser.options
end
def parse_arguments!(parser, arguments)
if arguments.size == 1
parser.options[:framework] = arguments.shift
elsif arguments.size == 0
raise Compass::Error, "Please specify an extension to unpack."
else
raise Compass::Error, "Too many arguments were specified."
end
end
end
end
end
end

View File

@ -7,10 +7,11 @@ module Compass
class Framework class Framework
attr_accessor :name attr_accessor :name
attr_accessor :path
attr_accessor :templates_directory, :stylesheets_directory attr_accessor :templates_directory, :stylesheets_directory
def initialize(name, *arguments) def initialize(name, *arguments)
options = arguments.last.is_a?(Hash) ? arguments.pop : {} options = arguments.last.is_a?(Hash) ? arguments.pop : {}
path = options[:path] || arguments.shift self.path = path = options[:path] || arguments.shift
@name = name @name = name
@templates_directory = options[:templates_directory] || File.join(path, 'templates') @templates_directory = options[:templates_directory] || File.join(path, 'templates')
@stylesheets_directory = options[:stylesheets_directory] || File.join(path, 'stylesheets') @stylesheets_directory = options[:stylesheets_directory] || File.join(path, 'stylesheets')
@ -97,7 +98,7 @@ module Compass
end end
end end
def pretty_print def pretty_print(skip_patterns = false)
result = "" result = ""
max = Compass::Frameworks::ALL.inject(0) do |gm, framework| max = Compass::Frameworks::ALL.inject(0) do |gm, framework|
fm = framework.template_directories.inject(0) do |lm,pattern| fm = framework.template_directories.inject(0) do |lm,pattern|
@ -108,12 +109,14 @@ module Compass
Compass::Frameworks::ALL.each do |framework| Compass::Frameworks::ALL.each do |framework|
next if framework.name =~ /^_/ next if framework.name =~ /^_/
result << " * #{framework.name}\n" result << " * #{framework.name}\n"
framework.template_directories.each do |pattern| unless skip_patterns
result << " - #{framework.name}/#{pattern}".ljust(max) framework.template_directories.each do |pattern|
if description = framework.manifest(pattern).description result << " - #{framework.name}/#{pattern}".ljust(max)
result << " - #{description}" if description = framework.manifest(pattern).description
result << " - #{description}"
end
result << "\n"
end end
result << "\n"
end end
end end
result result