1
 2
 3
 4
 5
 6
 7
 8
 9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
//! Provides macros for fetching the Cargo package version at compile time.
//!
//! All macros defined by this crate return constant expressions, so they can be used inside
//! `const fn`s or to initialize the value of a `const` or `static` item.
//!
//! # Example
//!
//! ```
//! use pkg_version::*;
//!
//! const MAJOR: u32 = pkg_version_major!();
//! const MINOR: u32 = pkg_version_minor!();
//! const PATCH: u32 = pkg_version_patch!();
//!
//! fn main() {
//!     let version = format!("{}.{}.{}", MAJOR, MINOR, PATCH);
//!     assert_eq!(version, "1.0.0");
//!
//!     println!("I am version {}", version);
//! }
//! ```

#![no_std]
#![doc(html_root_url = "https://docs.rs/pkg-version/1.0.0")]
#![warn(missing_debug_implementations, rust_2018_idioms)]

use proc_macro_hack::proc_macro_hack;

/// Expands to the major version number of the Cargo package, as an integer literal.
///
/// The resulting integer literal is *unsuffixed*, meaning that it does not use a type suffix like
/// `1u32`. This means that it can be used to initialize a variable of any integer type, as long as
/// the version number fits. If the number doesn't fit, the compiler will report an error.
#[proc_macro_hack]
pub use pkg_version_impl::pkg_version_major;

/// Expands to the minor version number of the Cargo package, as an integer literal.
///
/// The resulting integer literal is *unsuffixed*, meaning that it does not use a type suffix like
/// `1u32`. This means that it can be used to initialize a variable of any integer type, as long as
/// the version number fits. If the number doesn't fit, the compiler will report an error.
#[proc_macro_hack]
pub use pkg_version_impl::pkg_version_minor;

/// Expands to the patch version number of the Cargo package, as an integer literal.
///
/// The resulting integer literal is *unsuffixed*, meaning that it does not use a type suffix like
/// `1u32`. This means that it can be used to initialize a variable of any integer type, as long as
/// the version number fits. If the number doesn't fit, the compiler will report an error.
#[proc_macro_hack]
pub use pkg_version_impl::pkg_version_patch;

/// Make sure passing any arguments results in an error.
///
/// ```compile_fail
/// use pkg_version::*;
/// pkg_version_major!(_);
/// ```
///
/// ```compile_fail
/// use pkg_version::*;
/// pkg_version_minor!(_);
/// ```
///
/// ```compile_fail
/// use pkg_version::*;
/// pkg_version_patch!(_);
/// ```
const _COMPILE_FAIL: () = ();