JetBrains released a JDK 25 version of it's runtime today. It's marked "pre-release" but that doesn't scare me much since I only use it locally during development.
Quick testing showed it seemingly works fine with WO on Eclipse 2025-09 with the current hotswap-agent v2.0.1, so I changed all my own apps and libraries from targeting JDK 21 to JDK 25. Since my build and deployment environments are already running JDK 25, each project's "migration process" consisted of updating the JDK version in the pom.xml and doing a commit/push/build/deploy. Easy upgrade, everything works like a charm and I'm a happy man. Now giving it a few days in testing in my own projects before updating client projects.
I haven't migrated any of my public libraries or frameworks yet but probably will in the next few days. I'll be keeping Parsley and Vermilingua on JDK 21 for a while though, since they're used by others and I'm aware not everyone is in quite the same hurry to upgrade as I am.
For your WO application to work with JDK 25, you must use the workaround for the JDK's removal of GetPropertyAction or use wonder-slim which includes it. See previous article on JDK 25 for more info.
hotswap-agentxattr dance/Library/JavaVirtualMachines (or wherever you keep your JVMs)% curl -LO https://cache-redirector.jetbrains.com/intellij-jbr/jbrsdk-25-osx-aarch64-b176.4.tar.gz
% curl -LO https://github.com/HotswapProjects/HotswapAgent/releases/download/RELEASE-2.0.1/hotswap-agent-2.0.1.jar
% tar -xzf jbrsdk-25-osx-aarch64-b176.4.tar.gz
% mkdir jbrsdk-25-osx-aarch64-b176.4/Contents/Home/lib/hotswap
% mv hotswap-agent-2.0.1.jar jbrsdk-25-osx-aarch64-b176.4/Contents/Home/lib/hotswap/hotswap-agent.jar
% sudo xattr -r -d com.apple.quarantine jbrsdk-25-osx-aarch64-b176.4
% sudo mv jbrsdk-25-osx-aarch64-b176.4 /Library/Java/JavaVirtualMachines
Then add the JDK in Eclipse, which I assume you know how to do. And don't forget to configure the JDK with default arguments for WO and DCEVM/hotswap-agent.
Note that the set of packages you need to open may differ from these, based on which classes you actually use. But this basic set has served me well.
-XX:+AllowEnhancedClassRedefinition
-XX:HotswapAgent=fatjar
--add-opens java.base/java.time=ALL-UNNAMED
--add-opens java.base/java.lang=ALL-UNNAMED
--add-opens java.base/java.util=ALL-UNNAMED
| 🚀 ng-objects | Update junit v6.0.0 -> v6.0.1 | Dec 26 |
| 🚀 ng-objects | Renamed NGSession.shouldTerminate() to .shouldReap() | Dec 26 |
| 🌶 cayenne | CAY-2906 In-memory evaluation of `(not) exists` expressions | Dec 10 |
| 🌶 cayenne | CAY-2906 In-memory evaluation of `(not) exists` expressions | Dec 10 |
| 🌶 cayenne | CAY-2891 Expressions: incorrect SQL translation of the ASTNegate node… | Dec 10 |
| 🌶 cayenne | Merge pull request #634 from m-dzianishchyts/CAY-2891-negate-null | Dec 10 |
| 🌶 cayenne | CAY-2860 Translate (not)in expression with empty values | Dec 10 |
| 🌶 cayenne | Merge pull request #635 from m-dzianishchyts/CAY-2860-exp-in-empty | Dec 10 |
| 🔌 wo-adaptor-jetty | Update README | Dec 9 |
| 🔌 wo-adaptor-jetty | Update jetty v12.1.4 -> v12.1.5 | Dec 8 |