2023-05-07 18:58:40 +02:00
|
|
|
---
|
|
|
|
title: Parsing a Stylesheet
|
|
|
|
introduction: >
|
|
|
|
A Sass stylesheet is parsed from a sequence of Unicode code points. It's
|
|
|
|
parsed directly, without first being converted to a token stream.
|
|
|
|
---
|
|
|
|
|
2023-05-31 12:22:35 -04:00
|
|
|
## Input Encoding
|
2023-05-07 18:58:40 +02:00
|
|
|
|
2023-06-01 11:43:54 -04:00
|
|
|
{% compatibility 'dart: false', 'libsass: true', 'ruby: true' %}
|
2023-05-31 12:22:35 -04:00
|
|
|
Dart Sass currently *only* supports the UTF-8 encoding. As such, it's safest
|
|
|
|
to encode all Sass stylesheets as UTF-8.
|
2023-05-07 18:58:40 +02:00
|
|
|
{% endcompatibility %}
|
|
|
|
|
|
|
|
It's often the case that a document is initially available only as a sequence of
|
|
|
|
bytes, which must be decoded into Unicode. Sass performs this decoding as
|
|
|
|
follows:
|
|
|
|
|
2023-05-25 11:55:08 -04:00
|
|
|
* If the sequence of bytes begins with the UTF-8 or UTF-16 encoding of U+FEFF
|
2023-05-07 18:58:40 +02:00
|
|
|
BYTE ORDER MARK, the corresponding encoding is used.
|
|
|
|
|
2023-05-25 11:55:08 -04:00
|
|
|
* If the sequence of bytes begins with the plain ASCII string `@charset`, Sass
|
2023-05-07 18:58:40 +02:00
|
|
|
determines the encoding using step 2 of the CSS algorithm for
|
|
|
|
[determining the fallback encoding][].
|
|
|
|
|
|
|
|
[determining the fallback encoding]: https://drafts.csswg.org/css-syntax-3/#input-byte-stream
|
|
|
|
|
2023-05-25 11:55:08 -04:00
|
|
|
* Otherwise, UTF-8 is used.
|
2023-05-07 18:58:40 +02:00
|
|
|
|
|
|
|
## Parse Errors
|
|
|
|
|
|
|
|
When Sass encounters invalid syntax in a stylesheet, parsing will fail and an
|
|
|
|
error will be presented to the user with information about the location of the
|
|
|
|
invalid syntax and the reason it was invalid.
|
|
|
|
|
|
|
|
Note that this is different than CSS, which specifies how to recover from most
|
|
|
|
errors rather than failing immediately. This is one of the few cases where SCSS
|
2023-05-25 11:55:08 -04:00
|
|
|
isn't *strictly* a superset of CSS. However, it's much more useful to Sass users
|
2023-05-07 18:58:40 +02:00
|
|
|
to see errors immediately, rather than having them passed through to the CSS
|
|
|
|
output.
|
|
|
|
|
|
|
|
The location of parse errors can be accessed through implementation-specific
|
|
|
|
APIs. For example, in Dart Sass you can access [`SassException.span`][], and in
|
|
|
|
Node Sass's and Dart Sass's JS API you can access the [`file`, `line`, and
|
|
|
|
`column`][js error] properties.
|
|
|
|
|
|
|
|
[`SassException.span`]: https://pub.dartlang.org/documentation/sass/latest/sass/SassException/span.html
|
|
|
|
[js error]: https://github.com/sass/node-sass#error-object
|