From 52da1d1cfd641ab141aaa7c6479fb1805ac05599 Mon Sep 17 00:00:00 2001 From: Tamas Cservenak Date: Wed, 4 Dec 2024 11:46:50 +0100 Subject: [PATCH 1/8] Just an idea for chained --- .../ChainedLocalRepositoryManager.java | 31 +++++++++++++------ 1 file changed, 22 insertions(+), 9 deletions(-) diff --git a/maven-resolver-util/src/main/java/org/eclipse/aether/util/repository/ChainedLocalRepositoryManager.java b/maven-resolver-util/src/main/java/org/eclipse/aether/util/repository/ChainedLocalRepositoryManager.java index 6b32ab2f4..100496d52 100644 --- a/maven-resolver-util/src/main/java/org/eclipse/aether/util/repository/ChainedLocalRepositoryManager.java +++ b/maven-resolver-util/src/main/java/org/eclipse/aether/util/repository/ChainedLocalRepositoryManager.java @@ -90,24 +90,32 @@ public LocalRepository getRepository() { return head.getRepository(); } + private LocalRepositoryManager getInstallTarget() { + return head; + } + + private LocalRepositoryManager getCacheTarget() { + return head; + } + @Override public String getPathForLocalArtifact(Artifact artifact) { - return head.getPathForLocalArtifact(artifact); + return getInstallTarget().getPathForLocalArtifact(artifact); } @Override public String getPathForRemoteArtifact(Artifact artifact, RemoteRepository repository, String context) { - return head.getPathForRemoteArtifact(artifact, repository, context); + return getCacheTarget().getPathForRemoteArtifact(artifact, repository, context); } @Override public String getPathForLocalMetadata(Metadata metadata) { - return head.getPathForLocalMetadata(metadata); + return getInstallTarget().getPathForLocalMetadata(metadata); } @Override public String getPathForRemoteMetadata(Metadata metadata, RemoteRepository repository, String context) { - return head.getPathForRemoteMetadata(metadata, repository, context); + return getCacheTarget().getPathForRemoteMetadata(metadata, repository, context); } @Override @@ -134,15 +142,17 @@ public LocalArtifactResult find(RepositorySystemSession session, LocalArtifactRe @Override public void add(RepositorySystemSession session, LocalArtifactRegistration request) { String artifactPath; + LocalRepositoryManager target; if (request.getRepository() != null) { artifactPath = getPathForRemoteArtifact(request.getArtifact(), request.getRepository(), "check"); + target = getCacheTarget(); } else { artifactPath = getPathForLocalArtifact(request.getArtifact()); + target = getInstallTarget(); } - - Path file = head.getRepository().getBasePath().resolve(artifactPath); + Path file = target.getRepository().getBasePath().resolve(artifactPath); if (Files.isRegularFile(file)) { - head.add(session, request); + target.add(session, request); } } @@ -165,15 +175,18 @@ public LocalMetadataResult find(RepositorySystemSession session, LocalMetadataRe @Override public void add(RepositorySystemSession session, LocalMetadataRegistration request) { String metadataPath; + LocalRepositoryManager target; if (request.getRepository() != null) { metadataPath = getPathForRemoteMetadata(request.getMetadata(), request.getRepository(), "check"); + target = getCacheTarget(); } else { metadataPath = getPathForLocalMetadata(request.getMetadata()); + target = getInstallTarget(); } - Path file = head.getRepository().getBasePath().resolve(metadataPath); + Path file = target.getRepository().getBasePath().resolve(metadataPath); if (Files.isRegularFile(file)) { - head.add(session, request); + target.add(session, request); } } From e224b8e73853f12b63160ece29c385b36a05bdef Mon Sep 17 00:00:00 2001 From: Tamas Cservenak Date: Wed, 4 Dec 2024 12:38:25 +0100 Subject: [PATCH 2/8] Add more to it --- .../repository/LocalRepositoryManager.java | 62 +++++++++++++++++++ .../impl/DefaultArtifactResolver.java | 5 +- .../aether/internal/impl/DefaultDeployer.java | 4 +- .../internal/impl/DefaultInstaller.java | 4 +- .../impl/DefaultMetadataResolver.java | 14 ++--- .../impl/EnhancedLocalRepositoryManager.java | 14 ++--- .../impl/SimpleLocalRepositoryManager.java | 7 +-- 7 files changed, 79 insertions(+), 31 deletions(-) diff --git a/maven-resolver-api/src/main/java/org/eclipse/aether/repository/LocalRepositoryManager.java b/maven-resolver-api/src/main/java/org/eclipse/aether/repository/LocalRepositoryManager.java index 14651cb0d..dabdd3ad2 100644 --- a/maven-resolver-api/src/main/java/org/eclipse/aether/repository/LocalRepositoryManager.java +++ b/maven-resolver-api/src/main/java/org/eclipse/aether/repository/LocalRepositoryManager.java @@ -18,6 +18,8 @@ */ package org.eclipse.aether.repository; +import java.nio.file.Path; + import org.eclipse.aether.RepositorySystemSession; import org.eclipse.aether.artifact.Artifact; import org.eclipse.aether.metadata.Metadata; @@ -37,6 +39,18 @@ public interface LocalRepositoryManager { */ LocalRepository getRepository(); + /** + * Gets the absolute path for a locally installed artifact. Note that the artifact need not actually exist yet at + * the returned location, the path merely indicates where the artifact would eventually be stored. + * + * @param artifact The artifact for which to determine the path, must not be {@code null}. + * @return The path, relative to the local repository's base directory. + * @since TBD + */ + default Path getAbsolutePathForLocalArtifact(Artifact artifact) { + return getRepository().getBasePath().resolve(artifact.getArtifactId()); + } + /** * Gets the relative path for a locally installed artifact. Note that the artifact need not actually exist yet at * the returned location, the path merely indicates where the artifact would eventually be stored. The path uses the @@ -44,9 +58,25 @@ public interface LocalRepositoryManager { * * @param artifact The artifact for which to determine the path, must not be {@code null}. * @return The path, relative to the local repository's base directory. + * @deprecated See {@link #getAbsolutePathForLocalArtifact(Artifact)} */ + @Deprecated String getPathForLocalArtifact(Artifact artifact); + /** + * Gets the absolute path for an artifact cached from a remote repository. Note that the artifact need not actually + * exist yet at the returned location, the path merely indicates where the artifact would eventually be stored. + * + * @param artifact The artifact for which to determine the path, must not be {@code null}. + * @param repository The source repository of the artifact, must not be {@code null}. + * @param context The resolution context in which the artifact is being requested, may be {@code null}. + * @return The path, relative to the local repository's base directory. + * @since TBD + */ + default Path getAbsolutePathForRemoteArtifact(Artifact artifact, RemoteRepository repository, String context) { + return getRepository().getBasePath().resolve(getPathForRemoteArtifact(artifact, repository, context)); + } + /** * Gets the relative path for an artifact cached from a remote repository. Note that the artifact need not actually * exist yet at the returned location, the path merely indicates where the artifact would eventually be stored. The @@ -56,9 +86,23 @@ public interface LocalRepositoryManager { * @param repository The source repository of the artifact, must not be {@code null}. * @param context The resolution context in which the artifact is being requested, may be {@code null}. * @return The path, relative to the local repository's base directory. + * @deprecated See {@link #getAbsolutePathForRemoteArtifact(Artifact, RemoteRepository, String)} */ + @Deprecated String getPathForRemoteArtifact(Artifact artifact, RemoteRepository repository, String context); + /** + * Gets the absolute path for locally installed metadata. Note that the metadata need not actually exist yet at the + * returned location, the path merely indicates where the metadata would eventually be stored. + * + * @param metadata The metadata for which to determine the path, must not be {@code null}. + * @return The path, relative to the local repository's base directory. + * @since TBD + */ + default Path getAbsolutePathForLocalMetadata(Metadata metadata) { + return getRepository().getBasePath().resolve(getPathForLocalMetadata(metadata)); + } + /** * Gets the relative path for locally installed metadata. Note that the metadata need not actually exist yet at the * returned location, the path merely indicates where the metadata would eventually be stored. The path uses the @@ -66,9 +110,25 @@ public interface LocalRepositoryManager { * * @param metadata The metadata for which to determine the path, must not be {@code null}. * @return The path, relative to the local repository's base directory. + * @deprecated See {@link #getAbsolutePathForLocalMetadata(Metadata)} */ + @Deprecated String getPathForLocalMetadata(Metadata metadata); + /** + * Gets the absolute path for metadata cached from a remote repository. Note that the metadata need not actually + * exist yet at the returned location, the path merely indicates where the metadata would eventually be stored. + * + * @param metadata The metadata for which to determine the path, must not be {@code null}. + * @param repository The source repository of the metadata, must not be {@code null}. + * @param context The resolution context in which the metadata is being requested, may be {@code null}. + * @return The path, relative to the local repository's base directory. + * @since TBD + */ + default Path getAbsolutePathForRemoteMetadata(Metadata metadata, RemoteRepository repository, String context) { + return getRepository().getBasePath().resolve(getPathForRemoteMetadata(metadata, repository, context)); + } + /** * Gets the relative path for metadata cached from a remote repository. Note that the metadata need not actually * exist yet at the returned location, the path merely indicates where the metadata would eventually be stored. The @@ -78,7 +138,9 @@ public interface LocalRepositoryManager { * @param repository The source repository of the metadata, must not be {@code null}. * @param context The resolution context in which the metadata is being requested, may be {@code null}. * @return The path, relative to the local repository's base directory. + * @deprecated See {@link #getAbsolutePathForRemoteMetadata(Metadata, RemoteRepository, String)} */ + @Deprecated String getPathForRemoteMetadata(Metadata metadata, RemoteRepository repository, String context); /** diff --git a/maven-resolver-impl/src/main/java/org/eclipse/aether/internal/impl/DefaultArtifactResolver.java b/maven-resolver-impl/src/main/java/org/eclipse/aether/internal/impl/DefaultArtifactResolver.java index f4312691b..6c614d923 100644 --- a/maven-resolver-impl/src/main/java/org/eclipse/aether/internal/impl/DefaultArtifactResolver.java +++ b/maven-resolver-impl/src/main/java/org/eclipse/aether/internal/impl/DefaultArtifactResolver.java @@ -519,9 +519,8 @@ private List gatherDownloads(RepositorySystemSession session, download.setPath(item.local.getPath()); download.setExistenceCheck(true); } else { - String path = - lrm.getPathForRemoteArtifact(artifact, group.repository, item.request.getRequestContext()); - download.setPath(lrm.getRepository().getBasePath().resolve(path)); + download.setPath(lrm.getAbsolutePathForRemoteArtifact( + artifact, group.repository, item.request.getRequestContext())); } boolean snapshot = artifact.isSnapshot(); diff --git a/maven-resolver-impl/src/main/java/org/eclipse/aether/internal/impl/DefaultDeployer.java b/maven-resolver-impl/src/main/java/org/eclipse/aether/internal/impl/DefaultDeployer.java index c98cb5567..932b9065e 100644 --- a/maven-resolver-impl/src/main/java/org/eclipse/aether/internal/impl/DefaultDeployer.java +++ b/maven-resolver-impl/src/main/java/org/eclipse/aether/internal/impl/DefaultDeployer.java @@ -277,9 +277,7 @@ private void upload( EventCatapult catapult) throws DeploymentException { LocalRepositoryManager lrm = session.getLocalRepositoryManager(); - Path basePath = lrm.getRepository().getBasePath(); - - Path dstPath = basePath.resolve(lrm.getPathForRemoteMetadata(metadata, repository, "")); + Path dstPath = lrm.getAbsolutePathForRemoteMetadata(metadata, repository, ""); if (metadata instanceof MergeableMetadata) { if (!((MergeableMetadata) metadata).isMerged()) { diff --git a/maven-resolver-impl/src/main/java/org/eclipse/aether/internal/impl/DefaultInstaller.java b/maven-resolver-impl/src/main/java/org/eclipse/aether/internal/impl/DefaultInstaller.java index 06b7a18d9..c42d7f5e5 100644 --- a/maven-resolver-impl/src/main/java/org/eclipse/aether/internal/impl/DefaultInstaller.java +++ b/maven-resolver-impl/src/main/java/org/eclipse/aether/internal/impl/DefaultInstaller.java @@ -187,7 +187,7 @@ private void install(RepositorySystemSession session, RequestTrace trace, Artifa throws InstallationException { final LocalRepositoryManager lrm = session.getLocalRepositoryManager(); final Path srcPath = artifact.getPath(); - final Path dstPath = lrm.getRepository().getBasePath().resolve(lrm.getPathForLocalArtifact(artifact)); + final Path dstPath = lrm.getAbsolutePathForLocalArtifact(artifact); artifactInstalling(session, trace, artifact, dstPath); @@ -211,7 +211,7 @@ private void install(RepositorySystemSession session, RequestTrace trace, Metada throws InstallationException { LocalRepositoryManager lrm = session.getLocalRepositoryManager(); - Path dstPath = lrm.getRepository().getBasePath().resolve(lrm.getPathForLocalMetadata(metadata)); + Path dstPath = lrm.getAbsolutePathForLocalMetadata(metadata); metadataInstalling(session, trace, metadata, dstPath); diff --git a/maven-resolver-impl/src/main/java/org/eclipse/aether/internal/impl/DefaultMetadataResolver.java b/maven-resolver-impl/src/main/java/org/eclipse/aether/internal/impl/DefaultMetadataResolver.java index 28a43ae17..305655b21 100644 --- a/maven-resolver-impl/src/main/java/org/eclipse/aether/internal/impl/DefaultMetadataResolver.java +++ b/maven-resolver-impl/src/main/java/org/eclipse/aether/internal/impl/DefaultMetadataResolver.java @@ -257,10 +257,8 @@ private List resolve( check.setItem(metadata); // use 'main' installation file for the check (-> use requested repository) - Path checkPath = session.getLocalRepository() - .getBasePath() - .resolve(session.getLocalRepositoryManager() - .getPathForRemoteMetadata(metadata, repository, request.getRequestContext())); + Path checkPath = session.getLocalRepositoryManager() + .getAbsolutePathForRemoteMetadata(metadata, repository, request.getRequestContext()); check.setPath(checkPath); check.setRepository(repository); check.setAuthoritativeRepository(repo); @@ -283,11 +281,9 @@ private List resolve( RepositoryPolicy policy = getPolicy(session, repository, metadata.getNature()); // install path may be different from lookup path - Path installPath = session.getLocalRepository() - .getBasePath() - .resolve(session.getLocalRepositoryManager() - .getPathForRemoteMetadata( - metadata, request.getRepository(), request.getRequestContext())); + Path installPath = session.getLocalRepositoryManager() + .getAbsolutePathForRemoteMetadata( + metadata, request.getRepository(), request.getRequestContext()); ResolveTask task = new ResolveTask( session, trace, result, installPath, checks, policy.getChecksumPolicy()); diff --git a/maven-resolver-impl/src/main/java/org/eclipse/aether/internal/impl/EnhancedLocalRepositoryManager.java b/maven-resolver-impl/src/main/java/org/eclipse/aether/internal/impl/EnhancedLocalRepositoryManager.java index a414c8588..4fd5ec29c 100644 --- a/maven-resolver-impl/src/main/java/org/eclipse/aether/internal/impl/EnhancedLocalRepositoryManager.java +++ b/maven-resolver-impl/src/main/java/org/eclipse/aether/internal/impl/EnhancedLocalRepositoryManager.java @@ -119,20 +119,17 @@ public LocalArtifactResult find(RepositorySystemSession session, LocalArtifactRe Artifact artifact = request.getArtifact(); LocalArtifactResult result = new LocalArtifactResult(request); - String path; Path filePath; // Local repository CANNOT have timestamped installed, they are created only during deploy if (Objects.equals(artifact.getVersion(), artifact.getBaseVersion())) { - path = getPathForLocalArtifact(artifact); - filePath = getRepository().getBasePath().resolve(path); + filePath = getAbsolutePathForLocalArtifact(artifact); checkFind(filePath, result); } if (!result.isAvailable()) { for (RemoteRepository repository : request.getRepositories()) { - path = getPathForRemoteArtifact(artifact, repository, request.getContext()); - filePath = getRepository().getBasePath().resolve(path); + filePath = getAbsolutePathForRemoteArtifact(artifact, repository, request.getContext()); checkFind(filePath, result); @@ -208,10 +205,9 @@ private Collection getRepositoryKeys(RemoteRepository repository, Collec private void addArtifact( Artifact artifact, Collection repositories, RemoteRepository repository, String context) { requireNonNull(artifact, "artifact cannot be null"); - String path = repository == null - ? getPathForLocalArtifact(artifact) - : getPathForRemoteArtifact(artifact, repository, context); - Path file = getRepository().getBasePath().resolve(path); + Path file = repository == null + ? getAbsolutePathForLocalArtifact(artifact) + : getAbsolutePathForRemoteArtifact(artifact, repository, context); addRepo(file, repositories); } diff --git a/maven-resolver-impl/src/main/java/org/eclipse/aether/internal/impl/SimpleLocalRepositoryManager.java b/maven-resolver-impl/src/main/java/org/eclipse/aether/internal/impl/SimpleLocalRepositoryManager.java index ee393140d..6c5e2a884 100644 --- a/maven-resolver-impl/src/main/java/org/eclipse/aether/internal/impl/SimpleLocalRepositoryManager.java +++ b/maven-resolver-impl/src/main/java/org/eclipse/aether/internal/impl/SimpleLocalRepositoryManager.java @@ -132,13 +132,11 @@ public LocalArtifactResult find(RepositorySystemSession session, LocalArtifactRe Artifact artifact = request.getArtifact(); LocalArtifactResult result = new LocalArtifactResult(request); - String path; Path filePath; // Local repository CANNOT have timestamped installed, they are created only during deploy if (Objects.equals(artifact.getVersion(), artifact.getBaseVersion())) { - path = getPathForLocalArtifact(artifact); - filePath = getRepository().getBasePath().resolve(path); + filePath = getAbsolutePathForLocalArtifact(artifact); if (Files.isRegularFile(filePath)) { result.setPath(filePath); result.setAvailable(true); @@ -147,8 +145,7 @@ public LocalArtifactResult find(RepositorySystemSession session, LocalArtifactRe if (!result.isAvailable()) { for (RemoteRepository repository : request.getRepositories()) { - path = getPathForRemoteArtifact(artifact, repository, request.getContext()); - filePath = getRepository().getBasePath().resolve(path); + filePath = getAbsolutePathForRemoteArtifact(artifact, repository, request.getContext()); if (Files.isRegularFile(filePath)) { result.setPath(filePath); result.setAvailable(true); From 7a4e8c59da5540f7fdb1568e51239557aec7ab73 Mon Sep 17 00:00:00 2001 From: Tamas Cservenak Date: Wed, 4 Dec 2024 12:40:53 +0100 Subject: [PATCH 3/8] Fix wrong method --- .../org/eclipse/aether/repository/LocalRepositoryManager.java | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/maven-resolver-api/src/main/java/org/eclipse/aether/repository/LocalRepositoryManager.java b/maven-resolver-api/src/main/java/org/eclipse/aether/repository/LocalRepositoryManager.java index dabdd3ad2..653f5a2fa 100644 --- a/maven-resolver-api/src/main/java/org/eclipse/aether/repository/LocalRepositoryManager.java +++ b/maven-resolver-api/src/main/java/org/eclipse/aether/repository/LocalRepositoryManager.java @@ -48,7 +48,7 @@ public interface LocalRepositoryManager { * @since TBD */ default Path getAbsolutePathForLocalArtifact(Artifact artifact) { - return getRepository().getBasePath().resolve(artifact.getArtifactId()); + return getRepository().getBasePath().resolve(getPathForLocalArtifact(artifact)); } /** From afbd63a302cbdf9afa0d0545184f631a00fa343c Mon Sep 17 00:00:00 2001 From: Tamas Cservenak Date: Thu, 12 Dec 2024 17:46:55 +0100 Subject: [PATCH 4/8] Fix since --- .../eclipse/aether/repository/LocalRepositoryManager.java | 8 ++++---- 1 file changed, 4 insertions(+), 4 deletions(-) diff --git a/maven-resolver-api/src/main/java/org/eclipse/aether/repository/LocalRepositoryManager.java b/maven-resolver-api/src/main/java/org/eclipse/aether/repository/LocalRepositoryManager.java index 653f5a2fa..6d23deb7a 100644 --- a/maven-resolver-api/src/main/java/org/eclipse/aether/repository/LocalRepositoryManager.java +++ b/maven-resolver-api/src/main/java/org/eclipse/aether/repository/LocalRepositoryManager.java @@ -45,7 +45,7 @@ public interface LocalRepositoryManager { * * @param artifact The artifact for which to determine the path, must not be {@code null}. * @return The path, relative to the local repository's base directory. - * @since TBD + * @since 2.0.5 */ default Path getAbsolutePathForLocalArtifact(Artifact artifact) { return getRepository().getBasePath().resolve(getPathForLocalArtifact(artifact)); @@ -71,7 +71,7 @@ default Path getAbsolutePathForLocalArtifact(Artifact artifact) { * @param repository The source repository of the artifact, must not be {@code null}. * @param context The resolution context in which the artifact is being requested, may be {@code null}. * @return The path, relative to the local repository's base directory. - * @since TBD + * @since 2.0.5 */ default Path getAbsolutePathForRemoteArtifact(Artifact artifact, RemoteRepository repository, String context) { return getRepository().getBasePath().resolve(getPathForRemoteArtifact(artifact, repository, context)); @@ -97,7 +97,7 @@ default Path getAbsolutePathForRemoteArtifact(Artifact artifact, RemoteRepositor * * @param metadata The metadata for which to determine the path, must not be {@code null}. * @return The path, relative to the local repository's base directory. - * @since TBD + * @since 2.0.5 */ default Path getAbsolutePathForLocalMetadata(Metadata metadata) { return getRepository().getBasePath().resolve(getPathForLocalMetadata(metadata)); @@ -123,7 +123,7 @@ default Path getAbsolutePathForLocalMetadata(Metadata metadata) { * @param repository The source repository of the metadata, must not be {@code null}. * @param context The resolution context in which the metadata is being requested, may be {@code null}. * @return The path, relative to the local repository's base directory. - * @since TBD + * @since 2.0.5 */ default Path getAbsolutePathForRemoteMetadata(Metadata metadata, RemoteRepository repository, String context) { return getRepository().getBasePath().resolve(getPathForRemoteMetadata(metadata, repository, context)); From 84c45577932277a91b48e1c471f91d71d5702668 Mon Sep 17 00:00:00 2001 From: Tamas Cservenak Date: Thu, 12 Dec 2024 18:02:20 +0100 Subject: [PATCH 5/8] Finish the idea --- .../ChainedLocalRepositoryManager.java | 45 ++++++++++++++++--- 1 file changed, 38 insertions(+), 7 deletions(-) diff --git a/maven-resolver-util/src/main/java/org/eclipse/aether/util/repository/ChainedLocalRepositoryManager.java b/maven-resolver-util/src/main/java/org/eclipse/aether/util/repository/ChainedLocalRepositoryManager.java index 100496d52..d387a8f27 100644 --- a/maven-resolver-util/src/main/java/org/eclipse/aether/util/repository/ChainedLocalRepositoryManager.java +++ b/maven-resolver-util/src/main/java/org/eclipse/aether/util/repository/ChainedLocalRepositoryManager.java @@ -70,19 +70,42 @@ public final class ChainedLocalRepositoryManager implements LocalRepositoryManag private final boolean ignoreTailAvailability; + private final int installTarget; + + private final int cacheTarget; + public ChainedLocalRepositoryManager( LocalRepositoryManager head, List tail, boolean ignoreTailAvailability) { - this.head = requireNonNull(head, "head cannot be null"); - this.tail = requireNonNull(tail, "tail cannot be null"); - this.ignoreTailAvailability = ignoreTailAvailability; + this(head, tail, ignoreTailAvailability, 0, 0); } public ChainedLocalRepositoryManager( LocalRepositoryManager head, List tail, RepositorySystemSession session) { + this( + head, + tail, + ConfigUtils.getBoolean(session, DEFAULT_IGNORE_TAIL_AVAILABILITY, CONFIG_PROP_IGNORE_TAIL_AVAILABILITY), + 0, + 0); + } + + public ChainedLocalRepositoryManager( + LocalRepositoryManager head, + List tail, + boolean ignoreTailAvailability, + int installTarget, + int cacheTarget) { this.head = requireNonNull(head, "head cannot be null"); this.tail = requireNonNull(tail, "tail cannot be null"); - this.ignoreTailAvailability = - ConfigUtils.getBoolean(session, DEFAULT_IGNORE_TAIL_AVAILABILITY, CONFIG_PROP_IGNORE_TAIL_AVAILABILITY); + this.ignoreTailAvailability = ignoreTailAvailability; + if (installTarget < 0 || installTarget > tail.size()) { + throw new IllegalArgumentException("Illegal installTarget value"); + } + this.installTarget = installTarget; + if (cacheTarget < 0 || cacheTarget > tail.size()) { + throw new IllegalArgumentException("Illegal cacheTarget value"); + } + this.cacheTarget = cacheTarget; } @Override @@ -91,11 +114,19 @@ public LocalRepository getRepository() { } private LocalRepositoryManager getInstallTarget() { - return head; + if (installTarget == 0) { + return head; + } else { + return tail.get(installTarget - 1); + } } private LocalRepositoryManager getCacheTarget() { - return head; + if (cacheTarget == 0) { + return head; + } else { + return tail.get(cacheTarget - 1); + } } @Override From 08b7a50efb75d96a5008cc3d9e8725615e6a4018 Mon Sep 17 00:00:00 2001 From: Tamas Cservenak Date: Thu, 12 Dec 2024 18:04:34 +0100 Subject: [PATCH 6/8] Add javadoc. --- .../util/repository/ChainedLocalRepositoryManager.java | 10 ++++++++++ 1 file changed, 10 insertions(+) diff --git a/maven-resolver-util/src/main/java/org/eclipse/aether/util/repository/ChainedLocalRepositoryManager.java b/maven-resolver-util/src/main/java/org/eclipse/aether/util/repository/ChainedLocalRepositoryManager.java index d387a8f27..c1396e88d 100644 --- a/maven-resolver-util/src/main/java/org/eclipse/aether/util/repository/ChainedLocalRepositoryManager.java +++ b/maven-resolver-util/src/main/java/org/eclipse/aether/util/repository/ChainedLocalRepositoryManager.java @@ -89,6 +89,16 @@ public ChainedLocalRepositoryManager( 0); } + /** + * Warning: this is experimental feature of chained, is not recommended to be used/integrated into plain Maven. + * + * @param head The head LRM + * @param tail The tail LRMs + * @param ignoreTailAvailability Whether tail availability should be ignored (usually you do want this) + * @param installTarget The installation LRM index, integer from 0 to size of tail. + * @param cacheTarget The cache LRM index, integer from 0 to size of tail. + * @since 2.0.5 + */ public ChainedLocalRepositoryManager( LocalRepositoryManager head, List tail, From 06d1ba069aa2922e1c13000fa1b16c35399b187a Mon Sep 17 00:00:00 2001 From: Tamas Cservenak Date: Thu, 12 Dec 2024 18:08:19 +0100 Subject: [PATCH 7/8] Reformat --- .../aether/util/repository/ChainedLocalRepositoryManager.java | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/maven-resolver-util/src/main/java/org/eclipse/aether/util/repository/ChainedLocalRepositoryManager.java b/maven-resolver-util/src/main/java/org/eclipse/aether/util/repository/ChainedLocalRepositoryManager.java index c1396e88d..35dad1e0d 100644 --- a/maven-resolver-util/src/main/java/org/eclipse/aether/util/repository/ChainedLocalRepositoryManager.java +++ b/maven-resolver-util/src/main/java/org/eclipse/aether/util/repository/ChainedLocalRepositoryManager.java @@ -91,7 +91,7 @@ public ChainedLocalRepositoryManager( /** * Warning: this is experimental feature of chained, is not recommended to be used/integrated into plain Maven. - * + * * @param head The head LRM * @param tail The tail LRMs * @param ignoreTailAvailability Whether tail availability should be ignored (usually you do want this) From fe322a96f796e20d35571989b1c5838f27e6ee40 Mon Sep 17 00:00:00 2001 From: Tamas Cservenak Date: Thu, 12 Dec 2024 18:24:53 +0100 Subject: [PATCH 8/8] Add all method to chained --- .../ChainedLocalRepositoryManager.java | 20 +++++++++++++++++++ 1 file changed, 20 insertions(+) diff --git a/maven-resolver-util/src/main/java/org/eclipse/aether/util/repository/ChainedLocalRepositoryManager.java b/maven-resolver-util/src/main/java/org/eclipse/aether/util/repository/ChainedLocalRepositoryManager.java index 35dad1e0d..1223c4571 100644 --- a/maven-resolver-util/src/main/java/org/eclipse/aether/util/repository/ChainedLocalRepositoryManager.java +++ b/maven-resolver-util/src/main/java/org/eclipse/aether/util/repository/ChainedLocalRepositoryManager.java @@ -139,6 +139,26 @@ private LocalRepositoryManager getCacheTarget() { } } + @Override + public Path getAbsolutePathForLocalArtifact(Artifact artifact) { + return getInstallTarget().getAbsolutePathForLocalArtifact(artifact); + } + + @Override + public Path getAbsolutePathForRemoteArtifact(Artifact artifact, RemoteRepository repository, String context) { + return getCacheTarget().getAbsolutePathForRemoteArtifact(artifact, repository, context); + } + + @Override + public Path getAbsolutePathForLocalMetadata(Metadata metadata) { + return getInstallTarget().getAbsolutePathForLocalMetadata(metadata); + } + + @Override + public Path getAbsolutePathForRemoteMetadata(Metadata metadata, RemoteRepository repository, String context) { + return getCacheTarget().getAbsolutePathForRemoteMetadata(metadata, repository, context); + } + @Override public String getPathForLocalArtifact(Artifact artifact) { return getInstallTarget().getPathForLocalArtifact(artifact);