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

[wpiutil] Add Java algebraic data types #7447

Open
SamCarlberg opened this issue Nov 29, 2024 · 9 comments
Open

[wpiutil] Add Java algebraic data types #7447

SamCarlberg opened this issue Nov 29, 2024 · 9 comments
Labels
type: feature Brand new functionality, features, pages, workflows, endpoints, etc.
Milestone

Comments

@SamCarlberg
Copy link
Member

We currently use Java's Optional type to represent optional values, such as alliance station or color. This can still lead to errors in user code, however, since there's no guardrails to prevent users from calling get() without first checking for isPresent(). Adding ADTs for optional values would allow us to leverage the type system to put such guardrails in place.

This requires Java 21 for its pattern matching support. It would still be possible on Java 17 with its enhanced instanceof and sealed types, but the checks are clunky. Tagging this for 2027 for MRC and Java 21+ support

// Rust naming for sake of example
sealed interface Option<T> permits Some, None {
  record Some<T>(T value) implements Option<T> {}
  record None<T>() implements Option<T> {}
}

Option<Alliance> getAlliance() { ... }

// Java 21+
boolean shouldFlipPaths = getAlliance() instanceof Some(Alliance color) && color == Alliance.kRed;

// Java < 21
boolean shouldFlipPaths = false;
if (getAlliance() instanceof Some<Alliance> some) {
  shouldFlipPaths = some.value() == Alliance.kRed;
}

Types like Rust's Result probably shouldn't be added. Java already functionally has that with exceptions, which also force users to either handle the error results or let their program crash; a Result type would allow users to just ignore errors, which would be a regression

@SamCarlberg SamCarlberg added the type: feature Brand new functionality, features, pages, workflows, endpoints, etc. label Nov 29, 2024
@SamCarlberg SamCarlberg added this to the 2027 milestone Nov 29, 2024
@SamCarlberg SamCarlberg added this to 2027 Nov 29, 2024
@narmstro2020
Copy link
Contributor

I didn't know Java 21 brought in so many wonderful ADT features.

This will be useful almost everywhere in the codebase.

For instance the units library. 👍

@SamCarlberg
Copy link
Member Author

@narmstro2020 I hadn't considered how the units library would be affected. Can you give some examples of how you think it'd be used?

@narmstro2020
Copy link
Contributor

You could reduce the amount of instanceof's that currently exist in the api. With pattern matching. That's the first thing that came to mind.

The entire API is just loaded with types. It really just depends on how well ADTs and pattern matching play well with Java generics or if an alternative can be found.

@SamCarlberg
Copy link
Member Author

Well, measures are technically already product types; they'll just formally become so when we can transition them to records in 2027. I don't see how pattern matching would be useful for them, since you typically use the direct measure types when possible (eg Distance instead of Measure<DistanceUnit>), and can just call API methods directly without deconstruction

@narmstro2020
Copy link
Contributor

Whats preventing records from being used now. I thought they were a Java 14 feature?

@SamCarlberg
Copy link
Member Author

Whats preventing records from being used now

Immutability constraints imposed by the roboRIO. 2027 will have just a single record for measure objects, instead of an interface with an immutable and a mutable implementation.

@neebah
Copy link

neebah commented Dec 1, 2024

The thought was mostly a potential. I was watching a tutorial on ADT's in Java. Remembered your post and had a low level epiphany.

It may be for nought. It might be useful it might not. Wanted to share with you either way.

@narmstro2020
Copy link
Contributor

Sorry that above comment was from me on a different github account. Oopsy

I'm wondering if project Valhalla with its value based types will benefit the Units API as well.

@SamCarlberg
Copy link
Member Author

Valhalla might help, but I've done some experiments with its ea builds on my raspberry pi 5 testbed and didn't see a meaningful change in GC behavior. The final releases may be better for performance, but access to more RAM and the ZGC garbage collector on the MRC will be a huge improvement on their own even without Valhalla in the mix

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
type: feature Brand new functionality, features, pages, workflows, endpoints, etc.
Projects
Status: No status
Development

No branches or pull requests

3 participants