Implement the sourceMapIncludeSources JS option (#1583)

This commit is contained in:
Christophe Coevoet 2022-01-15 01:38:26 +01:00 committed by GitHub
parent e1fcbaaf36
commit f055db0797
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
3 changed files with 11 additions and 6 deletions

View File

@ -2,6 +2,10 @@
* Fix a bug in `string.insert` with certain negative indices. * Fix a bug in `string.insert` with certain negative indices.
### JS API
* Add support for the `sourceMapIncludeSources` option in the new JS API.
## 1.48.0 ## 1.48.0
### JS API ### JS API

View File

@ -47,7 +47,7 @@ NodeCompileResult compile(String path, [CompileOptions? options]) {
ascii: ascii), ascii: ascii),
importers: options?.importers?.map(_parseImporter), importers: options?.importers?.map(_parseImporter),
functions: _parseFunctions(options?.functions).cast()); functions: _parseFunctions(options?.functions).cast());
return _convertResult(result); return _convertResult(result, includeSourceContents: options?.sourceMapIncludeSources ?? false);
} on SassException catch (error, stackTrace) { } on SassException catch (error, stackTrace) {
throwNodeException(error, color: color, ascii: ascii, trace: stackTrace); throwNodeException(error, color: color, ascii: ascii, trace: stackTrace);
} }
@ -76,7 +76,7 @@ NodeCompileResult compileString(String text, [CompileStringOptions? options]) {
importer: options?.importer.andThen(_parseImporter) ?? importer: options?.importer.andThen(_parseImporter) ??
(options?.url == null ? NoOpImporter() : null), (options?.url == null ? NoOpImporter() : null),
functions: _parseFunctions(options?.functions).cast()); functions: _parseFunctions(options?.functions).cast());
return _convertResult(result); return _convertResult(result, includeSourceContents: options?.sourceMapIncludeSources ?? false);
} on SassException catch (error, stackTrace) { } on SassException catch (error, stackTrace) {
throwNodeException(error, color: color, ascii: ascii, trace: stackTrace); throwNodeException(error, color: color, ascii: ascii, trace: stackTrace);
} }
@ -102,7 +102,7 @@ Promise compileAsync(String path, [CompileOptions? options]) {
importers: options?.importers importers: options?.importers
?.map((importer) => _parseAsyncImporter(importer)), ?.map((importer) => _parseAsyncImporter(importer)),
functions: _parseFunctions(options?.functions, asynch: true)); functions: _parseFunctions(options?.functions, asynch: true));
return _convertResult(result); return _convertResult(result, includeSourceContents: options?.sourceMapIncludeSources ?? false);
}()), color: color, ascii: ascii); }()), color: color, ascii: ascii);
} }
@ -131,13 +131,13 @@ Promise compileStringAsync(String text, [CompileStringOptions? options]) {
.andThen((importer) => _parseAsyncImporter(importer)) ?? .andThen((importer) => _parseAsyncImporter(importer)) ??
(options?.url == null ? NoOpImporter() : null), (options?.url == null ? NoOpImporter() : null),
functions: _parseFunctions(options?.functions, asynch: true)); functions: _parseFunctions(options?.functions, asynch: true));
return _convertResult(result); return _convertResult(result, includeSourceContents: options?.sourceMapIncludeSources ?? false);
}()), color: color, ascii: ascii); }()), color: color, ascii: ascii);
} }
/// Converts a Dart [CompileResult] into a JS API [NodeCompileResult]. /// Converts a Dart [CompileResult] into a JS API [NodeCompileResult].
NodeCompileResult _convertResult(CompileResult result) { NodeCompileResult _convertResult(CompileResult result, {required bool includeSourceContents}) {
var sourceMap = result.sourceMap?.toJson(); var sourceMap = result.sourceMap?.toJson(includeSourceContents: includeSourceContents);
if (sourceMap is Map<String, dynamic> && !sourceMap.containsKey('sources')) { if (sourceMap is Map<String, dynamic> && !sourceMap.containsKey('sources')) {
// Dart's source map library can omit the sources key, but JS's type // Dart's source map library can omit the sources key, but JS's type
// declaration doesn't allow that. // declaration doesn't allow that.

View File

@ -18,6 +18,7 @@ class CompileOptions {
external String? get style; external String? get style;
external bool? get verbose; external bool? get verbose;
external bool? get sourceMap; external bool? get sourceMap;
external bool? get sourceMapIncludeSources;
external NodeLogger? get logger; external NodeLogger? get logger;
external List<Object?>? get importers; external List<Object?>? get importers;
external Object? get functions; external Object? get functions;