Class: Sass::Script::Tree::Interpolation

Inherits:
Node
  • Object
show all
Defined in:
lib/sass/script/tree/interpolation.rb

Overview

A SassScript object representing #{} interpolation outside a string.

Instance Attribute Summary collapse

Attributes inherited from Node

#filename, #line, #options, #source_range

Instance Method Summary collapse

Methods inherited from Node

#dasherize, #opts, #perform

Constructor Details

#initialize(before, mid, after, wb, wa, originally_text = false, warn_for_color = false) ⇒ Interpolation

Interpolation in a property is of the form before #{mid} after.

Parameters:



41
42
43
44
45
46
47
48
49
50
# File 'lib/sass/script/tree/interpolation.rb', line 41

def initialize(before, mid, after, wb, wa, originally_text = false, warn_for_color = false)
  # rubocop:enable ParameterLists
  @before = before
  @mid = mid
  @after = after
  @whitespace_before = wb
  @whitespace_after = wa
  @originally_text = originally_text
  @warn_for_color = warn_for_color
end

Instance Attribute Details

#afterNode (readonly)

Returns The SassScript after the interpolation.

Returns:

  • (Node)

    The SassScript after the interpolation



13
14
15
# File 'lib/sass/script/tree/interpolation.rb', line 13

def after
  @after
end

#beforeNode (readonly)

Returns The SassScript before the interpolation.

Returns:

  • (Node)

    The SassScript before the interpolation



7
8
9
# File 'lib/sass/script/tree/interpolation.rb', line 7

def before
  @before
end

#midNode (readonly)

Returns The SassScript within the interpolation.

Returns:

  • (Node)

    The SassScript within the interpolation



10
11
12
# File 'lib/sass/script/tree/interpolation.rb', line 10

def mid
  @mid
end

#originally_textBoolean (readonly)

Returns Whether the original format of the interpolation was plain text, not an interpolation. This is used when converting back to SassScript.

Returns:

  • (Boolean)

    Whether the original format of the interpolation was plain text, not an interpolation. This is used when converting back to SassScript.



24
25
26
# File 'lib/sass/script/tree/interpolation.rb', line 24

def originally_text
  @originally_text
end

#warn_for_colorBoolean (readonly)

Returns Whether a color value passed to the interpolation should generate a warning.

Returns:

  • (Boolean)

    Whether a color value passed to the interpolation should generate a warning.



28
29
30
# File 'lib/sass/script/tree/interpolation.rb', line 28

def warn_for_color
  @warn_for_color
end

#whitespace_afterBoolean (readonly)

Returns Whether there was whitespace between } and after.

Returns:

  • (Boolean)

    Whether there was whitespace between } and after



19
20
21
# File 'lib/sass/script/tree/interpolation.rb', line 19

def whitespace_after
  @whitespace_after
end

#whitespace_beforeBoolean (readonly)

Returns Whether there was whitespace between before and #{.

Returns:

  • (Boolean)

    Whether there was whitespace between before and #{



16
17
18
# File 'lib/sass/script/tree/interpolation.rb', line 16

def whitespace_before
  @whitespace_before
end

Instance Method Details

#_perform(environment) ⇒ Sass::Script::Value::String (protected)

Evaluates the interpolation.

Parameters:

  • environment (Sass::Environment)

    The environment in which to evaluate the SassScript

Returns:



95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
# File 'lib/sass/script/tree/interpolation.rb', line 95

def _perform(environment)
  res = ""
  res << @before.perform(environment).to_s if @before
  res << " " if @before && @whitespace_before

  val = @mid.perform(environment)
  if @warn_for_color && val.is_a?(Sass::Script::Value::Color) && val.name
    alternative = Operation.new(Sass::Script::Value::String.new("", :string), @mid, :plus)
    Sass::Util.sass_warn <<MESSAGE
WARNING on line #{line}, column #{source_range.start_pos.offset}#{" of #{filename}" if filename}:
You probably don't mean to use the color value `#{val}' in interpolation here.
It may end up represented as #{val.inspect}, which will likely produce invalid CSS.
Always quote color names when using them as strings (for example, "#{val}").
If you really want to use the color value here, use `#{alternative.to_sass}'.
MESSAGE
  end

  res << val.to_s(:quote => :none)
  res << " " if @after && @whitespace_after
  res << @after.perform(environment).to_s if @after
  opts(Sass::Script::Value::String.new(res))
end

#childrenArray<Node>

Returns the three components of the interpolation, before, mid, and after.

Returns:

See Also:



75
76
77
# File 'lib/sass/script/tree/interpolation.rb', line 75

def children
  [@before, @mid, @after].compact
end

#deep_copy

See Also:



80
81
82
83
84
85
86
# File 'lib/sass/script/tree/interpolation.rb', line 80

def deep_copy
  node = dup
  node.instance_variable_set('@before', @before.deep_copy) if @before
  node.instance_variable_set('@mid', @mid.deep_copy)
  node.instance_variable_set('@after', @after.deep_copy) if @after
  node
end

#inspectString

Returns A human-readable s-expression representation of the interpolation.

Returns:

  • (String)

    A human-readable s-expression representation of the interpolation



53
54
55
# File 'lib/sass/script/tree/interpolation.rb', line 53

def inspect
  "(interpolation #{@before.inspect} #{@mid.inspect} #{@after.inspect})"
end

#to_sass(opts = {})

See Also:



58
59
60
61
62
63
64
65
66
67
68
# File 'lib/sass/script/tree/interpolation.rb', line 58

def to_sass(opts = {})
  res = ""
  res << @before.to_sass(opts) if @before
  res << ' ' if @before && @whitespace_before
  res << '#{' unless @originally_text
  res << @mid.to_sass(opts)
  res << '}' unless @originally_text
  res << ' ' if @after && @whitespace_after
  res << @after.to_sass(opts) if @after
  res
end