You are viewing a plain text version of this content. The canonical link for it is here.
Posted to issues@geode.apache.org by "Udo Kohlmeyer (Jira)" <ji...@apache.org> on 2020/11/30 22:10:00 UTC
[jira] [Created] (GEODE-8747) Collect library dependencies into
single dependency
Udo Kohlmeyer created GEODE-8747:
------------------------------------
Summary: Collect library dependencies into single dependency
Key: GEODE-8747
URL: https://issues.apache.org/jira/browse/GEODE-8747
Project: Geode
Issue Type: New Feature
Components: build
Reporter: Udo Kohlmeyer
Library dependencies like Spring, Jackson, Spring Security, etc. usually have many dependencies. Which if used within a module, require the listing each of these dependencies.
With the addition of ClassLoader Isolation a need arose, where these libraries where loaded into a single ClassLoader, instead of being loaded by the ClassLoaders of each of the modules that depended on these libraries.
This feature is to replace the following:
{code:groovy}
implementation('org.springframework:spring-core')
implementation('org.springframework:spring-beans')
implementation('org.springframework:spring-context')
implementation('org.springframework:spring-jcl')
implementation('org.springframework:spring-web')
implementation('org.springframework.shell:spring-shell')
{code}
with a single entry:
{code:groovy}
implementation(project(':frameworks:springframework'))
{code}
What this new construct allows for is a pattern closer to "using a framework" without having to explicitly define all the library dependencies. In this approach, we "use" a framework library, rather than knowing all of the internal dependencies.
With this change, the ClassLoader isolation work, will only load each dependency once.
Currently identified dependencies that require to be loaded only once are:
Spring and Jackson
--
This message was sent by Atlassian Jira
(v8.3.4#803005)