Skip to content

Conversation

renovate[bot]
Copy link

@renovate renovate bot commented Dec 3, 2024

This PR contains the following updates:

Package Type Update Change
dart_style dependencies major ^1.3.3 -> ^3.0.0

Release Notes

dart-lang/dart_style (dart_style)

v3.1.2

Compare Source

  • Support dot shorthand syntax.
  • Update to the latest package:analyzer.
  • Enable language version 3.10.
Bug fixes
  • Preserved trailing commas (trailing_commas: preserve) applies to record
    type annotations too (#​1721).
Style changes

This change only applies to code whose language version is 3.10 or higher:

  • When trailing_commas is preserve, preserve a trailing comma after the last
    enum constant when members are present (#​1678, #​1729).

    // Before formatting:
    enum { constant, ; member() {} }
    
    // After formatting at language version 3.9 or lower:
    enum {
      constant;
    
      member() {}
    }
    
    // After formatting at language version 3.10 or higher:
    enum {
      constant,
      ;
    
      member() {}
    }

    (Thanks to jellynoone@ for this change.)

v3.1.1

Compare Source

  • Update to latest analyzer and enable language version 3.9.

v3.1.0

Compare Source

This release contains a fairly large number of style changes in response to
feedback we got from shipping the new tall style formatter.

Features
  • Allow preserving trailing commas and forcing the surrounding construct to
    split even when it would otherwise fit on one line. This is off by default
    (because it breaks reversibility among other reasons) but can be enabled
    by adding this to a surrounding analysis_options.yaml file:

    formatter:
      trailing_commas: preserve

    This is similar to how trailing commas work in the old short style formatter
    applied to code before language version 3.7.

Bug fixes
  • Don't add a trailing comma in lists that don't allow it, even when there is
    a trailing comment (#​1639).
Style changes

The following style changes are language versioned and only affect code whose
language version is 3.8 or later. Dart code at 3.7 or earlier is formatted the
same as it was before.

  • Allow more code on the same line as a named argument or => (#​1536, #​1545,
    #​1668, #​1679).

    // Before:
    function(
      name:
          (param, another) =>
              veryLongBody,
    );
    
    function(
      name:
          (param) => another(
            argument1,
            argument2,
            argument3,
          ),
    );
    
    // After:
    function(
      name: (param, another) =>
          veryLongBody,
    );
    
    function(
      name: (param) => another(
        argument1,
        argument2,
        argument3,
      ),
    );
  • Avoid splitting chains containing only properties.

    // Before:
    variable = target
        .property
        .another;
    
    // After:
    variable =
        target.property.another;

    Note that this only applies to . chains that are only properties. If there
    are method calls in the chain, then it prefers to split the chain instead of
    splitting at =, :, or =>.

  • Allow the target or property chain part of a split method chain on the RHS of
    =, :, and => (#​1466).

    // Before:
    variable =
        target.property
            .method()
            .another();
    
    // After:
    variable = target.property
        .method()
        .another();
  • Allow the condition part of a split conditional expression on the RHS of =,
    :, and => (#​1465).

    // Before:
    variable =
        condition
        ? longThenBranch
        : longElseBranch;
    
    // After:
    variable = condition
        ? longThenBranch
        : longElseBranch;
  • Don't indent conditional branches redundantly after =, :, and =>.

    // Before:
    function(
      argument:
          condition
              ? thenBranch
              : elseBranch,
    )
    
    // After:
    function(
      argument:
          condition
          ? thenBranch
          : elseBranch,
    )
  • Indent conditional branches past the operators (#​1534).

    // Before:
    condition
        ? thenBranch +
            anotherOperand
        : elseBranch(
          argument,
        );
    
    // After:
    condition
        ? thenBranch +
              anotherOperand
        : elseBranch(
            argument,
          );
  • Block format record types in typedefs (#​1651):

    // Before:
    typedef ExampleRecordTypedef =
        (
          String firstParameter,
          int secondParameter,
          String thirdParameter,
          String fourthParameter,
        );
    
    // After:
    typedef ExampleRecordTypedef = (
      String firstParameter,
      int secondParameter,
      String thirdParameter,
      String fourthParameter,
    );
  • Eagerly split argument lists whose contents are complex enough to be easier
    to read spread across multiple lines even if they would otherwise fit on a
    single line (#​1660). The rules are basically:

    • If an argument list contains at least three named arguments, at least one
      of which must be directly in the argument list and at least one of which
      must be nested in an inner argument list, then force the outer one to split.
      We make an exception where a named argument whose expression is a simple
      number, Boolean, or null literal doesn't count as a named argument.

    • If a list, set, or map literal is the immediate expression in a named
      argument and contains any argument lists with a named argument, then force
      the collection to split.

    // Before:
    TabBar(tabs: [Tab(text: 'A'), Tab(text: 'B')], labelColor: Colors.white70);
    
    // After:
    TabBar(
      tabs: [
        Tab(text: 'A'),
        Tab(text: 'B'),
      ],
      labelColor: Colors.white70,
    );

v3.0.1

Compare Source

  • Handle trailing commas in for-loop updaters (#​1354).
  • Format || patterns like fallthrough cases in switch expressions (#​1602).
  • Handle comments and metadata before variables more gracefully (#​1604).
  • Ensure comment formatting is idempotent (#​1606).
  • Better indentation of leading comments on property accesses in binary operator
    operands (#​1611).
  • Don't crash on doc comments in local variable declarations (#​1621).

v3.0.0

This is a large change. Under the hood, the formatter was almost completely
rewritten, with the codebase now containing both the old and new
implementations. The old formatter exists to support the older "short" style
and the new code implements the new "tall" style.

The formatter uses the language version of the formatted code to determine
which style you get. If the language version is 3.6 or lower, the code is
formatted with the old style. If 3.7 or later, you get the new tall style. You
typically control the language version by setting a min SDK constraint in your
package's pubspec
.

In addition to the new formatting style, a number of other API and CLI changes
are included, some of them breaking:

  • Support project-wide page width configuration. By long request, you can
    now configure your preferred formatting page width on a project-wide basis.
    When formatting files, the formatter will look in the file's directory and
    any surrounding directories for an analysis_options.yaml file. If it finds
    one, it looks for the following YAML:

    formatter:
      page_width: 123

    If it finds a formatter key containing a map with a page_width key whose
    value is an integer, then that is the page width that the file is formatted
    using. Since the formatter will walk the surrounding directories until it
    finds an analysis_options.yaml file, this can be used to globally set the
    page width for an entire directory, package, or even collection of packages.

  • Support overriding the page width for a single file. In code formatted
    using the new tall style, you can use a special marker comment to control the
    page width that it's formatted using:

    // dart format width=30
    main() {
      someExpression +
          thatSplitsAt30;
    }

    This comment must appear before any code in the file and must match that
    format exactly. The width set by the comment overrides the width set by any
    surrounding analysis_options.yaml file.

    This feature is mainly for code generators that generate and immediately
    format code but don't know about any surrounding analysis_options.yaml
    that might be configuring the page width. By inserting this comment in the
    generated code before formatting, it ensures that the code generator's
    behavior matches the behavior of dart format.

    End users should mostly use analysis_options.yaml for configuring their
    preferred page width (or do nothing and use the default page width of 80).

  • Support opting out a region of code from formatting. In code formatted
    using the new tall style, you can use a pair of special marker comments to
    opt a region of code out of automated formatting:

    main() {
      this.isFormatted();
      // dart format off
      no   +   formatting
        +
          here;
      // dart format on
      formatting.isBackOnHere();
    }

    The comments must be exactly // dart format off and // dart format on.
    A file may have multiple regions, but they can't overlap or nest.

    This can be useful for highly structured data where custom layout can help
    a reader understand the data, like large lists of numbers.

  • Remove support for fixes and --fix. The tools that come with the Dart
    SDK provide two ways to apply automated changes to code: dart format --fix
    and dart fix. The former is older and used to be faster. But it can only
    apply a few fixes and hasn't been maintained in many years. The dart fix
    command is actively maintained, can apply all of the fixes that
    dart format --fix could apply and many many more.

    In order to avoid duplicate engineering effort, we decided to consolidate on
    dart fix as the one way to make automated changes that go beyond the simple
    formatting and style changes that dart format applies.

    The ability to apply fixes is also removed from the DartFormatter() library
    API.

  • Make the language version parameter to DartFormatter() mandatory. This
    way, the formatter always knows what language version the input is intended
    to be treated as. Note that a // @​dart= language version comment, if
    present, overrides the specified language version. You can think of the
    version passed to the DartFormatter() constructor as a "default" language
    version which the file's contents may then override.

    If you don't particularly care about the version of what you're formatting,
    you can pass in DartFormatter.latestLanguageVersion to unconditionally get
    the latest language version that the formatter supports. Note that doing so
    means you will also implicitly opt into the new tall style.

    This change only affects the library API. When using the formatter from the
    command line, you can use --language-version= to specify a language version
    or pass --language-version=latest to use the latest supported version. If
    omitted, the formatter will look in the surrounding directories for a package
    config file and infer the language version for the package from that, similar
    to how other Dart tools behave like dart analyze and dart run.

  • Remove the old formatter executables and CLI options. Before the
    dart format command was added to the core Dart SDK, users accessed the
    formatter by running a separate dartfmt executable that was included with
    the Dart SDK. That executable had a different CLI interface. For example, you
    had to pass -w to get it to overwrite files. When we added dart format,
    we took that opportunity to revamp the CLI options.

    However, the dart_style package still exposed an executable with the old CLI.
    If you ran dart pub global activate dart_style, this would give you a
    dartfmt (and dartformat) executable with the old CLI options. Now that
    almost everyone is using dart format, we have removed the old CLI and the
    old package executables.

    You can still run the formatter on the CLI through the package (for example,
    if you want to use a particular version of dart_style instead of the one
    bundled with your Dart SDK). But it now uses the exact same CLI options and
    arguments as the dart format command. You can invoke it with
    dart run dart_style:format <args...>.

  • Treat the --stdin-name name as a path when inferring language version.
    When reading input on stdin, the formatter still needs to know what language
    version to parse the code as. If the --stdin-name option is set, then that
    is treated as a file path and the formatter looks for a package config
    surrounding that file path to infer the language version from.

    If you don't want that behavior, pass in an explicit language version using
    --language-version=, or use --language-version=latest to parse the input
    using the latest language version supported by the formatter.

    If --stdin-name and --language-version are both omitted, then the
    formatter parses stdin using the latest supported language version.

  • Rename the --line-length option to --page-width. This is consistent
    with the public API, internal implementation, and docs, which all use "page
    width" to refer to the limit that the formatter tries to fit code into.

    The --line-length name is still supported for backwards compatibility, but
    may be removed at some point in the future. You're encouraged to move to
    --page-width. Use of this option (however it's named) is rare, and will
    likely be even rarer now that project-wide configuration is supported, so
    this shouldn't affect many users.

  • Apply class modifiers to API classes. The dart_style package exposes only
    a few classes in its public API: DartFormatter, SourceCode,
    FormatterException, and UnexpectedOutputException. None were ever
    intended to be extended or implemented. They are now all marked final to
    make that intention explicit.

  • Require package:analyzer >=6.5.0 <8.0.0.

v2.3.7

Compare Source

  • Allow passing a language version to DartFomatter(). Formatted code will be
    parsed at that version. If omitted, defaults to the latest version. In a
    future release, this parameter will become required.
  • Allow opting out of formatting for a region of code using // dart format off
    and // dart format on comments. Note: This only works using the new tall
    style and requires passing the --enable-experiment=tall-style experiment
    flag (#​361).
  • Preserve type parameters on old-style function-typed formals that also use
    this. or super. (#​1321).
  • Correctly format imports with both as and if clauses (#​1544).
  • Remove temporary work around for analyzer 6.2.0 from dart_style 2.3.6.
  • Require package:analyzer >=6.5.0 <7.0.0.

v2.3.6

Compare Source

  • Fix compile error when using dart_style with analyzer 6.2.0.

v2.3.5

Compare Source

  • Ensure switch expressions containing line comments split (#​1404).
  • Use language version 3.3 to parse so that code with extension types can be
    formatted.
  • Support formatting the macro modifier when the macros experiment flag
    is passed.

v2.3.4

Compare Source

  • Add tall-style experiment flag to enable the in-progress unstable new
    formatting style (#​1253).
  • Format extension types.
  • Normalize ignored whitespace and "escaped whitespace" on first line
    of multiline string literals (#​1235).

v2.3.3

Compare Source

  • Always split enum declarations containing a line comment (#​1254).
  • Fix regression in splitting type annotations with library prefixes (#​1249).
  • Remove support for inline class since that syntax has changed.
  • Add --enable-experiment command-line option to enable language experiments.
    The library API also supports this with DartFormatter.experimentFlags.

v2.3.2

  • Don't indent parameters that have metadata annotations. Instead, align them
    with the metadata and other parameters.
  • Allow metadata annotations on parameters to split independently of annotations
    on other parameters (#​1212).
  • Don't split before . following a record literal (#​1213).
  • Don't force split on a line comment before a switch expression case (#​1215).
  • Require package:analyzer >=5.12.0 <7.0.0.
  • Preserve ? on nullable empty record types (#​1224).

v2.3.1

  • Hide --fix and related options in --help. The options are still there and
    supported, but are no longer shown by default. Eventually, we would like all
    users to move to using dart fix instead of dart format --fix.
  • Don't indent || pattern operands in switch expression cases.
  • Don't format sealed, interface, and final keywords on mixin
    declarations. The proposal was updated to no longer support them.
  • Don't split before a single-section cascade following a record literal.
  • Give records block-like formatting in argument lists (#​1205).

v2.3.0

Compare Source

New language features
  • Format patterns and related features.
  • Format record expressions and record type annotations.
  • Format class modifiers base, final, interface, mixin, and sealed.
  • Format inline class declarations.
  • Format unnamed libraries.
Bug fixes and style changes
  • Handle sync* and async* functions with => bodies.
  • Fix bug where parameter metadata wouldn't always split when it should.
  • Don't split after < in collection literals.
  • Better indentation of multiline function types inside type argument lists.
Internal changes
  • Use typed _visitFunctionOrMethodDeclaration instead of dynamically typed.
  • Fix metadata test to not fail when record syntax makes whitespace between
    metadata annotation names and ( significant (sdk#50769).
  • Require Dart 2.19.
  • Require package:analyzer ^5.7.0.

v2.2.5

Compare Source

  • Format unnamed libraries.
  • Require Dart 2.17.

v2.2.4

Compare Source

  • Unify how brace-delimited syntax is formatted. This is mostly an internal
    refactoring, but slightly changes how a type body containing only an inline
    block comment is formatted.
  • Refactor Chunk to store split before text instead of after. This mostly does
    not affect the visible behavior of the formatter, but a few edge cases are
    handled slightly differently. These are all bug fixes where the previous
    behavior was unintentional. The changes are:
  • Consistently discard blank lines between a { or [ and a subsequent
    comment. It used to do this before the { in type bodies, but not switch
    bodies, optional parameter sections, or named parameter sections.
  • Don't allow splitting an empty class body.
  • Allow splitting after an inline block comment in some places where it makes
    sense.
  • Don't allow a line comment in an argument list to cause preceding arguments
    to be misformatted.
  • Remove blank lines after a line comment at the end of a body.
  • Require package:analyzer >=4.4.0 <6.0.0.

v2.2.3

Compare Source

  • Allow the latest version of package:analyzer.

v2.2.2

Compare Source

v2.2.1

Compare Source

  • Require package:analyzer version 2.6.0.
  • Use NamedType instead of TypeName.

v2.2.0

Compare Source

  • Fix analyzer dependency constraint (#​1051).

v2.1.1

Compare Source

  • Republish 2.0.3 as 2.1.1 in order to avoid users getting 2.1.0, which has a
    bad dependency constraint (#​1051).

v2.1.0

Compare Source

  • Support generic function references and constructor tear-offs (#​1028).

v2.0.3

Compare Source

v2.0.2

Compare Source

  • Don't unnecessarily split argument lists with /* */ comments (#​837).
  • Return correct exit code from FormatCommand when formatting stdin (#​1035).
  • Always split cascades with multiple sections (#​1006).
  • Don't indent cascades farther than their receiver method chains.
  • Optimize line splitting cascades (#​811).
  • Split empty catch blocks with finally clauses (#​1029).
  • Split empty catch blocks with catches after them.
  • Allow the latest version of package:analyzer.

v2.0.1

Compare Source

  • Support triple-shift >>> and >>>= operators (#​992).
  • Support non-function type aliases (#​993).
  • Correct constructor initializer indentation after required (#​1010).

v2.0.0

  • Migrate to null safety.

Configuration

📅 Schedule: Branch creation - At any time (no schedule defined), Automerge - At any time (no schedule defined).

🚦 Automerge: Disabled by config. Please merge this manually once you are satisfied.

Rebasing: Whenever PR becomes conflicted, or you tick the rebase/retry checkbox.

🔕 Ignore: Close this PR and you won't be reminded about this update again.


  • If you want to rebase/retry this PR, check this box

This PR was generated by Mend Renovate. View the repository job log.

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment

Labels

None yet

Projects

None yet

Development

Successfully merging this pull request may close these issues.

0 participants