libsip 0.2.6

SIP protocol Implementation, with a focus towords softphone clients.
Documentation
/// Generate a URI domain from an domain name.
/// ```rust
/// # #[macro_use]
/// # extern crate libsip;
/// # fn main() {
/// let domain = domain!("example.com");
/// let domain = domain!("example.com", 5060);
/// # }
/// ```
#[macro_export]
macro_rules! domain {
    ($domain:tt) => {
        libsip::Domain::Domain($domain.into(), None)
    };
    ($domain:tt, $port:tt) => {
        libsip::Domain::Domain($domain.into(), Some($port))
    };
}

/// Generate a URI domain from an ip address.
/// ```rust
/// # #[macro_use]
/// # extern crate libsip;
/// # fn main() {
/// let domain = ip_domain!(192, 168, 0, 1);
/// let domain = ip_domain!(192, 168, 0, 1, 5060);
/// # }
/// ```
#[macro_export]
macro_rules! ip_domain {
    ($a:tt, $b:tt, $c:tt, $d:tt) => {
        libsip::Domain::Ipv4(::std::net::Ipv4Addr::new($a, $b, $c, $d), None)
    };

    ($a:tt, $b:tt, $c:tt, $d:tt, $port:tt) => {
        libsip::Domain::Ipv4(::std::net::Ipv4Addr::new($a, $b, $c, $d), Some($port))
    };
}

/// Generate a URI authentication from credentials.
/// ```rust
/// # #[macro_use]
/// # extern crate libsip;
/// # fn main() {
/// let auth = uri_auth!("user");
/// let auth = uri_auth!("user", "pass");
/// # }
/// ```
#[macro_export]
macro_rules! uri_auth {
    ($u:tt) => {
        libsip::UriAuth::new($u)
    };
    ($u:tt, $p:tt) => {
        libsip::UriAuth::new($u).password($p)
    };
}

/// Generate `NamedHeader` from a uri;
/// ```rust
/// # #[macro_use]
/// # extern crate libsip;
/// # fn main() {
/// let uri = libsip::Uri::sip(domain!("example.com"));
/// let domain = named_header!(uri);
/// # }
/// ```
#[macro_export]
macro_rules! named_header {
    ($u:tt) => {
        libsip::NamedHeader {
            display_name: None,
            uri: $u,
            parameters: ::std::collections::HashMap::new(),
        }
    };
    ($u:tt, $name:tt) => {
        libsip::NamedHeader {
            display_name: Some($name.into()),
            uri: $u,
            parameters: ::std::collections::HashMap::new(),
        }
    };
}

/// Same as `named_header` except for internal use.
macro_rules! __named_header {
    ($u:tt) => {
        crate::NamedHeader {
            display_name: None,
            uri: $u,
            parameters: ::std::collections::HashMap::new(),
        }
    };
}