From 264b2d58b056b0fa65dcbcec1b18cf8f3567bbe0 Mon Sep 17 00:00:00 2001 From: Natalie Weizenbaum Date: Tue, 30 Apr 2024 14:19:59 -0700 Subject: [PATCH] Deprecate function and mixin names beginning with `--` (#2230) See #2197 --- CHANGELOG.md | 6 +++++- lib/src/deprecation.dart | 4 ++++ lib/src/parse/stylesheet.dart | 24 ++++++++++++++++++++++++ pkg/sass_api/CHANGELOG.md | 4 ++++ pkg/sass_api/pubspec.yaml | 4 ++-- pubspec.yaml | 2 +- 6 files changed, 40 insertions(+), 4 deletions(-) diff --git a/CHANGELOG.md b/CHANGELOG.md index f908395f9..adfce2e9b 100644 --- a/CHANGELOG.md +++ b/CHANGELOG.md @@ -1,7 +1,11 @@ -## 1.75.1 +## 1.76.0 * Throw errors for misplaced statements in keyframe blocks. +* Mixins and functions whose names begin with `--` are now deprecated for + forwards-compatibility with the in-progress CSS functions and mixins spec. + This deprecation is named `css-function-mixin`. + ## 1.75.0 * Fix a bug in which stylesheet canonicalization could be cached incorrectly diff --git a/lib/src/deprecation.dart b/lib/src/deprecation.dart index a7412e2ce..b13180e10 100644 --- a/lib/src/deprecation.dart +++ b/lib/src/deprecation.dart @@ -74,6 +74,10 @@ enum Deprecation { description: 'Using the current working directory as an implicit load path.'), + cssFunctionMixin('css-function-mixin', + deprecatedIn: '1.76.0', + description: 'Function and mixin names beginning with --.'), + @Deprecated('This deprecation name was never actually used.') calcInterp('calc-interp', deprecatedIn: null), diff --git a/lib/src/parse/stylesheet.dart b/lib/src/parse/stylesheet.dart index 19662c192..fb1f1b614 100644 --- a/lib/src/parse/stylesheet.dart +++ b/lib/src/parse/stylesheet.dart @@ -846,7 +846,19 @@ abstract class StylesheetParser extends Parser { FunctionRule _functionRule(LineScannerState start) { var precedingComment = lastSilentComment; lastSilentComment = null; + var beforeName = scanner.state; var name = identifier(normalize: true); + + if (name.startsWith('--')) { + logger.warnForDeprecation( + Deprecation.cssFunctionMixin, + 'Sass @function names beginning with -- are deprecated for forward-' + 'compatibility with plain CSS mixins.\n' + '\n' + 'For details, see https://sass-lang.com/d/css-function-mixin', + span: scanner.spanFrom(beforeName)); + } + whitespace(); var arguments = _argumentDeclaration(); @@ -1261,7 +1273,19 @@ abstract class StylesheetParser extends Parser { MixinRule _mixinRule(LineScannerState start) { var precedingComment = lastSilentComment; lastSilentComment = null; + var beforeName = scanner.state; var name = identifier(normalize: true); + + if (name.startsWith('--')) { + logger.warnForDeprecation( + Deprecation.cssFunctionMixin, + 'Sass @mixin names beginning with -- are deprecated for forward-' + 'compatibility with plain CSS mixins.\n' + '\n' + 'For details, see https://sass-lang.com/d/css-function-mixin', + span: scanner.spanFrom(beforeName)); + } + whitespace(); var arguments = scanner.peekChar() == $lparen ? _argumentDeclaration() diff --git a/pkg/sass_api/CHANGELOG.md b/pkg/sass_api/CHANGELOG.md index 028cd0796..d72b35469 100644 --- a/pkg/sass_api/CHANGELOG.md +++ b/pkg/sass_api/CHANGELOG.md @@ -1,3 +1,7 @@ +## 10.3.0 + +* No user-visible changes. + ## 10.2.1 * No user-visible changes. diff --git a/pkg/sass_api/pubspec.yaml b/pkg/sass_api/pubspec.yaml index 5f7a9be18..3d8c3388a 100644 --- a/pkg/sass_api/pubspec.yaml +++ b/pkg/sass_api/pubspec.yaml @@ -2,7 +2,7 @@ name: sass_api # Note: Every time we add a new Sass AST node, we need to bump the *major* # version because it's a breaking change for anyone who's implementing the # visitor interface(s). -version: 10.2.1-dev +version: 10.3.0 description: Additional APIs for Dart Sass. homepage: https://github.com/sass/dart-sass @@ -10,7 +10,7 @@ environment: sdk: ">=3.0.0 <4.0.0" dependencies: - sass: 1.75.1 + sass: 1.76.0 dev_dependencies: dartdoc: ^6.0.0 diff --git a/pubspec.yaml b/pubspec.yaml index c0f363e2b..e78af1daa 100644 --- a/pubspec.yaml +++ b/pubspec.yaml @@ -1,5 +1,5 @@ name: sass -version: 1.75.1-dev +version: 1.76.0 description: A Sass implementation in Dart. homepage: https://github.com/sass/dart-sass