Class: Sass::Selector::Universal

Inherits:
Simple
  • Object
show all
Defined in:
lib/sass/selector.rb

Overview

A universal selector (* in CSS).

Instance Attribute Summary collapse

Attributes inherited from Simple

#filename, #line

Instance Method Summary collapse

Methods inherited from Simple

#eql?, #hash, #inspect, #to_s, #unify_namespaces

Constructor Details

#initialize(namespace) ⇒ Universal

Returns a new instance of Universal.

Parameters:



138
139
140
# File 'lib/sass/selector.rb', line 138

def initialize(namespace)
  @namespace = namespace
end

Instance Attribute Details

#namespaceArray<String, Sass::Script::Node>? (readonly)

The selector namespace. nil means the default namespace, [""] means no namespace, ["*"] means any namespace.

Returns:



135
136
137
# File 'lib/sass/selector.rb', line 135

def namespace
  @namespace
end

Instance Method Details

#specificity



189
190
191
# File 'lib/sass/selector.rb', line 189

def specificity
  0
end

#to_a

See Also:

  • Selector#to_a


143
144
145
# File 'lib/sass/selector.rb', line 143

def to_a
  @namespace ? @namespace + ["|*"] : ["*"]
end

#unify(sels)

TODO:

There are lots of cases that this documentation specifies; make sure we thoroughly test all of them.

TODO:

Keep track of whether a default namespace has been declared and handle namespace-unspecified selectors accordingly.

TODO:

If any branch of a CommaSequence ends up being just "*", then all other branches should be eliminated

Unification of a universal selector is somewhat complicated, especially when a namespace is specified. If there is no namespace specified or any namespace is specified (namespace "*"), then sel is returned without change (unless it's empty, in which case "*" is required).

If a namespace is specified but sel does not specify a namespace, then the given namespace is applied to sel, either by adding this Sass::Selector::Universal selector or applying this namespace to an existing Element selector.

If both this selector and sel specify namespaces, those namespaces are unified via Simple#unify_namespaces and the unified namespace is used, if possible.

See Also:

  • Selector#unify


172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
# File 'lib/sass/selector.rb', line 172

def unify(sels)
  name =
    case sels.first
    when Universal; :universal
    when Element; sels.first.name
    else
      return [self] + sels unless namespace.nil? || namespace == ['*']
      return sels unless sels.empty?
      return [self]
    end

  ns, accept = unify_namespaces(namespace, sels.first.namespace)
  return unless accept
  [name == :universal ? Universal.new(ns) : Element.new(name, ns)] + sels[1..-1]
end