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
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
#![warn(missing_docs)]
#![no_std]
macro_rules! code_name { () => { "sub-strs" }}
macro_rules! version { () => { "0.26.3" }}
pub const NAME: &str = "sub-strs";
pub const CODE_NAME: &str = code_name!();
pub const ID: &str = concat!(
"81c8cd7c-bb6ff55c-04532796-0c5f8e78-dc58e220-de29f966-6cf5438c-b8e7d644-",
"5599b650-c828cd64-75581638-1018c24e-1ae61d33-4eab6d5e-bb158f27-ecaf4911",
);
pub const VERSION: &str = version!();
pub const RELEASE_DATE: (u16, u8, u8) = (2022, 8, 20);
pub const TAG: &str = concat!(code_name!(), "::81c8cd7c::", version!());
extern crate alloc;
#[cfg(feature="std")]
extern crate std;
macro_rules! err {
() => {
crate::Error::new(line!(), module_path!(), None)
};
($s: literal) => {
crate::Error::new(line!(), module_path!(), Some(alloc::borrow::Cow::Borrowed($s)))
};
($s: literal, $($arg: tt)+) => {
crate::Error::new(line!(), module_path!(), Some(alloc::borrow::Cow::Owned(alloc::format!($s, $($arg)+))))
};
}
#[test]
fn test_macro_err() {
use alloc::borrow::Cow;
macro_rules! s_test { () => { "test" }}
fn eq(first: Error, second: Error) -> bool {
first.line() == second.line() && first.module_path() == second.module_path() && first.msg() == second.msg()
}
assert!(eq(err!(), Error::new(line!(), module_path!(), None)));
assert!(eq(err!("test"), Error::new(line!(), module_path!(), Some(Cow::Borrowed(s_test!())))));
assert!(eq(err!("{s:?}", s=s_test!()), Error::new(line!(), module_path!(), Some(Cow::Owned(alloc::format!("{:?}", s_test!()))))));
}
#[test]
fn test_crate_version() {
assert_eq!(VERSION, env!("CARGO_PKG_VERSION"));
}
pub mod version_info;
mod cain_str;
mod error;
mod glob;
mod glob_set;
mod order;
mod sub_str;
mod sub_str_iter;
pub use self::{
cain_str::*,
error::*,
glob::*,
glob_set::*,
order::*,
sub_str::*,
sub_str_iter::*,
};
pub type Result<T> = core::result::Result<T, Error>;