sassc 1.7.1 → 1.8.0.pre1

Sign up to get free protection for your applications and to get access to all the features.
Files changed (164) hide show
  1. checksums.yaml +4 -4
  2. data/README.md +3 -1
  3. data/ext/libsass/.gitignore +10 -6
  4. data/ext/libsass/.travis.yml +4 -1
  5. data/ext/libsass/GNUmakefile.am +88 -0
  6. data/ext/libsass/Makefile +157 -76
  7. data/ext/libsass/Makefile.conf +47 -0
  8. data/ext/libsass/Readme.md +13 -14
  9. data/ext/libsass/appveyor.yml +25 -41
  10. data/ext/libsass/configure.ac +20 -7
  11. data/ext/libsass/contrib/plugin.cpp +1 -1
  12. data/ext/libsass/include/sass.h +15 -0
  13. data/ext/libsass/{sass.h → include/sass/base.h} +17 -9
  14. data/ext/libsass/{sass_context.h → include/sass/context.h} +3 -1
  15. data/ext/libsass/{sass_functions.h → include/sass/functions.h} +4 -4
  16. data/ext/libsass/{sass_interface.h → include/sass/interface.h} +5 -2
  17. data/ext/libsass/{sass_values.h → include/sass/values.h} +15 -1
  18. data/ext/libsass/{sass_version.h → include/sass/version.h} +0 -0
  19. data/ext/libsass/{sass_version.h.in → include/sass/version.h.in} +0 -0
  20. data/ext/libsass/{sass2scss.h → include/sass2scss.h} +6 -7
  21. data/ext/libsass/m4/m4-ax_cxx_compile_stdcxx_11.m4 +167 -0
  22. data/ext/libsass/script/ci-build-libsass +67 -23
  23. data/ext/libsass/src/GNUmakefile.am +54 -0
  24. data/ext/libsass/src/ast.cpp +2029 -0
  25. data/ext/libsass/{ast.hpp → src/ast.hpp} +832 -660
  26. data/ext/libsass/src/ast_def_macros.hpp +47 -0
  27. data/ext/libsass/src/ast_factory.hpp +93 -0
  28. data/ext/libsass/{ast_fwd_decl.hpp → src/ast_fwd_decl.hpp} +9 -4
  29. data/ext/libsass/{b64 → src/b64}/cencode.h +1 -1
  30. data/ext/libsass/{b64 → src/b64}/encode.h +0 -0
  31. data/ext/libsass/{backtrace.hpp → src/backtrace.hpp} +9 -10
  32. data/ext/libsass/{base64vlq.cpp → src/base64vlq.cpp} +2 -2
  33. data/ext/libsass/{base64vlq.hpp → src/base64vlq.hpp} +1 -2
  34. data/ext/libsass/{bind.cpp → src/bind.cpp} +96 -59
  35. data/ext/libsass/{bind.hpp → src/bind.hpp} +1 -1
  36. data/ext/libsass/src/c99func.c +54 -0
  37. data/ext/libsass/{cencode.c → src/cencode.c} +5 -5
  38. data/ext/libsass/src/color_maps.cpp +643 -0
  39. data/ext/libsass/src/color_maps.hpp +333 -0
  40. data/ext/libsass/{constants.cpp → src/constants.cpp} +10 -1
  41. data/ext/libsass/{constants.hpp → src/constants.hpp} +7 -0
  42. data/ext/libsass/{context.cpp → src/context.cpp} +152 -122
  43. data/ext/libsass/src/context.hpp +150 -0
  44. data/ext/libsass/{cssize.cpp → src/cssize.cpp} +123 -109
  45. data/ext/libsass/{cssize.hpp → src/cssize.hpp} +9 -13
  46. data/ext/libsass/{debug.hpp → src/debug.hpp} +9 -9
  47. data/ext/libsass/src/debugger.hpp +683 -0
  48. data/ext/libsass/{emitter.cpp → src/emitter.cpp} +13 -13
  49. data/ext/libsass/{emitter.hpp → src/emitter.hpp} +10 -11
  50. data/ext/libsass/src/environment.cpp +184 -0
  51. data/ext/libsass/src/environment.hpp +92 -0
  52. data/ext/libsass/src/error_handling.cpp +46 -0
  53. data/ext/libsass/src/error_handling.hpp +34 -0
  54. data/ext/libsass/src/eval.cpp +1462 -0
  55. data/ext/libsass/src/eval.hpp +107 -0
  56. data/ext/libsass/src/expand.cpp +653 -0
  57. data/ext/libsass/{expand.hpp → src/expand.hpp} +17 -16
  58. data/ext/libsass/{extend.cpp → src/extend.cpp} +198 -139
  59. data/ext/libsass/{extend.hpp → src/extend.hpp} +7 -8
  60. data/ext/libsass/{file.cpp → src/file.cpp} +103 -57
  61. data/ext/libsass/{file.hpp → src/file.hpp} +23 -14
  62. data/ext/libsass/{functions.cpp → src/functions.cpp} +642 -333
  63. data/ext/libsass/{functions.hpp → src/functions.hpp} +17 -4
  64. data/ext/libsass/{inspect.cpp → src/inspect.cpp} +147 -260
  65. data/ext/libsass/{inspect.hpp → src/inspect.hpp} +7 -7
  66. data/ext/libsass/{json.cpp → src/json.cpp} +33 -43
  67. data/ext/libsass/{json.hpp → src/json.hpp} +1 -1
  68. data/ext/libsass/{kwd_arg_macros.hpp → src/kwd_arg_macros.hpp} +0 -0
  69. data/ext/libsass/{lexer.cpp → src/lexer.cpp} +28 -0
  70. data/ext/libsass/{lexer.hpp → src/lexer.hpp} +25 -10
  71. data/ext/libsass/{listize.cpp → src/listize.cpp} +17 -13
  72. data/ext/libsass/{listize.hpp → src/listize.hpp} +0 -2
  73. data/ext/libsass/{mapping.hpp → src/mapping.hpp} +0 -0
  74. data/ext/libsass/src/memory_manager.cpp +76 -0
  75. data/ext/libsass/src/memory_manager.hpp +48 -0
  76. data/ext/libsass/{node.cpp → src/node.cpp} +89 -18
  77. data/ext/libsass/{node.hpp → src/node.hpp} +5 -6
  78. data/ext/libsass/{operation.hpp → src/operation.hpp} +18 -12
  79. data/ext/libsass/{output.cpp → src/output.cpp} +47 -55
  80. data/ext/libsass/{output.hpp → src/output.hpp} +5 -4
  81. data/ext/libsass/src/parser.cpp +2529 -0
  82. data/ext/libsass/{parser.hpp → src/parser.hpp} +84 -60
  83. data/ext/libsass/{paths.hpp → src/paths.hpp} +10 -13
  84. data/ext/libsass/{plugins.cpp → src/plugins.cpp} +14 -17
  85. data/ext/libsass/{plugins.hpp → src/plugins.hpp} +10 -11
  86. data/ext/libsass/{position.cpp → src/position.cpp} +5 -6
  87. data/ext/libsass/{position.hpp → src/position.hpp} +19 -22
  88. data/ext/libsass/{prelexer.cpp → src/prelexer.cpp} +401 -53
  89. data/ext/libsass/{prelexer.hpp → src/prelexer.hpp} +50 -10
  90. data/ext/libsass/{remove_placeholders.cpp → src/remove_placeholders.cpp} +12 -16
  91. data/ext/libsass/{remove_placeholders.hpp → src/remove_placeholders.hpp} +1 -7
  92. data/ext/libsass/{sass.cpp → src/sass.cpp} +3 -5
  93. data/ext/libsass/{sass2scss.cpp → src/sass2scss.cpp} +51 -46
  94. data/ext/libsass/{sass_context.cpp → src/sass_context.cpp} +114 -112
  95. data/ext/libsass/{sass_functions.cpp → src/sass_functions.cpp} +11 -18
  96. data/ext/libsass/{sass_interface.cpp → src/sass_interface.cpp} +44 -81
  97. data/ext/libsass/{sass_util.cpp → src/sass_util.cpp} +26 -8
  98. data/ext/libsass/{sass_util.hpp → src/sass_util.hpp} +14 -18
  99. data/ext/libsass/{sass_values.cpp → src/sass_values.cpp} +91 -20
  100. data/ext/libsass/{source_map.cpp → src/source_map.cpp} +13 -13
  101. data/ext/libsass/{source_map.hpp → src/source_map.hpp} +9 -9
  102. data/ext/libsass/{subset_map.hpp → src/subset_map.hpp} +29 -31
  103. data/ext/libsass/{support → src/support}/libsass.pc.in +0 -0
  104. data/ext/libsass/src/to_c.cpp +73 -0
  105. data/ext/libsass/src/to_c.hpp +41 -0
  106. data/ext/libsass/src/to_string.cpp +47 -0
  107. data/ext/libsass/{to_string.hpp → src/to_string.hpp} +9 -7
  108. data/ext/libsass/src/to_value.cpp +109 -0
  109. data/ext/libsass/src/to_value.hpp +50 -0
  110. data/ext/libsass/{units.cpp → src/units.cpp} +56 -51
  111. data/ext/libsass/{units.hpp → src/units.hpp} +8 -9
  112. data/ext/libsass/{utf8.h → src/utf8.h} +0 -0
  113. data/ext/libsass/{utf8 → src/utf8}/checked.h +0 -0
  114. data/ext/libsass/{utf8 → src/utf8}/core.h +12 -12
  115. data/ext/libsass/{utf8 → src/utf8}/unchecked.h +0 -0
  116. data/ext/libsass/{utf8_string.cpp → src/utf8_string.cpp} +0 -0
  117. data/ext/libsass/{utf8_string.hpp → src/utf8_string.hpp} +6 -6
  118. data/ext/libsass/{util.cpp → src/util.cpp} +144 -86
  119. data/ext/libsass/src/util.hpp +59 -0
  120. data/ext/libsass/src/values.cpp +137 -0
  121. data/ext/libsass/src/values.hpp +12 -0
  122. data/ext/libsass/test/test_node.cpp +33 -33
  123. data/ext/libsass/test/test_paths.cpp +5 -6
  124. data/ext/libsass/test/test_selector_difference.cpp +4 -5
  125. data/ext/libsass/test/test_specificity.cpp +4 -5
  126. data/ext/libsass/test/test_subset_map.cpp +91 -91
  127. data/ext/libsass/test/test_superselector.cpp +11 -11
  128. data/ext/libsass/test/test_unification.cpp +4 -4
  129. data/ext/libsass/win/libsass.targets +101 -0
  130. data/ext/libsass/win/libsass.vcxproj +45 -127
  131. data/ext/libsass/win/libsass.vcxproj.filters +303 -0
  132. data/lib/sassc/import_handler.rb +1 -1
  133. data/lib/sassc/native/native_functions_api.rb +3 -3
  134. data/lib/sassc/version.rb +1 -1
  135. data/test/custom_importer_test.rb +1 -4
  136. data/test/functions_test.rb +3 -2
  137. data/test/native_test.rb +4 -3
  138. metadata +117 -110
  139. data/ext/libsass/Makefile.am +0 -146
  140. data/ext/libsass/ast.cpp +0 -945
  141. data/ext/libsass/ast_def_macros.hpp +0 -21
  142. data/ext/libsass/ast_factory.hpp +0 -92
  143. data/ext/libsass/color_names.hpp +0 -327
  144. data/ext/libsass/context.hpp +0 -157
  145. data/ext/libsass/contextualize.cpp +0 -148
  146. data/ext/libsass/contextualize.hpp +0 -46
  147. data/ext/libsass/contextualize_eval.cpp +0 -93
  148. data/ext/libsass/contextualize_eval.hpp +0 -44
  149. data/ext/libsass/debugger.hpp +0 -558
  150. data/ext/libsass/environment.hpp +0 -163
  151. data/ext/libsass/error_handling.cpp +0 -35
  152. data/ext/libsass/error_handling.hpp +0 -32
  153. data/ext/libsass/eval.cpp +0 -1392
  154. data/ext/libsass/eval.hpp +0 -88
  155. data/ext/libsass/expand.cpp +0 -575
  156. data/ext/libsass/memory_manager.hpp +0 -57
  157. data/ext/libsass/parser.cpp +0 -2403
  158. data/ext/libsass/posix/getopt.c +0 -562
  159. data/ext/libsass/posix/getopt.h +0 -95
  160. data/ext/libsass/to_c.cpp +0 -61
  161. data/ext/libsass/to_c.hpp +0 -44
  162. data/ext/libsass/to_string.cpp +0 -34
  163. data/ext/libsass/util.hpp +0 -54
  164. data/ext/libsass/win/libsass.filters +0 -312
@@ -1,32 +1,27 @@
1
1
  #ifndef SASS_CSSIZE_H
2
2
  #define SASS_CSSIZE_H
3
3
 
4
- #include <vector>
5
- #include <iostream>
6
-
7
4
  #include "ast.hpp"
8
5
  #include "context.hpp"
9
6
  #include "operation.hpp"
10
7
  #include "environment.hpp"
11
8
 
12
9
  namespace Sass {
13
- using namespace std;
14
10
 
15
11
  typedef Environment<AST_Node*> Env;
16
12
  struct Backtrace;
17
13
 
18
14
  class Cssize : public Operation_CRTP<Statement*, Cssize> {
19
15
 
20
- Context& ctx;
21
- Env* env;
22
- vector<Block*> block_stack;
23
- vector<Statement*> p_stack;
24
- Backtrace* backtrace;
16
+ Context& ctx;
17
+ std::vector<Block*> block_stack;
18
+ std::vector<Statement*> p_stack;
19
+ Backtrace* backtrace;
25
20
 
26
21
  Statement* fallback_impl(AST_Node* n);
27
22
 
28
23
  public:
29
- Cssize(Context&, Env*, Backtrace*);
24
+ Cssize(Context&, Backtrace*);
30
25
  virtual ~Cssize() { }
31
26
 
32
27
  using Operation<Statement*>::operator();
@@ -36,7 +31,7 @@ namespace Sass {
36
31
  // Statement* operator()(Propset*);
37
32
  // Statement* operator()(Bubble*);
38
33
  Statement* operator()(Media_Block*);
39
- Statement* operator()(Feature_Block*);
34
+ Statement* operator()(Supports_Block*);
40
35
  Statement* operator()(At_Root_Block*);
41
36
  Statement* operator()(At_Rule*);
42
37
  Statement* operator()(Keyframe_Rule*);
@@ -56,13 +51,14 @@ namespace Sass {
56
51
  // Statement* operator()(Definition*);
57
52
  // Statement* operator()(Mixin_Call*);
58
53
  // Statement* operator()(Content*);
54
+ Statement* operator()(Null*);
59
55
 
60
56
  Statement* parent();
61
- vector<pair<bool, Block*>> slice_by_bubble(Statement*);
57
+ std::vector<std::pair<bool, Block*>> slice_by_bubble(Statement*);
62
58
  Statement* bubble(At_Rule*);
63
59
  Statement* bubble(At_Root_Block*);
64
60
  Statement* bubble(Media_Block*);
65
- Statement* bubble(Feature_Block*);
61
+ Statement* bubble(Supports_Block*);
66
62
  Statement* shallow_copy(Statement*);
67
63
  Statement* debubble(Block* children, Statement* parent = 0);
68
64
  Statement* flatten(Statement*);
@@ -4,16 +4,16 @@
4
4
  #include <stdint.h>
5
5
 
6
6
  enum dbg_lvl_t : uint32_t {
7
- NONE = 0,
8
- TRIM = 1,
9
- CHUNKS = 2,
10
- SUBWEAVE = 4,
11
- WEAVE = 8,
12
- EXTEND_COMPOUND = 16,
13
- EXTEND_COMPLEX = 32,
14
- LCS = 64,
7
+ NONE = 0,
8
+ TRIM = 1,
9
+ CHUNKS = 2,
10
+ SUBWEAVE = 4,
11
+ WEAVE = 8,
12
+ EXTEND_COMPOUND = 16,
13
+ EXTEND_COMPLEX = 32,
14
+ LCS = 64,
15
15
  EXTEND_OBJECT = 128,
16
- ALL = UINT32_MAX
16
+ ALL = UINT32_MAX
17
17
  };
18
18
 
19
19
  #ifdef DEBUG
@@ -0,0 +1,683 @@
1
+ #ifndef SASS_DEBUGGER_H
2
+ #define SASS_DEBUGGER_H
3
+
4
+ #include <string>
5
+ #include <sstream>
6
+ #include "node.hpp"
7
+ #include "ast_fwd_decl.hpp"
8
+
9
+ using namespace Sass;
10
+
11
+ inline void debug_ast(AST_Node* node, std::string ind = "", Env* env = 0);
12
+
13
+ inline void debug_sources_set(SourcesSet& set, std::string ind = "")
14
+ {
15
+ if (ind == "") std::cerr << "#%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%\n";
16
+ for(auto const &pair : set) {
17
+ debug_ast(pair, ind + "");
18
+ // debug_ast(set[pair], ind + "first: ");
19
+ }
20
+ if (ind == "") std::cerr << "#%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%\n";
21
+ }
22
+
23
+ inline std::string str_replace(std::string str, const std::string& oldStr, const std::string& newStr)
24
+ {
25
+ size_t pos = 0;
26
+ while((pos = str.find(oldStr, pos)) != std::string::npos)
27
+ {
28
+ str.replace(pos, oldStr.length(), newStr);
29
+ pos += newStr.length();
30
+ }
31
+ return str;
32
+ }
33
+
34
+ inline std::string prettyprint(const std::string& str) {
35
+ std::string clean = str_replace(str, "\n", "\\n");
36
+ clean = str_replace(clean, " ", "\\t");
37
+ clean = str_replace(clean, "\r", "\\r");
38
+ return clean;
39
+ }
40
+
41
+ inline std::string longToHex(long long t) {
42
+ std::stringstream is;
43
+ is << std::hex << t;
44
+ return is.str();
45
+ }
46
+
47
+ inline std::string pstate_source_position(AST_Node* node)
48
+ {
49
+ std::stringstream str;
50
+ Position start(node->pstate());
51
+ Position end(start + node->pstate().offset);
52
+ str << (start.file == std::string::npos ? -1 : start.file)
53
+ << "@[" << start.line << ":" << start.column << "]"
54
+ << "-[" << end.line << ":" << end.column << "]";
55
+ return str.str();
56
+ }
57
+
58
+ inline void debug_ast(AST_Node* node, std::string ind, Env* env)
59
+ {
60
+ if (node == 0) return;
61
+ if (ind == "") std::cerr << "####################################################################\n";
62
+ if (dynamic_cast<Bubble*>(node)) {
63
+ Bubble* bubble = dynamic_cast<Bubble*>(node);
64
+ std::cerr << ind << "Bubble " << bubble;
65
+ std::cerr << " (" << pstate_source_position(node) << ")";
66
+ std::cerr << " " << bubble->tabs();
67
+ std::cerr << std::endl;
68
+ } else if (dynamic_cast<At_Root_Block*>(node)) {
69
+ At_Root_Block* root_block = dynamic_cast<At_Root_Block*>(node);
70
+ std::cerr << ind << "At_Root_Block " << root_block;
71
+ std::cerr << " (" << pstate_source_position(node) << ")";
72
+ std::cerr << " " << root_block->tabs();
73
+ std::cerr << std::endl;
74
+ if (root_block->block()) for(auto i : root_block->block()->elements()) { debug_ast(i, ind + " ", env); }
75
+ } else if (dynamic_cast<Selector_List*>(node)) {
76
+ Selector_List* selector = dynamic_cast<Selector_List*>(node);
77
+ std::cerr << ind << "Selector_List " << selector;
78
+ std::cerr << " (" << pstate_source_position(node) << ")";
79
+ std::cerr << " [@media:" << selector->media_block() << "]";
80
+ std::cerr << (selector->is_optional() ? " [is_optional]": " -");
81
+ std::cerr << (selector->has_line_break() ? " [line-break]": " -");
82
+ std::cerr << (selector->has_line_feed() ? " [line-feed]": " -");
83
+ std::cerr << std::endl;
84
+
85
+ for(auto i : selector->elements()) { debug_ast(i, ind + " ", env); }
86
+
87
+ // } else if (dynamic_cast<Expression*>(node)) {
88
+ // Expression* expression = dynamic_cast<Expression*>(node);
89
+ // std::cerr << ind << "Expression " << expression << " " << expression->concrete_type() << std::endl;
90
+
91
+ } else if (dynamic_cast<Parent_Selector*>(node)) {
92
+ Parent_Selector* selector = dynamic_cast<Parent_Selector*>(node);
93
+ std::cerr << ind << "Parent_Selector " << selector;
94
+ // if (selector->not_selector()) cerr << " [in_declaration]";
95
+ std::cerr << " (" << pstate_source_position(node) << ")";
96
+ std::cerr << " <" << prettyprint(selector->pstate().token.ws_before()) << ">" << std::endl;
97
+ // debug_ast(selector->selector(), ind + "->", env);
98
+
99
+ } else if (dynamic_cast<Complex_Selector*>(node)) {
100
+ Complex_Selector* selector = dynamic_cast<Complex_Selector*>(node);
101
+ std::cerr << ind << "Complex_Selector " << selector
102
+ << " (" << pstate_source_position(node) << ")"
103
+ << " [weight:" << longToHex(selector->specificity()) << "]"
104
+ << " [@media:" << selector->media_block() << "]"
105
+ << (selector->is_optional() ? " [is_optional]": " -")
106
+ << (selector->has_line_feed() ? " [line-feed]": " -")
107
+ << (selector->has_line_break() ? " [line-break]": " -")
108
+ << " -- ";
109
+ std::string del;
110
+ switch (selector->combinator()) {
111
+ case Complex_Selector::PARENT_OF: del = ">"; break;
112
+ case Complex_Selector::PRECEDES: del = "~"; break;
113
+ case Complex_Selector::ADJACENT_TO: del = "+"; break;
114
+ case Complex_Selector::ANCESTOR_OF: del = " "; break;
115
+ case Complex_Selector::REFERENCE: del = "//"; break;
116
+ }
117
+ // if (del = "/") del += selector->reference()->perform(&to_string) + "/";
118
+ std::cerr << " <" << prettyprint(selector->pstate().token.ws_before()) << ">" << std::endl;
119
+ debug_ast(selector->head(), ind + " " /* + "[" + del + "]" */, env);
120
+ if (selector->tail()) {
121
+ debug_ast(selector->tail(), ind + "{" + del + "}", env);
122
+ } else if(del != " ") {
123
+ std::cerr << ind << " |" << del << "| {trailing op}" << std::endl;
124
+ }
125
+ SourcesSet set = selector->sources();
126
+ // debug_sources_set(set, ind + " @--> ");
127
+ } else if (dynamic_cast<Compound_Selector*>(node)) {
128
+ Compound_Selector* selector = dynamic_cast<Compound_Selector*>(node);
129
+ std::cerr << ind << "Compound_Selector " << selector;
130
+ std::cerr << " (" << pstate_source_position(node) << ")";
131
+ std::cerr << " [weight:" << longToHex(selector->specificity()) << "]";
132
+ std::cerr << " [@media:" << selector->media_block() << "]";
133
+ std::cerr << (selector->is_optional() ? " [is_optional]": " -");
134
+ std::cerr << (selector->has_line_break() ? " [line-break]": " -");
135
+ std::cerr << (selector->has_line_feed() ? " [line-feed]": " -");
136
+ std::cerr << " <" << prettyprint(selector->pstate().token.ws_before()) << ">" << std::endl;
137
+ for(auto i : selector->elements()) { debug_ast(i, ind + " ", env); }
138
+ } else if (dynamic_cast<Propset*>(node)) {
139
+ Propset* selector = dynamic_cast<Propset*>(node);
140
+ std::cerr << ind << "Propset " << selector;
141
+ std::cerr << " (" << pstate_source_position(node) << ")";
142
+ std::cerr << " " << selector->tabs() << std::endl;
143
+ if (selector->block()) for(auto i : selector->block()->elements()) { debug_ast(i, ind + " ", env); }
144
+ } else if (dynamic_cast<Wrapped_Selector*>(node)) {
145
+ Wrapped_Selector* selector = dynamic_cast<Wrapped_Selector*>(node);
146
+ std::cerr << ind << "Wrapped_Selector " << selector;
147
+ std::cerr << " (" << pstate_source_position(node) << ")";
148
+ std::cerr << " <<" << selector->ns_name() << ">>" << (selector->has_line_break() ? " [line-break]": " -") << (selector->has_line_feed() ? " [line-feed]": " -") << std::endl;
149
+ debug_ast(selector->selector(), ind + " () ", env);
150
+ } else if (dynamic_cast<Pseudo_Selector*>(node)) {
151
+ Pseudo_Selector* selector = dynamic_cast<Pseudo_Selector*>(node);
152
+ std::cerr << ind << "Pseudo_Selector " << selector;
153
+ std::cerr << " (" << pstate_source_position(node) << ")";
154
+ std::cerr << " <<" << selector->ns_name() << ">>" << (selector->has_line_break() ? " [line-break]": " -") << (selector->has_line_feed() ? " [line-feed]": " -") << std::endl;
155
+ debug_ast(selector->expression(), ind + " <= ", env);
156
+ } else if (dynamic_cast<Attribute_Selector*>(node)) {
157
+ Attribute_Selector* selector = dynamic_cast<Attribute_Selector*>(node);
158
+ std::cerr << ind << "Attribute_Selector " << selector;
159
+ std::cerr << " (" << pstate_source_position(node) << ")";
160
+ std::cerr << " <<" << selector->ns_name() << ">>" << (selector->has_line_break() ? " [line-break]": " -") << (selector->has_line_feed() ? " [line-feed]": " -") << std::endl;
161
+ debug_ast(selector->value(), ind + "[" + selector->matcher() + "] ", env);
162
+ } else if (dynamic_cast<Selector_Qualifier*>(node)) {
163
+ Selector_Qualifier* selector = dynamic_cast<Selector_Qualifier*>(node);
164
+ std::cerr << ind << "Selector_Qualifier " << selector;
165
+ std::cerr << " (" << pstate_source_position(node) << ")";
166
+ std::cerr << " <<" << selector->ns_name() << ">>" << (selector->has_line_break() ? " [line-break]": " -") << (selector->has_line_feed() ? " [line-feed]": " -") << std::endl;
167
+ } else if (dynamic_cast<Type_Selector*>(node)) {
168
+ Type_Selector* selector = dynamic_cast<Type_Selector*>(node);
169
+ std::cerr << ind << "Type_Selector " << selector;
170
+ std::cerr << " (" << pstate_source_position(node) << ")";
171
+ std::cerr << " <<" << selector->ns_name() << ">>" << (selector->has_line_break() ? " [line-break]": " -") <<
172
+ " <" << prettyprint(selector->pstate().token.ws_before()) << ">" << std::endl;
173
+ } else if (dynamic_cast<Selector_Placeholder*>(node)) {
174
+
175
+ Selector_Placeholder* selector = dynamic_cast<Selector_Placeholder*>(node);
176
+ std::cerr << ind << "Selector_Placeholder [" << selector->ns_name() << "] " << selector
177
+ << " [@media:" << selector->media_block() << "]"
178
+ << (selector->is_optional() ? " [is_optional]": " -")
179
+ << (selector->has_line_break() ? " [line-break]": " -")
180
+ << (selector->has_line_feed() ? " [line-feed]": " -")
181
+ << std::endl;
182
+
183
+ } else if (dynamic_cast<Simple_Selector*>(node)) {
184
+ Simple_Selector* selector = dynamic_cast<Simple_Selector*>(node);
185
+ std::cerr << ind << "Simple_Selector " << selector;
186
+ std::cerr << " (" << pstate_source_position(node) << ")";
187
+ std::cerr << (selector->has_line_break() ? " [line-break]": " -") << (selector->has_line_feed() ? " [line-feed]": " -") << std::endl;
188
+
189
+ } else if (dynamic_cast<Selector_Schema*>(node)) {
190
+ Selector_Schema* selector = dynamic_cast<Selector_Schema*>(node);
191
+ std::cerr << ind << "Selector_Schema " << selector;
192
+ std::cerr << " (" << pstate_source_position(node) << ")"
193
+ << (selector->at_root() && selector->at_root() ? " [@ROOT]" : "")
194
+ << " [@media:" << selector->media_block() << "]"
195
+ << (selector->has_line_break() ? " [line-break]": " -")
196
+ << (selector->has_line_feed() ? " [line-feed]": " -")
197
+ << std::endl;
198
+
199
+ debug_ast(selector->contents(), ind + " ");
200
+ // for(auto i : selector->elements()) { debug_ast(i, ind + " ", env); }
201
+
202
+ } else if (dynamic_cast<Selector*>(node)) {
203
+ Selector* selector = dynamic_cast<Selector*>(node);
204
+ std::cerr << ind << "Selector " << selector;
205
+ std::cerr << " (" << pstate_source_position(node) << ")";
206
+ std::cerr << (selector->has_line_break() ? " [line-break]": " -")
207
+ << (selector->has_line_feed() ? " [line-feed]": " -")
208
+ << std::endl;
209
+
210
+ } else if (dynamic_cast<Media_Query_Expression*>(node)) {
211
+ Media_Query_Expression* block = dynamic_cast<Media_Query_Expression*>(node);
212
+ std::cerr << ind << "Media_Query_Expression " << block;
213
+ std::cerr << " (" << pstate_source_position(node) << ")";
214
+ std::cerr << (block->is_interpolated() ? " [is_interpolated]": " -")
215
+ << std::endl;
216
+ debug_ast(block->feature(), ind + " feature) ");
217
+ debug_ast(block->value(), ind + " value) ");
218
+
219
+ } else if (dynamic_cast<Media_Query*>(node)) {
220
+ Media_Query* block = dynamic_cast<Media_Query*>(node);
221
+ std::cerr << ind << "Media_Query " << block;
222
+ std::cerr << " (" << pstate_source_position(node) << ")";
223
+ std::cerr << (block->is_negated() ? " [is_negated]": " -")
224
+ << (block->is_restricted() ? " [is_restricted]": " -")
225
+ << std::endl;
226
+ debug_ast(block->media_type(), ind + " ");
227
+ for(auto i : block->elements()) { debug_ast(i, ind + " ", env); }
228
+
229
+ } else if (dynamic_cast<Media_Block*>(node)) {
230
+ Media_Block* block = dynamic_cast<Media_Block*>(node);
231
+ std::cerr << ind << "Media_Block " << block;
232
+ std::cerr << " (" << pstate_source_position(node) << ")";
233
+ std::cerr << " " << block->tabs() << std::endl;
234
+ debug_ast(block->media_queries(), ind + " =@ ");
235
+ if (block->block()) for(auto i : block->block()->elements()) { debug_ast(i, ind + " ", env); }
236
+ } else if (dynamic_cast<Supports_Block*>(node)) {
237
+ Supports_Block* block = dynamic_cast<Supports_Block*>(node);
238
+ std::cerr << ind << "Supports_Block " << block;
239
+ std::cerr << " (" << pstate_source_position(node) << ")";
240
+ std::cerr << " " << block->tabs() << std::endl;
241
+ debug_ast(block->condition(), ind + " =@ ");
242
+ } else if (dynamic_cast<Supports_Operator*>(node)) {
243
+ Supports_Operator* block = dynamic_cast<Supports_Operator*>(node);
244
+ std::cerr << ind << "Supports_Operator " << block;
245
+ std::cerr << " (" << pstate_source_position(node) << ")"
246
+ << std::endl;
247
+ debug_ast(block->left(), ind + " left) ");
248
+ debug_ast(block->right(), ind + " right) ");
249
+ } else if (dynamic_cast<Supports_Negation*>(node)) {
250
+ Supports_Negation* block = dynamic_cast<Supports_Negation*>(node);
251
+ std::cerr << ind << "Supports_Negation " << block;
252
+ std::cerr << " (" << pstate_source_position(node) << ")"
253
+ << std::endl;
254
+ debug_ast(block->condition(), ind + " condition) ");
255
+ } else if (dynamic_cast<Supports_Declaration*>(node)) {
256
+ Supports_Declaration* block = dynamic_cast<Supports_Declaration*>(node);
257
+ std::cerr << ind << "Supports_Declaration " << block;
258
+ std::cerr << " (" << pstate_source_position(node) << ")"
259
+ << std::endl;
260
+ debug_ast(block->feature(), ind + " feature) ");
261
+ debug_ast(block->value(), ind + " value) ");
262
+ } else if (dynamic_cast<Block*>(node)) {
263
+ Block* root_block = dynamic_cast<Block*>(node);
264
+ std::cerr << ind << "Block " << root_block;
265
+ std::cerr << " (" << pstate_source_position(node) << ")";
266
+ if (root_block->is_root()) std::cerr << " [root]";
267
+ std::cerr << " " << root_block->tabs() << std::endl;
268
+ if (root_block->block()) for(auto i : root_block->block()->elements()) { debug_ast(i, ind + " ", env); }
269
+ } else if (dynamic_cast<Warning*>(node)) {
270
+ Warning* block = dynamic_cast<Warning*>(node);
271
+ std::cerr << ind << "Warning " << block;
272
+ std::cerr << " (" << pstate_source_position(node) << ")";
273
+ std::cerr << " " << block->tabs() << std::endl;
274
+ } else if (dynamic_cast<Error*>(node)) {
275
+ Error* block = dynamic_cast<Error*>(node);
276
+ std::cerr << ind << "Error " << block;
277
+ std::cerr << " (" << pstate_source_position(node) << ")";
278
+ std::cerr << " " << block->tabs() << std::endl;
279
+ } else if (dynamic_cast<Debug*>(node)) {
280
+ Debug* block = dynamic_cast<Debug*>(node);
281
+ std::cerr << ind << "Debug " << block;
282
+ std::cerr << " (" << pstate_source_position(node) << ")";
283
+ std::cerr << " " << block->tabs() << std::endl;
284
+ } else if (dynamic_cast<Comment*>(node)) {
285
+ Comment* block = dynamic_cast<Comment*>(node);
286
+ std::cerr << ind << "Comment " << block;
287
+ std::cerr << " (" << pstate_source_position(node) << ")";
288
+ std::cerr << " " << block->tabs() <<
289
+ " <" << prettyprint(block->pstate().token.ws_before()) << ">" << std::endl;
290
+ debug_ast(block->text(), ind + "// ", env);
291
+ } else if (dynamic_cast<If*>(node)) {
292
+ If* block = dynamic_cast<If*>(node);
293
+ std::cerr << ind << "If " << block;
294
+ std::cerr << " (" << pstate_source_position(node) << ")";
295
+ std::cerr << " " << block->tabs() << std::endl;
296
+ debug_ast(block->predicate(), ind + " = ");
297
+ debug_ast(block->block(), ind + " <>");
298
+ debug_ast(block->alternative(), ind + " ><");
299
+ } else if (dynamic_cast<Return*>(node)) {
300
+ Return* block = dynamic_cast<Return*>(node);
301
+ std::cerr << ind << "Return " << block;
302
+ std::cerr << " (" << pstate_source_position(node) << ")";
303
+ std::cerr << " " << block->tabs() << std::endl;
304
+ } else if (dynamic_cast<Extension*>(node)) {
305
+ Extension* block = dynamic_cast<Extension*>(node);
306
+ std::cerr << ind << "Extension " << block;
307
+ std::cerr << " (" << pstate_source_position(node) << ")";
308
+ std::cerr << " " << block->tabs() << std::endl;
309
+ debug_ast(block->selector(), ind + "-> ", env);
310
+ } else if (dynamic_cast<Content*>(node)) {
311
+ Content* block = dynamic_cast<Content*>(node);
312
+ std::cerr << ind << "Content " << block;
313
+ std::cerr << " (" << pstate_source_position(node) << ")";
314
+ std::cerr << " " << block->tabs() << std::endl;
315
+ } else if (dynamic_cast<Import_Stub*>(node)) {
316
+ Import_Stub* block = dynamic_cast<Import_Stub*>(node);
317
+ std::cerr << ind << "Import_Stub " << block;
318
+ std::cerr << " (" << pstate_source_position(node) << ")";
319
+ std::cerr << " " << block->tabs() << std::endl;
320
+ } else if (dynamic_cast<Import*>(node)) {
321
+ Import* block = dynamic_cast<Import*>(node);
322
+ std::cerr << ind << "Import " << block;
323
+ std::cerr << " (" << pstate_source_position(node) << ")";
324
+ std::cerr << " " << block->tabs() << std::endl;
325
+ debug_ast(block->media_queries(), ind + " @ ");
326
+ // std::vector<std::string> files_;
327
+ for (auto imp : block->urls()) debug_ast(imp, "@ ", env);
328
+ } else if (dynamic_cast<Assignment*>(node)) {
329
+ Assignment* block = dynamic_cast<Assignment*>(node);
330
+ std::cerr << ind << "Assignment " << block;
331
+ std::cerr << " (" << pstate_source_position(node) << ")";
332
+ std::cerr << " <<" << block->variable() << ">> " << block->tabs() << std::endl;
333
+ debug_ast(block->value(), ind + "=", env);
334
+ } else if (dynamic_cast<Declaration*>(node)) {
335
+ Declaration* block = dynamic_cast<Declaration*>(node);
336
+ std::cerr << ind << "Declaration " << block;
337
+ std::cerr << " (" << pstate_source_position(node) << ")";
338
+ std::cerr << " " << block->tabs() << std::endl;
339
+ debug_ast(block->property(), ind + " prop: ", env);
340
+ debug_ast(block->value(), ind + " value: ", env);
341
+ } else if (dynamic_cast<Keyframe_Rule*>(node)) {
342
+ Keyframe_Rule* has_block = dynamic_cast<Keyframe_Rule*>(node);
343
+ std::cerr << ind << "Keyframe_Rule " << has_block;
344
+ std::cerr << " (" << pstate_source_position(node) << ")";
345
+ std::cerr << " " << has_block->tabs() << std::endl;
346
+ if (has_block->selector()) debug_ast(has_block->selector(), ind + "@");
347
+ if (has_block->block()) for(auto i : has_block->block()->elements()) { debug_ast(i, ind + " ", env); }
348
+ } else if (dynamic_cast<At_Rule*>(node)) {
349
+ At_Rule* block = dynamic_cast<At_Rule*>(node);
350
+ std::cerr << ind << "At_Rule " << block;
351
+ std::cerr << " (" << pstate_source_position(node) << ")";
352
+ std::cerr << " [" << block->keyword() << "] " << block->tabs() << std::endl;
353
+ debug_ast(block->selector(), ind + "~", env);
354
+ debug_ast(block->value(), ind + "+", env);
355
+ if (block->block()) for(auto i : block->block()->elements()) { debug_ast(i, ind + " ", env); }
356
+ } else if (dynamic_cast<Each*>(node)) {
357
+ Each* block = dynamic_cast<Each*>(node);
358
+ std::cerr << ind << "Each " << block;
359
+ std::cerr << " (" << pstate_source_position(node) << ")";
360
+ std::cerr << " " << block->tabs() << std::endl;
361
+ if (block->block()) for(auto i : block->block()->elements()) { debug_ast(i, ind + " ", env); }
362
+ } else if (dynamic_cast<For*>(node)) {
363
+ For* block = dynamic_cast<For*>(node);
364
+ std::cerr << ind << "For " << block;
365
+ std::cerr << " (" << pstate_source_position(node) << ")";
366
+ std::cerr << " " << block->tabs() << std::endl;
367
+ if (block->block()) for(auto i : block->block()->elements()) { debug_ast(i, ind + " ", env); }
368
+ } else if (dynamic_cast<While*>(node)) {
369
+ While* block = dynamic_cast<While*>(node);
370
+ std::cerr << ind << "While " << block;
371
+ std::cerr << " (" << pstate_source_position(node) << ")";
372
+ std::cerr << " " << block->tabs() << std::endl;
373
+ if (block->block()) for(auto i : block->block()->elements()) { debug_ast(i, ind + " ", env); }
374
+ } else if (dynamic_cast<Definition*>(node)) {
375
+ Definition* block = dynamic_cast<Definition*>(node);
376
+ std::cerr << ind << "Definition " << block;
377
+ std::cerr << " (" << pstate_source_position(node) << ")";
378
+ std::cerr << " [name: " << block->name() << "] ";
379
+ std::cerr << " [type: " << (block->type() == Sass::Definition::Type::MIXIN ? "Mixin " : "Function ") << "] ";
380
+ // this seems to lead to segfaults some times?
381
+ // std::cerr << " [signature: " << block->signature() << "] ";
382
+ std::cerr << " [native: " << block->native_function() << "] ";
383
+ std::cerr << " " << block->tabs() << std::endl;
384
+ debug_ast(block->parameters(), ind + " params: ", env);
385
+ if (block->block()) for(auto i : block->block()->elements()) { debug_ast(i, ind + " ", env); }
386
+ } else if (dynamic_cast<Mixin_Call*>(node)) {
387
+ Mixin_Call* block = dynamic_cast<Mixin_Call*>(node);
388
+ std::cerr << ind << "Mixin_Call " << block << " " << block->tabs();
389
+ std::cerr << " [" << block->name() << "]";
390
+ std::cerr << " [has_content: " << block->has_content() << "] " << std::endl;
391
+ debug_ast(block->arguments(), ind + " args: ");
392
+ if (block->block()) for(auto i : block->block()->elements()) { debug_ast(i, ind + " ", env); }
393
+ } else if (Ruleset* ruleset = dynamic_cast<Ruleset*>(node)) {
394
+ std::cerr << ind << "Ruleset " << ruleset;
395
+ std::cerr << " (" << pstate_source_position(node) << ")";
396
+ std::cerr << " [indent: " << ruleset->tabs() << "]";
397
+ std::cerr << (ruleset->at_root() ? " [@ROOT]" : "");
398
+ std::cerr << (ruleset->is_root() ? " [root]" : "");
399
+ std::cerr << std::endl;
400
+ debug_ast(ruleset->selector(), ind + ">");
401
+ debug_ast(ruleset->block(), ind + " ");
402
+ } else if (dynamic_cast<Block*>(node)) {
403
+ Block* block = dynamic_cast<Block*>(node);
404
+ std::cerr << ind << "Block " << block;
405
+ std::cerr << " (" << pstate_source_position(node) << ")";
406
+ std::cerr << " [indent: " << block->tabs() << "]" << std::endl;
407
+ for(auto i : block->elements()) { debug_ast(i, ind + " ", env); }
408
+ } else if (dynamic_cast<Textual*>(node)) {
409
+ Textual* expression = dynamic_cast<Textual*>(node);
410
+ std::cerr << ind << "Textual ";
411
+ if (expression->type() == Textual::NUMBER) std::cerr << " [NUMBER]";
412
+ else if (expression->type() == Textual::PERCENTAGE) std::cerr << " [PERCENTAGE]";
413
+ else if (expression->type() == Textual::DIMENSION) std::cerr << " [DIMENSION]";
414
+ else if (expression->type() == Textual::HEX) std::cerr << " [HEX]";
415
+ std::cerr << expression << " [" << expression->value() << "]";
416
+ if (expression->is_delayed()) std::cerr << " [delayed]";
417
+ std::cerr << std::endl;
418
+ } else if (dynamic_cast<Variable*>(node)) {
419
+ Variable* expression = dynamic_cast<Variable*>(node);
420
+ std::cerr << ind << "Variable " << expression;
421
+ std::cerr << " (" << pstate_source_position(node) << ")";
422
+ std::cerr << " [" << expression->name() << "]" << std::endl;
423
+ std::string name(expression->name());
424
+ if (env && env->has(name)) debug_ast(static_cast<Expression*>((*env)[name]), ind + " -> ", env);
425
+ } else if (dynamic_cast<Function_Call_Schema*>(node)) {
426
+ Function_Call_Schema* expression = dynamic_cast<Function_Call_Schema*>(node);
427
+ std::cerr << ind << "Function_Call_Schema " << expression;
428
+ std::cerr << " (" << pstate_source_position(node) << ")";
429
+ std::cerr << "" << std::endl;
430
+ debug_ast(expression->name(), ind + "name: ", env);
431
+ debug_ast(expression->arguments(), ind + " args: ", env);
432
+ } else if (dynamic_cast<Function_Call*>(node)) {
433
+ Function_Call* expression = dynamic_cast<Function_Call*>(node);
434
+ std::cerr << ind << "Function_Call " << expression;
435
+ std::cerr << " (" << pstate_source_position(node) << ")";
436
+ std::cerr << " [" << expression->name() << "]" << std::endl;
437
+ debug_ast(expression->arguments(), ind + " args: ", env);
438
+ } else if (dynamic_cast<Arguments*>(node)) {
439
+ Arguments* expression = dynamic_cast<Arguments*>(node);
440
+ std::cerr << ind << "Arguments " << expression;
441
+ if (expression->is_delayed()) std::cerr << " [delayed]";
442
+ std::cerr << " (" << pstate_source_position(node) << ")";
443
+ if (expression->has_named_arguments()) std::cerr << " [has_named_arguments]";
444
+ if (expression->has_rest_argument()) std::cerr << " [has_rest_argument]";
445
+ if (expression->has_keyword_argument()) std::cerr << " [has_keyword_argument]";
446
+ std::cerr << std::endl;
447
+ for(auto i : expression->elements()) { debug_ast(i, ind + " ", env); }
448
+ } else if (dynamic_cast<Argument*>(node)) {
449
+ Argument* expression = dynamic_cast<Argument*>(node);
450
+ std::cerr << ind << "Argument " << expression;
451
+ std::cerr << " (" << pstate_source_position(node) << ")";
452
+ std::cerr << " [" << expression->value() << "]";
453
+ std::cerr << " [name: " << expression->name() << "] ";
454
+ std::cerr << " [rest: " << expression->is_rest_argument() << "] ";
455
+ std::cerr << " [keyword: " << expression->is_keyword_argument() << "] " << std::endl;
456
+ debug_ast(expression->value(), ind + " value: ", env);
457
+ } else if (dynamic_cast<Parameters*>(node)) {
458
+ Parameters* expression = dynamic_cast<Parameters*>(node);
459
+ std::cerr << ind << "Parameters " << expression;
460
+ std::cerr << " (" << pstate_source_position(node) << ")";
461
+ std::cerr << " [has_optional: " << expression->has_optional_parameters() << "] ";
462
+ std::cerr << " [has_rest: " << expression->has_rest_parameter() << "] ";
463
+ std::cerr << std::endl;
464
+ for(auto i : expression->elements()) { debug_ast(i, ind + " ", env); }
465
+ } else if (dynamic_cast<Parameter*>(node)) {
466
+ Parameter* expression = dynamic_cast<Parameter*>(node);
467
+ std::cerr << ind << "Parameter " << expression;
468
+ std::cerr << " (" << pstate_source_position(node) << ")";
469
+ std::cerr << " [name: " << expression->name() << "] ";
470
+ std::cerr << " [default: " << expression->default_value() << "] ";
471
+ std::cerr << " [rest: " << expression->is_rest_parameter() << "] " << std::endl;
472
+ } else if (dynamic_cast<Unary_Expression*>(node)) {
473
+ Unary_Expression* expression = dynamic_cast<Unary_Expression*>(node);
474
+ std::cerr << ind << "Unary_Expression " << expression;
475
+ std::cerr << " (" << pstate_source_position(node) << ")";
476
+ std::cerr << " [" << expression->type() << "]" << std::endl;
477
+ debug_ast(expression->operand(), ind + " operand: ", env);
478
+ } else if (dynamic_cast<Binary_Expression*>(node)) {
479
+ Binary_Expression* expression = dynamic_cast<Binary_Expression*>(node);
480
+ std::cerr << ind << "Binary_Expression " << expression;
481
+ std::cerr << " [delayed: " << expression->is_delayed() << "] ";
482
+ std::cerr << " (" << pstate_source_position(node) << ")";
483
+ std::cerr << " [" << expression->type_name() << "]" << std::endl;
484
+ debug_ast(expression->left(), ind + " left: ", env);
485
+ debug_ast(expression->right(), ind + " right: ", env);
486
+ } else if (dynamic_cast<Map*>(node)) {
487
+ Map* expression = dynamic_cast<Map*>(node);
488
+ std::cerr << ind << "Map " << expression;
489
+ std::cerr << " (" << pstate_source_position(node) << ")";
490
+ std::cerr << " [Hashed]" << std::endl;
491
+ for (auto i : expression->elements()) {
492
+ debug_ast(i.first, ind + " key: ");
493
+ debug_ast(i.second, ind + " val: ");
494
+ }
495
+ } else if (dynamic_cast<List*>(node)) {
496
+ List* expression = dynamic_cast<List*>(node);
497
+ std::cerr << ind << "List " << expression;
498
+ std::cerr << " (" << pstate_source_position(node) << ")";
499
+ std::cerr << " (" << expression->length() << ") " <<
500
+ (expression->separator() == SASS_COMMA ? "Comma " : "Space ") <<
501
+ " [delayed: " << expression->is_delayed() << "] " <<
502
+ " [interpolant: " << expression->is_interpolant() << "] " <<
503
+ " [arglist: " << expression->is_arglist() << "] " <<
504
+ " [hash: " << expression->hash() << "] " <<
505
+ std::endl;
506
+ for(auto i : expression->elements()) { debug_ast(i, ind + " ", env); }
507
+ } else if (dynamic_cast<Content*>(node)) {
508
+ Content* expression = dynamic_cast<Content*>(node);
509
+ std::cerr << ind << "Content " << expression;
510
+ std::cerr << " (" << pstate_source_position(node) << ")";
511
+ std::cerr << " [Statement]" << std::endl;
512
+ } else if (dynamic_cast<Boolean*>(node)) {
513
+ Boolean* expression = dynamic_cast<Boolean*>(node);
514
+ std::cerr << ind << "Boolean " << expression;
515
+ std::cerr << " (" << pstate_source_position(node) << ")";
516
+ std::cerr << " [" << expression->value() << "]" << std::endl;
517
+ } else if (dynamic_cast<Color*>(node)) {
518
+ Color* expression = dynamic_cast<Color*>(node);
519
+ std::cerr << ind << "Color " << expression;
520
+ std::cerr << " (" << pstate_source_position(node) << ")";
521
+ std::cerr << " [" << expression->r() << ":" << expression->g() << ":" << expression->b() << "@" << expression->a() << "]" << std::endl;
522
+ } else if (dynamic_cast<Number*>(node)) {
523
+ Number* expression = dynamic_cast<Number*>(node);
524
+ std::cerr << ind << "Number " << expression;
525
+ std::cerr << " (" << pstate_source_position(node) << ")";
526
+ std::cerr << " [" << expression->value() << expression->unit() << "]" << std::endl;
527
+ } else if (dynamic_cast<String_Quoted*>(node)) {
528
+ String_Quoted* expression = dynamic_cast<String_Quoted*>(node);
529
+ std::cerr << ind << "String_Quoted " << expression;
530
+ std::cerr << " (" << pstate_source_position(node) << ")";
531
+ std::cerr << " [" << prettyprint(expression->value()) << "]";
532
+ if (expression->is_delayed()) std::cerr << " [delayed]";
533
+ if (expression->sass_fix_1291()) std::cerr << " [sass_fix_1291]";
534
+ if (expression->is_interpolant()) std::cerr << " [interpolant]";
535
+ if (expression->quote_mark()) std::cerr << " [quote_mark: " << expression->quote_mark() << "]";
536
+ std::cerr << " <" << prettyprint(expression->pstate().token.ws_before()) << ">" << std::endl;
537
+ } else if (dynamic_cast<String_Constant*>(node)) {
538
+ String_Constant* expression = dynamic_cast<String_Constant*>(node);
539
+ std::cerr << ind << "String_Constant " << expression;
540
+ if (expression->concrete_type()) {
541
+ std::cerr << " " << expression->concrete_type();
542
+ }
543
+ std::cerr << " (" << pstate_source_position(node) << ")";
544
+ std::cerr << " [" << prettyprint(expression->value()) << "]";
545
+ if (expression->is_delayed()) std::cerr << " [delayed]";
546
+ if (expression->sass_fix_1291()) std::cerr << " [sass_fix_1291]";
547
+ if (expression->is_interpolant()) std::cerr << " [interpolant]";
548
+ std::cerr << " <" << prettyprint(expression->pstate().token.ws_before()) << ">" << std::endl;
549
+ } else if (dynamic_cast<String_Schema*>(node)) {
550
+ String_Schema* expression = dynamic_cast<String_Schema*>(node);
551
+ std::cerr << ind << "String_Schema " << expression;
552
+ std::cerr << " " << expression->concrete_type();
553
+ if (expression->is_delayed()) std::cerr << " [delayed]";
554
+ if (expression->has_interpolants()) std::cerr << " [has_interpolants]";
555
+ if (expression->is_interpolant()) std::cerr << " [interpolant]";
556
+ std::cerr << " <" << prettyprint(expression->pstate().token.ws_before()) << ">" << std::endl;
557
+ for(auto i : expression->elements()) { debug_ast(i, ind + " ", env); }
558
+ } else if (dynamic_cast<String*>(node)) {
559
+ String* expression = dynamic_cast<String*>(node);
560
+ std::cerr << ind << "String " << expression;
561
+ std::cerr << " " << expression->concrete_type();
562
+ std::cerr << " (" << pstate_source_position(node) << ")";
563
+ if (expression->sass_fix_1291()) std::cerr << " [sass_fix_1291]";
564
+ if (expression->is_interpolant()) std::cerr << " [interpolant]";
565
+ std::cerr << " <" << prettyprint(expression->pstate().token.ws_before()) << ">" << std::endl;
566
+ } else if (dynamic_cast<Expression*>(node)) {
567
+ Expression* expression = dynamic_cast<Expression*>(node);
568
+ std::cerr << ind << "Expression " << expression;
569
+ std::cerr << " (" << pstate_source_position(node) << ")";
570
+ switch (expression->concrete_type()) {
571
+ case Expression::Concrete_Type::NONE: std::cerr << " [NONE]"; break;
572
+ case Expression::Concrete_Type::BOOLEAN: std::cerr << " [BOOLEAN]"; break;
573
+ case Expression::Concrete_Type::NUMBER: std::cerr << " [NUMBER]"; break;
574
+ case Expression::Concrete_Type::COLOR: std::cerr << " [COLOR]"; break;
575
+ case Expression::Concrete_Type::STRING: std::cerr << " [STRING]"; break;
576
+ case Expression::Concrete_Type::LIST: std::cerr << " [LIST]"; break;
577
+ case Expression::Concrete_Type::MAP: std::cerr << " [MAP]"; break;
578
+ case Expression::Concrete_Type::SELECTOR: std::cerr << " [SELECTOR]"; break;
579
+ case Expression::Concrete_Type::NULL_VAL: std::cerr << " [NULL_VAL]"; break;
580
+ case Expression::Concrete_Type::C_WARNING: std::cerr << " [C_WARNING]"; break;
581
+ case Expression::Concrete_Type::C_ERROR: std::cerr << " [C_ERROR]"; break;
582
+ case Expression::Concrete_Type::NUM_TYPES: std::cerr << " [NUM_TYPES]"; break;
583
+ }
584
+ std::cerr << std::endl;
585
+ } else if (dynamic_cast<Has_Block*>(node)) {
586
+ Has_Block* has_block = dynamic_cast<Has_Block*>(node);
587
+ std::cerr << ind << "Has_Block " << has_block;
588
+ std::cerr << " (" << pstate_source_position(node) << ")";
589
+ std::cerr << " " << has_block->tabs() << std::endl;
590
+ if (has_block->block()) for(auto i : has_block->block()->elements()) { debug_ast(i, ind + " ", env); }
591
+ } else if (dynamic_cast<Statement*>(node)) {
592
+ Statement* statement = dynamic_cast<Statement*>(node);
593
+ std::cerr << ind << "Statement " << statement;
594
+ std::cerr << " (" << pstate_source_position(node) << ")";
595
+ std::cerr << " " << statement->tabs() << std::endl;
596
+ }
597
+
598
+ if (ind == "") std::cerr << "####################################################################\n";
599
+ }
600
+
601
+ inline void debug_node(Node* node, std::string ind = "")
602
+ {
603
+ if (ind == "") std::cerr << "#@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@\n";
604
+ if (node->isCombinator()) {
605
+ std::cerr << ind;
606
+ std::cerr << "Combinator ";
607
+ std::cerr << node << " ";
608
+ if (node->got_line_feed) std::cerr << "[LF] ";
609
+ switch (node->combinator()) {
610
+ case Complex_Selector::ADJACENT_TO: std::cerr << "{+} "; break;
611
+ case Complex_Selector::PARENT_OF: std::cerr << "{>} "; break;
612
+ case Complex_Selector::PRECEDES: std::cerr << "{~} "; break;
613
+ case Complex_Selector::REFERENCE: std::cerr << "{@} "; break;
614
+ case Complex_Selector::ANCESTOR_OF: std::cerr << "{ } "; break;
615
+ }
616
+ std::cerr << std::endl;
617
+ // debug_ast(node->combinator(), ind + " ");
618
+ } else if (node->isSelector()) {
619
+ std::cerr << ind;
620
+ std::cerr << "Selector ";
621
+ std::cerr << node << " ";
622
+ if (node->got_line_feed) std::cerr << "[LF] ";
623
+ std::cerr << std::endl;
624
+ debug_ast(node->selector(), ind + " ");
625
+ } else if (node->isCollection()) {
626
+ std::cerr << ind;
627
+ std::cerr << "Collection ";
628
+ std::cerr << node << " ";
629
+ if (node->got_line_feed) std::cerr << "[LF] ";
630
+ std::cerr << std::endl;
631
+ for(auto n : (*node->collection())) {
632
+ debug_node(&n, ind + " ");
633
+ }
634
+ } else if (node->isNil()) {
635
+ std::cerr << ind;
636
+ std::cerr << "Nil ";
637
+ std::cerr << node << " ";
638
+ if (node->got_line_feed) std::cerr << "[LF] ";
639
+ std::cerr << std::endl;
640
+ } else {
641
+ std::cerr << ind;
642
+ std::cerr << "OTHER ";
643
+ std::cerr << node << " ";
644
+ if (node->got_line_feed) std::cerr << "[LF] ";
645
+ std::cerr << std::endl;
646
+ }
647
+ if (ind == "") std::cerr << "#@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@\n";
648
+ }
649
+
650
+ inline void debug_ast(const AST_Node* node, std::string ind = "", Env* env = 0)
651
+ {
652
+ debug_ast(const_cast<AST_Node*>(node), ind, env);
653
+ }
654
+
655
+ inline void debug_node(const Node* node, std::string ind = "")
656
+ {
657
+ debug_node(const_cast<Node*>(node), ind);
658
+ }
659
+
660
+ inline void debug_extenstion_map(Sass::ExtensionSubsetMap* map, std::string ind = "")
661
+ {
662
+ if (ind == "") std::cerr << "#%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%\n";
663
+ for(auto const &it : map->values()) {
664
+ debug_ast(it.first, ind + "first: ");
665
+ debug_ast(it.second, ind + "second: ");
666
+ }
667
+ if (ind == "") std::cerr << "#%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%\n";
668
+ }
669
+
670
+ typedef std::pair<Complex_Selector*, Compound_Selector*> ExtensionPair;
671
+ typedef std::vector<ExtensionPair> SubsetMapEntries;
672
+
673
+ inline void debug_subset_entries(SubsetMapEntries* entries, std::string ind = "")
674
+ {
675
+ if (ind == "") std::cerr << "#%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%\n";
676
+ for(auto const &pair : *entries) {
677
+ debug_ast(pair.first, ind + "first: ");
678
+ debug_ast(pair.second, ind + "second: ");
679
+ }
680
+ if (ind == "") std::cerr << "#%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%\n";
681
+ }
682
+
683
+ #endif // SASS_DEBUGGER