Package org.codehaus.plexus.archiver.jar
Class JarToolModularJarArchiver
- java.lang.Object
-
- org.codehaus.plexus.logging.AbstractLogEnabled
-
- org.codehaus.plexus.archiver.AbstractArchiver
-
- org.codehaus.plexus.archiver.zip.AbstractZipArchiver
-
- org.codehaus.plexus.archiver.zip.ZipArchiver
-
- org.codehaus.plexus.archiver.jar.JarArchiver
-
- org.codehaus.plexus.archiver.jar.ModularJarArchiver
-
- org.codehaus.plexus.archiver.jar.JarToolModularJarArchiver
-
- All Implemented Interfaces:
Archiver
,FinalizerEnabled
,org.codehaus.plexus.logging.LogEnabled
,org.codehaus.plexus.personality.plexus.lifecycle.phase.Contextualizable
public class JarToolModularJarArchiver extends ModularJarArchiver
AModularJarArchiver
implementation that uses thejar
tool provided byjava.util.spi.ToolProvider
to create modular JAR files.The basic JAR archive is created by
JarArchiver
and thejar
tool is used to upgrade it to modular JAR.If the JAR file does not contain module descriptor or the JDK does not provide the
jar
tool (for example JDK prior to Java 9), then the archive created byJarArchiver
is left unchanged.
-
-
Nested Class Summary
-
Nested classes/interfaces inherited from class org.codehaus.plexus.archiver.jar.JarArchiver
JarArchiver.FilesetManifestConfig
-
-
Field Summary
Fields Modifier and Type Field Description private java.lang.Object
jarTool
private static java.lang.String
MODULE_DESCRIPTOR_FILE_NAME
private boolean
moduleDescriptorFound
private static java.util.regex.Pattern
MRJAR_VERSION_AREA
-
Fields inherited from class org.codehaus.plexus.archiver.zip.AbstractZipArchiver
addedDirs, addingNewFiles, archiveType, doubleFilePass, duplicate, entries, skipWriting, zipArchiveOutputStream
-
Fields inherited from interface org.codehaus.plexus.archiver.Archiver
DEFAULT_DIR_MODE, DEFAULT_FILE_MODE, DEFAULT_SYMLILNK_MODE, DUPLICATES_ADD, DUPLICATES_FAIL, DUPLICATES_PRESERVE, DUPLICATES_SKIP, DUPLICATES_VALID_BEHAVIORS, ROLE
-
-
Constructor Summary
Constructors Constructor Description JarToolModularJarArchiver()
-
Method Summary
All Methods Instance Methods Concrete Methods Modifier and Type Method Description private java.lang.String[]
getJarToolArguments()
Prepares the arguments for the jar tool.private boolean
isModuleDescriptor(java.lang.String path)
Returnstrue
ifpath
is a module descriptor.protected void
postCreateArchive()
This method is called after the archive creation completes successfully (no exceptions are thrown).protected void
zipFile(org.apache.commons.compress.parallel.InputStreamSupplier is, ConcurrentJarCreator zOut, java.lang.String vPath, long lastModified, java.io.File fromArchive, int mode, java.lang.String symlinkDestination, boolean addInParallel)
Overridden from Zip class to deal with manifests and index lists.-
Methods inherited from class org.codehaus.plexus.archiver.jar.ModularJarArchiver
createManifest, getManifestMainClass, getModuleMainClass, getModuleVersion, reset, setModuleMainClass, setModuleVersion
-
Methods inherited from class org.codehaus.plexus.archiver.jar.JarArchiver
addConfiguredIndexJars, addConfiguredManifest, cleanUp, createEmptyZip, finalizeZipOutputStream, findJarName, grabFilesAndDirs, hasVirtualFiles, initZipOutputStream, setFilesetmanifest, setIndex, setManifest, setManifestEncoding, setMinimalDefaultManifest, writeIndexLikeList
-
Methods inherited from class org.codehaus.plexus.archiver.zip.AbstractZipArchiver
addResources, close, createInputStreamSupplier, execute, getArchiveType, getComment, getEncoding, isCompress, isFilesonly, isInUpdateMode, isRecompressAddedZips, isSupportingForced, normalizeLastModifiedDate, revert, setComment, setCompress, setEncoding, setFilesonly, setRecompressAddedZips, setUpdateMode, zipDir, zipFile
-
Methods inherited from class org.codehaus.plexus.archiver.AbstractArchiver
addArchivedFileSet, addArchivedFileSet, addArchivedFileSet, addArchivedFileSet, addArchivedFileSet, addArchivedFileSet, addArchiveFinalizer, addDirectory, addDirectory, addDirectory, addDirectory, addFile, addFile, addFileSet, addResource, addResources, addSymlink, addSymlink, asArchiveEntry, asResourceCollection, checkForced, configureReproducible, contextualize, createArchive, getDefaultDirectoryMode, getDefaultFileMode, getDestFile, getDirectoryMode, getDuplicateBehavior, getFileMode, getFilenameComparator, getFiles, getIncludeEmptyDirs, getLastModifiedDate, getLogger, getOverrideDirectoryMode, getOverrideFileMode, getOverrideGid, getOverrideGroupName, getOverrideUid, getOverrideUserName, getRawDefaultFileMode, getResources, isForced, isIgnorePermissions, isUptodate, isUseJvmChmod, runArchiveFinalizers, setArchiveFinalizers, setDefaultDirectoryMode, setDefaultFileMode, setDestFile, setDirectoryMode, setDotFileDirectory, setDuplicateBehavior, setFileMode, setFilenameComparator, setForced, setIgnorePermissions, setIncludeEmptyDirs, setLastModifiedDate, setOverrideGid, setOverrideGroupName, setOverrideUid, setOverrideUserName, setUseJvmChmod, validate
-
-
-
-
Field Detail
-
MODULE_DESCRIPTOR_FILE_NAME
private static final java.lang.String MODULE_DESCRIPTOR_FILE_NAME
- See Also:
- Constant Field Values
-
MRJAR_VERSION_AREA
private static final java.util.regex.Pattern MRJAR_VERSION_AREA
-
jarTool
private java.lang.Object jarTool
-
moduleDescriptorFound
private boolean moduleDescriptorFound
-
-
Method Detail
-
zipFile
protected void zipFile(org.apache.commons.compress.parallel.InputStreamSupplier is, ConcurrentJarCreator zOut, java.lang.String vPath, long lastModified, java.io.File fromArchive, int mode, java.lang.String symlinkDestination, boolean addInParallel) throws java.io.IOException, ArchiverException
Description copied from class:JarArchiver
Overridden from Zip class to deal with manifests and index lists.- Overrides:
zipFile
in classJarArchiver
- Parameters:
is
- the stream to read data for the entry from.zOut
- the stream to write to.vPath
- the name this entry shall have in the archive.lastModified
- last modification time for the entry.fromArchive
- the original archive we are copying thisaddInParallel
- Indicates if the entry should be add in parallel. If set tofalse
it is added synchronously. If the entry is symbolic link this parameter is ignored.- Throws:
java.io.IOException
ArchiverException
-
postCreateArchive
protected void postCreateArchive() throws ArchiverException
Description copied from class:AbstractArchiver
This method is called after the archive creation completes successfully (no exceptions are thrown). Subclasses may override this method in order to augment or validate the archive after it is created.- Overrides:
postCreateArchive
in classAbstractArchiver
- Throws:
ArchiverException
-
isModuleDescriptor
private boolean isModuleDescriptor(java.lang.String path)
Returnstrue
ifpath
is a module descriptor.
-
getJarToolArguments
private java.lang.String[] getJarToolArguments() throws java.io.IOException
Prepares the arguments for the jar tool. It takes into account the module version, main class, etc.- Throws:
java.io.IOException
-
-