[code-reflection] RFR: Onnx direct reflection over records as tuples [v6]

Paul Sandoz psandoz at openjdk.org
Mon Mar 31 22:17:10 UTC 2025


On Mon, 31 Mar 2025 18:49:33 GMT, Adam Sotona <asotona at openjdk.org> wrote:

>> This PR removes `ExplicitOnnxOps.LoopReturn` and reflects directly on Records.
>> 
>> Unfortunately in some situations `new LoopReturn` cause javac crashing with IOOBE  at `jdk.incubator.code/jdk.incubator.code.internal.ReflectMethods$BodyScanner.thisValue(ReflectMethods.java:689)`.
>> 
>> Problematic use cases are at `WalkTheMazeTest::turnRight` and `WalkTheMazeTest::turnLeftWhileWall`.
>> While seamlessly working use cases are at `WalkTheMazeTest::walkAroundTheMaze` and `SimpleTest::forLoopAdd`.
>> 
>> As a temporary workaround any static factory method returning a record is also treated as a tuple constructor.
>> 
>> Please review.
>> 
>> Thanks,
>> Adam
>
> Adam Sotona has updated the pull request incrementally with one additional commit since the last revision:
> 
>   main loop in WalkTheMazeTest use tuple with three tensors

cr-examples/onnx/src/main/java/oracle/code/onnx/ExplicitOnnxOperators.java line 90:

> 88: 
> 89:     public record LoopReturn<T>(Tensor<Boolean> cond, T output) {}
> 90:     public interface LoopBody<T> extends Quotable {

Suggest renaming `LoopReturn` to `LoopResult`

-------------

PR Review Comment: https://git.openjdk.org/babylon/pull/375#discussion_r2021845531


More information about the babylon-dev mailing list