Semver: The unknown buildMetadata
2 min read • Posted on July 14, 2022
I was reading semver’s spec and I noticed something weird in the regex:
This is the 1st time that I ever encountered the mention of buildmetadata
.
Let’s deconstruct that a bit
When you read the regex, it mentions at the beginning the required major
, minor
, and patch
: a valid semver version needs to be at least MAJOR.MINOR.PATCH
, for instance 1.2.3
.
Then the version can contain an option prerelease
tag starting with a -
, for instance 1.2.3-hello
and this prelease tag can be anything made of alpha numerics (0-9 or a-z or A-Z), .
and -
.
But what surprised me is the last one: the buildmetadata
prefixed with a +
(same thing as the prerelease so any alpha numerics, or .
, or -
).
So for instance 1.2.3+build
is valid, and so is 1.2.3-beta.1+build.linux
Verification
Just to be sure, I run this in runkit, and indeed it can properly parse 1.2.3-pre.release.4+build.meta.5.6
as:
See for yourselves:
Discussion
I’ve seen plenty of times the prerelease being used (and I used it myself a few times too).
For instance, React uses it a lot:
My topic for a conversation with you is: Have you ever seen this used anywhere on NPM (or else where)? And if so, for what purpose?