Skip to content

Latest commit

 

History

History
48 lines (42 loc) · 2.52 KB

README.md

File metadata and controls

48 lines (42 loc) · 2.52 KB

semver

Описание

Простая реализация логики семантического версионирования с упором на embedded решения. В данном варианте используется шаблон Major.Minor.Patch-PreRelease.PreReleaseNumber, при этом часть -PreRelease.PreReleaseNumber не обязательная. Часть, которая отвечает за сборочные параметры (которая начинается после +) в данном варианте для простоты не используется.

Мажорная, минорная и версия патча могут быть любыми не отрицательными числами, PreRelease - alpha, betha, rc, номер PreRelease от нуля (не отображается) до 99 (и то, если версия дошла до -alpha.10 - уже что-то пошло не так :) ).

Более подробно о семантическом версионировании можно почитать здесь.

Примеры

Создание:

Version version;

При этом будет задана версия 0.1.0. Версию можно задать параметрами конструктора:

Version version(1, 0, 0, Version::Pre::Alpha);

После преобразования в строку это даст 1.0.0-alpha. Так же возможно задание версии из строки:

Version version = Semver::fromString("1.12.0");

Или задать через метод set:

Version version;
version.set(2, 0, 0, Version::Pre::ReleaseCandidate); // 2.0.0-rc

Вывод

Для вывода можно использовать либо метод toString, либо приведение:

char buffer[22] = {0};
std::printf("Version: %s\n", Semver::toString(version, buffer));

Все поля версий (major, minor, etc) являются открытыми и свободны в использовании.

Сравнение

Для сравнения версий можно использовать как операторы >,<,==, так и методы:

if(version1.isEquals(version2)) { /* ... */ }
if(version1.isNewerThen(version2)) { /* ... */ }
if(version1.isOlderThen(version2)) { /* ... */ }

if(version1 == version2) { /* ... */ }
if(version1 > version2) { /* ... */ }
if(version1 < version2) { /* ... */ }