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.
- checksums.yaml +4 -4
- data/.travis.yml +2 -0
- data/CHANGELOG.md +24 -0
- data/Rakefile +2 -4
- data/ext/extconf.rb +13 -5
- data/ext/libsass/VERSION +1 -1
- data/ext/libsass/include/sass/base.h +2 -1
- data/ext/libsass/include/sass/context.h +4 -0
- data/ext/libsass/src/MurmurHash2.hpp +91 -0
- data/ext/libsass/src/ast.cpp +158 -168
- data/ext/libsass/src/ast.hpp +389 -230
- data/ext/libsass/src/ast_def_macros.hpp +18 -10
- data/ext/libsass/src/ast_fwd_decl.cpp +4 -3
- data/ext/libsass/src/ast_fwd_decl.hpp +98 -165
- data/ext/libsass/src/ast_helpers.hpp +292 -0
- data/ext/libsass/src/ast_sel_cmp.cpp +219 -732
- data/ext/libsass/src/ast_sel_super.cpp +539 -0
- data/ext/libsass/src/ast_sel_unify.cpp +207 -212
- data/ext/libsass/src/ast_sel_weave.cpp +616 -0
- data/ext/libsass/src/ast_selectors.cpp +594 -1026
- data/ext/libsass/src/ast_selectors.hpp +339 -385
- data/ext/libsass/src/ast_supports.cpp +36 -52
- data/ext/libsass/src/ast_supports.hpp +29 -29
- data/ext/libsass/src/ast_values.cpp +271 -84
- data/ext/libsass/src/ast_values.hpp +116 -107
- data/ext/libsass/src/backtrace.cpp +9 -9
- data/ext/libsass/src/backtrace.hpp +5 -5
- data/ext/libsass/src/base64vlq.cpp +2 -2
- data/ext/libsass/src/base64vlq.hpp +1 -1
- data/ext/libsass/src/bind.cpp +18 -18
- data/ext/libsass/src/bind.hpp +1 -1
- data/ext/libsass/src/c2ast.cpp +3 -3
- data/ext/libsass/src/c2ast.hpp +1 -1
- data/ext/libsass/src/cencode.c +4 -6
- data/ext/libsass/src/check_nesting.cpp +40 -41
- data/ext/libsass/src/check_nesting.hpp +6 -2
- data/ext/libsass/src/color_maps.cpp +14 -13
- data/ext/libsass/src/color_maps.hpp +1 -9
- data/ext/libsass/src/constants.cpp +5 -0
- data/ext/libsass/src/constants.hpp +6 -0
- data/ext/libsass/src/context.cpp +92 -119
- data/ext/libsass/src/context.hpp +41 -53
- data/ext/libsass/src/cssize.cpp +66 -149
- data/ext/libsass/src/cssize.hpp +17 -23
- data/ext/libsass/src/dart_helpers.hpp +199 -0
- data/ext/libsass/src/debugger.hpp +451 -295
- data/ext/libsass/src/emitter.cpp +15 -16
- data/ext/libsass/src/emitter.hpp +10 -12
- data/ext/libsass/src/environment.cpp +27 -27
- data/ext/libsass/src/environment.hpp +29 -24
- data/ext/libsass/src/error_handling.cpp +62 -41
- data/ext/libsass/src/error_handling.hpp +61 -51
- data/ext/libsass/src/eval.cpp +167 -281
- data/ext/libsass/src/eval.hpp +27 -29
- data/ext/libsass/src/eval_selectors.cpp +75 -0
- data/ext/libsass/src/expand.cpp +275 -222
- data/ext/libsass/src/expand.hpp +36 -16
- data/ext/libsass/src/extender.cpp +1188 -0
- data/ext/libsass/src/extender.hpp +399 -0
- data/ext/libsass/src/extension.cpp +43 -0
- data/ext/libsass/src/extension.hpp +89 -0
- data/ext/libsass/src/file.cpp +81 -72
- data/ext/libsass/src/file.hpp +28 -37
- data/ext/libsass/src/fn_colors.cpp +20 -18
- data/ext/libsass/src/fn_lists.cpp +30 -29
- data/ext/libsass/src/fn_maps.cpp +3 -3
- data/ext/libsass/src/fn_miscs.cpp +34 -46
- data/ext/libsass/src/fn_numbers.cpp +20 -13
- data/ext/libsass/src/fn_selectors.cpp +98 -128
- data/ext/libsass/src/fn_strings.cpp +47 -33
- data/ext/libsass/src/fn_utils.cpp +31 -29
- data/ext/libsass/src/fn_utils.hpp +17 -11
- data/ext/libsass/src/inspect.cpp +186 -148
- data/ext/libsass/src/inspect.hpp +31 -29
- data/ext/libsass/src/lexer.cpp +20 -82
- data/ext/libsass/src/lexer.hpp +5 -16
- data/ext/libsass/src/listize.cpp +23 -37
- data/ext/libsass/src/listize.hpp +8 -9
- data/ext/libsass/src/mapping.hpp +1 -0
- data/ext/libsass/src/memory.hpp +12 -0
- data/ext/libsass/src/memory/allocator.cpp +48 -0
- data/ext/libsass/src/memory/allocator.hpp +138 -0
- data/ext/libsass/src/memory/config.hpp +20 -0
- data/ext/libsass/src/memory/memory_pool.hpp +186 -0
- data/ext/libsass/src/memory/{SharedPtr.cpp → shared_ptr.cpp} +2 -2
- data/ext/libsass/src/memory/{SharedPtr.hpp → shared_ptr.hpp} +55 -9
- data/ext/libsass/src/operation.hpp +71 -61
- data/ext/libsass/src/operators.cpp +19 -18
- data/ext/libsass/src/operators.hpp +11 -11
- data/ext/libsass/src/ordered_map.hpp +112 -0
- data/ext/libsass/src/output.cpp +45 -64
- data/ext/libsass/src/output.hpp +6 -6
- data/ext/libsass/src/parser.cpp +512 -700
- data/ext/libsass/src/parser.hpp +89 -97
- data/ext/libsass/src/parser_selectors.cpp +189 -0
- data/ext/libsass/src/permutate.hpp +164 -0
- data/ext/libsass/src/plugins.cpp +7 -7
- data/ext/libsass/src/plugins.hpp +8 -8
- data/ext/libsass/src/position.cpp +7 -26
- data/ext/libsass/src/position.hpp +44 -21
- data/ext/libsass/src/prelexer.cpp +6 -6
- data/ext/libsass/src/remove_placeholders.cpp +55 -56
- data/ext/libsass/src/remove_placeholders.hpp +21 -18
- data/ext/libsass/src/sass.cpp +16 -15
- data/ext/libsass/src/sass.hpp +10 -5
- data/ext/libsass/src/sass2scss.cpp +4 -4
- data/ext/libsass/src/sass_context.cpp +91 -122
- data/ext/libsass/src/sass_context.hpp +2 -2
- data/ext/libsass/src/sass_functions.cpp +1 -1
- data/ext/libsass/src/sass_values.cpp +8 -11
- data/ext/libsass/src/settings.hpp +19 -0
- data/ext/libsass/src/source.cpp +69 -0
- data/ext/libsass/src/source.hpp +95 -0
- data/ext/libsass/src/source_data.hpp +32 -0
- data/ext/libsass/src/source_map.cpp +22 -18
- data/ext/libsass/src/source_map.hpp +12 -9
- data/ext/libsass/src/stylesheet.cpp +22 -0
- data/ext/libsass/src/stylesheet.hpp +57 -0
- data/ext/libsass/src/to_value.cpp +2 -2
- data/ext/libsass/src/to_value.hpp +1 -1
- data/ext/libsass/src/units.cpp +24 -22
- data/ext/libsass/src/units.hpp +8 -8
- data/ext/libsass/src/utf8_string.cpp +9 -10
- data/ext/libsass/src/utf8_string.hpp +7 -6
- data/ext/libsass/src/util.cpp +48 -50
- data/ext/libsass/src/util.hpp +20 -21
- data/ext/libsass/src/util_string.cpp +111 -61
- data/ext/libsass/src/util_string.hpp +62 -8
- data/ext/libsass/src/values.cpp +12 -12
- data/lib/sassc/engine.rb +5 -3
- data/lib/sassc/functions_handler.rb +11 -13
- data/lib/sassc/native.rb +9 -7
- data/lib/sassc/script.rb +4 -6
- data/lib/sassc/version.rb +1 -1
- data/test/functions_test.rb +38 -1
- data/test/native_test.rb +4 -4
- metadata +31 -18
- data/ext/libsass/src/extend.cpp +0 -2132
- data/ext/libsass/src/extend.hpp +0 -86
- data/ext/libsass/src/node.cpp +0 -322
- data/ext/libsass/src/node.hpp +0 -118
- data/ext/libsass/src/paths.hpp +0 -71
- data/ext/libsass/src/sass_util.cpp +0 -152
- data/ext/libsass/src/sass_util.hpp +0 -256
- data/ext/libsass/src/subset_map.cpp +0 -58
- data/ext/libsass/src/subset_map.hpp +0 -76
- 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
|
data/ext/libsass/src/plugins.cpp
CHANGED
@@ -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 =
|
48
|
-
if (pos !=
|
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 ==
|
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
|
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
|
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
|
-
|
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
|
-
|
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
|
data/ext/libsass/src/plugins.hpp
CHANGED
@@ -36,19 +36,19 @@ namespace Sass {
|
|
36
36
|
|
37
37
|
public: // methods
|
38
38
|
// load one specific plugin
|
39
|
-
bool load_plugin(const
|
39
|
+
bool load_plugin(const sass::string& path);
|
40
40
|
// load all plugins from a directory
|
41
|
-
size_t load_plugins(const
|
41
|
+
size_t load_plugins(const sass::string& path);
|
42
42
|
|
43
43
|
public: // public accessors
|
44
|
-
const
|
45
|
-
const
|
46
|
-
const
|
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
|
-
|
50
|
-
|
51
|
-
|
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
|
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
|
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
|
-
|
121
|
-
:
|
121
|
+
SourceSpan::SourceSpan(const char* path)
|
122
|
+
: source(SASS_MEMORY_NEW(SynthFile, path)), position(0, 0), offset(0, 0) { }
|
122
123
|
|
123
|
-
|
124
|
-
|
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
|
-
|
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
|
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
|
-
|
89
|
-
|
90
|
-
|
91
|
-
|
92
|
-
|
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
|
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
|
103
|
+
class SourceSpan {
|
103
104
|
|
104
|
-
public:
|
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
|
-
|
110
|
-
Offset off() { return *this; }
|
111
|
-
Position pos() { return *this; }
|
112
|
-
ParserState pstate() { return *this; }
|
107
|
+
SourceSpan(const char* path);
|
113
108
|
|
114
|
-
|
115
|
-
|
116
|
-
|
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
|
-
|
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
|
-
|
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
|
-
|
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
|
-
|
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
|
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) {
|