Advertisement

client.json

This feature is exclusive to Java Edition. 

client.json is the file that accompanies client.jar in .minecraft/versions/<version> and lists the version's attributes. When using the latest version of the Minecraft launcher, it is named <game version>.json. The JSON file for specific versions is located in the version_manifest.json file.

JSON format

This is the JSON format for client.json.

  • The root tag.
    •  arguments:
      •  game: Contains arguments supplied to the game, such as information about the username and the version.
        • An argument.
        • A conditional argument.
          •  rules: A list of rules.
            • A rule.
              •  action: Its value is "allow".
              •  features: Includes a set of features that can be checked.
                •  is_demo_user: Appears only in the first appearance of the compound tag.
                •  has_custom_resolution: Appears only in the second appearance of the compound tag.
          •  value: An argument or a list of arguments that is added when the condition is matched.
      •  jvm: Contains JVM arguments, such as information about memory allocation, garbage collector selection, or environmental variables.
        • : A conditional argument.
          •  rules: A list of rules.
            • : A rule.
              •  action: Its value is "allow".
              •  os:
                •  name: Its value is "osx" for the first appearance of the compound tag and "windows" for the second and third. Does not appear in the fourth appearance.
                •  version: Appears only in the third appearance of the compound tag. Its value is "^10\\.".
                •  arch: Appears only in the fourth appearance of the compound tag. Its value is "x86".
          •  value: An argument or a list of arguments that is added when the condition is matched.
    •  assetIndex:
      •  id: The assets version.
      •  sha1: The SHA1 of the assets file.
      •  size: The size of the version.
      •  totalSize: The total size of the version.
      •  url: The URL that the game should visit to download the assets.
    •  assets: The assets version.
    •  complianceLevel: Its value is 1 for all recent versions of the game (1.16.4 and above) or 0 for all others. This tag tells the launcher whether it should urge the user to be careful since this version is older and might not support the latest player safety features.
    •  downloads:
      •  client: The client.jar download information.
        •  sha1: The SHA1 of the jar.
        •  size: The size of jar in bytes.
        •  url: The URL where the jar is hosted.
      •  client_mappings: The obfuscation maps for this client version. Added in Java Edition 19w36a but got included in 1.14.4 also. Repeats the structure of the client download information.
      •  server: The server download information. Repeats the structure of the client download information.
      •  server_mappings: The obfuscation maps for this server version. Added in Java Edition 19w36a but got included in 1.14.4 also. Repeats the structure of the client download information.
    •  id: The name of this version client (e.g. 1.14.4).
    •  javaVersion: The version of the Java Runtime Environment.
      •  component: Its value for all 1.17 snapshots is "jre-legacy" until 21w18a and "java-runtime-alpha" since 21w19a.
      •  majorVersion: Its value for all 1.17 snapshots is 8 until 21w18a and 16 since 21w19a.
    •  libraries: A list of libraries.
      • : A library.
        •  downloads: The library's download information.
          •  artifact: Info about the artifact.
            •  path: Path to store the downloaded artifact, relative to the "libraries" directory in .minecraft.
            •  sha1: The SHA1 of the file.
            •  size: The size of the file.
            •  url: The URL that the game should visit to download the file.
          •  classifiers: Appears only for some libraries.
            •  <classifier>: Specifies the artifact information for the artifact with this specific classifier. Repeats the artifact structure above.
        •  name: A maven name for the library, in the form of "groupId:artifactId:version".
        •  url: The URL of the Maven repository (used by Forge).
        •  natives: Information about native libraries (in C) bundled with this library. Appears only when there are classifiers for natives.
          • : This tag's name depends on the natives that appear in the classifiers, so it can be "linux", "macos", "windows", or "osx". Its value is the corresponding classifier ("natives-linux" etc.).
        •  extract: Appears only in two libraries.
          •  exclude: Shows what to exclude from the extraction.
            • : Its value is "META-INF/".
        •  rules: Contains a compound with the tags "action" and "os", as shown above.
    •  logging: Information about Log4j log configuration.
      •  client:
        •  argument: The JVM argument for adding the log configuration. Its value is "-Dlog4j.configurationFile=${path}".
        •  file: The Log4j2 XML configuration used by this version for the launcher for launcher's log screen.
          •  id: Its value is "client-1.12.xml", but may differ for older versions.[note 1]
          •  sha1: The SHA1 for this file.
          •  size: The size of the file.
          •  url: The URL the game should visit to download the log configuration..
        •  type: Its value is "log4j2-xml".
    •  mainClass: The main game class; for modern versions, it is net.minecraft.client.main.Main, but it may differ for older or ancient versions.[note 2]
    •  minimumLauncherVersion: The minimum Launcher version that can run this version of the game.
    •  releaseTime: The release date and time.
    •  time: Same as "releaseTime".
    •  type: The type of this game version. It is shown in the version list when you create a new installation. The default values are "release" and "snapshot".

History

Java Edition
1.6.113w16aWith the new launcher, versions are now stored in .minecraft/versions and each version has its own folder with a minecraft.jar (which is now called client.jar) and a .json file, which is the client.json.
1.7.213w39aAdded the  logging tag in the root tag.
1.1317w43aThe  arguments tag replaced the old  minecraftArguments tag.
1.1519w36aObfuscation mappings are now listed in the  downloads tag. They are implemented in 1.14.4 also.
1.1620w21aAdded two new arguments: disableChat, which disables the chat in-game, and disableMultiplayer, which disables the "Multiplayer" and "Minecraft Realms" buttons.
1.1720w45aAdded the  javaVersion tag with all its children.

Notes

  1. For instance, for Java Edition 1.10.2, the value is "client-1.7.xml".
  2. For instance, for rd-132211, the value is com.mojang.rubydung.RubyDung.
Community content is available under CC BY-NC-SA unless otherwise noted.
  NODES
admin 1
Bugs 1
chat 2
COMMUNITY 8
Note 4
Project 1