Package org.apache.ivy.plugins.resolver
Class DualResolver
- java.lang.Object
-
- org.apache.ivy.plugins.resolver.AbstractResolver
-
- org.apache.ivy.plugins.resolver.DualResolver
-
- All Implemented Interfaces:
Validatable,DependencyResolver,HasLatestStrategy
public class DualResolver extends AbstractResolver
DualResolver is used to resolve dependencies with one dependency revolver, called ivy resolver, and then download artifacts found in the resolved dependencies from a second dependency resolver, called artifact resolver. It is especially useful with resolvers using repository where there is a lot of artifact, but no ivy file, like the maven ibiblio repository. If no ivy file is found by the ivy resolver, the artifact resolver is used to check if there is artifact corresponding to the request (with default ivy file). For artifact download, however, only the artifact resolver is used. Exactly two resolvers should be added to this resolver for it to work properly. The first resolver added if the ivy resolver, the second is the artifact one.
-
-
Field Summary
Fields Modifier and Type Field Description static java.lang.StringDESCRIPTOR_OPTIONALstatic java.lang.StringDESCRIPTOR_REQUIRED
-
Constructor Summary
Constructors Constructor Description DualResolver()
-
Method Summary
All Methods Instance Methods Concrete Methods Modifier and Type Method Description voidabortPublishTransaction()voidadd(DependencyResolver resolver)voidbeginPublishTransaction(ModuleRevisionId module, boolean overwrite)voidcommitPublishTransaction()ArtifactDownloadReportdownload(ArtifactOrigin artifact, DownloadOptions options)Default implementation downloads the artifact without taking advantage of its locationDownloadReportdownload(Artifact[] artifacts, DownloadOptions options)Download artifacts with specified DownloadOptions.voiddumpSettings()booleanexists(Artifact artifact)Returnstrueif the given artifact can be located by this resolver and actually exist.ResolvedResourcefindIvyFileRef(DependencyDescriptor dd, ResolveData data)Finds the module descriptor for the specified DependencyDescriptor.DependencyResolvergetArtifactResolver()ResolvedModuleRevisiongetDependency(DependencyDescriptor dd, ResolveData data)Resolve a module by id, getting its module descriptor and resolving the revision if it's a latest one (i.e. a revision uniquely identifying the revision of a module in the current environment - If this revision is not able to identify uniquely the revision of the module outside of the current environment, then the resolved revision must begin by ##)DependencyResolvergetIvyResolver()booleanisAllownomd()ArtifactOriginlocate(Artifact artifact)Default implementation actually download the artifact Subclasses should overwrite this to avoid the downloadvoidpublish(Artifact artifact, java.io.File src, boolean overwrite)voidreportFailure()Reports last resolve failure as MessagesvoidreportFailure(Artifact art)Reports last artifact download failure as MessagesvoidsetAllownomd(boolean allownomd)voidsetArtifactResolver(DependencyResolver artifactResolver)voidsetDescriptor(java.lang.String descriptorRule)Sets the module descriptor presence rule.voidsetIvyResolver(DependencyResolver ivyResolver)-
Methods inherited from class org.apache.ivy.plugins.resolver.AbstractResolver
checkInterrupted, checkLatest, doValidate, findModuleInCache, findModuleInCache, fromSystem, fromSystem, getCacheDownloadOptions, getCacheOptions, getChangingMatcherName, getChangingPattern, getDownloadOptions, getEventManager, getLatest, getLatestStrategy, getName, getNamespace, getParserSettings, getRepositoryCacheManager, getSettings, getSystemNode, getTimeoutConstraint, getTypeName, hidePassword, isAfter, isValidate, listModules, listOrganisations, listRevisions, listTokenValues, listTokenValues, saveModuleRevisionIfNeeded, setCache, setChangingMatcher, setChangingPattern, setCheckmodified, setEventManager, setLatest, setLatestStrategy, setName, setNamespace, setRepositoryCacheManager, setSettings, setTimeoutConstraint, setValidate, toString, toSystem, toSystem, toSystem, toSystem, toSystem, toSystem, validate
-
-
-
-
Field Detail
-
DESCRIPTOR_OPTIONAL
public static final java.lang.String DESCRIPTOR_OPTIONAL
- See Also:
- Constant Field Values
-
DESCRIPTOR_REQUIRED
public static final java.lang.String DESCRIPTOR_REQUIRED
- See Also:
- Constant Field Values
-
-
Method Detail
-
add
public void add(DependencyResolver resolver)
-
getDependency
public ResolvedModuleRevision getDependency(DependencyDescriptor dd, ResolveData data) throws java.text.ParseException
Description copied from interface:DependencyResolverResolve a module by id, getting its module descriptor and resolving the revision if it's a latest one (i.e. a revision uniquely identifying the revision of a module in the current environment - If this revision is not able to identify uniquely the revision of the module outside of the current environment, then the resolved revision must begin by ##)- Parameters:
dd- DependencyDescriptordata- ResolveData- Returns:
- ResolvedModuleRevision
- Throws:
java.text.ParseException- if something goes wrong
-
findIvyFileRef
public ResolvedResource findIvyFileRef(DependencyDescriptor dd, ResolveData data)
Description copied from interface:DependencyResolverFinds the module descriptor for the specified DependencyDescriptor. If this resolver can't find the module descriptor, null is returned.- Parameters:
dd- the dependency descriptordata- the resolve data- Returns:
- the module descriptor, or null
-
reportFailure
public void reportFailure()
Description copied from interface:DependencyResolverReports last resolve failure as Messages- Specified by:
reportFailurein interfaceDependencyResolver- Overrides:
reportFailurein classAbstractResolver
-
reportFailure
public void reportFailure(Artifact art)
Description copied from interface:DependencyResolverReports last artifact download failure as Messages- Specified by:
reportFailurein interfaceDependencyResolver- Overrides:
reportFailurein classAbstractResolver- Parameters:
art- Artifact
-
download
public DownloadReport download(Artifact[] artifacts, DownloadOptions options)
Description copied from interface:DependencyResolverDownload artifacts with specified DownloadOptions.The resolver will always make a best effort, and do not stop when an artifact is not available. It rather continue to attempt to download other requested artifacts, and report what has been done in the returned DownloadReport.
The returned DownloadReport is never
null, and always contain anArtifactDownloadReportfor each requested Artifact.- Parameters:
artifacts- an array of artifacts to download. Must not benull.options- options to apply for this download. Must not benull.- Returns:
- a DownloadReport with details about each Artifact download.
-
getArtifactResolver
public DependencyResolver getArtifactResolver()
-
setArtifactResolver
public void setArtifactResolver(DependencyResolver artifactResolver)
-
getIvyResolver
public DependencyResolver getIvyResolver()
-
setIvyResolver
public void setIvyResolver(DependencyResolver ivyResolver)
-
publish
public void publish(Artifact artifact, java.io.File src, boolean overwrite) throws java.io.IOException
- Throws:
java.io.IOException
-
abortPublishTransaction
public void abortPublishTransaction() throws java.io.IOException- Specified by:
abortPublishTransactionin interfaceDependencyResolver- Overrides:
abortPublishTransactionin classAbstractResolver- Throws:
java.io.IOException
-
beginPublishTransaction
public void beginPublishTransaction(ModuleRevisionId module, boolean overwrite) throws java.io.IOException
- Specified by:
beginPublishTransactionin interfaceDependencyResolver- Overrides:
beginPublishTransactionin classAbstractResolver- Throws:
java.io.IOException
-
commitPublishTransaction
public void commitPublishTransaction() throws java.io.IOException- Specified by:
commitPublishTransactionin interfaceDependencyResolver- Overrides:
commitPublishTransactionin classAbstractResolver- Throws:
java.io.IOException
-
dumpSettings
public void dumpSettings()
- Specified by:
dumpSettingsin interfaceDependencyResolver- Overrides:
dumpSettingsin classAbstractResolver
-
exists
public boolean exists(Artifact artifact)
Description copied from interface:DependencyResolverReturnstrueif the given artifact can be located by this resolver and actually exist.- Specified by:
existsin interfaceDependencyResolver- Overrides:
existsin classAbstractResolver- Parameters:
artifact- the artifact which should be tested.- Returns:
trueif the given artifact can be located by this resolver and actually exist.
-
locate
public ArtifactOrigin locate(Artifact artifact)
Description copied from class:AbstractResolverDefault implementation actually download the artifact Subclasses should overwrite this to avoid the download- Specified by:
locatein interfaceDependencyResolver- Overrides:
locatein classAbstractResolver- Parameters:
artifact- ArtifactOrigin- Returns:
- ArtifactOrigin
-
download
public ArtifactDownloadReport download(ArtifactOrigin artifact, DownloadOptions options)
Description copied from class:AbstractResolverDefault implementation downloads the artifact without taking advantage of its location- Specified by:
downloadin interfaceDependencyResolver- Overrides:
downloadin classAbstractResolver- Parameters:
artifact- ArtifactOriginoptions- DownloadOptions- Returns:
- ArtifactDownloadReport
-
isAllownomd
public boolean isAllownomd()
-
setAllownomd
public void setAllownomd(boolean allownomd)
-
setDescriptor
public void setDescriptor(java.lang.String descriptorRule)
Sets the module descriptor presence rule. Should be one ofDESCRIPTOR_REQUIREDorDESCRIPTOR_OPTIONAL.- Parameters:
descriptorRule- the descriptor rule to use with this resolver.
-
-