version ------- Generate, parse and modify versions purely with CMake. Supports Semantic Versioning 2.0.0, 1.0.0 and other version formats. Synopsis ^^^^^^^^ .. parsed-literal:: version(`PARSE`_ ) version(`GENERATE`_ [COMPRESS] [MAJOR ] [MINOR ] [PATCH ] [TWEAK ] [PRERELEASE ] [BUILD ]) version(`MODIFY`_ [COMPRESS] [MAJOR ] [MINOR ] [TWEAK ] [PRERELEASE ] [BUILD ]) version(`COMPARE`_ ) The following version constructs are currently supported: .. code-block:: "." ["." ["." ]] "." ["." ["." ]] [["-"] ] ["+" ] Parsing ^^^^^^^ .. _PARSE: .. code-block:: cmake version(PARSE ) Attempts to parse the version in ```` and stores the individual compoents into ``_``. If a component is not present in the given version, it will be undefined. If an error occurred, ``_ERROR`` will be defined and contain the error message. Generating ^^^^^^^^^^ .. _GENERATE: .. code-block:: cmake version(GENERATE [COMPRESS] [MAJOR ] [MINOR ] [PATCH ] [TWEAK ] [PRERELEASE ] [BUILD ]) Generates a version from the components provided and stores the result in ````. The components ```` and ```` will default to ``0`` if not provided. If an error occurred, ``_ERROR`` will be defined and contain the error message. Modifying ^^^^^^^^^ .. _MODIFY: .. code-block:: cmake version(MODIFY [COMPRESS] [MAJOR ] [MINOR ] [TWEAK ] [PRERELEASE ] [BUILD ]) Modifies the version provided in ```` with the components provided. The components ````, ````, ```` and ```` may have a prefix of ``+`` or ``-`` to add and subtract the value, or no prefix to replace. The result of this operation will be stored as a string in ````. If a component did not exist in the original, it will be added to the version as a replace operation. If an error occurred, ``_ERROR`` will be defined and contain the error message. Comparing ^^^^^^^^^ .. _COMPARE: .. code-block:: cmake version(COMPARE ) Compares the version ```` against ```` and stores the result in ````. The provided version will be evaluated in the order MAJOR, MINOR, PATCH, TWEAK, PRERELEASE, and then BUILD. The following results should be expected: - If a component is only in ````, ```` will contain the componenent name prefixed by ``+``. - If a component is only in ````, ```` will contain the componenent name prefixed by ``-``. - If a component is numerical and the value is larger in ````, ```` will contain the componenent name prefixed by ``>``. - If a component is numerical and the value is larger in ````, ```` will contain the componenent name prefixed by ``<``. - If a component is alphanumerical and the value is different in either, ```` will contain the component name with no prefix. - In all other cases, ```` will be empty. - If an error occurred, ``_ERROR`` will be defined and contain the error message, and ```` will be undefined.