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

Dictionary expressions: update key-value pair conversions #8850

Merged
merged 3 commits into from
Dec 31, 2024

Conversation

cston
Copy link
Member

@cston cston commented Dec 8, 2024

No description provided.

> * If `Eᵢ` is a *key value pair element* `Kᵢ:Vᵢ`, there is an implicit conversion from `Kᵢ` to `K` and an implicit conversion from `Vᵢ` to `V`.
> * If `Eᵢ` is a *spread element* `..Sᵢ`, then the *iteration type* of `Sᵢ` is `KeyValuePair<Kᵢ:Vᵢ>` and there is an implicit conversion from `Kᵢ` to `K` and an implicit conversion from `Vᵢ` to `V`.
> * Otherwise there is *no implicit conversion* from the collection expression to the target type.
An explicit *key-value pair conversion* exists from an expression of type `KeyValuePair<T1, T2>` to a type `KeyValuePair<U1, U2>`
Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Does the explicit conversion matter for us? Or is now for parity/completeness with existing conversions?

Trying to figure out how it would matter for CEs

Copy link
Member Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

The explicit conversion is for completeness and consistency with other conversions.

Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Sounds good :)

@jcouv jcouv self-assigned this Dec 12, 2024
```

Key-value pair conversions are similar to *tuple conversions* that allow converting between distinct tuple types.
That said, a tuple conversion is [*defined*](https://github.com/dotnet/csharpstandard/blob/draft-v8/standard/conversions.md#10213-implicit-tuple-conversions) as a conversion from a *tuple expression* rather than a tuple type, despite being allowed in conversions like `b = a` below, so perhaps conversions between `KeyValuePair<,>` *types* should not be supported.
Copy link
Member Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

See csharpstandard/issues 1155

@cston cston marked this pull request as ready for review December 30, 2024 20:27
@cston cston requested a review from a team as a code owner December 30, 2024 20:28
@cston cston requested review from jnm2 and MadsTorgersen December 30, 2024 20:28
@cston cston merged commit 1102fa9 into dotnet:main Dec 31, 2024
1 check passed
@cston cston deleted the kvp-conversions branch December 31, 2024 19:54
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.

4 participants