Guice600 (original) (raw)
Guice 6.0.0
Released May 12th, 2023.
Maven
Guice:
com.google.inject guice 6.0.0Extensions:
com.google.inject.extensions guice-${extension} 6.0.0Downloads
- Guice:guice-6.0.0.jar
- Guice extensions are all directly downloadablefrom this search page. Just click on the "jar" link for the appropriate extension.
Docs
Changes since Guice 5.1.0
JEE Jakarta Transition
Guice 6.0 adds support for jakarta.inject, the new namespace for theJSR330 spec (after the javax -> jakarta JEE transition). The following links talk more about the jakarta transition:Jarkata EE blog post,Eclipse Foundation blog post,Jakarta EE Wikipedia article,Oracle blog post
Guice 6.0 is being released alongsideGuice 7.0 and is intended to help users migrate their code to the jakarta namespace. Guice 6.0 continues to fully support the javax.inject namespace while also mostly supporting thejakarta.inject namespace. The only part of Guice 6.0 that doesn't supportjakarta.inject are the bind(..).toProvider methods. Those methods still require javax.inject or com.google.inject Providers.
The Guice 6.0 servlet & persist extensions only support the javax.servlet andjavax.persistence namespaces respectively. If compatibility withjakarta.servlet or jakarta.persistence is required, use Guice 7.0.
Guice 7.0 removes support for javax.inject, javax.servlet andjavax.persistence. Other than the namespace changes, Guice 6.0 & Guice 7.0 are identical.
Guice 6.0 can help with incremental migrations to the jakarta.injectnamespace, by incrementally replacing javax.inject references tojakarta.inject. This works everywhere, except for code where a jakartaProvider is passed to bind(..).toProvider. Any one of the following options can be used to workaround the toProvider issue.
- Update to Guice 7.0 instead. Guice 7.0 fully supports
jakarta.inject(but does not have support forjavax.injectanymore). - Change the provider implementation to instead implement
com.google.inject.Provider(which works in both 6.0 & 7.0). - Change the provider implementations to instead be
@Providesmethods, or add a wrapper@Providesmethod that delegates to the actual provider. - Call
bind(..).toProvider(Providers.guicify(myJakartaProvider)). Theguicifymethod will adapt a jakarta provider instance to acom.google.inject.Provider. This only works if binding a Provider_instance_. It will not work for binding provider classes, type literals, or keys. If using this approach, it's best to revert theguicifycalls when later updating to Guice 7.0, because they otherwise mask the actual provider implementation (which can be accessed through the Guice SPI'sProviderInstanceBinding.getUserSuppliedProvider).
Note that even though Guice 6.0's toProvider methods don't support jakarta providers, Guice 6.0 can inject jakarta.inject.Provider.
Details
See https://github.com/google/guice/compare/5.1.0...6.0.0 for a complete list of changes.
Guice Core
- Adds
jakarta.injectsupport. (#1630,#1679,#1490,#1383, with significant advice & help from many people) - Support Java 21 (via updating ASM to 9.5 and other changes). (#1671,#1657,#1654)
- Improve AOP support on JVMs such as Azul. (#1672, with significant help from @mcculls and@alsemenov)
- Fix a deadlock or crash associated with recursively loading just-in-time bindings. (#1633,#785,#1389,#1394, with significant help from @swankjesse and@PaulFridrick)
- Make
PrivateModule.binder()non-private, to allow subclass customization, such as callingskipSources. (#1569,#1525, by@visi) - Fix an endloop loop (that can OOM) in singleton lock cycle detection. (#1635,#1510, with significant help from @trancexpress and@gvisco)
- Fix tests to pass on Windows, despite the different line separator. (#1213)
- Improvements to OSGi metadata. (#1173,#1050,#1049,#1708 by@mcculls,@kenwenzel, and@HannesWell)
- Mark the JSR305 dependency as optional (since it's not required at runtime). (#1172, by@mcculls)
- Fix
Binder.requestInjection(TypeLiteral<T>, T)to use theTypeLiteral. (#1071, by@jedediah) - Honor scoping annotations on concrete types when provisioned by their
@ProvidedByannotation (#251,#1319) - Add a way to tell if a class is "enhanced" by Guice, and retrieve the original class. (#1340,#187)
- Ensure the order of
bind(...)statements does not matter when referring to JIT bindings. (#700,#1650, with significant help from @nineninesevenfour) - Implement
Matcher.andandMatcher.oras default methods directly inMatcher, so that theAbstractMatchersubclass isn't required. (#1716,#1177, by@kashike) - Mark the error_prone_annotations dependency as optional. (#1739, by@HannesWell)
Servlet
- Fix an NPE if
contextPathis null (#1656,#1655, by@kurtseebauer)
Persist
Persist had a number of changes, some of which are backwards incompatible. Notably: injection of EntityManager no longer implicitly starts a unit of work (because this led to leaks). Users can opt-in to the legacy behavior by constructing theJpaPersistModulewith aJpaPersistOptionsthat setssetAutoBeginWorkOnEntityManagerCreationto true.
- EntityManager provisioning no longer automatically starts a unit of work. (#739,#997,#730,#985,#959,#731)
- Ignore multiple start/stop calls, rather than throwing an exception. (#1214,#972,#598, by@chrisparton1991)
- Support manually initiated rollbacks. (#1137,#1136, by@Vogel612)
- Don't wrap Object-defined methods (e.g: toString, finalize, equals, hashCode) in transactions. (#958,#788, by@andresviedma)