JDK-8321274 : Rename ZipEntry.extraAttributes to ZipEntry.externalFileAttributes
  • Type: Enhancement
  • Component: core-libs
  • Sub-Component: java.util.jar
  • Priority: P4
  • Status: Resolved
  • Resolution: Fixed
  • Submitted: 2023-12-04
  • Updated: 2024-07-05
  • Resolved: 2024-07-03
The Version table provides details related to the release that this issue/RFE will be addressed.

Unresolved : Release in which this issue/RFE will be addressed.
Resolved: Release in which this issue/RFE has been resolved.
Fixed : Release in which this issue/RFE has been fixed. The release containing this fix may be available for download as an Early Access Release or a General Availability Release.

To download the current JDK release, click here.
JDK 24
24 b05Fixed
Related Reports
Relates :  
Relates :  
Relates :  
Description
The internal field 'ZipEntry.extraAttributes' was introduced in JDK-8218021, then under the name 'ZipEntry.posixPerms'. JDK-8250968 later renamed the field to 'ZipEntry.extraAttributes' and extended its semantics to hold the full value of the "external file attributes" field, as defined by APPNOTE.TXT.

The name 'extraAttributes' is misleading. The two-byte field it holds refers to the 'external file attributes' field of the CEN header. It has nothing to do with the 'extra field', an unrelated structure defined in APPNOTE.TXT.

To prevent confusion and make life easier for future maintainers, the field  should be renamed to 'ZipEntry.externalFileAttributes'. Any derived local variable or method should be renamed accordingly.

The field is not public, so renaming it does not change the API and should have no compatibility impact.

A similar rename should also be done in zipfs
Comments
Changeset: d51141e5 Author: Eirik Bjørsnøs <eirbjo@openjdk.org> Committer: Jaikiran Pai <jpai@openjdk.org> Date: 2024-07-03 04:36:32 +0000 URL: https://git.openjdk.org/jdk/commit/d51141e5fc84f9f933e78d0eb25af86e41798ad5
03-07-2024

Yes, that's my understanding from reviewing the code changes and releated issues. The field was added for the specific purpose of enabling preservation of posix attribuites for signed jars. It was not exposed for public use, this was probably intentional, or at least the simplest choice given that exposing it would be an API change, require a CSR and a discussion.
12-12-2023

Are you implying that the public class ZipEntry is not intended to be used except by JarSigner?
12-12-2023

My understanding is that this field was added to preserve this field in the jar signing process. JarSigner "copies" ZipEntry instances from ZipFile to ZipOutputStream.
12-12-2023

Is there some reason why there are no public accessors for this field? I understand that the interpretation of the field is not standardized, but the field itself is defined in the standard.
12-12-2023

A pull request was submitted for review. URL: https://git.openjdk.org/jdk/pull/16952 Date: 2023-12-04 15:34:34 +0000
04-12-2023