Home | History | Annotate | Line # | Download | only in lzma
      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 8
     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