Obfuscation map

This feature is exclusive to Java Edition.
 
This article describes content that will likely be removed in a future update of Java Edition.
 
This content has been removed in development versions for Java Edition 26.1, but the full update removing it has not been released yet.
There is a related tutorial page for this topic!
 

Obfuscation maps are ProGuard mappings from old (original) names to new (obfuscated) names for classes and class members that have been renamed.[1] They have been exported in the client.json for every snapshot and release available in the Launcher since 19w36a, and the client.json for 1.14.4 has been updated slightly after 19w36a's release to include obfuscation maps as well.[2]

Usage

The obfuscation maps can be used to remap obfuscated stack traces (as in crash reports) to readable stack traces.[3] See Tutorial:Obtaining a crash report for further reading.

Dinnerbone and Adrian Östergård have suggested that the obfuscation maps may make modding easier.[4][5] Searge has implied that the obfuscation maps can replace certain third-party programs such as the Mod Coder Pack.[6]

On August 12th, 2020, Dinnerbone announced that the license for the obfuscation maps would be revised to encourage modding projects to adopt them.[7]

Third-party usages

The contents of this section are not supported by Mojang Studios or the Minecraft Wiki.

The obfuscation maps include enough information to deobfuscate Minecraft for decompilation, making it possible to reconstruct human-readable Java code. See Tutorial:See Minecraft's code for further reading.

According to the License, such decompiled source code can only be distributed in a modified version or part of a larger project. This was changed from being available only for internal purposes before August 14th, 2020.

Unobfuscated versions

Unobfuscated versions were created in preparation for the removal of obfuscation in Java Edition. They are no longer be released separately starting with 26.1 Snapshot 1, as the standard versions are no longer obfuscated. They are variants of versions from 25w45a through 1.21.11.

Format

Unobfuscated versions are formatted as "<version name> Unobfuscated". The shortened name used in the launcher is "<version ID>_unobfuscated"

License

Every obfuscation map file starts with a line indicating the license of the maps.

The current license has been in use since the release of 21w03a.

# (c) 2020 Microsoft Corporation. These mappings are provided "as-is" and you bear the risk of using them. You may copy and use the mappings for development purposes, but you may not redistribute the mappings complete and unmodified. Microsoft makes no warranties, express or implied, with respect to the mappings provided here.  Use and modification of this document or the source code (in any form) of Minecraft: Java Edition is governed by the Minecraft End User License Agreement available at https://account.mojang.com/documents/minecraft_eula.

According to Dinnerbone, any obfuscation mapping released before the license update on August 14, 2020 would be still available under this older license in addition to being available under the new license.[8]

History

Java Edition
September 3, 2019Dinnerbone mentions "a small surprise for modders!" for 19w36a.
1.1519w36aDownloads to client and server obfuscation maps are now included in client.json.
1.14.4September 4, 2019Dinnerbone releases obfuscation mappings for 1.14.4 as well.
August 12, 2020Dinnerbone indicates the license of the obfuscation maps will be updated and encourages modders to switch to Mojang's obfuscation map, claiming in another tweet that it would "help with compatibility".
He offered a preview of the updated license as well.
August 14, 2020The license of obfuscation maps was updated.
The version_manifest.json was updated to have client.json entries for 1.14.4 and versions since 19w36a to link to updated obfuscation maps.
1.1721w03aAltered the wording of the license.
October 29, 2025It is announced that obfuscation maps would no longer be published starting with the first snapshot after Mounts of Mayhem. This is because the game will be published without any obfuscation.
1.21.1125w45a UnobfuscatedExperimental builds without obfuscation are now released alongside the standard builds, which are currently still obfuscated.
Upcoming Java Edition
26.1snap1Obfuscation maps are no longer provided, as the game is no longer obfuscated.

Trivia

  • Before the August 16th, 2020 license update, versions released in year 2020 had # (c) 2019 Microsoft Corporation. in the license notice in the obfuscation map files.
  • Despite being published after the license update, Combat Test 8b still uses the old license notice.
  • In client obfuscation mappings, one of the first listed functions is called youJustLostTheGame(), an easter egg reference to The Game.
  • This function is used to trigger a Java crash after holding the debug key combination Ctrl + F3 + C for ten seconds.

References

See also

Navigation