Switch to libc 0.2
This commit is contained in:
parent
03e4908c13
commit
309b6d9f46
|
|
@ -26,7 +26,7 @@ rfc5114 = []
|
||||||
ecdh_auto = []
|
ecdh_auto = []
|
||||||
|
|
||||||
[dependencies]
|
[dependencies]
|
||||||
libc = "0.1"
|
libc = "0.2"
|
||||||
|
|
||||||
[build-dependencies]
|
[build-dependencies]
|
||||||
pkg-config = "0.3"
|
pkg-config = "0.3"
|
||||||
|
|
|
||||||
|
|
@ -30,8 +30,10 @@ version = "0.6.7"
|
||||||
[dependencies]
|
[dependencies]
|
||||||
bitflags = ">= 0.2, < 0.4"
|
bitflags = ">= 0.2, < 0.4"
|
||||||
lazy_static = "0.1"
|
lazy_static = "0.1"
|
||||||
libc = "0.1"
|
libc = "0.2"
|
||||||
|
|
||||||
[dev-dependencies]
|
[dev-dependencies]
|
||||||
rustc-serialize = "0.3"
|
rustc-serialize = "0.3"
|
||||||
net2 = "0.2.16"
|
net2 = "0.2.16"
|
||||||
|
winapi = "0.2"
|
||||||
|
ws2_32-sys = "0.1"
|
||||||
|
|
|
||||||
|
|
@ -1,31 +1,18 @@
|
||||||
use libc;
|
use libc;
|
||||||
pub use self::imp::*;
|
pub use self::imp::*;
|
||||||
|
|
||||||
extern "system" {
|
|
||||||
#[link_name = "select"]
|
|
||||||
fn raw_select(nfds: libc::c_int,
|
|
||||||
readfds: *mut fd_set,
|
|
||||||
writefds: *mut fd_set,
|
|
||||||
errorfds: *mut fd_set,
|
|
||||||
timeout: *mut libc::timeval) -> libc::c_int;
|
|
||||||
}
|
|
||||||
|
|
||||||
#[cfg(unix)]
|
#[cfg(unix)]
|
||||||
mod imp {
|
mod imp {
|
||||||
use std::os::unix::prelude::*;
|
use std::os::unix::prelude::*;
|
||||||
use std::io;
|
use std::io;
|
||||||
use libc;
|
use libc;
|
||||||
|
|
||||||
const FD_SETSIZE: usize = 1024;
|
pub use libc::fd_set;
|
||||||
|
|
||||||
#[repr(C)]
|
|
||||||
pub struct fd_set {
|
|
||||||
fds_bits: [u64; FD_SETSIZE / 64]
|
|
||||||
}
|
|
||||||
|
|
||||||
pub fn fd_set<F: AsRawFd>(set: &mut fd_set, f: &F) {
|
pub fn fd_set<F: AsRawFd>(set: &mut fd_set, f: &F) {
|
||||||
let fd = f.as_raw_fd() as usize;
|
unsafe {
|
||||||
set.fds_bits[fd / 64] |= 1 << (fd % 64);
|
libc::FD_SET(f.as_raw_fd(), set);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
pub unsafe fn select<F: AsRawFd>(max: &F,
|
pub unsafe fn select<F: AsRawFd>(max: &F,
|
||||||
|
|
@ -38,8 +25,7 @@ mod imp {
|
||||||
tv_sec: (timeout_ms / 1000) as libc::time_t,
|
tv_sec: (timeout_ms / 1000) as libc::time_t,
|
||||||
tv_usec: (timeout_ms % 1000 * 1000) as libc::suseconds_t,
|
tv_usec: (timeout_ms % 1000 * 1000) as libc::suseconds_t,
|
||||||
};
|
};
|
||||||
let rc = super::raw_select(max.as_raw_fd() + 1, read, write, error,
|
let rc = libc::select(max.as_raw_fd() + 1, read, write, error, &mut timeout);
|
||||||
&mut timeout);
|
|
||||||
if rc < 0 {
|
if rc < 0 {
|
||||||
Err(io::Error::last_os_error())
|
Err(io::Error::last_os_error())
|
||||||
} else {
|
} else {
|
||||||
|
|
@ -50,17 +36,16 @@ mod imp {
|
||||||
|
|
||||||
#[cfg(windows)]
|
#[cfg(windows)]
|
||||||
mod imp {
|
mod imp {
|
||||||
|
extern crate winapi;
|
||||||
|
extern crate ws2_32;
|
||||||
|
|
||||||
use std::os::windows::prelude::*;
|
use std::os::windows::prelude::*;
|
||||||
use std::io;
|
use std::io;
|
||||||
use libc::{SOCKET, c_uint, c_long, timeval};
|
use libc::{c_uint, c_long};
|
||||||
|
use self::winapi::SOCKET;
|
||||||
|
use self::winapi::winsock2;
|
||||||
|
|
||||||
const FD_SETSIZE: usize = 64;
|
pub use self::winapi::winsock2::fd_set;
|
||||||
|
|
||||||
#[repr(C)]
|
|
||||||
pub struct fd_set {
|
|
||||||
fd_count: c_uint,
|
|
||||||
fd_array: [SOCKET; FD_SETSIZE],
|
|
||||||
}
|
|
||||||
|
|
||||||
pub fn fd_set<F: AsRawSocket>(set: &mut fd_set, f: &F) {
|
pub fn fd_set<F: AsRawSocket>(set: &mut fd_set, f: &F) {
|
||||||
set.fd_array[set.fd_count as usize] = f.as_raw_socket();
|
set.fd_array[set.fd_count as usize] = f.as_raw_socket();
|
||||||
|
|
@ -73,11 +58,11 @@ mod imp {
|
||||||
error: *mut fd_set,
|
error: *mut fd_set,
|
||||||
timeout_ms: u32)
|
timeout_ms: u32)
|
||||||
-> io::Result<bool> {
|
-> io::Result<bool> {
|
||||||
let mut timeout = timeval {
|
let mut timeout = winsock2::timeval {
|
||||||
tv_sec: (timeout_ms / 1000) as c_long,
|
tv_sec: (timeout_ms / 1000) as c_long,
|
||||||
tv_usec: (timeout_ms % 1000 * 1000) as c_long,
|
tv_usec: (timeout_ms % 1000 * 1000) as c_long,
|
||||||
};
|
};
|
||||||
let rc = super::raw_select(1, read, write, error, &mut timeout);
|
let rc = ws2_32::select(1, read, write, error, &mut timeout);
|
||||||
if rc < 0 {
|
if rc < 0 {
|
||||||
Err(io::Error::last_os_error())
|
Err(io::Error::last_os_error())
|
||||||
} else {
|
} else {
|
||||||
|
|
|
||||||
Loading…
Reference in New Issue