2016-10-15 03:24:50 +02:00
|
|
|
// Copyright 2016 Google Inc. Use of this source code is governed by an
|
|
|
|
// MIT-style license that can be found in the LICENSE file or at
|
|
|
|
// https://opensource.org/licenses/MIT.
|
|
|
|
|
|
|
|
import 'package:path/path.dart' as p;
|
|
|
|
|
|
|
|
import 'src/ast/sass.dart';
|
2017-02-04 21:20:34 +01:00
|
|
|
import 'src/exception.dart';
|
|
|
|
import 'src/io.dart';
|
2017-02-03 10:08:06 +01:00
|
|
|
import 'src/sync_package_resolver.dart';
|
2016-10-15 03:24:50 +02:00
|
|
|
import 'src/visitor/perform.dart';
|
|
|
|
import 'src/visitor/serialize.dart';
|
|
|
|
|
|
|
|
/// Loads the Sass file at [path], converts it to CSS, and returns the result.
|
|
|
|
///
|
2016-10-20 23:35:45 +02:00
|
|
|
/// If [color] is `true`, this will use terminal colors in warnings.
|
|
|
|
///
|
2017-02-03 10:08:06 +01:00
|
|
|
/// If [packageResolver] is provided, it's used to resolve `package:` imports.
|
|
|
|
/// Otherwise, they aren't supported. It takes a [SyncPackageResolver][] from
|
|
|
|
/// the `package_resolver` package.
|
|
|
|
///
|
|
|
|
/// [SyncPackageResolver]: https://www.dartdocs.org/documentation/package_resolver/latest/package_resolver/SyncPackageResolver-class.html
|
|
|
|
///
|
|
|
|
/// Finally throws a [SassException] if conversion fails.
|
|
|
|
String render(String path,
|
|
|
|
{bool color: false, SyncPackageResolver packageResolver}) {
|
2017-02-04 21:20:34 +01:00
|
|
|
var contents = readFile(path);
|
2016-10-15 03:24:50 +02:00
|
|
|
var url = p.toUri(path);
|
|
|
|
var sassTree = p.extension(path) == '.sass'
|
2016-10-20 23:35:45 +02:00
|
|
|
? new Stylesheet.parseSass(contents, url: url, color: color)
|
|
|
|
: new Stylesheet.parseScss(contents, url: url, color: color);
|
2017-02-03 10:08:06 +01:00
|
|
|
var cssTree =
|
|
|
|
evaluate(sassTree, color: color, packageResolver: packageResolver);
|
2016-10-15 03:24:50 +02:00
|
|
|
return toCss(cssTree);
|
|
|
|
}
|