gems.sass-3.2.8.lib.sass.scss.static_parser.rb Maven / Gradle / Ivy
Go to download
Sass makes CSS fun again. Sass is an extension of CSS3, adding nested rules, variables, mixins, selector
inheritance, and more. It's translated to well-formatted, standard CSS using the command line tool or a
web-framework plugin.
This is a repackaged GEM in a JAR format of the sass-lang.gem package. The sass-gems package version
follows the sass-lang.gem versions located http://rubyforge.org/frs/?group_id=9702. Simply change
the version of this package to download and repackage the same GEM version.
require 'sass/script/css_parser'
module Sass
module SCSS
# A parser for a static SCSS tree.
# Parses with SCSS extensions, like nested rules and parent selectors,
# but without dynamic SassScript.
# This is useful for e.g. \{#parse\_selector parsing selectors}
# after resolving the interpolation.
class StaticParser < Parser
# Parses the text as a selector.
#
# @param filename [String, nil] The file in which the selector appears,
# or nil if there is no such file.
# Used for error reporting.
# @return [Selector::CommaSequence] The parsed selector
# @raise [Sass::SyntaxError] if there's a syntax error in the selector
def parse_selector
init_scanner!
seq = expr!(:selector_comma_sequence)
expected("selector") unless @scanner.eos?
seq.line = @line
seq.filename = @filename
seq
end
private
def moz_document_function
return unless val = tok(URI) || tok(URL_PREFIX) || tok(DOMAIN) ||
function(!:allow_var)
ss
[val]
end
def variable; nil; end
def script_value; nil; end
def interpolation; nil; end
def var_expr; nil; end
def interp_string; s = tok(STRING) and [s]; end
def interp_uri; s = tok(URI) and [s]; end
def interp_ident(ident = IDENT); s = tok(ident) and [s]; end
def use_css_import?; true; end
def special_directive(name)
return unless %w[media import charset -moz-document].include?(name)
super
end
@sass_script_parser = Class.new(Sass::Script::CssParser)
@sass_script_parser.send(:include, ScriptParser)
end
end
end