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
// Copyright 2022 - 2023 Wenmeng See the COPYRIGHT
// file at the top-level directory of this distribution.
// 
// Licensed under the Apache License, Version 2.0 <LICENSE-APACHE or
// http://www.apache.org/licenses/LICENSE-2.0>, at your
// option. This file may not be copied, modified, or distributed
// except according to those terms.
// 
// Author: tickbh
// -----
// Created Date: 2023/08/15 09:59:05

#[macro_export]
macro_rules! byte_map {
    ($($flag:expr,)*) => ([
        $($flag != 0,)*
    ])
}

#[macro_export]
macro_rules! next {
    ($bytes:ident) => ({
        match $bytes.get_next() {
            Some(b) => Ok(b),
            None => Err(crate::WebError::from(crate::HttpError::Partial))
        }
    })
}

#[macro_export]
macro_rules! must_have {
    ($bytes:ident, $num:expr) => ({
        if $bytes.remaining() >= $num {
            Ok(())
        } else {
            Err(webparse::WebError::from(webparse::HttpError::Partial))
        }
    })
}


#[macro_export]
macro_rules! peek {
    ($bytes:ident) => ({
        match $bytes.peek() {
            Some(b) => Ok(b),
            None => Err(WebError::from(crate::HttpError::Partial))
        }
    })
}


#[macro_export]
macro_rules! expect {
    ($bytes:ident.next() == $pat:pat => $ret:expr) => {
        expect!(next!($bytes) => $pat |? $ret)
    };
    ($e:expr => $pat:pat_param |? $ret:expr) => {
        match $e {
            Ok(_v@$pat) => (),
            Err(e) => return Err(e),
            _ => return $ret
        }
    };
}


#[macro_export]
macro_rules! try_advance {
    ($flag:expr) => {
        if !$flag {
            return Err(std::io::Error::new(std::io::ErrorKind::UnexpectedEof, "not enough"));
        }
    };
}