sassc 2.1.0.pre3 → 2.4.0

Sign up to get free protection for your applications and to get access to all the features.
Files changed (147) hide show
  1. checksums.yaml +4 -4
  2. data/.travis.yml +2 -0
  3. data/CHANGELOG.md +24 -0
  4. data/Rakefile +2 -4
  5. data/ext/extconf.rb +13 -5
  6. data/ext/libsass/VERSION +1 -1
  7. data/ext/libsass/include/sass/base.h +2 -1
  8. data/ext/libsass/include/sass/context.h +4 -0
  9. data/ext/libsass/src/MurmurHash2.hpp +91 -0
  10. data/ext/libsass/src/ast.cpp +158 -168
  11. data/ext/libsass/src/ast.hpp +389 -230
  12. data/ext/libsass/src/ast_def_macros.hpp +18 -10
  13. data/ext/libsass/src/ast_fwd_decl.cpp +4 -3
  14. data/ext/libsass/src/ast_fwd_decl.hpp +98 -165
  15. data/ext/libsass/src/ast_helpers.hpp +292 -0
  16. data/ext/libsass/src/ast_sel_cmp.cpp +219 -732
  17. data/ext/libsass/src/ast_sel_super.cpp +539 -0
  18. data/ext/libsass/src/ast_sel_unify.cpp +207 -212
  19. data/ext/libsass/src/ast_sel_weave.cpp +616 -0
  20. data/ext/libsass/src/ast_selectors.cpp +594 -1026
  21. data/ext/libsass/src/ast_selectors.hpp +339 -385
  22. data/ext/libsass/src/ast_supports.cpp +36 -52
  23. data/ext/libsass/src/ast_supports.hpp +29 -29
  24. data/ext/libsass/src/ast_values.cpp +271 -84
  25. data/ext/libsass/src/ast_values.hpp +116 -107
  26. data/ext/libsass/src/backtrace.cpp +9 -9
  27. data/ext/libsass/src/backtrace.hpp +5 -5
  28. data/ext/libsass/src/base64vlq.cpp +2 -2
  29. data/ext/libsass/src/base64vlq.hpp +1 -1
  30. data/ext/libsass/src/bind.cpp +18 -18
  31. data/ext/libsass/src/bind.hpp +1 -1
  32. data/ext/libsass/src/c2ast.cpp +3 -3
  33. data/ext/libsass/src/c2ast.hpp +1 -1
  34. data/ext/libsass/src/cencode.c +4 -6
  35. data/ext/libsass/src/check_nesting.cpp +40 -41
  36. data/ext/libsass/src/check_nesting.hpp +6 -2
  37. data/ext/libsass/src/color_maps.cpp +14 -13
  38. data/ext/libsass/src/color_maps.hpp +1 -9
  39. data/ext/libsass/src/constants.cpp +5 -0
  40. data/ext/libsass/src/constants.hpp +6 -0
  41. data/ext/libsass/src/context.cpp +92 -119
  42. data/ext/libsass/src/context.hpp +41 -53
  43. data/ext/libsass/src/cssize.cpp +66 -149
  44. data/ext/libsass/src/cssize.hpp +17 -23
  45. data/ext/libsass/src/dart_helpers.hpp +199 -0
  46. data/ext/libsass/src/debugger.hpp +451 -295
  47. data/ext/libsass/src/emitter.cpp +15 -16
  48. data/ext/libsass/src/emitter.hpp +10 -12
  49. data/ext/libsass/src/environment.cpp +27 -27
  50. data/ext/libsass/src/environment.hpp +29 -24
  51. data/ext/libsass/src/error_handling.cpp +62 -41
  52. data/ext/libsass/src/error_handling.hpp +61 -51
  53. data/ext/libsass/src/eval.cpp +167 -281
  54. data/ext/libsass/src/eval.hpp +27 -29
  55. data/ext/libsass/src/eval_selectors.cpp +75 -0
  56. data/ext/libsass/src/expand.cpp +275 -222
  57. data/ext/libsass/src/expand.hpp +36 -16
  58. data/ext/libsass/src/extender.cpp +1188 -0
  59. data/ext/libsass/src/extender.hpp +399 -0
  60. data/ext/libsass/src/extension.cpp +43 -0
  61. data/ext/libsass/src/extension.hpp +89 -0
  62. data/ext/libsass/src/file.cpp +81 -72
  63. data/ext/libsass/src/file.hpp +28 -37
  64. data/ext/libsass/src/fn_colors.cpp +20 -18
  65. data/ext/libsass/src/fn_lists.cpp +30 -29
  66. data/ext/libsass/src/fn_maps.cpp +3 -3
  67. data/ext/libsass/src/fn_miscs.cpp +34 -46
  68. data/ext/libsass/src/fn_numbers.cpp +20 -13
  69. data/ext/libsass/src/fn_selectors.cpp +98 -128
  70. data/ext/libsass/src/fn_strings.cpp +47 -33
  71. data/ext/libsass/src/fn_utils.cpp +31 -29
  72. data/ext/libsass/src/fn_utils.hpp +17 -11
  73. data/ext/libsass/src/inspect.cpp +186 -148
  74. data/ext/libsass/src/inspect.hpp +31 -29
  75. data/ext/libsass/src/lexer.cpp +20 -82
  76. data/ext/libsass/src/lexer.hpp +5 -16
  77. data/ext/libsass/src/listize.cpp +23 -37
  78. data/ext/libsass/src/listize.hpp +8 -9
  79. data/ext/libsass/src/mapping.hpp +1 -0
  80. data/ext/libsass/src/memory.hpp +12 -0
  81. data/ext/libsass/src/memory/allocator.cpp +48 -0
  82. data/ext/libsass/src/memory/allocator.hpp +138 -0
  83. data/ext/libsass/src/memory/config.hpp +20 -0
  84. data/ext/libsass/src/memory/memory_pool.hpp +186 -0
  85. data/ext/libsass/src/memory/{SharedPtr.cpp → shared_ptr.cpp} +2 -2
  86. data/ext/libsass/src/memory/{SharedPtr.hpp → shared_ptr.hpp} +55 -9
  87. data/ext/libsass/src/operation.hpp +71 -61
  88. data/ext/libsass/src/operators.cpp +19 -18
  89. data/ext/libsass/src/operators.hpp +11 -11
  90. data/ext/libsass/src/ordered_map.hpp +112 -0
  91. data/ext/libsass/src/output.cpp +45 -64
  92. data/ext/libsass/src/output.hpp +6 -6
  93. data/ext/libsass/src/parser.cpp +512 -700
  94. data/ext/libsass/src/parser.hpp +89 -97
  95. data/ext/libsass/src/parser_selectors.cpp +189 -0
  96. data/ext/libsass/src/permutate.hpp +164 -0
  97. data/ext/libsass/src/plugins.cpp +7 -7
  98. data/ext/libsass/src/plugins.hpp +8 -8
  99. data/ext/libsass/src/position.cpp +7 -26
  100. data/ext/libsass/src/position.hpp +44 -21
  101. data/ext/libsass/src/prelexer.cpp +6 -6
  102. data/ext/libsass/src/remove_placeholders.cpp +55 -56
  103. data/ext/libsass/src/remove_placeholders.hpp +21 -18
  104. data/ext/libsass/src/sass.cpp +16 -15
  105. data/ext/libsass/src/sass.hpp +10 -5
  106. data/ext/libsass/src/sass2scss.cpp +4 -4
  107. data/ext/libsass/src/sass_context.cpp +91 -122
  108. data/ext/libsass/src/sass_context.hpp +2 -2
  109. data/ext/libsass/src/sass_functions.cpp +1 -1
  110. data/ext/libsass/src/sass_values.cpp +8 -11
  111. data/ext/libsass/src/settings.hpp +19 -0
  112. data/ext/libsass/src/source.cpp +69 -0
  113. data/ext/libsass/src/source.hpp +95 -0
  114. data/ext/libsass/src/source_data.hpp +32 -0
  115. data/ext/libsass/src/source_map.cpp +22 -18
  116. data/ext/libsass/src/source_map.hpp +12 -9
  117. data/ext/libsass/src/stylesheet.cpp +22 -0
  118. data/ext/libsass/src/stylesheet.hpp +57 -0
  119. data/ext/libsass/src/to_value.cpp +2 -2
  120. data/ext/libsass/src/to_value.hpp +1 -1
  121. data/ext/libsass/src/units.cpp +24 -22
  122. data/ext/libsass/src/units.hpp +8 -8
  123. data/ext/libsass/src/utf8_string.cpp +9 -10
  124. data/ext/libsass/src/utf8_string.hpp +7 -6
  125. data/ext/libsass/src/util.cpp +48 -50
  126. data/ext/libsass/src/util.hpp +20 -21
  127. data/ext/libsass/src/util_string.cpp +111 -61
  128. data/ext/libsass/src/util_string.hpp +62 -8
  129. data/ext/libsass/src/values.cpp +12 -12
  130. data/lib/sassc/engine.rb +5 -3
  131. data/lib/sassc/functions_handler.rb +11 -13
  132. data/lib/sassc/native.rb +9 -7
  133. data/lib/sassc/script.rb +4 -6
  134. data/lib/sassc/version.rb +1 -1
  135. data/test/functions_test.rb +38 -1
  136. data/test/native_test.rb +4 -4
  137. metadata +31 -18
  138. data/ext/libsass/src/extend.cpp +0 -2132
  139. data/ext/libsass/src/extend.hpp +0 -86
  140. data/ext/libsass/src/node.cpp +0 -322
  141. data/ext/libsass/src/node.hpp +0 -118
  142. data/ext/libsass/src/paths.hpp +0 -71
  143. data/ext/libsass/src/sass_util.cpp +0 -152
  144. data/ext/libsass/src/sass_util.hpp +0 -256
  145. data/ext/libsass/src/subset_map.cpp +0 -58
  146. data/ext/libsass/src/subset_map.hpp +0 -76
  147. data/lib/sassc/native/lib_c.rb +0 -21
@@ -0,0 +1,164 @@
1
+ #ifndef SASS_PATHS_H
2
+ #define SASS_PATHS_H
3
+
4
+ #include <vector>
5
+
6
+ namespace Sass {
7
+
8
+ // Returns a list of all possible paths through the given lists.
9
+ //
10
+ // For example, given `[[1, 2], [3, 4], [5, 6]]`, this returns:
11
+ //
12
+ // ```
13
+ // [[1, 3, 5],
14
+ // [2, 3, 5],
15
+ // [1, 4, 5],
16
+ // [2, 4, 5],
17
+ // [1, 3, 6],
18
+ // [2, 3, 6],
19
+ // [1, 4, 6],
20
+ // [2, 4, 6]]
21
+ // ```
22
+ //
23
+ // Note: called `paths` in dart-sass
24
+ template <class T>
25
+ sass::vector<sass::vector<T>> permutate(
26
+ const sass::vector<sass::vector<T>>& in)
27
+ {
28
+
29
+ size_t L = in.size(), n = 0;
30
+
31
+ if (L == 0) return {};
32
+ // Exit early if any entry is empty
33
+ for (size_t i = 0; i < L; i += 1) {
34
+ if (in[i].size() == 0) return {};
35
+ }
36
+
37
+ size_t* state = new size_t[L + 1];
38
+ sass::vector<sass::vector<T>> out;
39
+
40
+ // First initialize all states for every permutation group
41
+ for (size_t i = 0; i < L; i += 1) {
42
+ state[i] = in[i].size() - 1;
43
+ }
44
+ while (true) {
45
+ sass::vector<T> perm;
46
+ // Create one permutation for state
47
+ for (size_t i = 0; i < L; i += 1) {
48
+ perm.push_back(in.at(i).at(in[i].size() - state[i] - 1));
49
+ }
50
+ // Current group finished
51
+ if (state[n] == 0) {
52
+ // Find position of next decrement
53
+ while (n < L && state[++n] == 0) {}
54
+
55
+ if (n == L) {
56
+ out.push_back(perm);
57
+ break;
58
+ }
59
+
60
+ state[n] -= 1;
61
+
62
+ for (size_t p = 0; p < n; p += 1) {
63
+ state[p] = in[p].size() - 1;
64
+ }
65
+
66
+ // Restart from front
67
+ n = 0;
68
+
69
+ }
70
+ else {
71
+ state[n] -= 1;
72
+ }
73
+ out.push_back(perm);
74
+ }
75
+
76
+ delete[] state;
77
+ return out;
78
+ }
79
+ // EO permutate
80
+
81
+ // ToDo: this variant is used in resolveParentSelectors
82
+ // Returns a list of all possible paths through the given lists.
83
+ //
84
+ // For example, given `[[1, 2], [3, 4], [5, 6]]`, this returns:
85
+ //
86
+ // ```
87
+ // [[1, 3, 5],
88
+ // [1, 3, 6],
89
+ // [1, 4, 5],
90
+ // [1, 4, 6],
91
+ // [2, 3, 5],
92
+ // [2, 3, 6],
93
+ // [2, 4, 5],
94
+ // [2, 4, 6]]
95
+ // ```
96
+ //
97
+ template <class T>
98
+ sass::vector<sass::vector<T>>
99
+ permutateAlt(const sass::vector<sass::vector<T>>& in) {
100
+
101
+ size_t L = in.size();
102
+ size_t n = in.size() - 1;
103
+
104
+ if (L == 0) return {};
105
+ // Exit early if any entry is empty
106
+ for (size_t i = 0; i < L; i += 1) {
107
+ if (in[i].size() == 0) return {};
108
+ }
109
+
110
+ size_t* state = new size_t[L];
111
+ sass::vector<sass::vector<T>> out;
112
+
113
+ // First initialize all states for every permutation group
114
+ for (size_t i = 0; i < L; i += 1) {
115
+ state[i] = in[i].size() - 1;
116
+ }
117
+
118
+ while (true) {
119
+ /*
120
+ // std::cerr << "PERM: ";
121
+ for (size_t p = 0; p < L; p++)
122
+ { // std::cerr << state[p] << " "; }
123
+ // std::cerr << "\n";
124
+ */
125
+ sass::vector<T> perm;
126
+ // Create one permutation for state
127
+ for (size_t i = 0; i < L; i += 1) {
128
+ perm.push_back(in.at(i).at(in[i].size() - state[i] - 1));
129
+ }
130
+ // Current group finished
131
+ if (state[n] == 0) {
132
+ // Find position of next decrement
133
+ while (n > 0 && state[--n] == 0) {}
134
+
135
+ // Check for end condition
136
+ if (state[n] != 0) {
137
+ // Decrease next on the left side
138
+ state[n] -= 1;
139
+ // Reset all counters to the right
140
+ for (size_t p = n + 1; p < L; p += 1) {
141
+ state[p] = in[p].size() - 1;
142
+ }
143
+ // Restart from end
144
+ n = L - 1;
145
+ }
146
+ else {
147
+ out.push_back(perm);
148
+ break;
149
+ }
150
+ }
151
+ else {
152
+ state[n] -= 1;
153
+ }
154
+ out.push_back(perm);
155
+ }
156
+
157
+ delete[] state;
158
+ return out;
159
+ }
160
+ // EO permutateAlt
161
+
162
+ }
163
+
164
+ #endif
@@ -44,18 +44,18 @@ namespace Sass {
44
44
  if (!strcmp(our_version, "[na]")) return false;
45
45
 
46
46
  // find the position of the second dot
47
- size_t pos = std::string(our_version).find('.', 0);
48
- if (pos != std::string::npos) pos = std::string(our_version).find('.', pos + 1);
47
+ size_t pos = sass::string(our_version).find('.', 0);
48
+ if (pos != sass::string::npos) pos = sass::string(our_version).find('.', pos + 1);
49
49
 
50
50
  // if we do not have two dots we fallback to compare complete string
51
- if (pos == std::string::npos) { return strcmp(their_version, our_version) ? 0 : 1; }
51
+ if (pos == sass::string::npos) { return strcmp(their_version, our_version) ? 0 : 1; }
52
52
  // otherwise only compare up to the second dot (major versions)
53
53
  else { return strncmp(their_version, our_version, pos) ? 0 : 1; }
54
54
 
55
55
  }
56
56
 
57
57
  // load one specific plugin
58
- bool Plugins::load_plugin (const std::string& path)
58
+ bool Plugins::load_plugin (const sass::string& path)
59
59
  {
60
60
 
61
61
  typedef const char* (*__plugin_version__)(void);
@@ -112,7 +112,7 @@ namespace Sass {
112
112
 
113
113
  }
114
114
 
115
- size_t Plugins::load_plugins(const std::string& path)
115
+ size_t Plugins::load_plugins(const sass::string& path)
116
116
  {
117
117
 
118
118
  // count plugins
@@ -126,7 +126,7 @@ namespace Sass {
126
126
  // use wchar (utf16)
127
127
  WIN32_FIND_DATAW data;
128
128
  // trailing slash is guaranteed
129
- std::string globsrch(path + "*.dll");
129
+ sass::string globsrch(path + "*.dll");
130
130
  // convert to wide chars (utf16) for system call
131
131
  std::wstring wglobsrch(UTF_8::convert_to_utf16(globsrch));
132
132
  HANDLE hFile = FindFirstFileW(wglobsrch.c_str(), &data);
@@ -140,7 +140,7 @@ namespace Sass {
140
140
  try
141
141
  {
142
142
  // the system will report the filenames with wide chars (utf16)
143
- std::string entry = UTF_8::convert_from_utf16(data.cFileName);
143
+ sass::string entry = UTF_8::convert_from_utf16(data.cFileName);
144
144
  // check if file ending matches exactly
145
145
  if (!ends_with(entry, ".dll")) continue;
146
146
  // load the plugin and increase counter
@@ -36,19 +36,19 @@ namespace Sass {
36
36
 
37
37
  public: // methods
38
38
  // load one specific plugin
39
- bool load_plugin(const std::string& path);
39
+ bool load_plugin(const sass::string& path);
40
40
  // load all plugins from a directory
41
- size_t load_plugins(const std::string& path);
41
+ size_t load_plugins(const sass::string& path);
42
42
 
43
43
  public: // public accessors
44
- const std::vector<Sass_Importer_Entry> get_headers(void) { return headers; }
45
- const std::vector<Sass_Importer_Entry> get_importers(void) { return importers; }
46
- const std::vector<Sass_Function_Entry> get_functions(void) { return functions; }
44
+ const sass::vector<Sass_Importer_Entry> get_headers(void) { return headers; }
45
+ const sass::vector<Sass_Importer_Entry> get_importers(void) { return importers; }
46
+ const sass::vector<Sass_Function_Entry> get_functions(void) { return functions; }
47
47
 
48
48
  private: // private vars
49
- std::vector<Sass_Importer_Entry> headers;
50
- std::vector<Sass_Importer_Entry> importers;
51
- std::vector<Sass_Function_Entry> functions;
49
+ sass::vector<Sass_Importer_Entry> headers;
50
+ sass::vector<Sass_Importer_Entry> importers;
51
+ sass::vector<Sass_Function_Entry> functions;
52
52
 
53
53
  };
54
54
 
@@ -3,6 +3,7 @@
3
3
  #include "sass.hpp"
4
4
 
5
5
  #include "position.hpp"
6
+ #include "source.hpp"
6
7
 
7
8
  namespace Sass {
8
9
 
@@ -18,7 +19,7 @@ namespace Sass {
18
19
  *this = inc(string, string + strlen(string));
19
20
  }
20
21
 
21
- Offset::Offset(const std::string& text)
22
+ Offset::Offset(const sass::string& text)
22
23
  : line(0), column(0)
23
24
  {
24
25
  *this = inc(text.c_str(), text.c_str() + text.size());
@@ -56,7 +57,7 @@ namespace Sass {
56
57
  // skip over 10xxxxxx
57
58
  // is 1st bit not set
58
59
  if ((chr & 128) == 0) {
59
- // regular ascii char
60
+ // regular ASCII char
60
61
  column += 1;
61
62
  }
62
63
  // is 2nd bit not set
@@ -117,14 +118,11 @@ namespace Sass {
117
118
  : Offset(line, column), file(file) { }
118
119
 
119
120
 
120
- ParserState::ParserState(const char* path, const char* src, const size_t file)
121
- : Position(file, 0, 0), path(path), src(src), offset(0, 0), token() { }
121
+ SourceSpan::SourceSpan(const char* path)
122
+ : source(SASS_MEMORY_NEW(SynthFile, path)), position(0, 0), offset(0, 0) { }
122
123
 
123
- ParserState::ParserState(const char* path, const char* src, const Position& position, Offset offset)
124
- : Position(position), path(path), src(src), offset(offset), token() { }
125
-
126
- ParserState::ParserState(const char* path, const char* src, const Token& token, const Position& position, Offset offset)
127
- : Position(position), path(path), src(src), offset(offset), token(token) { }
124
+ SourceSpan::SourceSpan(SourceDataObj source, const Offset& position, const Offset& offset)
125
+ : source(source), position(position), offset(offset) { }
128
126
 
129
127
  Position Position::add(const char* begin, const char* end)
130
128
  {
@@ -164,21 +162,4 @@ namespace Sass {
164
162
  return Offset(line - off.line, off.line == line ? column - off.column : column);
165
163
  }
166
164
 
167
- /* not used anymore - remove?
168
- std::ostream& operator<<(std::ostream& strm, const Offset& off)
169
- {
170
- if (off.line == string::npos) strm << "-1:"; else strm << off.line << ":";
171
- if (off.column == string::npos) strm << "-1"; else strm << off.column;
172
- return strm;
173
- } */
174
-
175
- /* not used anymore - remove?
176
- std::ostream& operator<<(std::ostream& strm, const Position& pos)
177
- {
178
- if (pos.file != string::npos) strm << pos.file << ":";
179
- if (pos.line == string::npos) strm << "-1:"; else strm << pos.line << ":";
180
- if (pos.column == string::npos) strm << "-1"; else strm << pos.column;
181
- return strm;
182
- } */
183
-
184
165
  }
@@ -3,7 +3,8 @@
3
3
 
4
4
  #include <string>
5
5
  #include <cstring>
6
- // #include <iostream>
6
+ #include "source_data.hpp"
7
+ #include "ast_fwd_decl.hpp"
7
8
 
8
9
  namespace Sass {
9
10
 
@@ -13,7 +14,7 @@ namespace Sass {
13
14
  public: // c-tor
14
15
  Offset(const char chr);
15
16
  Offset(const char* string);
16
- Offset(const std::string& text);
17
+ Offset(const sass::string& text);
17
18
  Offset(const size_t line, const size_t column);
18
19
 
19
20
  // return new position, incremented by the given string
@@ -85,37 +86,59 @@ namespace Sass {
85
86
  : prefix(p), begin(b), end(e) { }
86
87
 
87
88
  size_t length() const { return end - begin; }
88
- std::string ws_before() const { return std::string(prefix, begin); }
89
- const std::string to_string() const { return std::string(begin, end); }
90
- std::string time_wspace() const {
91
- std::string str(to_string());
92
- std::string whitespaces(" \t\f\v\n\r");
89
+ sass::string ws_before() const { return sass::string(prefix, begin); }
90
+ sass::string to_string() const { return sass::string(begin, end); }
91
+ sass::string time_wspace() const {
92
+ sass::string str(to_string());
93
+ sass::string whitespaces(" \t\f\v\n\r");
93
94
  return str.erase(str.find_last_not_of(whitespaces)+1);
94
95
  }
95
96
 
96
97
  operator bool() { return begin && end && begin >= end; }
97
- operator std::string() { return to_string(); }
98
+ operator sass::string() { return to_string(); }
98
99
 
99
100
  bool operator==(Token t) { return to_string() == t.to_string(); }
100
101
  };
101
102
 
102
- class ParserState : public Position {
103
+ class SourceSpan {
103
104
 
104
- public: // c-tor
105
- ParserState(const char* path, const char* src = 0, const size_t file = std::string::npos);
106
- ParserState(const char* path, const char* src, const Position& position, Offset offset = Offset(0, 0));
107
- ParserState(const char* path, const char* src, const Token& token, const Position& position, Offset offset = Offset(0, 0));
105
+ public:
108
106
 
109
- public: // down casts
110
- Offset off() { return *this; }
111
- Position pos() { return *this; }
112
- ParserState pstate() { return *this; }
107
+ SourceSpan(const char* path);
113
108
 
114
- public:
115
- const char* path;
116
- const char* src;
109
+ SourceSpan(SourceDataObj source,
110
+ const Offset& position = Offset(0, 0),
111
+ const Offset& offset = Offset(0, 0));
112
+
113
+ const char* getPath() const {
114
+ return source->getPath();
115
+ }
116
+
117
+ const char* getRawData() const {
118
+ return source->getRawData();
119
+ }
120
+
121
+ Offset getPosition() const {
122
+ return position;
123
+ }
124
+
125
+ size_t getLine() const {
126
+ return position.line + 1;
127
+ }
128
+
129
+ size_t getColumn() const {
130
+ return position.column + 1;
131
+ }
132
+
133
+ size_t getSrcId() const {
134
+ return source == nullptr
135
+ ? std::string::npos
136
+ : source->getSrcId();
137
+ }
138
+
139
+ SourceDataObj source;
140
+ Offset position;
117
141
  Offset offset;
118
- Token token;
119
142
 
120
143
  };
121
144
 
@@ -2,10 +2,10 @@
2
2
  // __EXTENSIONS__ fix on Solaris.
3
3
  #include "sass.hpp"
4
4
 
5
- #include <cctype>
6
5
  #include <iostream>
7
6
  #include <iomanip>
8
7
  #include "util.hpp"
8
+ #include "util_string.hpp"
9
9
  #include "position.hpp"
10
10
  #include "prelexer.hpp"
11
11
  #include "constants.hpp"
@@ -336,7 +336,7 @@ namespace Sass {
336
336
  return alternatives<
337
337
  unicode_seq,
338
338
  alpha,
339
- unicode,
339
+ nonascii,
340
340
  exactly<'-'>,
341
341
  exactly<'_'>,
342
342
  NONASCII,
@@ -351,7 +351,7 @@ namespace Sass {
351
351
  return alternatives<
352
352
  unicode_seq,
353
353
  alnum,
354
- unicode,
354
+ nonascii,
355
355
  exactly<'-'>,
356
356
  exactly<'_'>,
357
357
  NONASCII,
@@ -385,7 +385,7 @@ namespace Sass {
385
385
  {
386
386
  return alternatives <
387
387
  alpha,
388
- unicode,
388
+ nonascii,
389
389
  escape_seq,
390
390
  exactly<'_'>
391
391
  >(src);
@@ -395,7 +395,7 @@ namespace Sass {
395
395
  {
396
396
  return alternatives <
397
397
  alnum,
398
- unicode,
398
+ nonascii,
399
399
  escape_seq,
400
400
  exactly<'_'>
401
401
  >(src);
@@ -1400,7 +1400,7 @@ namespace Sass {
1400
1400
  }*/
1401
1401
 
1402
1402
  const char* H(const char* src) {
1403
- return std::isxdigit(static_cast<unsigned char>(*src)) ? src+1 : 0;
1403
+ return Util::ascii_isxdigit(static_cast<unsigned char>(*src)) ? src+1 : 0;
1404
1404
  }
1405
1405
 
1406
1406
  const char* W(const char* src) {