public static interface Pack200.Unpacker
Pack200.newUnpacker().
 Every JAR file produced by this engine will include the string "PACK200" as a zip file comment. This allows a deployer to detect if a JAR archive was packed and unpacked.
 Note: Unless otherwise noted, passing a null argument to a
 constructor or method in this class will cause a NullPointerException
 to be thrown.
 
This version of the unpacker is compatible with all previous versions.
| Modifier and Type | Field and Description | 
|---|---|
| static String | DEFLATE_HINT | 
| static String | FALSEThe string "false", a possible value for certain properties. | 
| static String | KEEPThe string "keep", a possible value for certain properties. | 
| static String | PROGRESSThe unpacker's progress as a percentage, as periodically
 updated by the unpacker. | 
| static String | TRUEThe string "true", a possible value for certain properties. | 
| Modifier and Type | Method and Description | 
|---|---|
| default void | addPropertyChangeListener(PropertyChangeListener listener)Deprecated. 
 The dependency on  PropertyChangeListenercreates
             a significant impediment to future modularization of the
             Java platform. This method will be removed in a future
             release.
             Applications that need to monitor progress of the
             unpacker can poll the value of thePROGRESSproperty instead. | 
| SortedMap<String,String> | properties()Get the set of this engine's properties. | 
| default void | removePropertyChangeListener(PropertyChangeListener listener)Deprecated. 
 The dependency on  PropertyChangeListenercreates
             a significant impediment to future modularization of the
             Java platform. This method will be removed in a future
             release. | 
| void | unpack(File in,
      JarOutputStream out)Read a Pack200 archive, and write the encoded JAR to
 a JarOutputStream. | 
| void | unpack(InputStream in,
      JarOutputStream out)Read a Pack200 archive, and write the encoded JAR to
 a JarOutputStream. | 
static final String KEEP
DEFLATE_HINT, 
Constant Field Valuesstatic final String TRUE
DEFLATE_HINT, 
Constant Field Valuesstatic final String FALSE
DEFLATE_HINT, 
Constant Field Valuesstatic final String DEFLATE_HINT
TRUE or FALSE.
 The default value is the special string KEEP,
 which asks the unpacker to preserve all transmitted
 deflation hints.static final String PROGRESS
At a minimum, the unpacker must set progress to 0 at the beginning of a packing operation, and to 100 at the end.
SortedMap<String,String> properties()
The property map may contain pre-defined implementation specific and default properties. Users are encouraged to read the information and fully understand the implications, before modifying pre-existing properties.
Implementation specific properties are prefixed with a package name associated with the implementor, beginning with com. or a similar prefix. All property names beginning with pack. and unpack. are reserved for use by this API.
Unknown properties may be ignored or rejected with an unspecified error, and invalid entries may cause an unspecified error to be thrown.
void unpack(InputStream in, JarOutputStream out) throws IOException
Closes its input but not its output. (The output can accumulate more elements.)
in - an InputStream.out - a JarOutputStream.IOException - if an error is encountered.void unpack(File in, JarOutputStream out) throws IOException
Does not close its output. (The output can accumulate more elements.)
in - a File.out - a JarOutputStream.IOException - if an error is encountered.@Deprecated default void addPropertyChangeListener(PropertyChangeListener listener)
PropertyChangeListener creates
             a significant impediment to future modularization of the
             Java platform. This method will be removed in a future
             release.
             Applications that need to monitor progress of the
             unpacker can poll the value of the PROGRESS property instead.The default implementation of this method does nothing and has no side-effects.
WARNING: This method is omitted from the interface
 declaration in all subset Profiles of Java SE that do not include
 the java.beans package. 
listener - An object to be invoked when a property is changed.properties(), 
PROGRESS@Deprecated default void removePropertyChangeListener(PropertyChangeListener listener)
PropertyChangeListener creates
             a significant impediment to future modularization of the
             Java platform. This method will be removed in a future
             release.addPropertyChangeListener(java.beans.PropertyChangeListener).
 The default implementation of this method does nothing and has no side-effects.
WARNING: This method is omitted from the interface
 declaration in all subset Profiles of Java SE that do not include
 the java.beans package. 
listener - The PropertyChange listener to be removed.addPropertyChangeListener(java.beans.PropertyChangeListener) Submit a bug or feature 
For further API reference and developer documentation, see Java SE Documentation. That documentation contains more detailed, developer-targeted descriptions, with conceptual overviews, definitions of terms, workarounds, and working code examples.
 Copyright © 1993, 2025, Oracle and/or its affiliates.  All rights reserved. Use is subject to license terms. Also see the documentation redistribution policy.