Fix a smattering of bugs.

This commit is contained in:
Chris Eppstein 2010-01-24 16:02:53 -08:00
parent 98ee33953a
commit 3b88df6bbe
2 changed files with 50 additions and 8 deletions

View File

@ -60,6 +60,7 @@ end
def possible_filenames_for_stylesheet(ss) def possible_filenames_for_stylesheet(ss)
ext = File.extname(ss) ext = File.extname(ss)
path = File.dirname(ss) path = File.dirname(ss)
path = path == "." ? "" : "#{path}/"
base = File.basename(ss)[0..-(ext.size+1)] base = File.basename(ss)[0..-(ext.size+1)]
extensions = if ext.size > 0 extensions = if ext.size > 0
[ext] [ext]
@ -70,7 +71,7 @@ def possible_filenames_for_stylesheet(ss)
filenames = [] filenames = []
basenames.each do |basename| basenames.each do |basename|
extensions.each do |extension| extensions.each do |extension|
filenames << "#{path}/#{basename}#{extension}" filenames << "#{path}#{basename}#{extension}"
end end
end end
filenames filenames
@ -132,6 +133,8 @@ def mixin_source_dialog(mixin, &block)
end end
def format_doc(docstring) def format_doc(docstring)
if docstring
RDiscount.new(docstring).to_html RDiscount.new(docstring).to_html
end end
end

View File

@ -33,7 +33,7 @@ module Sass
class IfNode < Node class IfNode < Node
def to_sass def to_sass
sass_str = %Q{@if #{@expr.inspect unless @expr.nil?} sass_str = %Q{@if #{@expr.inspect unless @expr.nil?}
- #{tab children_to_sass} - #{children_to_sass}
-}.gsub(/^\s+-/,'') -}.gsub(/^\s+-/,'')
if @else if @else
sass_str << %Q{@else sass_str << %Q{@else
@ -48,12 +48,48 @@ module Sass
"" ""
end end
end end
class CommentNode < Node
def to_sass
comment = silent ? "//" : "/*"
comment << value
lines.each do |line|
comment << " " << line
end
comment
end
end
class RuleNode < Node
def to_sass
rules.join(",\n")+"\n #{children_to_sass}"
end
end
class ForNode < Node
def to_sass
sass_str = "@for !#{@var} from #{@from.to_sass} #{@exclusive ? "to" : "thru"} #{@to.to_sass}"
sass_str << "\n #{children_to_sass}"
sass_str
end
end
class PropNode < Node
def to_sass
sass_str = "#{name}"
sass_str << (value.is_a?(Script::Node) ? "=" : ":")
if value
sass_str << " " unless value.nil?
sass_str << (value.is_a?(Script::Node) ? value.to_sass : value)
end
unless (s = children_to_sass).empty?
sass_str << "\n #{s}"
end
sass_str
end
end
class MixinNode < Node class MixinNode < Node
attr_accessor :name unless method_defined? :name attr_accessor :name unless method_defined? :name
attr_accessor :args unless method_defined? :args attr_accessor :args unless method_defined? :args
def to_sass def to_sass
sass_str = "+#{name}" sass_str = "+#{name}"
if args.any? if args && args.any?
sass_str << "(#{args.map{|a| a.inspect}.join(", ")})" sass_str << "(#{args.map{|a| a.inspect}.join(", ")})"
end end
sass_str sass_str
@ -61,6 +97,9 @@ module Sass
end end
class VariableNode < Node class VariableNode < Node
attr_accessor :comment unless method_defined? :comment attr_accessor :comment unless method_defined? :comment
def to_sass
"!#{@name} #{"||" if @guarded}= #{expr.to_sass}"
end
end end
class MixinDefNode < Node class MixinDefNode < Node
attr_accessor :name unless method_defined? :name attr_accessor :name unless method_defined? :name
@ -83,7 +122,7 @@ module Sass
private private
def arglist_to_sass def arglist_to_sass
if args.any? if args && args.any?
"(#{args.map{|a| arg_to_sass(a)}.join(", ")})" "(#{args.map{|a| arg_to_sass(a)}.join(", ")})"
else else
"" ""
@ -145,10 +184,10 @@ module Sass
(self.value * PRECISION).round / PRECISION (self.value * PRECISION).round / PRECISION
end end
value = "#{value}#{numerator_units.first}" value = "#{value}#{numerator_units.first}"
if (nu = numerator_units[1..-1]).any? if (nu = numerator_units[1..-1]) && nu.any?
value << " * " + nu.map{|u| "1#{u}"}.join(" * ") value << " * " + nu.map{|u| "1#{u}"}.join(" * ")
end end
if (du = denominator_units).any? if (du = denominator_units) && du.any?
value << " / " + du.map{|u| "1#{u}"}.join(" / ") value << " / " + du.map{|u| "1#{u}"}.join(" / ")
end end
value value
@ -182,7 +221,7 @@ module Sass
end end
class String < Literal class String < Literal
def to_sass(format = :text) def to_sass(format = :text)
value.inspect %q{"}+value.gsub(%r{"},%q{\"})+%q{"}
end end
end end
class UnaryOperation < Node class UnaryOperation < Node