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
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
//! # vlog
//!
//! Macros to do stdout / stderr logs based on verbosity level.
//!
//! Useful for CLI applications. The default verbosity level is 0, and the
//! supported max verbosity level is 3, which is equivalent to `-vvv` flags seen
//! in most Linux CLI applications.
//!
//! # Example
//! ```
//! #[macro_use]
//! extern crate vlog;
//!
//! use vlog::{get_verbosity_level, set_verbosity_level};
//!
//! fn main() {
//! // default verbosity level is 0
//! assert_eq!(0, get_verbosity_level());
//!
//! v0!("v0 stdout prints");
//! v1!("v1 stdout won't print");
//! v2!("v2 stdout won't print");
//! v3!("v3 stdout won't print");
//!
//! // set custom verbosity level
//! set_verbosity_level(1);
//! assert_eq!(1, get_verbosity_level());
//!
//! v0!("{} stdout prints", "v0");
//! v1!("{} stdout prints", "v1");
//! v2!("{} stdout won't print", "v2");
//! v3!("{} stdout won't print", "v3");
//!
//! // set custom max verbosity level
//! set_verbosity_level(3);
//! assert_eq!(3, get_verbosity_level());
//!
//! v0!("{} stdout prints", "v0");
//! v1!("{} stdout prints", "v1");
//! v2!("{} stdout prints", "v2");
//! v3!("{} stdout prints", "v3");
//!
//! // stderr macros also available
//! ve0!("{} stderr prints", "ve0");
//! ve1!("{} stderr prints", "ve1");
//! ve2!("{} stderr prints", "ve2");
//! ve3!("{} stderr prints", "ve3");
//! }
//! ```
use ;
/// Application verbosity level value.
static mut VERBOSITY_LEVEL: AtomicUsize = new;
/// Sets the application verbosity level atomically. This method is thread-safe.
///
/// # Arguments
/// * `verbosity_level` - Verbosity level value. While there is no check on the
/// upper bound, the expected max level value is 3.
///
/// # Example
/// ```
/// use vlog::set_verbosity_level;
///
/// // min verbosity level
/// set_verbosity_level(0);
///
/// // max verbosity level
/// set_verbosity_level(3);
/// ```
/// Gets the application verbosity level atomically. This method is thread-safe.
///
/// # Example
/// ```
/// use vlog::{get_verbosity_level, set_verbosity_level};
///
/// // default verbosity level
/// assert_eq!(0, get_verbosity_level());
///
/// // custom verbosity level
/// set_verbosity_level(1);
/// assert_eq!(1, get_verbosity_level());
/// ```