Preset variables

You can preset variables before compilation by using the replaceVariables($vars) or addVariables($vars) methods of the Compiler. Compiler::getVariables allows to get the list of registered variables. Compiler::unsetVariable($name) allows to unset a variable (the exact name used for the registration must be passed).

Presetting variables is semantically equivalent to prepending variable declarations at the beginning of the input. If the variable is also defined in your scss source, use the !default flag in the source to prevent your preset variables from being overridden.

Variable names can optionally include the leading $ and can use dashes or underscores interchangeably. If multiple preset variables have the same normalized name, the last one wins (as they are declared in order). The recommendation is to stick with normalized names (no leading $ and dashes rather than underscores) to avoid confusion.

Variable values must be provided using the modern representation of Sass values. They can either be build directly using the Value API or can be converted using the \ScssPhp\ScssPhp\ValueConverter API. This API exposes 2 helpers:

use ScssPhp\ScssPhp\Compiler;
use ScssPhp\ScssPhp\ValueConverter;

$compiler = new Compiler();
$compiler->replaceVariables(array(
    'var' => ValueConverter::parseValue('false'),
    'size' => ValueConverter::parseValue('25px'),
));

echo $compiler->compileString('$var: true !default; @debug $var;')->getCss();
Fork me on GitHub