Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
turbo-tasks: Expand
<T as TaskOutput>::Return
values in macros (ver…
…cel/turborepo#8096) Previously, we'd generate function return types like: ```rust <Vc<AssetIdent> as TaskOutput>::Return ``` which is equivalent to the much simpler: ```rust Vc<AssetIdent> ``` That approach is nice because it's easier to implement in the macros, and it's more correct, because it uses the type system to verify the type of `Vc` and `Result` are what we expect. However, it makes the rustdoc output much harder to read. This attempts to the expansion of `TaskOutput::Return` inside the macro to generate more readable documentation, at the cost of some correctness. <details> <summary><strong>Rustdoc Before</strong></summary> data:image/s3,"s3://crabby-images/cea21/cea215008b729ce62a81f186f4404b1dfc1c6422" alt="Screenshot 2024-05-06 at 5.35.11 PM.png" </details> <details> <summary><strong>Rustdoc After</strong></summary> data:image/s3,"s3://crabby-images/ab590/ab590d2065fa73a7e4629b4229defd1ac360dd65" alt="Screenshot 2024-05-06 at 5.35.01 PM.png" </details> <details> <summary><strong>Example compilation error</strong> with an invalid return type</summary> data:image/s3,"s3://crabby-images/f9863/f9863cbe5f377ba6d353099280fe1a4458fea89c" alt="Screenshot 2024-05-06 at 5.48.00 PM.png" </details>
- Loading branch information