gems.sass-3.4.24.lib.sass.selector.abstract_sequence.rb Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of sass-maven-plugin Show documentation
Show all versions of sass-maven-plugin Show documentation
A Maven Plugin that compiles Sass files.
module Sass
module Selector
# The abstract parent class of the various selector sequence classes.
#
# All subclasses should implement a `members` method that returns an array
# of object that respond to `#line=` and `#filename=`, as well as a `to_s`
# method that returns the string representation of the selector.
class AbstractSequence
# The line of the Sass template on which this selector was declared.
#
# @return [Integer]
attr_reader :line
# The name of the file in which this selector was declared.
#
# @return [String, nil]
attr_reader :filename
# Sets the line of the Sass template on which this selector was declared.
# This also sets the line for all child selectors.
#
# @param line [Integer]
# @return [Integer]
def line=(line)
members.each {|m| m.line = line}
@line = line
end
# Sets 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).
# This also sets the filename for all child selectors.
#
# @param filename [String, nil]
# @return [String, nil]
def filename=(filename)
members.each {|m| m.filename = filename}
@filename = filename
end
# Returns a hash code for this sequence.
#
# Subclasses should define `#_hash` rather than overriding this method,
# which automatically handles memoizing the result.
#
# @return [Integer]
def hash
@_hash ||= _hash
end
# Checks equality between this and another object.
#
# Subclasses should define `#_eql?` rather than overriding this method,
# which handles checking class equality and hash equality.
#
# @param other [Object] The object to test equality against
# @return [Boolean] Whether or not this is equal to `other`
def eql?(other)
other.class == self.class && other.hash == hash && _eql?(other)
end
alias_method :==, :eql?
# Whether or not this selector sequence contains a placeholder selector.
# Checks recursively.
def has_placeholder?
@has_placeholder ||= members.any? do |m|
next m.has_placeholder? if m.is_a?(AbstractSequence)
next m.selector && m.selector.has_placeholder? if m.is_a?(Pseudo)
m.is_a?(Placeholder)
end
end
# Returns the selector string.
#
# @param opts [Hash] rendering options.
# @option opts [Symbol] :style The css rendering style.
# @return [String]
def to_s(opts = {})
Sass::Util.abstract(self)
end
# Returns the specificity of the selector.
#
# The base is given by {Sass::Selector::SPECIFICITY_BASE}. This can be a
# number or a range representing possible specificities.
#
# @return [Integer, Range]
def specificity
_specificity(members)
end
protected
def _specificity(arr)
min = 0
max = 0
arr.each do |m|
next if m.is_a?(String)
spec = m.specificity
if spec.is_a?(Range)
min += spec.begin
max += spec.end
else
min += spec
max += spec
end
end
min == max ? min : (min..max)
end
end
end
end
© 2015 - 2025 Weber Informatics LLC | Privacy Policy