// option. This file may not be copied, modified, or distributed
// except according to those terms.
-use ai = std::io::net::addrinfo;
-use std::cast;
-use libc;
use libc::c_int;
-use std::ptr::null;
+use libc;
+use std::mem;
+use std::ptr::{null, null_mut};
use std::rt::task::BlockedTask;
+use std::rt::rtio;
use net;
use super::{Loop, UvError, Request, wait_until_woken_after, wakeup};
use uvll;
struct Addrinfo {
- handle: *libc::addrinfo,
+ handle: *const libc::addrinfo,
}
struct Ctx {
impl GetAddrInfoRequest {
pub fn run(loop_: &Loop, node: Option<&str>, service: Option<&str>,
- hints: Option<ai::Hint>) -> Result<Vec<ai::Info>, UvError> {
+ hints: Option<rtio::AddrinfoHint>)
+ -> Result<Vec<rtio::AddrinfoInfo>, UvError>
+ {
assert!(node.is_some() || service.is_some());
let (_c_node, c_node_ptr) = match node {
Some(n) => {
let c_node = n.to_c_str();
- let c_node_ptr = c_node.with_ref(|r| r);
+ let c_node_ptr = c_node.as_ptr();
(Some(c_node), c_node_ptr)
}
None => (None, null())
let (_c_service, c_service_ptr) = match service {
Some(s) => {
let c_service = s.to_c_str();
- let c_service_ptr = c_service.with_ref(|r| r);
+ let c_service_ptr = c_service.as_ptr();
(Some(c_service), c_service_ptr)
}
None => (None, null())
};
let hint = hints.map(|hint| {
- let mut flags = 0;
- each_ai_flag(|cval, aival| {
- if hint.flags & (aival as uint) != 0 {
- flags |= cval as i32;
- }
- });
- let socktype = 0;
- let protocol = 0;
-
libc::addrinfo {
- ai_flags: flags,
+ ai_flags: 0,
ai_family: hint.family as c_int,
- ai_socktype: socktype,
- ai_protocol: protocol,
+ ai_socktype: 0,
+ ai_protocol: 0,
ai_addrlen: 0,
- ai_canonname: null(),
- ai_addr: null(),
- ai_next: null(),
+ ai_canonname: null_mut(),
+ ai_addr: null_mut(),
+ ai_next: null_mut(),
}
});
- let hint_ptr = hint.as_ref().map_or(null(), |x| x as *libc::addrinfo);
+ let hint_ptr = hint.as_ref().map_or(null(), |x| {
+ x as *const libc::addrinfo
+ });
let mut req = Request::new(uvll::UV_GETADDRINFO);
return match unsafe {
let mut cx = Ctx { slot: None, status: 0, addrinfo: None };
wait_until_woken_after(&mut cx.slot, loop_, || {
- req.set_data(&cx);
+ req.set_data(&mut cx);
});
match cx.status {
- 0 => Ok(accum_addrinfo(cx.addrinfo.get_ref())),
+ 0 => Ok(accum_addrinfo(cx.addrinfo.as_ref().unwrap())),
n => Err(UvError(n))
}
}
};
- extern fn getaddrinfo_cb(req: *uvll::uv_getaddrinfo_t,
+ extern fn getaddrinfo_cb(req: *mut uvll::uv_getaddrinfo_t,
status: c_int,
- res: *libc::addrinfo) {
+ res: *const libc::addrinfo) {
let req = Request::wrap(req);
assert!(status != uvll::ECANCELED);
let cx: &mut Ctx = unsafe { req.get_data() };
impl Drop for Addrinfo {
fn drop(&mut self) {
- unsafe { uvll::uv_freeaddrinfo(self.handle) }
+ unsafe { uvll::uv_freeaddrinfo(self.handle as *mut _) }
}
}
-fn each_ai_flag(_f: |c_int, ai::Flag|) {
- /* FIXME: do we really want to support these?
- unsafe {
- f(uvll::rust_AI_ADDRCONFIG(), ai::AddrConfig);
- f(uvll::rust_AI_ALL(), ai::All);
- f(uvll::rust_AI_CANONNAME(), ai::CanonName);
- f(uvll::rust_AI_NUMERICHOST(), ai::NumericHost);
- f(uvll::rust_AI_NUMERICSERV(), ai::NumericServ);
- f(uvll::rust_AI_PASSIVE(), ai::Passive);
- f(uvll::rust_AI_V4MAPPED(), ai::V4Mapped);
- }
- */
-}
-
// Traverse the addrinfo linked list, producing a vector of Rust socket addresses
-pub fn accum_addrinfo(addr: &Addrinfo) -> Vec<ai::Info> {
+pub fn accum_addrinfo(addr: &Addrinfo) -> Vec<rtio::AddrinfoInfo> {
unsafe {
let mut addr = addr.handle;
let mut addrs = Vec::new();
loop {
- let rustaddr = net::sockaddr_to_addr(cast::transmute((*addr).ai_addr),
+ let rustaddr = net::sockaddr_to_addr(mem::transmute((*addr).ai_addr),
(*addr).ai_addrlen as uint);
- let mut flags = 0;
- each_ai_flag(|cval, aival| {
- if (*addr).ai_flags & cval != 0 {
- flags |= aival as uint;
- }
- });
-
- /* FIXME: do we really want to support these
- let protocol = match (*addr).ai_protocol {
- p if p == uvll::rust_IPPROTO_UDP() => Some(ai::UDP),
- p if p == uvll::rust_IPPROTO_TCP() => Some(ai::TCP),
- _ => None,
- };
- let socktype = match (*addr).ai_socktype {
- p if p == uvll::rust_SOCK_STREAM() => Some(ai::Stream),
- p if p == uvll::rust_SOCK_DGRAM() => Some(ai::Datagram),
- p if p == uvll::rust_SOCK_RAW() => Some(ai::Raw),
- _ => None,
- };
- */
- let protocol = None;
- let socktype = None;
-
- addrs.push(ai::Info {
+ addrs.push(rtio::AddrinfoInfo {
address: rustaddr,
family: (*addr).ai_family as uint,
- socktype: socktype,
- protocol: protocol,
- flags: flags,
+ socktype: 0,
+ protocol: 0,
+ flags: 0,
});
if (*addr).ai_next.is_not_null() {
- addr = (*addr).ai_next;
+ addr = (*addr).ai_next as *const _;
} else {
break;
}