Alex Crichton | dafaca9 | 2015-09-09 21:50:47 -0700 | [diff] [blame] | 1 | // Copyright 2012-2015 The Rust Project Developers. See the COPYRIGHT |
| 2 | // file at the top-level directory of this distribution and at |
| 3 | // http://rust-lang.org/COPYRIGHT. |
| 4 | // |
| 5 | // Licensed under the Apache License, Version 2.0 <LICENSE-APACHE or |
| 6 | // http://www.apache.org/licenses/LICENSE-2.0> or the MIT license |
| 7 | // <LICENSE-MIT or http://opensource.org/licenses/MIT>, at your |
| 8 | // option. This file may not be copied, modified, or distributed |
| 9 | // except according to those terms. |
| 10 | |
Alex Crichton | 95b18b7 | 2015-09-17 10:06:58 -0700 | [diff] [blame] | 11 | //! Crate docs |
| 12 | |
Alex Crichton | 07d3a0d | 2015-10-30 10:21:32 -0700 | [diff] [blame] | 13 | #![allow(bad_style, raw_pointer_derive, overflowing_literals, improper_ctypes)] |
Alex Crichton | f7efe34 | 2015-11-02 14:26:04 -0800 | [diff] [blame] | 14 | #![crate_type = "rlib"] |
| 15 | #![crate_name = "libc"] |
Alex Crichton | 24abc4f | 2015-09-16 23:54:56 -0700 | [diff] [blame] | 16 | #![cfg_attr(dox, feature(no_core, lang_items))] |
| 17 | #![cfg_attr(dox, no_core)] |
| 18 | #![doc(html_logo_url = "https://www.rust-lang.org/logos/rust-logo-128x128-blk-v2.png", |
| 19 | html_favicon_url = "https://doc.rust-lang.org/favicon.ico")] |
| 20 | |
Alex Crichton | 730a17f | 2015-09-17 10:05:36 -0700 | [diff] [blame] | 21 | #![cfg_attr(all(target_os = "linux", target_arch = "x86_64"), doc( |
Alex Crichton | 13418a5 | 2015-10-29 11:54:12 -0700 | [diff] [blame] | 22 | html_root_url = "https://doc.rust-lang.org/libc/x86_64-unknown-linux-gnu" |
Alex Crichton | 730a17f | 2015-09-17 10:05:36 -0700 | [diff] [blame] | 23 | ))] |
| 24 | #![cfg_attr(all(target_os = "linux", target_arch = "x86"), doc( |
Alex Crichton | 13418a5 | 2015-10-29 11:54:12 -0700 | [diff] [blame] | 25 | html_root_url = "https://doc.rust-lang.org/libc/i686-unknown-linux-gnu" |
Alex Crichton | 730a17f | 2015-09-17 10:05:36 -0700 | [diff] [blame] | 26 | ))] |
| 27 | #![cfg_attr(all(target_os = "linux", target_arch = "arm"), doc( |
Alex Crichton | 13418a5 | 2015-10-29 11:54:12 -0700 | [diff] [blame] | 28 | html_root_url = "https://doc.rust-lang.org/libc/arm-unknown-linux-gnueabihf" |
Alex Crichton | 730a17f | 2015-09-17 10:05:36 -0700 | [diff] [blame] | 29 | ))] |
| 30 | #![cfg_attr(all(target_os = "linux", target_arch = "mips"), doc( |
Alex Crichton | 13418a5 | 2015-10-29 11:54:12 -0700 | [diff] [blame] | 31 | html_root_url = "https://doc.rust-lang.org/libc/mips-unknown-linux-gnu" |
Alex Crichton | 730a17f | 2015-09-17 10:05:36 -0700 | [diff] [blame] | 32 | ))] |
Alex Crichton | d13e1e4 | 2015-09-17 17:29:18 -0700 | [diff] [blame] | 33 | #![cfg_attr(all(target_os = "linux", target_arch = "aarch64"), doc( |
Alex Crichton | 13418a5 | 2015-10-29 11:54:12 -0700 | [diff] [blame] | 34 | html_root_url = "https://doc.rust-lang.org/libc/aarch64-unknown-linux-gnu" |
Alex Crichton | d13e1e4 | 2015-09-17 17:29:18 -0700 | [diff] [blame] | 35 | ))] |
Alex Crichton | 730a17f | 2015-09-17 10:05:36 -0700 | [diff] [blame] | 36 | #![cfg_attr(all(target_os = "linux", target_env = "musl"), doc( |
Alex Crichton | 13418a5 | 2015-10-29 11:54:12 -0700 | [diff] [blame] | 37 | html_root_url = "https://doc.rust-lang.org/libc/x86_64-unknown-linux-musl" |
Alex Crichton | 730a17f | 2015-09-17 10:05:36 -0700 | [diff] [blame] | 38 | ))] |
| 39 | #![cfg_attr(all(target_os = "macos", target_arch = "x86_64"), doc( |
Alex Crichton | 13418a5 | 2015-10-29 11:54:12 -0700 | [diff] [blame] | 40 | html_root_url = "https://doc.rust-lang.org/libc/x86_64-apple-darwin" |
Alex Crichton | 730a17f | 2015-09-17 10:05:36 -0700 | [diff] [blame] | 41 | ))] |
| 42 | #![cfg_attr(all(target_os = "macos", target_arch = "x86"), doc( |
Alex Crichton | 13418a5 | 2015-10-29 11:54:12 -0700 | [diff] [blame] | 43 | html_root_url = "https://doc.rust-lang.org/libc/i686-apple-darwin" |
Alex Crichton | 730a17f | 2015-09-17 10:05:36 -0700 | [diff] [blame] | 44 | ))] |
| 45 | #![cfg_attr(all(windows, target_arch = "x86_64", target_env = "gnu"), doc( |
Alex Crichton | 13418a5 | 2015-10-29 11:54:12 -0700 | [diff] [blame] | 46 | html_root_url = "https://doc.rust-lang.org/libc/x86_64-pc-windows-gnu" |
Alex Crichton | 730a17f | 2015-09-17 10:05:36 -0700 | [diff] [blame] | 47 | ))] |
Alex Crichton | 611e9a3 | 2015-09-17 10:06:19 -0700 | [diff] [blame] | 48 | #![cfg_attr(all(windows, target_arch = "x86", target_env = "gnu"), doc( |
Alex Crichton | 13418a5 | 2015-10-29 11:54:12 -0700 | [diff] [blame] | 49 | html_root_url = "https://doc.rust-lang.org/libc/i686-pc-windows-gnu" |
Alex Crichton | 730a17f | 2015-09-17 10:05:36 -0700 | [diff] [blame] | 50 | ))] |
| 51 | #![cfg_attr(all(windows, target_arch = "x86_64", target_env = "msvc"), doc( |
Alex Crichton | 13418a5 | 2015-10-29 11:54:12 -0700 | [diff] [blame] | 52 | html_root_url = "https://doc.rust-lang.org/libc/x86_64-pc-windows-msvc" |
Alex Crichton | 730a17f | 2015-09-17 10:05:36 -0700 | [diff] [blame] | 53 | ))] |
Alex Crichton | 611e9a3 | 2015-09-17 10:06:19 -0700 | [diff] [blame] | 54 | #![cfg_attr(all(windows, target_arch = "x86", target_env = "msvc"), doc( |
Alex Crichton | 13418a5 | 2015-10-29 11:54:12 -0700 | [diff] [blame] | 55 | html_root_url = "https://doc.rust-lang.org/libc/i686-pc-windows-msvc" |
Alex Crichton | 730a17f | 2015-09-17 10:05:36 -0700 | [diff] [blame] | 56 | ))] |
| 57 | #![cfg_attr(all(target_os = "android"), doc( |
Alex Crichton | 13418a5 | 2015-10-29 11:54:12 -0700 | [diff] [blame] | 58 | html_root_url = "https://doc.rust-lang.org/libc/arm-linux-androideabi" |
Alex Crichton | 730a17f | 2015-09-17 10:05:36 -0700 | [diff] [blame] | 59 | ))] |
Alex Crichton | dafaca9 | 2015-09-09 21:50:47 -0700 | [diff] [blame] | 60 | |
Alex Crichton | f7efe34 | 2015-11-02 14:26:04 -0800 | [diff] [blame] | 61 | // Attributes needed when building as part of the standard library |
| 62 | #![cfg_attr(stdbuild, feature(no_std, core, core_slice_ext, staged_api))] |
| 63 | #![cfg_attr(stdbuild, no_std)] |
| 64 | #![cfg_attr(stdbuild, staged_api)] |
Alex Crichton | 56f6104 | 2015-11-02 16:57:39 -0800 | [diff] [blame^] | 65 | #![cfg_attr(stdbuild, allow(warnings))] |
Alex Crichton | f7efe34 | 2015-11-02 14:26:04 -0800 | [diff] [blame] | 66 | #![cfg_attr(stdbuild, unstable(feature = "libc", |
| 67 | reason = "use `libc` from crates.io", |
| 68 | issue = "27783"))] |
| 69 | |
| 70 | #[cfg(all(not(stdbuild), not(dox)))] |
| 71 | extern crate std as core; |
| 72 | |
Alex Crichton | 5d6cf05 | 2015-09-11 14:52:34 -0700 | [diff] [blame] | 73 | #[macro_use] mod macros; |
Alex Crichton | 24abc4f | 2015-09-16 23:54:56 -0700 | [diff] [blame] | 74 | mod dox; |
Alex Crichton | 3150484 | 2015-09-10 23:43:41 -0700 | [diff] [blame] | 75 | |
Alex Crichton | d5c4e55 | 2015-10-29 15:46:16 -0700 | [diff] [blame] | 76 | // Use repr(u8) as LLVM expects `void*` to be the same as `i8*` to help enable |
| 77 | // more optimization opportunities around it recognizing things like |
| 78 | // malloc/free. |
Alex Crichton | 5d6cf05 | 2015-09-11 14:52:34 -0700 | [diff] [blame] | 79 | #[repr(u8)] |
| 80 | pub enum c_void { |
Alex Crichton | d5c4e55 | 2015-10-29 15:46:16 -0700 | [diff] [blame] | 81 | // Two dummy variants so the #[repr] attribute can be used. |
Alex Crichton | 9f2b101 | 2015-09-16 23:32:21 -0700 | [diff] [blame] | 82 | #[doc(hidden)] |
Alex Crichton | 5d6cf05 | 2015-09-11 14:52:34 -0700 | [diff] [blame] | 83 | __variant1, |
Alex Crichton | 9f2b101 | 2015-09-16 23:32:21 -0700 | [diff] [blame] | 84 | #[doc(hidden)] |
Alex Crichton | 5d6cf05 | 2015-09-11 14:52:34 -0700 | [diff] [blame] | 85 | __variant2, |
| 86 | } |
Alex Crichton | dafaca9 | 2015-09-09 21:50:47 -0700 | [diff] [blame] | 87 | |
Alex Crichton | 5d6cf05 | 2015-09-11 14:52:34 -0700 | [diff] [blame] | 88 | pub type int8_t = i8; |
| 89 | pub type int16_t = i16; |
| 90 | pub type int32_t = i32; |
| 91 | pub type int64_t = i64; |
| 92 | pub type uint8_t = u8; |
| 93 | pub type uint16_t = u16; |
| 94 | pub type uint32_t = u32; |
| 95 | pub type uint64_t = u64; |
Alex Crichton | dafaca9 | 2015-09-09 21:50:47 -0700 | [diff] [blame] | 96 | |
Alex Crichton | 1791046 | 2015-09-22 19:11:04 -0700 | [diff] [blame] | 97 | pub type c_schar = i8; |
| 98 | pub type c_uchar = u8; |
| 99 | pub type c_short = i16; |
| 100 | pub type c_ushort = u16; |
| 101 | pub type c_int = i32; |
| 102 | pub type c_uint = u32; |
| 103 | pub type c_float = f32; |
| 104 | pub type c_double = f64; |
| 105 | pub type c_longlong = i64; |
| 106 | pub type c_ulonglong = u64; |
| 107 | pub type intmax_t = i64; |
| 108 | pub type uintmax_t = u64; |
| 109 | |
| 110 | pub type size_t = usize; |
| 111 | pub type ptrdiff_t = isize; |
| 112 | pub type intptr_t = isize; |
| 113 | pub type uintptr_t = usize; |
| 114 | pub type ssize_t = isize; |
| 115 | |
Alex Crichton | 5d6cf05 | 2015-09-11 14:52:34 -0700 | [diff] [blame] | 116 | pub enum FILE {} |
Alex Crichton | 7482522 | 2015-10-29 17:36:55 -0700 | [diff] [blame] | 117 | pub enum fpos_t {} // TODO: fill this out with a struct |
Alex Crichton | dafaca9 | 2015-09-09 21:50:47 -0700 | [diff] [blame] | 118 | |
Alex Crichton | 5d6cf05 | 2015-09-11 14:52:34 -0700 | [diff] [blame] | 119 | extern { |
| 120 | pub fn isalnum(c: c_int) -> c_int; |
| 121 | pub fn isalpha(c: c_int) -> c_int; |
| 122 | pub fn iscntrl(c: c_int) -> c_int; |
| 123 | pub fn isdigit(c: c_int) -> c_int; |
| 124 | pub fn isgraph(c: c_int) -> c_int; |
| 125 | pub fn islower(c: c_int) -> c_int; |
| 126 | pub fn isprint(c: c_int) -> c_int; |
| 127 | pub fn ispunct(c: c_int) -> c_int; |
| 128 | pub fn isspace(c: c_int) -> c_int; |
| 129 | pub fn isupper(c: c_int) -> c_int; |
| 130 | pub fn isxdigit(c: c_int) -> c_int; |
| 131 | pub fn tolower(c: c_int) -> c_int; |
| 132 | pub fn toupper(c: c_int) -> c_int; |
Alex Crichton | dafaca9 | 2015-09-09 21:50:47 -0700 | [diff] [blame] | 133 | |
Alex Crichton | 5d6cf05 | 2015-09-11 14:52:34 -0700 | [diff] [blame] | 134 | #[cfg_attr(all(target_os = "macos", target_arch = "x86"), |
| 135 | link_name = "fopen$UNIX2003")] |
| 136 | pub fn fopen(filename: *const c_char, |
| 137 | mode: *const c_char) -> *mut FILE; |
| 138 | #[cfg_attr(all(target_os = "macos", target_arch = "x86"), |
| 139 | link_name = "freopen$UNIX2003")] |
| 140 | pub fn freopen(filename: *const c_char, mode: *const c_char, |
Alex Crichton | bfc6ebc | 2015-09-11 15:29:40 -0700 | [diff] [blame] | 141 | file: *mut FILE) -> *mut FILE; |
Alex Crichton | 5d6cf05 | 2015-09-11 14:52:34 -0700 | [diff] [blame] | 142 | pub fn fflush(file: *mut FILE) -> c_int; |
| 143 | pub fn fclose(file: *mut FILE) -> c_int; |
| 144 | pub fn remove(filename: *const c_char) -> c_int; |
Alex Crichton | bfc6ebc | 2015-09-11 15:29:40 -0700 | [diff] [blame] | 145 | pub fn rename(oldname: *const c_char, newname: *const c_char) -> c_int; |
Alex Crichton | 5d6cf05 | 2015-09-11 14:52:34 -0700 | [diff] [blame] | 146 | pub fn tmpfile() -> *mut FILE; |
| 147 | pub fn setvbuf(stream: *mut FILE, |
| 148 | buffer: *mut c_char, |
| 149 | mode: c_int, |
Alex Crichton | bfc6ebc | 2015-09-11 15:29:40 -0700 | [diff] [blame] | 150 | size: size_t) -> c_int; |
Alex Crichton | 5d6cf05 | 2015-09-11 14:52:34 -0700 | [diff] [blame] | 151 | pub fn setbuf(stream: *mut FILE, buf: *mut c_char); |
Alex Crichton | 5d6cf05 | 2015-09-11 14:52:34 -0700 | [diff] [blame] | 152 | pub fn fgetc(stream: *mut FILE) -> c_int; |
Alex Crichton | bfc6ebc | 2015-09-11 15:29:40 -0700 | [diff] [blame] | 153 | pub fn fgets(buf: *mut c_char, n: c_int, stream: *mut FILE) -> *mut c_char; |
Alex Crichton | 5d6cf05 | 2015-09-11 14:52:34 -0700 | [diff] [blame] | 154 | pub fn fputc(c: c_int, stream: *mut FILE) -> c_int; |
| 155 | #[cfg_attr(all(target_os = "macos", target_arch = "x86"), |
| 156 | link_name = "fputs$UNIX2003")] |
| 157 | pub fn fputs(s: *const c_char, stream: *mut FILE)-> c_int; |
| 158 | pub fn puts(s: *const c_char) -> c_int; |
| 159 | pub fn ungetc(c: c_int, stream: *mut FILE) -> c_int; |
| 160 | pub fn fread(ptr: *mut c_void, |
| 161 | size: size_t, |
| 162 | nobj: size_t, |
| 163 | stream: *mut FILE) |
| 164 | -> size_t; |
| 165 | #[cfg_attr(all(target_os = "macos", target_arch = "x86"), |
| 166 | link_name = "fwrite$UNIX2003")] |
| 167 | pub fn fwrite(ptr: *const c_void, |
| 168 | size: size_t, |
| 169 | nobj: size_t, |
| 170 | stream: *mut FILE) |
| 171 | -> size_t; |
Alex Crichton | bfc6ebc | 2015-09-11 15:29:40 -0700 | [diff] [blame] | 172 | pub fn fseek(stream: *mut FILE, offset: c_long, whence: c_int) -> c_int; |
Alex Crichton | 5d6cf05 | 2015-09-11 14:52:34 -0700 | [diff] [blame] | 173 | pub fn ftell(stream: *mut FILE) -> c_long; |
| 174 | pub fn rewind(stream: *mut FILE); |
| 175 | pub fn fgetpos(stream: *mut FILE, ptr: *mut fpos_t) -> c_int; |
| 176 | pub fn fsetpos(stream: *mut FILE, ptr: *const fpos_t) -> c_int; |
| 177 | pub fn feof(stream: *mut FILE) -> c_int; |
| 178 | pub fn ferror(stream: *mut FILE) -> c_int; |
| 179 | pub fn perror(s: *const c_char); |
Alex Crichton | 5d6cf05 | 2015-09-11 14:52:34 -0700 | [diff] [blame] | 180 | pub fn atoi(s: *const c_char) -> c_int; |
| 181 | #[cfg_attr(all(target_os = "macos", target_arch = "x86"), |
| 182 | link_name = "strtod$UNIX2003")] |
Alex Crichton | bfc6ebc | 2015-09-11 15:29:40 -0700 | [diff] [blame] | 183 | pub fn strtod(s: *const c_char, endp: *mut *mut c_char) -> c_double; |
Alex Crichton | 5d6cf05 | 2015-09-11 14:52:34 -0700 | [diff] [blame] | 184 | pub fn strtol(s: *const c_char, |
| 185 | endp: *mut *mut c_char, base: c_int) -> c_long; |
| 186 | pub fn strtoul(s: *const c_char, endp: *mut *mut c_char, |
| 187 | base: c_int) -> c_ulong; |
| 188 | pub fn calloc(nobj: size_t, size: size_t) -> *mut c_void; |
| 189 | pub fn malloc(size: size_t) -> *mut c_void; |
| 190 | pub fn realloc(p: *mut c_void, size: size_t) -> *mut c_void; |
| 191 | pub fn free(p: *mut c_void); |
| 192 | pub fn exit(status: c_int) -> !; |
| 193 | pub fn _exit(status: c_int) -> !; |
| 194 | pub fn atexit(cb: extern fn()) -> c_int; |
| 195 | #[cfg_attr(all(target_os = "macos", target_arch = "x86"), |
| 196 | link_name = "system$UNIX2003")] |
| 197 | pub fn system(s: *const c_char) -> c_int; |
| 198 | pub fn getenv(s: *const c_char) -> *mut c_char; |
Alex Crichton | dafaca9 | 2015-09-09 21:50:47 -0700 | [diff] [blame] | 199 | |
Alex Crichton | 5d6cf05 | 2015-09-11 14:52:34 -0700 | [diff] [blame] | 200 | pub fn strcpy(dst: *mut c_char, src: *const c_char) -> *mut c_char; |
| 201 | pub fn strncpy(dst: *mut c_char, src: *const c_char, n: size_t) |
| 202 | -> *mut c_char; |
| 203 | pub fn strcat(s: *mut c_char, ct: *const c_char) -> *mut c_char; |
| 204 | pub fn strncat(s: *mut c_char, ct: *const c_char, n: size_t) -> *mut c_char; |
| 205 | pub fn strcmp(cs: *const c_char, ct: *const c_char) -> c_int; |
| 206 | pub fn strncmp(cs: *const c_char, ct: *const c_char, n: size_t) -> c_int; |
| 207 | pub fn strcoll(cs: *const c_char, ct: *const c_char) -> c_int; |
| 208 | pub fn strchr(cs: *const c_char, c: c_int) -> *mut c_char; |
| 209 | pub fn strrchr(cs: *const c_char, c: c_int) -> *mut c_char; |
| 210 | pub fn strspn(cs: *const c_char, ct: *const c_char) -> size_t; |
| 211 | pub fn strcspn(cs: *const c_char, ct: *const c_char) -> size_t; |
| 212 | pub fn strpbrk(cs: *const c_char, ct: *const c_char) -> *mut c_char; |
| 213 | pub fn strstr(cs: *const c_char, ct: *const c_char) -> *mut c_char; |
| 214 | pub fn strlen(cs: *const c_char) -> size_t; |
| 215 | #[cfg_attr(all(target_os = "macos", target_arch = "x86"), |
| 216 | link_name = "strerror$UNIX2003")] |
| 217 | pub fn strerror(n: c_int) -> *mut c_char; |
| 218 | pub fn strtok(s: *mut c_char, t: *const c_char) -> *mut c_char; |
| 219 | pub fn strxfrm(s: *mut c_char, ct: *const c_char, n: size_t) -> size_t; |
| 220 | pub fn wcslen(buf: *const wchar_t) -> size_t; |
Alex Crichton | dafaca9 | 2015-09-09 21:50:47 -0700 | [diff] [blame] | 221 | |
Alex Crichton | 5d6cf05 | 2015-09-11 14:52:34 -0700 | [diff] [blame] | 222 | pub fn memcmp(cx: *const c_void, ct: *const c_void, n: size_t) -> c_int; |
| 223 | pub fn memchr(cx: *const c_void, c: c_int, n: size_t) -> *mut c_void; |
Alex Crichton | dafaca9 | 2015-09-09 21:50:47 -0700 | [diff] [blame] | 224 | } |
Alex Crichton | d3d7792 | 2015-09-11 17:03:39 -0700 | [diff] [blame] | 225 | |
Alex Crichton | d5c4e55 | 2015-10-29 15:46:16 -0700 | [diff] [blame] | 226 | // These are all inline functions on android, so they end up just being entirely |
| 227 | // missing on that platform. |
Alex Crichton | d3d7792 | 2015-09-11 17:03:39 -0700 | [diff] [blame] | 228 | #[cfg(not(target_os = "android"))] |
| 229 | extern { |
| 230 | pub fn abs(i: c_int) -> c_int; |
| 231 | pub fn atof(s: *const c_char) -> c_double; |
| 232 | pub fn labs(i: c_long) -> c_long; |
| 233 | pub fn rand() -> c_int; |
| 234 | pub fn srand(seed: c_uint); |
| 235 | } |
Alex Crichton | 50a42e2 | 2015-09-15 14:27:15 -0700 | [diff] [blame] | 236 | |
| 237 | cfg_if! { |
| 238 | if #[cfg(windows)] { |
| 239 | mod windows; |
| 240 | pub use windows::*; |
| 241 | } else { |
| 242 | mod unix; |
| 243 | pub use unix::*; |
| 244 | } |
| 245 | } |