sprockets-sass was overwriting image-url and breaking relative assets. Fixes #256

This commit is contained in:
Thomas Reynolds 2012-02-05 11:43:19 -08:00
parent c8c6a1938e
commit 8286879f36
9 changed files with 35 additions and 56 deletions

View file

@ -33,17 +33,16 @@ end
# Default command is server # Default command is server
ARGV.unshift("server") if ARGV.length < 1 || ARGV.first.include?("-") ARGV.unshift("server") if ARGV.length < 1 || ARGV.first.include?("-")
# Require Middleman
require 'middleman-core'
begin begin
# Rubygems # Local
require "middleman-more" require File.expand_path(File.join(File.dirname(File.dirname(libdir)), "middleman-more", "lib", "middleman-more"))
rescue LoadError rescue LoadError
begin begin
# Local # Rubygems
require File.expand_path(File.join(File.dirname(File.dirname(libdir)), "middleman-more", "lib", "middleman-more")) require "middleman-more"
rescue LoadError rescue LoadError
# Require Middleman
require 'middleman-core'
end end
end end

View file

@ -44,6 +44,8 @@ module Middleman::Cli
exit(1) exit(1)
end end
self.class.shared_instance(options["verbose"] || false)
if options.has_key?("relative") && options["relative"] if options.has_key?("relative") && options["relative"]
self.class.shared_instance.activate :relative_assets self.class.shared_instance.activate :relative_assets
end end
@ -65,9 +67,10 @@ module Middleman::Cli
# Middleman::Base singleton # Middleman::Base singleton
# #
# @return [Middleman::Base] # @return [Middleman::Base]
def shared_instance def shared_instance(verbose=false)
@_shared_instance ||= ::Middleman.server.inst do @_shared_instance ||= ::Middleman.server.inst do
set :environment, :build set :environment, :build
set :logging, verbose
end end
end end

View file

@ -97,17 +97,17 @@ module Middleman::CoreExtensions::Extensions
# @param [Symbol, Module] ext Which extension to activate # @param [Symbol, Module] ext Which extension to activate
# @return [void] # @return [void]
def activate(ext, options={}, &block) def activate(ext, options={}, &block)
if !ext.is_a?(Module) ext_module = if ext.is_a?(Module)
ext = ::Middleman::Extensions.load(ext.to_sym) ext
else
::Middleman::Extensions.load(ext.to_sym)
end end
if ext.nil? if ext_module.nil?
puts "== Unknown Extension: #{ext}" puts "== Unknown Extension: #{ext}"
elsif ext.is_a?(String)
puts ext
else else
puts "== Activating: #{ext}" if logging? puts "== Activating: #{ext}" if logging?
self.class.register(ext, options, &block) self.class.register(ext_module, options, &block)
end end
end end

View file

@ -6,7 +6,7 @@ Feature: Relative Assets
And the Server is running at "relative-assets-app" And the Server is running at "relative-assets-app"
When I go to "/stylesheets/relative_assets.css" When I go to "/stylesheets/relative_assets.css"
Then I should not see "url('../" Then I should not see "url('../"
And I should see "url('/images/blank.gif')" And I should see "/images/blank.gif')"
Scenario: Building css with the feature disabled Scenario: Building css with the feature disabled
Given a fixture app "relative-assets-app" Given a fixture app "relative-assets-app"
@ -46,8 +46,8 @@ Feature: Relative Assets
Then I should not see "/images/blank.gif" Then I should not see "/images/blank.gif"
And I should see "images/blank.gif" And I should see "images/blank.gif"
Scenario: Rendering html with a custom images_dir Scenario: Rendering css with a custom images_dir
Given "css" feature is "enabled" Given "relative_assets" feature is "enabled"
And "images_dir" is set to "img" And "images_dir" is set to "img"
And the Server is running at "relative-assets-app" And the Server is running at "relative-assets-app"
When I go to "/stylesheets/relative_assets.css" When I go to "/stylesheets/relative_assets.css"

View file

@ -1 +1 @@
activate :relative_assets # activate :relative_assets

View file

@ -16,39 +16,16 @@ module Middleman::CoreExtensions::Compass
app.after_configuration do app.after_configuration do
::Compass.configuration do |config| ::Compass.configuration do |config|
config.project_path = root config.project_path = source_dir
config.environment = :development config.environment = :development
config.cache_path = File.join(root, ".sass-cache") config.cache_path = File.join(root, ".sass-cache")
config.sass_dir = File.join(source, css_dir) config.sass_dir = css_dir
config.css_dir = File.join(source, css_dir) config.css_dir = css_dir
config.javascripts_dir = File.join(source, js_dir) config.javascripts_dir = js_dir
config.fonts_dir = File.join(source, fonts_dir) config.fonts_dir = fonts_dir
config.images_dir = File.join(source, images_dir) config.images_dir = images_dir
config.http_path = http_prefix
config.http_images_path = if respond_to? :http_images_path
http_images_path
else
File.join(http_prefix, images_dir)
end
config.http_stylesheets_path = if respond_to? :http_css_path
http_css_path
else
File.join(http_prefix, css_dir)
end
config.http_javascripts_path = if respond_to? :http_js_path
http_js_path
else
File.join(http_prefix, js_dir)
end
config.http_fonts_path = if respond_to? :http_fonts_path
http_fonts_path
else
File.join(http_prefix, fonts_dir)
end
config.asset_cache_buster :none config.asset_cache_buster :none
config.output_style = :nested config.output_style = :nested
@ -57,13 +34,9 @@ module Middleman::CoreExtensions::Compass
end end
end end
# Change paths when in build mode. Required for relative paths # if build?
# configure :build do
# ::Compass.configuration do |config| # ::Compass.configuration do |config|
# config.environment = :production # config.environment = :production
# config.css_dir = File.join(build_dir, css_dir)
# config.images_dir = File.join(build_dir, images_dir)
# config.fonts_dir = File.join(build_dir, fonts_dir)
# end # end
# end # end

View file

@ -17,6 +17,7 @@ module Middleman::Extensions
# Include instance methods # Include instance methods
app.send :include, InstanceMethods app.send :include, InstanceMethods
end end
alias :included :registered alias :included :registered
end end

View file

@ -1,7 +1,10 @@
# Pull in gems # Pull in gems
require "sass"
require "sprockets" require "sprockets"
require "sprockets-sass" require "sprockets-sass"
require "sass"
# Stick with Compass' asset functions
Sprockets::Sass.add_sass_functions = false
# Sass renderer # Sass renderer
module Middleman::Renderers::Sass module Middleman::Renderers::Sass

View file

@ -22,7 +22,7 @@ Gem::Specification.new do |s|
s.add_dependency("uglifier", ["~> 1.2.0"]) s.add_dependency("uglifier", ["~> 1.2.0"])
s.add_dependency("haml", ["~> 3.1.0"]) s.add_dependency("haml", ["~> 3.1.0"])
s.add_dependency("sass", ["~> 3.1.7"]) s.add_dependency("sass", ["~> 3.1.7"])
s.add_dependency("compass", ["0.12.rc.0"]) s.add_dependency("compass", ["0.12.rc.1"])
s.add_dependency("coffee-script", ["~> 2.2.0"]) s.add_dependency("coffee-script", ["~> 2.2.0"])
s.add_dependency("execjs", ["~> 1.2.7"]) s.add_dependency("execjs", ["~> 1.2.7"])
s.add_dependency("sprockets", ["~> 2.1.0"]) s.add_dependency("sprockets", ["~> 2.1.0"])