Versioning
This article will break down how versioning works in Minecraft and NeoForge, and will give some recommendations for mod versioning as well.
Minecraft
Minecraft uses semantic versioning. Semantic versioning, or "semver" for short, has the format major.minor.patch
. So for example, Minecraft 1.20.2 has the major version 1, the minor version 20 and the patch version 2.
Minecraft has used 1
as the major version since 2011, when Minecraft 1.0 was introduced. Before that, the versioning scheme changed often, and there were versions like a1.1
(Alpha 1.1), b1.7.3
(Beta 1.7.3) or even the infdev
versions, which didn't follow a clear versioning scheme at all. Due to the 1
major version holding up for over a decade now, and due to the in-joke that is Minecraft 2, it is generally considered unlikely that this is ever going to change.
Snapshots
Snapshots deviate from the standard semver scheme. They are labeled as YYwWWa
, where YY
represents the last two digits of the year (e.g. 23
) and WW
represents the week of that year (e.g. 01
). So for example, snapshot 23w01a
is the snapshot released in the first week of 2023.
The a
suffix exists for occasions where two snapshots get released in the same week (where the second snapshot would then be named something like 23w01b
). Mojang has occasionally used this in the past. The alternative suffix has also been used for snapshots like 20w14infinite
, which was the 2020 infinite dimensions April Fool's joke.
Pre-releases and Release Candidates
When a snapshot cycle is coming completion, Mojang starts releasing so-called pre-releases. Pre-releases are deemed feature-complete for a version and focus solely on bugfixes. They use the semver notation for the version it is for, suffixed by -preX
. So for example, the first pre-release for 1.20.2 was named 1.20.2-pre1
. There can be and usually are multiple pre-releases, which are accordingly suffixed with -pre2
, -pre3
, etc.
Similarly, when the pre-release cycle completes, Mojang releases Release Candidate 1 (suffixing the version with -rc1
, for example 1.20.2-rc1
). Mojang aims to have one release candidate that they can release if no further bugs occur. However, if an unexpected bug occurs, then there can also be an -rc2
, -rc3
, etc. version, similar to pre-releases.
NeoForge
NeoForge uses an adapted semver system: The major version is Minecraft's minor version, the minor version is Minecraft's patch version, and the patch version is the "actual" NeoForge version. So for example, NeoForge 20.2.59 is the 60th version (we start at 0) for Minecraft 1.20.2. The 1
at the beginning is omitted because it is very unlikely that it will ever change, see above for why that is the case.
A few places in NeoForge also use Maven version ranges, for example the Minecraft and NeoForge version ranges in the mods.toml
file. These are mostly, but not fully compatible with semver (the pre
-tag is not considered by it, for example).
Mods
There is no definitive best versioning system. Different styles of development, scopes of projects, etc. all influence the decision of what versioning system to use. Sometimes, versioning system can also be combined. This section attempts to give an overview over some commonly used versioning systems, with real-life examples.
Usually, a mod's file name looks like modid-<version>.jar
. So if our mod id is examplemod
and our version is 1.2.3
, our mod file would be named examplemod-1.2.3.jar
.
Versioning systems are suggestions, rather than strictly enforced rules. This is especially true with regard to when the version is changed ("bumped"), and in what way. If you want to use a different versioning system, nobody is going to stop you.