sassc 2.2.1 → 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 +18 -0
- data/Rakefile +1 -3
- 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/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/memory.hpp +12 -0
- 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 +8 -8
- data/lib/sassc/native.rb +4 -6
- data/lib/sassc/script.rb +4 -4
- data/lib/sassc/version.rb +1 -1
- data/test/functions_test.rb +18 -1
- data/test/native_test.rb +4 -4
- metadata +29 -15
- 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
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) {
|
@@ -1,11 +1,9 @@
|
|
1
1
|
// sass.hpp must go before all system headers to get the
|
2
2
|
// __EXTENSIONS__ fix on Solaris.
|
3
3
|
#include "sass.hpp"
|
4
|
+
#include "ast.hpp"
|
4
5
|
|
5
6
|
#include "remove_placeholders.hpp"
|
6
|
-
#include "context.hpp"
|
7
|
-
#include "inspect.hpp"
|
8
|
-
#include <iostream>
|
9
7
|
|
10
8
|
namespace Sass {
|
11
9
|
|
@@ -13,75 +11,76 @@ namespace Sass {
|
|
13
11
|
{ }
|
14
12
|
|
15
13
|
void Remove_Placeholders::operator()(Block* b) {
|
16
|
-
|
17
|
-
|
18
|
-
|
19
|
-
}
|
14
|
+
for (size_t i = 0, L = b->length(); i < L; ++i) {
|
15
|
+
if (b->get(i)) b->get(i)->perform(this);
|
16
|
+
}
|
20
17
|
}
|
21
18
|
|
22
|
-
|
19
|
+
void Remove_Placeholders::remove_placeholders(SimpleSelector* simple)
|
23
20
|
{
|
24
|
-
|
25
|
-
|
26
|
-
for (size_t i = 0, L = sl->length(); i < L; ++i) {
|
27
|
-
if (!sl->at(i)->contains_placeholder()) {
|
28
|
-
new_sl->append(sl->at(i));
|
29
|
-
}
|
21
|
+
if (PseudoSelector * pseudo = simple->getPseudoSelector()) {
|
22
|
+
if (pseudo->selector()) remove_placeholders(pseudo->selector());
|
30
23
|
}
|
31
|
-
|
32
|
-
return new_sl;
|
33
|
-
|
34
24
|
}
|
35
25
|
|
26
|
+
void Remove_Placeholders::remove_placeholders(CompoundSelector* compound)
|
27
|
+
{
|
28
|
+
for (size_t i = 0, L = compound->length(); i < L; ++i) {
|
29
|
+
if (compound->get(i)) remove_placeholders(compound->get(i));
|
30
|
+
}
|
31
|
+
listEraseItemIf(compound->elements(), listIsEmpty<SimpleSelector>);
|
32
|
+
}
|
36
33
|
|
37
|
-
void Remove_Placeholders::
|
38
|
-
|
39
|
-
|
40
|
-
|
41
|
-
|
42
|
-
|
43
|
-
|
44
|
-
|
45
|
-
|
46
|
-
while (cs) {
|
47
|
-
if (cs->head()) {
|
48
|
-
for (Simple_Selector_Obj& ss : cs->head()->elements()) {
|
49
|
-
if (Wrapped_Selector* ws = Cast<Wrapped_Selector>(ss)) {
|
50
|
-
if (Selector_List* wsl = Cast<Selector_List>(ws->selector())) {
|
51
|
-
Selector_List* clean = remove_placeholders(wsl);
|
52
|
-
// also clean superflous parent selectors
|
53
|
-
// probably not really the correct place
|
54
|
-
clean->remove_parent_selectors();
|
55
|
-
ws->selector(clean);
|
56
|
-
}
|
57
|
-
}
|
58
|
-
}
|
59
|
-
}
|
60
|
-
cs = cs->tail();
|
61
|
-
}
|
34
|
+
void Remove_Placeholders::remove_placeholders(ComplexSelector* complex)
|
35
|
+
{
|
36
|
+
if (complex->has_placeholder()) {
|
37
|
+
complex->clear(); // remove all
|
38
|
+
}
|
39
|
+
else {
|
40
|
+
for (size_t i = 0, L = complex->length(); i < L; ++i) {
|
41
|
+
if (CompoundSelector * compound = complex->get(i)->getCompound()) {
|
42
|
+
if (compound) remove_placeholders(compound);
|
62
43
|
}
|
63
44
|
}
|
45
|
+
listEraseItemIf(complex->elements(), listIsEmpty<SelectorComponent>);
|
46
|
+
}
|
47
|
+
}
|
64
48
|
|
65
|
-
|
66
|
-
|
49
|
+
SelectorList* Remove_Placeholders::remove_placeholders(SelectorList* sl)
|
50
|
+
{
|
51
|
+
for (size_t i = 0, L = sl->length(); i < L; ++i) {
|
52
|
+
if (sl->get(i)) remove_placeholders(sl->get(i));
|
53
|
+
}
|
54
|
+
listEraseItemIf(sl->elements(), listIsEmpty<ComplexSelector>);
|
55
|
+
return sl;
|
56
|
+
}
|
67
57
|
|
68
|
-
|
69
|
-
|
70
|
-
|
71
|
-
st->perform(this);
|
72
|
-
}
|
73
|
-
}
|
58
|
+
void Remove_Placeholders::operator()(CssMediaRule* rule)
|
59
|
+
{
|
60
|
+
if (rule->block()) operator()(rule->block());
|
74
61
|
}
|
75
62
|
|
76
|
-
void Remove_Placeholders::operator()(
|
77
|
-
|
63
|
+
void Remove_Placeholders::operator()(StyleRule* r)
|
64
|
+
{
|
65
|
+
if (SelectorListObj sl = r->selector()) {
|
66
|
+
// Set the new placeholder selector list
|
67
|
+
r->selector((remove_placeholders(sl)));
|
68
|
+
}
|
69
|
+
// Iterate into child blocks
|
70
|
+
Block_Obj b = r->block();
|
71
|
+
for (size_t i = 0, L = b->length(); i < L; ++i) {
|
72
|
+
if (b->get(i)) { b->get(i)->perform(this); }
|
73
|
+
}
|
78
74
|
}
|
79
|
-
|
80
|
-
|
75
|
+
|
76
|
+
void Remove_Placeholders::operator()(SupportsRule* m)
|
77
|
+
{
|
78
|
+
if (m->block()) operator()(m->block());
|
81
79
|
}
|
82
80
|
|
83
|
-
void Remove_Placeholders::operator()(
|
84
|
-
|
81
|
+
void Remove_Placeholders::operator()(AtRule* a)
|
82
|
+
{
|
83
|
+
if (a->block()) a->block()->perform(this);
|
85
84
|
}
|
86
85
|
|
87
86
|
}
|
@@ -1,33 +1,36 @@
|
|
1
1
|
#ifndef SASS_REMOVE_PLACEHOLDERS_H
|
2
2
|
#define SASS_REMOVE_PLACEHOLDERS_H
|
3
3
|
|
4
|
-
#
|
5
|
-
|
6
|
-
#include "ast.hpp"
|
4
|
+
#include "ast_fwd_decl.hpp"
|
7
5
|
#include "operation.hpp"
|
8
6
|
|
9
7
|
namespace Sass {
|
10
8
|
|
9
|
+
class Remove_Placeholders : public Operation_CRTP<void, Remove_Placeholders> {
|
10
|
+
|
11
|
+
public:
|
12
|
+
|
13
|
+
SelectorList* remove_placeholders(SelectorList*);
|
14
|
+
void remove_placeholders(SimpleSelector* simple);
|
15
|
+
void remove_placeholders(CompoundSelector* complex);
|
16
|
+
void remove_placeholders(ComplexSelector* complex);
|
11
17
|
|
12
|
-
class Remove_Placeholders : public Operation_CRTP<void, Remove_Placeholders> {
|
13
18
|
|
14
|
-
|
15
|
-
|
19
|
+
public:
|
20
|
+
Remove_Placeholders();
|
21
|
+
~Remove_Placeholders() { }
|
16
22
|
|
17
|
-
|
18
|
-
|
19
|
-
|
23
|
+
void operator()(Block*);
|
24
|
+
void operator()(StyleRule*);
|
25
|
+
void operator()(CssMediaRule*);
|
26
|
+
void operator()(SupportsRule*);
|
27
|
+
void operator()(AtRule*);
|
20
28
|
|
21
|
-
|
22
|
-
|
23
|
-
|
24
|
-
void operator()(Supports_Block*);
|
25
|
-
void operator()(Directive*);
|
29
|
+
// ignore missed types
|
30
|
+
template <typename U>
|
31
|
+
void fallback(U x) {}
|
26
32
|
|
27
|
-
|
28
|
-
template <typename U>
|
29
|
-
void fallback(U x) {}
|
30
|
-
};
|
33
|
+
};
|
31
34
|
|
32
35
|
}
|
33
36
|
|
data/ext/libsass/src/sass.cpp
CHANGED
@@ -17,9 +17,9 @@
|
|
17
17
|
namespace Sass {
|
18
18
|
|
19
19
|
// helper to convert string list to vector
|
20
|
-
|
20
|
+
sass::vector<sass::string> list2vec(struct string_list* cur)
|
21
21
|
{
|
22
|
-
|
22
|
+
sass::vector<sass::string> list;
|
23
23
|
while (cur) {
|
24
24
|
list.push_back(cur->string);
|
25
25
|
cur = cur->next;
|
@@ -46,6 +46,7 @@ extern "C" {
|
|
46
46
|
|
47
47
|
char* ADDCALL sass_copy_c_string(const char* str)
|
48
48
|
{
|
49
|
+
if (str == nullptr) return nullptr;
|
49
50
|
size_t len = strlen(str) + 1;
|
50
51
|
char* cpy = (char*) sass_alloc_memory(len);
|
51
52
|
std::memcpy(cpy, str, len);
|
@@ -61,14 +62,14 @@ extern "C" {
|
|
61
62
|
// caller must free the returned memory
|
62
63
|
char* ADDCALL sass_string_quote (const char *str, const char quote_mark)
|
63
64
|
{
|
64
|
-
|
65
|
+
sass::string quoted = quote(str, quote_mark);
|
65
66
|
return sass_copy_c_string(quoted.c_str());
|
66
67
|
}
|
67
68
|
|
68
69
|
// caller must free the returned memory
|
69
70
|
char* ADDCALL sass_string_unquote (const char *str)
|
70
71
|
{
|
71
|
-
|
72
|
+
sass::string unquoted = unquote(str);
|
72
73
|
return sass_copy_c_string(unquoted.c_str());
|
73
74
|
}
|
74
75
|
|
@@ -76,13 +77,13 @@ extern "C" {
|
|
76
77
|
{
|
77
78
|
// get the last import entry to get current base directory
|
78
79
|
Sass_Import_Entry import = sass_compiler_get_last_import(compiler);
|
79
|
-
const
|
80
|
+
const sass::vector<sass::string>& incs = compiler->cpp_ctx->include_paths;
|
80
81
|
// create the vector with paths to lookup
|
81
|
-
|
82
|
+
sass::vector<sass::string> paths(1 + incs.size());
|
82
83
|
paths.push_back(File::dir_name(import->abs_path));
|
83
84
|
paths.insert( paths.end(), incs.begin(), incs.end() );
|
84
85
|
// now resolve the file path relative to lookup paths
|
85
|
-
|
86
|
+
sass::string resolved(File::find_include(file, paths));
|
86
87
|
return sass_copy_c_string(resolved.c_str());
|
87
88
|
}
|
88
89
|
|
@@ -90,13 +91,13 @@ extern "C" {
|
|
90
91
|
{
|
91
92
|
// get the last import entry to get current base directory
|
92
93
|
Sass_Import_Entry import = sass_compiler_get_last_import(compiler);
|
93
|
-
const
|
94
|
+
const sass::vector<sass::string>& incs = compiler->cpp_ctx->include_paths;
|
94
95
|
// create the vector with paths to lookup
|
95
|
-
|
96
|
+
sass::vector<sass::string> paths(1 + incs.size());
|
96
97
|
paths.push_back(File::dir_name(import->abs_path));
|
97
98
|
paths.insert( paths.end(), incs.begin(), incs.end() );
|
98
99
|
// now resolve the file path relative to lookup paths
|
99
|
-
|
100
|
+
sass::string resolved(File::find_file(file, paths));
|
100
101
|
return sass_copy_c_string(resolved.c_str());
|
101
102
|
}
|
102
103
|
|
@@ -105,8 +106,8 @@ extern "C" {
|
|
105
106
|
// this has the original resolve logic for sass include
|
106
107
|
char* ADDCALL sass_find_include (const char* file, struct Sass_Options* opt)
|
107
108
|
{
|
108
|
-
|
109
|
-
|
109
|
+
sass::vector<sass::string> vec(list2vec(opt->include_paths));
|
110
|
+
sass::string resolved(File::find_include(file, vec));
|
110
111
|
return sass_copy_c_string(resolved.c_str());
|
111
112
|
}
|
112
113
|
|
@@ -114,8 +115,8 @@ extern "C" {
|
|
114
115
|
// Incs array has to be null terminated!
|
115
116
|
char* ADDCALL sass_find_file (const char* file, struct Sass_Options* opt)
|
116
117
|
{
|
117
|
-
|
118
|
-
|
118
|
+
sass::vector<sass::string> vec(list2vec(opt->include_paths));
|
119
|
+
sass::string resolved(File::find_file(file, vec));
|
119
120
|
return sass_copy_c_string(resolved.c_str());
|
120
121
|
}
|
121
122
|
|
@@ -136,7 +137,7 @@ extern "C" {
|
|
136
137
|
namespace Sass {
|
137
138
|
|
138
139
|
// helper to aid dreaded MSVC debug mode
|
139
|
-
char* sass_copy_string(
|
140
|
+
char* sass_copy_string(sass::string str)
|
140
141
|
{
|
141
142
|
// In MSVC the following can lead to segfault:
|
142
143
|
// sass_copy_c_string(stream.str().c_str());
|
data/ext/libsass/src/sass.hpp
CHANGED
@@ -11,7 +11,7 @@
|
|
11
11
|
#pragma warning(disable : 4005)
|
12
12
|
#endif
|
13
13
|
|
14
|
-
//
|
14
|
+
// applies to MSVC and MinGW
|
15
15
|
#ifdef _WIN32
|
16
16
|
// we do not want the ERROR macro
|
17
17
|
# ifndef NOGDI
|
@@ -48,13 +48,17 @@
|
|
48
48
|
#endif
|
49
49
|
|
50
50
|
|
51
|
-
//
|
51
|
+
// Include C-API header
|
52
52
|
#include "sass/base.h"
|
53
53
|
|
54
|
+
// Include allocator
|
55
|
+
#include "memory.hpp"
|
56
|
+
|
54
57
|
// For C++ helper
|
55
58
|
#include <string>
|
59
|
+
#include <vector>
|
56
60
|
|
57
|
-
// output
|
61
|
+
// output behavior
|
58
62
|
namespace Sass {
|
59
63
|
|
60
64
|
// create some C++ aliases for the most used options
|
@@ -65,14 +69,15 @@ namespace Sass {
|
|
65
69
|
// only used internal to trigger ruby inspect behavior
|
66
70
|
const static Sass_Output_Style INSPECT = SASS_STYLE_INSPECT;
|
67
71
|
const static Sass_Output_Style TO_SASS = SASS_STYLE_TO_SASS;
|
72
|
+
const static Sass_Output_Style TO_CSS = SASS_STYLE_TO_CSS;
|
68
73
|
|
69
74
|
// helper to aid dreaded MSVC debug mode
|
70
75
|
// see implementation for more details
|
71
|
-
char* sass_copy_string(
|
76
|
+
char* sass_copy_string(sass::string str);
|
72
77
|
|
73
78
|
}
|
74
79
|
|
75
|
-
// input
|
80
|
+
// input behaviors
|
76
81
|
enum Sass_Input_Style {
|
77
82
|
SASS_CONTEXT_NULL,
|
78
83
|
SASS_CONTEXT_FILE,
|