Class: Sass::Tree::Visitors::CheckNesting
- Inherits:
-
Base
- Object
- Base
- Sass::Tree::Visitors::CheckNesting
show all
- Defined in:
- lib/sass/tree/visitors/check_nesting.rb
Overview
A visitor for checking that all nodes are properly nested.
Constant Summary
collapse
- CONTROL_NODES =
[Sass::Tree::EachNode, Sass::Tree::ForNode, Sass::Tree::IfNode,
Sass::Tree::WhileNode, Sass::Tree::TraceNode]
- SCRIPT_NODES =
[Sass::Tree::ImportNode] + CONTROL_NODES
- VALID_EXTEND_PARENTS =
[Sass::Tree::RuleNode, Sass::Tree::MixinDefNode, Sass::Tree::MixinNode]
- INVALID_IMPORT_PARENTS =
CONTROL_NODES +
[Sass::Tree::MixinDefNode, Sass::Tree::MixinNode]
- VALID_FUNCTION_CHILDREN =
[
Sass::Tree::CommentNode, Sass::Tree::DebugNode, Sass::Tree::ReturnNode,
Sass::Tree::VariableNode, Sass::Tree::WarnNode, Sass::Tree::ErrorNode
] + CONTROL_NODES
- VALID_PROP_CHILDREN =
CONTROL_NODES + [Sass::Tree::CommentNode,
Sass::Tree::PropNode,
Sass::Tree::MixinNode]
- VALID_PROP_PARENTS =
[Sass::Tree::RuleNode, Sass::Tree::KeyframeRuleNode, Sass::Tree::PropNode,
Sass::Tree::MixinDefNode, Sass::Tree::DirectiveNode, Sass::Tree::MixinNode]
Instance Method Summary
collapse
-
#initialize ⇒ CheckNesting
constructor
protected
A new instance of CheckNesting.
-
#invalid_charset_parent?(parent, child) ⇒ Boolean
protected
-
#invalid_content_parent?(parent, child) ⇒ Boolean
protected
-
#invalid_extend_parent?(parent, child) ⇒ Boolean
protected
-
#invalid_function_child?(parent, child) ⇒ Boolean
protected
-
#invalid_function_parent?(parent, child) ⇒ Boolean
protected
-
#invalid_import_parent?(parent, child) ⇒ Boolean
protected
-
#invalid_mixindef_parent?(parent, child) ⇒ Boolean
protected
-
#invalid_prop_child?(parent, child) ⇒ Boolean
protected
-
#invalid_prop_parent?(parent, child) ⇒ Boolean
protected
-
#invalid_return_parent?(parent, child) ⇒ Boolean
protected
-
#visit(node)
protected
-
#visit_children(parent)
protected
-
#visit_import(node)
protected
-
#visit_mixindef(node)
protected
-
#visit_root(node)
protected
Methods inherited from Base
node_name, visit, #visit_if
Constructor Details
Returns a new instance of CheckNesting.
5
6
7
8
9
|
# File 'lib/sass/tree/visitors/check_nesting.rb', line 5
def initialize
@parents = []
@parent = nil
@current_mixin_def = nil
end
|
Instance Method Details
#invalid_charset_parent?(parent, child) ⇒ Boolean
89
90
91
|
# File 'lib/sass/tree/visitors/check_nesting.rb', line 89
def invalid_charset_parent?(parent, child)
"@charset may only be used at the root of a document." unless parent.is_a?(Sass::Tree::RootNode)
end
|
#invalid_content_parent?(parent, child) ⇒ Boolean
80
81
82
83
84
85
86
87
|
# File 'lib/sass/tree/visitors/check_nesting.rb', line 80
def invalid_content_parent?(parent, child)
if @current_mixin_def
@current_mixin_def.has_content = true
nil
else
"@content may only be used within a mixin."
end
end
|
#invalid_extend_parent?(parent, child) ⇒ Boolean
94
95
96
97
|
# File 'lib/sass/tree/visitors/check_nesting.rb', line 94
def invalid_extend_parent?(parent, child)
return if is_any_of?(parent, VALID_EXTEND_PARENTS)
"Extend directives may only be used within rules."
end
|
#invalid_function_child?(parent, child) ⇒ Boolean
127
128
129
130
|
# File 'lib/sass/tree/visitors/check_nesting.rb', line 127
def invalid_function_child?(parent, child)
return if is_any_of?(child, VALID_FUNCTION_CHILDREN)
"Functions can only contain variable declarations and control directives."
end
|
#invalid_function_parent?(parent, child) ⇒ Boolean
118
119
120
121
|
# File 'lib/sass/tree/visitors/check_nesting.rb', line 118
def invalid_function_parent?(parent, child)
return if (@parents.map {|p| p.class} & INVALID_IMPORT_PARENTS).empty?
"Functions may not be defined within control directives or other mixins."
end
|
#invalid_import_parent?(parent, child) ⇒ Boolean
101
102
103
104
105
106
107
108
109
110
111
|
# File 'lib/sass/tree/visitors/check_nesting.rb', line 101
def invalid_import_parent?(parent, child)
unless (@parents.map {|p| p.class} & INVALID_IMPORT_PARENTS).empty?
return "Import directives may not be used within control directives or mixins."
end
return if parent.is_a?(Sass::Tree::RootNode)
return "CSS import directives may only be used at the root of a document." if child.css_import?
rescue Sass::SyntaxError => e
e.modify_backtrace(:filename => child.imported_file.options[:filename])
e.add_backtrace(:filename => child.filename, :line => child.line)
raise e
end
|
#invalid_mixindef_parent?(parent, child) ⇒ Boolean
113
114
115
116
|
# File 'lib/sass/tree/visitors/check_nesting.rb', line 113
def invalid_mixindef_parent?(parent, child)
return if (@parents.map {|p| p.class} & INVALID_IMPORT_PARENTS).empty?
"Mixins may not be defined within control directives or other mixins."
end
|
#invalid_prop_child?(parent, child) ⇒ Boolean
135
136
137
138
|
# File 'lib/sass/tree/visitors/check_nesting.rb', line 135
def invalid_prop_child?(parent, child)
return if is_any_of?(child, VALID_PROP_CHILDREN)
"Illegal nesting: Only properties may be nested beneath properties."
end
|
#invalid_prop_parent?(parent, child) ⇒ Boolean
142
143
144
145
146
|
# File 'lib/sass/tree/visitors/check_nesting.rb', line 142
def invalid_prop_parent?(parent, child)
return if is_any_of?(parent, VALID_PROP_PARENTS)
"Properties are only allowed within rules, directives, mixin includes, or other properties." +
child.pseudo_class_selector_message
end
|
#invalid_return_parent?(parent, child) ⇒ Boolean
148
149
150
|
# File 'lib/sass/tree/visitors/check_nesting.rb', line 148
def invalid_return_parent?(parent, child)
"@return may only be used within a function." unless parent.is_a?(Sass::Tree::FunctionNode)
end
|
#visit(node)
11
12
13
14
15
16
17
18
19
20
21
|
# File 'lib/sass/tree/visitors/check_nesting.rb', line 11
def visit(node)
if (error = @parent && (
try_send(@parent.class.invalid_child_method_name, @parent, node) ||
try_send(node.class.invalid_parent_method_name, @parent, node)))
raise Sass::SyntaxError.new(error)
end
super
rescue Sass::SyntaxError => e
e.modify_backtrace(:filename => node.filename, :line => node.line)
raise e
end
|
#visit_children(parent)
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
|
# File 'lib/sass/tree/visitors/check_nesting.rb', line 26
def visit_children(parent)
old_parent = @parent
# When checking a static tree, resolve at-roots to be sure they won't send
# nodes where they don't belong.
if parent.is_a?(Sass::Tree::AtRootNode) && parent.resolved_value
old_parents = @parents
@parents = @parents.reject {|p| parent.exclude_node?(p)}
@parent = @parents.reverse.each_with_index.
find {|p, i| !transparent_parent?(p, @parents[-i - 2])}.first
begin
return super
ensure
@parents = old_parents
@parent = old_parent
end
end
unless transparent_parent?(parent, old_parent)
@parent = parent
end
@parents.push parent
begin
super
ensure
@parent = old_parent
@parents.pop
end
end
|
#visit_import(node)
65
66
67
68
69
70
71
|
# File 'lib/sass/tree/visitors/check_nesting.rb', line 65
def visit_import(node)
yield
rescue Sass::SyntaxError => e
e.modify_backtrace(:filename => node.children.first.filename)
e.add_backtrace(:filename => node.filename, :line => node.line)
raise e
end
|
#visit_mixindef(node)
73
74
75
76
77
78
|
# File 'lib/sass/tree/visitors/check_nesting.rb', line 73
def visit_mixindef(node)
@current_mixin_def, old_mixin_def = node, @current_mixin_def
yield
ensure
@current_mixin_def = old_mixin_def
end
|
#visit_root(node)
58
59
60
61
62
63
|
# File 'lib/sass/tree/visitors/check_nesting.rb', line 58
def visit_root(node)
yield
rescue Sass::SyntaxError => e
e.sass_template ||= node.template
raise e
end
|