Skip to content
Projects
Groups
Snippets
Help
This project
Loading...
Sign in / Register
Toggle navigation
N
node-sass
Overview
Overview
Details
Activity
Cycle Analytics
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Charts
Issues
0
Issues
0
List
Board
Labels
Milestones
Merge Requests
0
Merge Requests
0
CI / CD
CI / CD
Pipelines
Jobs
Schedules
Charts
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Charts
Create a new issue
Jobs
Commits
Issue Boards
Open sidebar
楚学文
node-sass
Commits
7db55551
Commit
7db55551
authored
Apr 19, 2012
by
Aaron Leung
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
Handling values with embedded interpolants.
parent
0936e9d8
Show whitespace changes
Inline
Side-by-side
Showing
5 changed files
with
60 additions
and
36 deletions
+60
-36
document_parser.cpp
src/document_parser.cpp
+25
-34
eval_apply.cpp
src/eval_apply.cpp
+4
-0
functions.cpp
src/functions.cpp
+1
-0
prelexer.cpp
src/prelexer.cpp
+2
-2
prelexer.hpp
src/prelexer.hpp
+28
-0
No files found.
src/document_parser.cpp
View file @
7db55551
...
@@ -670,11 +670,12 @@ namespace Sass {
...
@@ -670,11 +670,12 @@ namespace Sass {
return
result
;
return
result
;
}
}
if
(
peek
<
value_schema
>
())
if
(
lex
<
value_schema
>
())
{
{
// TO DO: handle value schemas!
cerr
<<
"parsing value schema: "
<<
lexed
.
to_string
()
<<
endl
;
return
Node
(
Node
::
identifier
,
line_number
,
lexed
);
return
parse_value_schema
();
Document
schema_doc
(
path
,
line_number
,
lexed
,
context
);
return
schema_doc
.
parse_value_schema
();
}
}
if
(
lex
<
sequence
<
true_kwd
,
negate
<
identifier
>
>
>
())
if
(
lex
<
sequence
<
true_kwd
,
negate
<
identifier
>
>
>
())
...
@@ -724,37 +725,31 @@ namespace Sass {
...
@@ -724,37 +725,31 @@ namespace Sass {
return
var
;
return
var
;
}
}
if
(
lex
<
interpolant
>
())
{
Token
insides
(
Token
::
make
(
lexed
.
begin
+
2
,
lexed
.
end
-
1
));
Document
interp
(
path
,
line_number
,
insides
,
context
);
return
interp
.
parse_list
();
}
syntax_error
(
"error reading values after "
+
lexed
.
to_string
());
syntax_error
(
"error reading values after "
+
lexed
.
to_string
());
}
}
Node
Document
::
parse_value_schema
()
Node
Document
::
parse_value_schema
()
{
{
Node
schema
;
// Node schema;
// just an interpolant
// if (lex< interpolant >()) {
if
(
lex
<
interpolant
>
())
{
// Token insides(Token::make(lexed.begin + 2, lexed.end - 1));
Token
insides
(
Token
::
make
(
lexed
.
begin
+
2
,
lexed
.
end
-
1
));
// Document interp_doc(path, line_number, insides, context);
Document
interp_doc
(
path
,
line_number
,
insides
,
context
);
// Node interp_node(interp_doc.parse_list());
Node
interp_node
(
interp_doc
.
parse_list
());
// if (position >= end) {
if
(
peek
<
alternatives
<
spaces
,
comment
,
// return interp_node;
exactly
<
';'
>
,
exactly
<
','
>
,
// }
exactly
<
'('
>
,
exactly
<
')'
>
>
>
())
{
// else {
return
interp_node
;
// schema = Node(Node::value_schema, context.registry, line_number, 2);
}
// schema << interp_node;
// interpolant with stuff immediately behind it
// }
else
{
// }
schema
=
Node
(
Node
::
value_schema
,
context
.
registry
,
line_number
,
2
);
// else {
schema
<<
interp_node
;
// schema = Node(Node::value_schema, context.registry, line_number, 2);
}
// }
}
while
(
true
)
{
Node
schema
(
Node
::
value_schema
,
context
.
registry
,
line_number
,
1
);
while
(
position
<
end
)
{
if
(
lex
<
interpolant
>
())
{
if
(
lex
<
interpolant
>
())
{
Token
insides
(
Token
::
make
(
lexed
.
begin
+
2
,
lexed
.
end
-
1
));
Token
insides
(
Token
::
make
(
lexed
.
begin
+
2
,
lexed
.
end
-
1
));
Document
interp_doc
(
path
,
line_number
,
insides
,
context
);
Document
interp_doc
(
path
,
line_number
,
insides
,
context
);
...
@@ -785,12 +780,8 @@ namespace Sass {
...
@@ -785,12 +780,8 @@ namespace Sass {
else
{
else
{
syntax_error
(
"error parsing interpolated value"
);
syntax_error
(
"error parsing interpolated value"
);
}
}
if
(
peek
<
alternatives
<
spaces
,
comment
,
exactly
<
';'
>
,
exactly
<
','
>
,
exactly
<
'('
>
,
exactly
<
')'
>
>
>
())
{
break
;
}
}
}
schema
.
eval_me
=
true
;
return
schema
;
return
schema
;
}
}
...
...
src/eval_apply.cpp
View file @
7db55551
...
@@ -86,6 +86,9 @@ namespace Sass {
...
@@ -86,6 +86,9 @@ namespace Sass {
if
(
rhs
[
i
].
eval_me
)
rhs
[
i
]
=
eval
(
rhs
[
i
],
env
,
f_env
,
registry
);
if
(
rhs
[
i
].
eval_me
)
rhs
[
i
]
=
eval
(
rhs
[
i
],
env
,
f_env
,
registry
);
}
}
}
}
else
if
(
rhs
.
type
==
Node
::
value_schema
)
{
eval
(
rhs
,
env
,
f_env
,
registry
);
}
else
{
else
{
if
(
rhs
.
eval_me
)
expr
[
1
]
=
eval
(
rhs
,
env
,
f_env
,
registry
);
if
(
rhs
.
eval_me
)
expr
[
1
]
=
eval
(
rhs
,
env
,
f_env
,
registry
);
}
}
...
@@ -221,6 +224,7 @@ namespace Sass {
...
@@ -221,6 +224,7 @@ namespace Sass {
}
break
;
}
break
;
case
Node
:
:
value_schema
:
{
case
Node
:
:
value_schema
:
{
cerr
<<
"evaluating schema of size "
<<
expr
.
size
()
<<
endl
;
for
(
int
i
=
0
;
i
<
expr
.
size
();
++
i
)
{
for
(
int
i
=
0
;
i
<
expr
.
size
();
++
i
)
{
expr
[
i
]
=
eval
(
expr
[
i
],
env
,
f_env
,
registry
);
expr
[
i
]
=
eval
(
expr
[
i
],
env
,
f_env
,
registry
);
}
}
...
...
src/functions.cpp
View file @
7db55551
...
@@ -452,6 +452,7 @@ namespace Sass {
...
@@ -452,6 +452,7 @@ namespace Sass {
type
.
content
.
token
=
Token
::
make
(
bool_name
);
type
.
content
.
token
=
Token
::
make
(
bool_name
);
break
;
break
;
case
Node
:
:
string_constant
:
case
Node
:
:
string_constant
:
case
Node
:
:
value_schema
:
type
.
content
.
token
=
Token
::
make
(
string_name
);
type
.
content
.
token
=
Token
::
make
(
string_name
);
break
;
break
;
case
Node
:
:
numeric_color
:
case
Node
:
:
numeric_color
:
...
...
src/prelexer.cpp
View file @
7db55551
...
@@ -83,9 +83,9 @@ namespace Sass {
...
@@ -83,9 +83,9 @@ namespace Sass {
// Match interpolant schemas
// Match interpolant schemas
const
char
*
value_schema
(
const
char
*
src
)
{
const
char
*
value_schema
(
const
char
*
src
)
{
// follows this pattern: ([xyz]*i[xyz]*)+
// follows this pattern: ([xyz]*i[xyz]*)+
return
one_plus
<
sequence
<
zero_plus
<
alternatives
<
identifier
,
number
>
>
,
return
one_plus
<
sequence
<
zero_plus
<
alternatives
<
identifier
,
percentage
,
dimension
,
hex
,
number
,
string_constant
>
>
,
interpolant
,
interpolant
,
zero_plus
<
alternatives
<
identifier
,
number
>
>
>
>
(
src
);
zero_plus
<
alternatives
<
identifier
,
percentage
,
dimension
,
hex
,
number
,
string_constant
>
>
>
>
(
src
);
}
}
// Match CSS '@' keywords.
// Match CSS '@' keywords.
...
...
src/prelexer.hpp
View file @
7db55551
...
@@ -151,6 +151,34 @@ namespace Sass {
...
@@ -151,6 +151,34 @@ namespace Sass {
return
rslt
;
return
rslt
;
}
}
// Same as above, but with 7 arguments.
template
<
prelexer
mx1
,
prelexer
mx2
,
prelexer
mx3
,
prelexer
mx4
,
prelexer
mx5
,
prelexer
mx6
,
prelexer
mx7
>
const
char
*
alternatives
(
const
char
*
src
)
{
const
char
*
rslt
=
src
;
(
rslt
=
mx1
(
rslt
))
||
(
rslt
=
mx2
(
rslt
))
||
(
rslt
=
mx3
(
rslt
))
||
(
rslt
=
mx4
(
rslt
))
||
(
rslt
=
mx5
(
rslt
))
||
(
rslt
=
mx6
(
rslt
))
||
(
rslt
=
mx7
(
rslt
));
return
rslt
;
}
// Same as above, but with 8 arguments.
template
<
prelexer
mx1
,
prelexer
mx2
,
prelexer
mx3
,
prelexer
mx4
,
prelexer
mx5
,
prelexer
mx6
,
prelexer
mx7
,
prelexer
mx8
>
const
char
*
alternatives
(
const
char
*
src
)
{
const
char
*
rslt
=
src
;
(
rslt
=
mx1
(
rslt
))
||
(
rslt
=
mx2
(
rslt
))
||
(
rslt
=
mx3
(
rslt
))
||
(
rslt
=
mx4
(
rslt
))
||
(
rslt
=
mx5
(
rslt
))
||
(
rslt
=
mx6
(
rslt
))
||
(
rslt
=
mx7
(
rslt
))
||
(
rslt
=
mx8
(
rslt
));
return
rslt
;
}
// Tries the matchers in sequence and succeeds if they all succeed.
// Tries the matchers in sequence and succeeds if they all succeed.
template
<
prelexer
mx1
,
prelexer
mx2
>
template
<
prelexer
mx1
,
prelexer
mx2
>
const
char
*
sequence
(
const
char
*
src
)
{
const
char
*
sequence
(
const
char
*
src
)
{
...
...
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment