Class: Sass::Script::Tree::StringInterpolation

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

Overview

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

See Also:

Instance Attribute Summary collapse

Attributes inherited from Node

#filename, #line, #options, #source_range

Instance Method Summary collapse

Methods inherited from Node

#dasherize, #force_division!, #opts, #perform

Constructor Details

#initialize(before, mid, after) ⇒ StringInterpolation

Interpolation in a string is of the form "before #{mid} after", where before and after may include more interpolation.

Parameters:



33
34
35
36
37
# File 'lib/sass/script/tree/string_interpolation.rb', line 33

def initialize(before, mid, after)
  @before = before
  @mid = mid
  @after = after
end

Instance Attribute Details

#afterStringInterpolation, Literal (readonly)

Returns The string literal or string interpolation before this interpolation.

Returns:



14
15
16
# File 'lib/sass/script/tree/string_interpolation.rb', line 14

def after
  @after
end

#beforeLiteral (readonly)

Returns The string literal before this interpolation.

Returns:

  • (Literal)

    The string literal before this interpolation.



7
8
9
# File 'lib/sass/script/tree/string_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/string_interpolation.rb', line 10

def mid
  @mid
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:



83
84
85
86
87
88
89
90
91
# File 'lib/sass/script/tree/string_interpolation.rb', line 83

def _perform(environment)
  res = ""
  before = @before.perform(environment)
  res << before.value
  mid = @mid.perform(environment)
  res << (mid.is_a?(Sass::Script::Value::String) ? mid.value : mid.to_s(:quote => :none))
  res << @after.perform(environment).value
  opts(Sass::Script::Value::String.new(res, before.type))
end

#childrenArray<Node>

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

Returns:

See Also:



63
64
65
# File 'lib/sass/script/tree/string_interpolation.rb', line 63

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

#deep_copy

See Also:



68
69
70
71
72
73
74
# File 'lib/sass/script/tree/string_interpolation.rb', line 68

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



40
41
42
# File 'lib/sass/script/tree/string_interpolation.rb', line 40

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

#to_sass(opts = {})

See Also:



45
46
47
48
49
50
51
52
53
54
55
56
# File 'lib/sass/script/tree/string_interpolation.rb', line 45

def to_sass(opts = {})
  quote = type == :string ? opts[:quote] || quote_for(self) || '"' : :none
  opts = opts.merge(:quote => quote)

  res = ""
  res << quote if quote != :none
  res << _to_sass(before, opts)
  res << '#{' << @mid.to_sass(opts.merge(:quote => nil)) << '}'
  res << _to_sass(after, opts)
  res << quote if quote != :none
  res
end

#typeSymbol

Whether this is a CSS string or a CSS identifier. The difference is that strings are written with double-quotes, while identifiers aren't.

String interpolations are only ever identifiers if they're quote-like functions such as url().

Returns:

  • (Symbol)

    :string or :identifier



23
24
25
# File 'lib/sass/script/tree/string_interpolation.rb', line 23

def type
  @before.value.type
end