Dart: fix problems with default values that use collection types #1622
Add this suggestion to a batch that can be applied as a single commit.
This suggestion is invalid because no changes were made to the code.
Suggestions cannot be applied while the pull request is closed.
Suggestions cannot be applied while viewing a subset of changes.
Only one suggestion per line can be applied in a batch.
Add this suggestion to a batch that can be applied as a single commit.
Applying suggestions on deleted lines is not supported.
You must change the existing code in this line in order to create a valid suggestion.
Outdated suggestions cannot be applied.
This suggestion has been applied or marked resolved.
Suggestions cannot be applied from pending reviews.
Suggestions cannot be applied on multi-line comments.
Suggestions cannot be applied while the pull request is queued to merge.
Suggestion cannot be applied right now. Please check back later.
This series fixes problems that occur when either
@Immutable
or
@PositionalDefaults
annotation is used in combination withcollection types.
--------
@PositionalDefaults
--------The usage of 'PositionalDefaults' annotation
combined with nullable collection field that has 'null'
default value yields the code that does not compile.
The generator blindly applies 'const' keyword before
the default value for collections. A special 'null' value is
not taken into account.
--------
@Immutable
--------Usage of 'Immutable' annotation combined
with collection fields that have default values yields the
code that does not compile.
The generator does not apply 'const' keyword before the calls
to constructors of collections. It is required, because the
constructor of 'Immutable' structure is marked as 'const'.
The same happens when an explicit field constructor is used.
Because of 'Immutable' usage it is marked as a const, but
the default values are not initialized with values prepended
by 'const'.
-------- Content of change --------
the invalid behavior.
correctly prepend 'const' keyword when needed and to treat
'null' as it should be treated.