From 37e0ed54da1bd3ba3d4f4127da3a9575f7a9224e Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?=E3=81=AA=E3=81=A4=E3=81=8D?= Date: Fri, 15 Sep 2023 16:55:49 -0700 Subject: [PATCH] Fix source span for calculation deprecation warnings (#2084) Co-authored-by: Natalie Weizenbaum --- CHANGELOG.md | 4 ++++ lib/src/visitor/async_evaluate.dart | 5 +++++ lib/src/visitor/evaluate.dart | 7 ++++++- pubspec.yaml | 2 +- 4 files changed, 16 insertions(+), 2 deletions(-) diff --git a/CHANGELOG.md b/CHANGELOG.md index 7c8055dd7..31dc00661 100644 --- a/CHANGELOG.md +++ b/CHANGELOG.md @@ -1,3 +1,7 @@ +## 1.67.1 + +* Fix the source spans associated with the `abs-percent` deprecation. + ## 1.67.0 * All functions defined in CSS Values and Units 4 are now once again parsed as diff --git a/lib/src/visitor/async_evaluate.dart b/lib/src/visitor/async_evaluate.dart index b8917ba42..6e16a71bf 100644 --- a/lib/src/visitor/async_evaluate.dart +++ b/lib/src/visitor/async_evaluate.dart @@ -2431,6 +2431,9 @@ final class _EvaluateVisitor return SassCalculation.unsimplified(node.name, arguments); } + var oldCallableNode = _callableNode; + _callableNode = node; + try { return switch (node.name.toLowerCase()) { "calc" => SassCalculation.calc(arguments[0]), @@ -2471,6 +2474,8 @@ final class _EvaluateVisitor _verifyCompatibleNumbers(arguments, node.arguments.positional); } throwWithTrace(_exception(error.message, node.span), error, stackTrace); + } finally { + _callableNode = oldCallableNode; } } diff --git a/lib/src/visitor/evaluate.dart b/lib/src/visitor/evaluate.dart index 521e6cd02..87f3ef6c0 100644 --- a/lib/src/visitor/evaluate.dart +++ b/lib/src/visitor/evaluate.dart @@ -5,7 +5,7 @@ // DO NOT EDIT. This file was generated from async_evaluate.dart. // See tool/grind/synchronize.dart for details. // -// Checksum: ccd4ec1a65cfc2487fccd30481d427086f5c76cc +// Checksum: 7669de19668af665d1a9a60cf67e53e071bf415e // // ignore_for_file: unused_import @@ -2411,6 +2411,9 @@ final class _EvaluateVisitor return SassCalculation.unsimplified(node.name, arguments); } + var oldCallableNode = _callableNode; + _callableNode = node; + try { return switch (node.name.toLowerCase()) { "calc" => SassCalculation.calc(arguments[0]), @@ -2451,6 +2454,8 @@ final class _EvaluateVisitor _verifyCompatibleNumbers(arguments, node.arguments.positional); } throwWithTrace(_exception(error.message, node.span), error, stackTrace); + } finally { + _callableNode = oldCallableNode; } } diff --git a/pubspec.yaml b/pubspec.yaml index e9cceabb1..3036d6b5e 100644 --- a/pubspec.yaml +++ b/pubspec.yaml @@ -1,5 +1,5 @@ name: sass -version: 1.67.0 +version: 1.67.1-dev description: A Sass implementation in Dart. homepage: https://github.com/sass/dart-sass