Skip to content

Commit 4d5e128

Browse files
authored
Merge pull request #1732 from WaffleLapkin/as-cast-improvements
`as` cast improvements
2 parents de2d528 + 39d94e1 commit 4d5e128

File tree

1 file changed

+27
-27
lines changed

1 file changed

+27
-27
lines changed

src/expressions/operator-expr.md

+27-27
Original file line numberDiff line numberDiff line change
@@ -454,35 +454,35 @@ Any cast that does not fit either a coercion rule or an entry in the table is a
454454
Here `*T` means either `*const T` or `*mut T`. `m` stands for optional `mut` in
455455
reference types and `mut` or `const` in pointer types.
456456

457-
| Type of `e` | `U` | Cast performed by `e as U` |
458-
|-----------------------|-----------------------|----------------------------------|
459-
| Integer or Float type | Integer or Float type | Numeric cast |
460-
| Enumeration | Integer type | Enum cast |
461-
| `bool` or `char` | Integer type | Primitive to integer cast |
462-
| `u8` | `char` | `u8` to `char` cast |
463-
| `*T` | `*V` where `V: Sized` \* | Pointer to pointer cast |
464-
| `*T` where `T: Sized` | Integer type | Pointer to address cast |
465-
| Integer type | `*V` where `V: Sized` | Address to pointer cast |
466-
| `&m₁ T` | `*m₂ T` \*\* | Reference to pointer cast |
467-
| `&m₁ [T; n]` | `*m₂ T` \*\* | Array to pointer cast |
468-
| [Function item] | [Function pointer] | Function item to function pointer cast |
469-
| [Function item] | `*V` where `V: Sized` | Function item to pointer cast |
470-
| [Function item] | Integer | Function item to address cast |
471-
| [Function pointer] | `*V` where `V: Sized` | Function pointer to pointer cast |
472-
| [Function pointer] | Integer | Function pointer to address cast |
473-
| Closure \*\*\* | Function pointer | Closure to function pointer cast |
474-
475-
\* or `T` and `V` are unsized types with compatible metadata:
476-
477-
* Both slice metadata (`*[u16]` -> `*[u8]`, `*str` -> `*(u8, [u32])`).
478-
* Both the same trait object metadata, modulo dropping auto traits (`*dyn Debug` -> `*(u16, dyn Debug)`, `*dyn Debug + Send` -> `*dyn Debug`).
479-
* **Note**: Adding auto traits is only allowed if the principal trait has the auto trait as a super trait (given `trait T: Send {}`, `*dyn T` -> `*dyn T + Send` is valid, but `*dyn Debug` -> `*dyn Debug + Send` is not).
480-
* **Note**: Generics (including lifetimes) must match (`*dyn T<'a, A>` -> `*dyn T<'b, B>` requires `'a = 'b` and `A = B`).
481-
482-
\*\* only when `m₁` is `mut` or `m₂` is `const`. Casting `mut` reference to
457+
| Type of `e` | `U` | Cast performed by `e as U` |
458+
|-----------------------|-----------------------|-------------------------------------------------------|
459+
| Integer or Float type | Integer or Float type | [Numeric cast][expr.as.numeric] |
460+
| Enumeration | Integer type | [Enum cast][expr.as.enum] |
461+
| `bool` or `char` | Integer type | [Primitive to integer cast][expr.as.bool-char-as-int] |
462+
| `u8` | `char` | [`u8` to `char` cast][expr.as.u8-as-char] |
463+
| `*T` | `*V` [^meta-compat] | [Pointer to pointer cast][expr.as.pointer] |
464+
| `*T` where `T: Sized` | Integer type | [Pointer to address cast][expr.as.pointer-as-int] |
465+
| Integer type | `*V` where `V: Sized` | [Address to pointer cast][expr.as.int-as-pointer] |
466+
| `&m₁ [T; n]` | `*m₂ T` [^lessmut] | Array to pointer cast |
467+
| `*m₁ [T; n]` | `*m₂ T` [^lessmut] | Array to pointer cast |
468+
| [Function item] | [Function pointer] | Function item to function pointer cast |
469+
| [Function item] | `*V` where `V: Sized` | Function item to pointer cast |
470+
| [Function item] | Integer | Function item to address cast |
471+
| [Function pointer] | `*V` where `V: Sized` | Function pointer to pointer cast |
472+
| [Function pointer] | Integer | Function pointer to address cast |
473+
| Closure [^no-capture] | Function pointer | Closure to function pointer cast |
474+
475+
[^meta-compat]: where `T` and `V` have compatible metadata:
476+
* `V: Sized`, or
477+
* Both slice metadata (`*[u16]` -> `*[u8]`, `*str` -> `*(u8, [u32])`), or
478+
* Both the same trait object metadata, modulo dropping auto traits (`*dyn Debug` -> `*(u16, dyn Debug)`, `*dyn Debug + Send` -> `*dyn Debug`)
479+
* **Note**: *adding* auto traits is only allowed if the principal trait has the auto trait as a super trait (given `trait T: Send {}`, `*dyn T` -> `*dyn T + Send` is valid, but `*dyn Debug` -> `*dyn Debug + Send` is not)
480+
* **Note**: Generics (including lifetimes) must match (`*dyn T<'a, A>` -> `*dyn T<'b, B>` requires `'a = 'b` and `A = B`)
481+
482+
[^lessmut]: only when `m₁` is `mut` or `m₂` is `const`. Casting `mut` reference/pointer to
483483
`const` pointer is allowed.
484484

485-
\*\*\* only for closures that do not capture (close over) any local variables
485+
[^no-capture]: only for closures that do not capture (close over) any local variables can be casted to function pointers.
486486

487487
### Semantics
488488

0 commit comments

Comments
 (0)