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
|
//! Rust friendly bindings to the various *nix system functions.
//!
//! Modules are structured according to the C header file that they would be
//! defined in.
#![crate_name = "nix"]
#![feature(collections, core, net, linkage, libc, os, path, std_misc)]
#![allow(non_camel_case_types)]
#[macro_use]
extern crate bitflags;
extern crate libc;
extern crate core;
#[cfg(test)]
extern crate "nix-test" as nixtest;
// Re-export some libc constants
pub use libc::{c_int, c_void};
mod nix;
pub use nix::{NixResult, NixError, NixPath, from_ffi};
#[cfg(unix)]
pub mod errno;
#[cfg(unix)]
pub mod features;
#[cfg(unix)]
pub mod fcntl;
#[cfg(any(target_os = "linux", target_os = "android"))]
pub mod mount;
#[cfg(any(target_os = "linux", target_os = "android"))]
pub mod sched;
#[cfg(unix)]
pub mod sys;
#[cfg(unix)]
pub mod unistd;
/*
*
* ===== Impl utilities =====
*
*/
use std::ffi::OsStr;
use std::os::unix::OsStrExt;
/// Converts a value to an external (FFI) string representation
trait AsExtStr {
fn as_ext_str(&self) -> *const libc::c_char;
}
impl AsExtStr for OsStr {
fn as_ext_str(&self) -> *const libc::c_char {
self.as_bytes().as_ptr() as *const libc::c_char
}
}
|