Class: Sass::Selector::Simple
- Inherits:
-
Object
- Object
- Sass::Selector::Simple
- Defined in:
- lib/sass/selector/simple.rb
Overview
The abstract superclass for simple selectors (that is, those that don't compose multiple selectors).
Instance Attribute Summary collapse
-
#filename ⇒ String?
The name of the file in which this selector was declared, or
nil
if it was not declared in a file (e.g. on stdin). -
#line ⇒ Fixnum
The line of the Sass template on which this selector was declared.
Instance Method Summary collapse
-
#eql?(other) ⇒ Boolean
(also: #==)
Checks equality between this and another object.
-
#equality_key ⇒ String
protected
Returns the key used for testing whether selectors are equal.
-
#hash ⇒ Fixnum
Returns a hash code for this selector object.
- #inspect ⇒ String
-
#to_s ⇒ String
Returns the selector string.
-
#unify(sels) ⇒ Array<Simple>?
Unifies this selector with a SimpleSequence's members array, returning another
SimpleSequence
members array that matches both this selector and the input selector. -
#unify_namespaces(ns1, ns2) ⇒ Array(String or nil, Boolean)
protected
Unifies two namespaces, returning a namespace that works for both of them if possible.
Instance Attribute Details
#filename ⇒ String?
The name of the file in which this selector was declared,
or nil
if it was not declared in a file (e.g. on stdin).
15 16 17 |
# File 'lib/sass/selector/simple.rb', line 15
def filename
@filename
end
|
#line ⇒ Fixnum
The line of the Sass template on which this selector was declared.
9 10 11 |
# File 'lib/sass/selector/simple.rb', line 9
def line
@line
end
|
Instance Method Details
#eql?(other) ⇒ Boolean Also known as: ==
Checks equality between this and another object.
By default, this is based on the value of #to_a, so if that contains information irrelevant to the identity of the selector, this should be overridden.
50 51 52 |
# File 'lib/sass/selector/simple.rb', line 50
def eql?(other)
other.class == self.class && other.hash == hash && other.equality_key == equality_key
end
|
#equality_key ⇒ String (protected)
Returns the key used for testing whether selectors are equal.
This is a cached version of #to_s.
92 93 94 |
# File 'lib/sass/selector/simple.rb', line 92
def equality_key
@equality_key ||= to_s
end
|
#hash ⇒ Fixnum
Returns a hash code for this selector object.
By default, this is based on the value of #to_a, so if that contains information irrelevant to the identity of the selector, this should be overridden.
38 39 40 |
# File 'lib/sass/selector/simple.rb', line 38
def hash
@_hash ||= equality_key.hash
end
|
#inspect ⇒ String
20 21 22 |
# File 'lib/sass/selector/simple.rb', line 20
def inspect
to_s
end
|
#to_s ⇒ String
Returns the selector string.
27 28 29 |
# File 'lib/sass/selector/simple.rb', line 27
def to_s
Sass::Util.abstract(self)
end
|
#unify(sels) ⇒ Array<Simple>?
Unifies this selector with a Sass::Selector::SimpleSequence's members array,
returning another SimpleSequence
members array
that matches both this selector and the input selector.
By default, this just appends this selector to the end of the array (or returns the original array if this selector already exists in it).
72 73 74 75 76 77 78 79 80 81 82 83 |
# File 'lib/sass/selector/simple.rb', line 72
def unify(sels)
return sels if sels.any? {|sel2| eql?(sel2)}
sels_with_ix = Sass::Util.enum_with_index(sels)
_, i =
if is_a?(Pseudo)
sels_with_ix.find {|sel, _| sel.is_a?(Pseudo) && (sels.last.type == :element)}
else
sels_with_ix.find {|sel, _| sel.is_a?(Pseudo)}
end
return sels + [self] unless i
sels[0...i] + [self] + sels[i..-1]
end
|
#unify_namespaces(ns1, ns2) ⇒ Array(String or nil, Boolean) (protected)
Unifies two namespaces, returning a namespace that works for both of them if possible.
109 110 111 112 113 114 |
# File 'lib/sass/selector/simple.rb', line 109
def unify_namespaces(ns1, ns2)
return nil, false unless ns1 == ns2 || ns1.nil? || ns1 == '*' || ns2.nil? || ns2 == '*'
return ns2, true if ns1 == '*'
return ns1, true if ns2 == '*'
[ns1 || ns2, true]
end
|