Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Declaring constructors and field type inheritance #4178

Open
lrhn opened this issue Nov 26, 2024 · 2 comments
Open

Declaring constructors and field type inheritance #4178

lrhn opened this issue Nov 26, 2024 · 2 comments
Labels
feature Proposed language feature that solves one or more problems primary-constructors

Comments

@lrhn
Copy link
Member

lrhn commented Nov 26, 2024

@munificent has a magnificent write-up of declaring constructors: #4169

One thing it says is that a this(final name) introduces an instance variable with signature final dynamic name;.

If the same thing was written the "old-style way":

abstract class Bar {
  abstract final String name;
}
class Foo implements Bar {
  final name;
  Foo(this.name);
}

the final name would be subject to interface type inheritance, giving Foo.namethe typeString`.

Should writing Foo as:

class Foo implements Bar {
  this(final name);
}

also be subject to interface inheritance, and only fall back to dynamic if there is nothing to inherit (and an error if there are multiple super-interfaces whose combined super-interface doesn't have a unique most-specific type for name).

If not, a quick-fix to create a declaring constructor from a non-declaring one would have to insert the type. (Which it probably can.)
And quick-fixing in the other direction would have to insert dynamic on the field.

If it does inherit, then the two ways of writing the constructor are symmetric.
I think I prefer this, because I want to think of the parameters of this as field declarations that happen to be written inside a constructor. And as a field declaration, it does get interface inheritance.

(If we do go with no inheritance, could it at least default to Object? instead of dynamic. Then the user will figure out that they forgot to write the type. Or is that a job for the "no implicit dynamic" language feature, let's call it "Dart 4.0"!)

@dart-lang/language-team

@lrhn lrhn added feature Proposed language feature that solves one or more problems primary-constructors labels Nov 26, 2024
@eernstg
Copy link
Member

eernstg commented Dec 2, 2024

Yes, I think it makes sense to support override inference also for instance variables implicitly declared by a declaring constructor. After all, the reader of code using this feature would need to have in mind that the parameter declaration in such a constructor implies an instance variable declaration, and the instance variable declaration would allow for override inference. So the inferred type should not come as a big surprise. Also, we probably don't want to make parameter-declared instance variables less attractive just because they don't support inferred types.

By the way, this proposal does support override inference for parameter-declared instance variables.

@gryznar
Copy link

gryznar commented Dec 21, 2024

I am quite confused by both proposals for primary constructors and declaring constructors. What are the status of them? It seems that primary ctors in current version mainly overlap the declaring ctors, so the primary ctors can be considered as a superset with the same possibilities as declaring ctors + ctors in class headers? The only thing I do not notice was section about private field declaration in primary ctors (it is present in declaring one)

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
feature Proposed language feature that solves one or more problems primary-constructors
Projects
None yet
Development

No branches or pull requests

3 participants