diesel/macros/
static_cond.rs

1#![cfg_attr(rustfmt, rustfmt_skip)] // https://github.com/rust-lang-nursery/rustfmt/issues/2754
2
3// Vendored from the static-cond crate as macro re-exports are not available in stable Rust.
4// https://github.com/durka/static-cond/blob/36aa2dd/src/lib.rs
5//
6// Code is dual licensed under MIT/Apache-2.0
7// Copyright (c) 2016 Alex Burka
8#[macro_export]
9#[doc(hidden)]
10macro_rules! static_cond {
11    // private rule to define and call the local macro
12    (@go $lhs:tt $rhs:tt $arm1:tt $arm2:tt) => {
13        // note that the inner macro has no captures (it can't, because there's no way to escape `$`)
14        macro_rules! __static_cond {
15            ($lhs $lhs) => $arm1;
16            ($lhs $rhs) => $arm2
17        }
18
19        __static_cond!($lhs $rhs);
20    };
21
22    // no else condition provided: fall through with empty else
23    (if $lhs:tt == $rhs:tt $then:tt) => {
24        $crate::static_cond!(if $lhs == $rhs $then else { });
25    };
26    (if $lhs:tt != $rhs:tt $then:tt) => {
27        $crate::static_cond!(if $lhs != $rhs $then else { });
28    };
29
30    // we evaluate a conditional by generating a new macro (in an inner scope, so name shadowing is
31    // not a big concern) and calling it
32    (if $lhs:tt == $rhs:tt $then:tt else $els:tt) => {
33        $crate::static_cond!(@go $lhs $rhs $then $els);
34    };
35    (if $lhs:tt != $rhs:tt $then:tt else $els:tt) => {
36        $crate::static_cond!(@go $lhs $rhs $els $then);
37    };
38}