Working with Sass values

Modern value representation

scssphp represents Sass values using the \ScssPhp\ScssPhp\Value\Value class and its subclasses.

The Value class exposes various assert* methods to check the type of values. These methods return the value refined to the proper type or throw a SassScriptException about the unexpected type. Those methods accept a name argument (without the leading $) in case the asserted value correspond to an argument of a Sass function, to provide a better error message.

The scssphp value API is strongly typed. It is recommended to use static analysis on your code when using it to catch invalid usages.

Legacy value representation

scssphp used to represent Sass values using array|\ScssPhp\ScssPhp\Node\Number. The index 0 of the array will be the type of value (one of the \ScssPhp\ScssPhp\Type constants).

[!NOTE] The legacy value representation is deprecated. Migrate to the modern representation instead.

The Compiler class exposes various assert* methods to check the type of values. These methods return the asserted value (which may not be exactly the same as the input due to complex implementation details, so the return value should be used).

If a string representation of a value is needed to include it in an error message, the Compiler::compileValue method can be used.

Null

Sass’ null value is representation using [Type::T_NULL]. It can be referenced as Compiler::$null.

Booleans

Sass’ boolean values are represented as Compiler::$true and Compiler::$false.

When accepting a parameter in a function, it is generally better to use Compiler::isTruthy instead of explicitly checking for boolean value.

Numbers

Sass’ numbers are represented using the \ScssPhp\ScssPhp\Node\Number class.

Strings

Sass’ strings are represented as an array with 3 elements:

Note: arguments received by functions may not always use the Type::T_STRING due to internal details. However, Compiler::assertString guarantees that its return value is actually a string using Type::T_STRING.

Colors

Sass’ colors are represented as an array with 4 or 5 elements (the alpha channel is optional):

Note: arguments might receive a Type::T_KEYWORD corresponding to a color keyword. Always use Compiler::assertColor to get the actual color.

Maps

Sass’ maps are represented as an array with 3 elements:

The actual handling of keys is weird, as it does not rely on the equality rules of values (which is not spec compliant). When writing custom functions, it is advised to stay away from maps as arguments or return value for now.

As Sass empty lists can be used as maps, always use Compiler::assertMap to get the actual map value (this helper takes care of converting empty lists).

Lists

Sass’ lists are represented as an array with 3 elements:

Bracketed lists are represented by adding an enclosing key with a value of bracket.

Note that the handling of the list separator is not fully compliant. List values might have an undecided separators in cases where they should not in Sass.

Argument lists

Sass’s argument lists are representing the list of rest arguments for variadic functions.

They are represented as a Sass list (see above) containing positional arguments with an additional element in the array to store the keyword arguments. To access keyword arguments of the Sass argument list, use Compiler::getArgumentListKeywords.

Fork me on GitHub