Book a Demo!
CoCalc Logo Icon
StoreFeaturesDocsShareSupportNewsAboutPoliciesSign UpSign In
Kitware
GitHub Repository: Kitware/CMake
Path: blob/master/Utilities/cmliblzma/liblzma/api/lzma/version.h
3158 views
1
/* SPDX-License-Identifier: 0BSD */
2
3
/**
4
* \file lzma/version.h
5
* \brief Version number
6
* \note Never include this file directly. Use <lzma.h> instead.
7
*/
8
9
/*
10
* Author: Lasse Collin
11
*/
12
13
#ifndef LZMA_H_INTERNAL
14
# error Never include this file directly. Use <lzma.h> instead.
15
#endif
16
17
18
/** \brief Major version number of the liblzma release. */
19
#define LZMA_VERSION_MAJOR 5
20
21
/** \brief Minor version number of the liblzma release. */
22
#define LZMA_VERSION_MINOR 6
23
24
/** \brief Patch version number of the liblzma release. */
25
#define LZMA_VERSION_PATCH 3
26
27
/**
28
* \brief Version stability marker
29
*
30
* This will always be one of three values:
31
* - LZMA_VERSION_STABILITY_ALPHA
32
* - LZMA_VERSION_STABILITY_BETA
33
* - LZMA_VERSION_STABILITY_STABLE
34
*/
35
#define LZMA_VERSION_STABILITY LZMA_VERSION_STABILITY_STABLE
36
37
/** \brief Commit version number of the liblzma release */
38
#ifndef LZMA_VERSION_COMMIT
39
# define LZMA_VERSION_COMMIT ""
40
#endif
41
42
43
/*
44
* Map symbolic stability levels to integers.
45
*/
46
#define LZMA_VERSION_STABILITY_ALPHA 0
47
#define LZMA_VERSION_STABILITY_BETA 1
48
#define LZMA_VERSION_STABILITY_STABLE 2
49
50
51
/**
52
* \brief Compile-time version number
53
*
54
* The version number is of format xyyyzzzs where
55
* - x = major
56
* - yyy = minor
57
* - zzz = revision
58
* - s indicates stability: 0 = alpha, 1 = beta, 2 = stable
59
*
60
* The same xyyyzzz triplet is never reused with different stability levels.
61
* For example, if 5.1.0alpha has been released, there will never be 5.1.0beta
62
* or 5.1.0 stable.
63
*
64
* \note The version number of liblzma has nothing to with
65
* the version number of Igor Pavlov's LZMA SDK.
66
*/
67
#define LZMA_VERSION (LZMA_VERSION_MAJOR * UINT32_C(10000000) \
68
+ LZMA_VERSION_MINOR * UINT32_C(10000) \
69
+ LZMA_VERSION_PATCH * UINT32_C(10) \
70
+ LZMA_VERSION_STABILITY)
71
72
73
/*
74
* Macros to construct the compile-time version string
75
*/
76
#if LZMA_VERSION_STABILITY == LZMA_VERSION_STABILITY_ALPHA
77
# define LZMA_VERSION_STABILITY_STRING "alpha"
78
#elif LZMA_VERSION_STABILITY == LZMA_VERSION_STABILITY_BETA
79
# define LZMA_VERSION_STABILITY_STRING "beta"
80
#elif LZMA_VERSION_STABILITY == LZMA_VERSION_STABILITY_STABLE
81
# define LZMA_VERSION_STABILITY_STRING ""
82
#else
83
# error Incorrect LZMA_VERSION_STABILITY
84
#endif
85
86
#define LZMA_VERSION_STRING_C_(major, minor, patch, stability, commit) \
87
#major "." #minor "." #patch stability commit
88
89
#define LZMA_VERSION_STRING_C(major, minor, patch, stability, commit) \
90
LZMA_VERSION_STRING_C_(major, minor, patch, stability, commit)
91
92
93
/**
94
* \brief Compile-time version as a string
95
*
96
* This can be for example "4.999.5alpha", "4.999.8beta", or "5.0.0" (stable
97
* versions don't have any "stable" suffix). In future, a snapshot built
98
* from source code repository may include an additional suffix, for example
99
* "4.999.8beta-21-g1d92". The commit ID won't be available in numeric form
100
* in LZMA_VERSION macro.
101
*/
102
#define LZMA_VERSION_STRING LZMA_VERSION_STRING_C( \
103
LZMA_VERSION_MAJOR, LZMA_VERSION_MINOR, \
104
LZMA_VERSION_PATCH, LZMA_VERSION_STABILITY_STRING, \
105
LZMA_VERSION_COMMIT)
106
107
108
/* #ifndef is needed for use with windres (MinGW-w64 or Cygwin). */
109
#ifndef LZMA_H_INTERNAL_RC
110
111
/**
112
* \brief Run-time version number as an integer
113
*
114
* This allows an application to compare if it was built against the same,
115
* older, or newer version of liblzma that is currently running.
116
*
117
* \return The value of LZMA_VERSION macro at the compile time of liblzma
118
*/
119
extern LZMA_API(uint32_t) lzma_version_number(void)
120
lzma_nothrow lzma_attr_const;
121
122
123
/**
124
* \brief Run-time version as a string
125
*
126
* This function may be useful to display which version of liblzma an
127
* application is currently using.
128
*
129
* \return Run-time version of liblzma
130
*/
131
extern LZMA_API(const char *) lzma_version_string(void)
132
lzma_nothrow lzma_attr_const;
133
134
#endif
135
136