Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Move universal libc types to the root #1244

Closed
wants to merge 6 commits into from
Closed
Show file tree
Hide file tree
Changes from all commits
Commits
File filter

Filter by extension

Filter by extension


Conversations
Failed to load comments.
Jump to
Jump to file
Failed to load files.
Diff view
Diff view
1 change: 1 addition & 0 deletions Cargo.toml
Expand Up @@ -28,6 +28,7 @@ use_std = []
align = []
rustc-dep-of-std = ['align', 'rustc-std-workspace-core']
extra_traits = ["align"]
generic_ctypes = []

[workspace]
members = ["libc-test"]
18 changes: 17 additions & 1 deletion README.md
Expand Up @@ -45,7 +45,7 @@ libc = { version = "0.2", features = ["align"] }
```

All structs implemented by the libc crate have the `Copy` and `Clone` traits
implemented for them. The additional traits of `Debug, `Eq`, `Hash`, and
implemented for them. The additional traits of `Debug`, `Eq`, `Hash`, and
`PartialEq` can be enabled with the *extra_traits* feature (requires Rust 1.25
or newer):

Expand All @@ -54,6 +54,22 @@ or newer):
libc = { version = "0.2", features = ["extra_traits"] }
```

A large number of targets are supported by libc; however, some unsupported or
custom targets just need libc's basic types (`c_int`, `size_t`, etc...) for
linking to C code. These types can be enabled for _any_ target with the
*generic_ctypes* feature:

```toml
[dependencies.libc]
version = "0.2"
default-features = false
features = ["generic_ctypes"]
```

Note that if you target has strange definitions for C types, *generic_ctypes*
will not necessarily generate the correct types, as the generation process is
based only on your CPU architecture and pointer size.

## What is libc?

The primary purpose of this crate is to provide all of the definitions necessary
Expand Down
240 changes: 108 additions & 132 deletions src/cloudabi/mod.rs
@@ -1,31 +1,16 @@
use dox::Option;

pub type int8_t = i8;
pub type int16_t = i16;
pub type int32_t = i32;
pub type int64_t = i64;
pub type uint8_t = u8;
pub type uint16_t = u16;
pub type uint32_t = u32;
pub type uint64_t = u64;

pub type c_schar = i8;
pub type c_uchar = u8;
pub type c_short = i16;
pub type c_ushort = u16;
pub type c_int = i32;
pub type c_uint = u32;
pub type c_float = f32;
pub type c_double = f64;
pub type c_longlong = i64;
pub type c_ulonglong = u64;
pub type intmax_t = i64;
pub type uintmax_t = u64;

pub type size_t = usize;
pub type ptrdiff_t = isize;
pub type intptr_t = isize;
pub type uintptr_t = usize;
pub type ssize_t = isize;

pub type in_addr_t = u32;
Expand Down Expand Up @@ -136,116 +121,126 @@ impl ::dox::Clone for fpos_t {
}

extern {
pub fn isalnum(c: c_int) -> c_int;
pub fn isalpha(c: c_int) -> c_int;
pub fn iscntrl(c: c_int) -> c_int;
pub fn isdigit(c: c_int) -> c_int;
pub fn isgraph(c: c_int) -> c_int;
pub fn islower(c: c_int) -> c_int;
pub fn isprint(c: c_int) -> c_int;
pub fn ispunct(c: c_int) -> c_int;
pub fn isspace(c: c_int) -> c_int;
pub fn isupper(c: c_int) -> c_int;
pub fn isxdigit(c: c_int) -> c_int;
pub fn tolower(c: c_int) -> c_int;
pub fn toupper(c: c_int) -> c_int;
pub fn fopen(filename: *const c_char, mode: *const c_char) -> *mut FILE;
pub fn freopen(filename: *const c_char, mode: *const c_char,
pub fn isalnum(c: ::c_int) -> ::c_int;
pub fn isalpha(c: ::c_int) -> ::c_int;
pub fn iscntrl(c: ::c_int) -> ::c_int;
pub fn isdigit(c: ::c_int) -> ::c_int;
pub fn isgraph(c: ::c_int) -> ::c_int;
pub fn islower(c: ::c_int) -> ::c_int;
pub fn isprint(c: ::c_int) -> ::c_int;
pub fn ispunct(c: ::c_int) -> ::c_int;
pub fn isspace(c: ::c_int) -> ::c_int;
pub fn isupper(c: ::c_int) -> ::c_int;
pub fn isxdigit(c: ::c_int) -> ::c_int;
pub fn tolower(c: ::c_int) -> ::c_int;
pub fn toupper(c: ::c_int) -> ::c_int;
pub fn fopen(filename: *const ::c_char,
mode: *const ::c_char) -> *mut FILE;
pub fn freopen(filename: *const ::c_char, mode: *const ::c_char,
file: *mut FILE) -> *mut FILE;
pub fn fflush(file: *mut FILE) -> c_int;
pub fn fclose(file: *mut FILE) -> c_int;
pub fn remove(filename: *const c_char) -> c_int;
pub fn rename(oldname: *const c_char, newname: *const c_char) -> c_int;
pub fn fflush(file: *mut FILE) -> ::c_int;
pub fn fclose(file: *mut FILE) -> ::c_int;
pub fn remove(filename: *const ::c_char) -> ::c_int;
pub fn rename(oldname: *const ::c_char,
newname: *const ::c_char) -> ::c_int;
pub fn tmpfile() -> *mut FILE;
pub fn setvbuf(stream: *mut FILE, buffer: *mut c_char, mode: c_int,
size: size_t) -> c_int;
pub fn setbuf(stream: *mut FILE, buf: *mut c_char);
pub fn getchar() -> c_int;
pub fn putchar(c: c_int) -> c_int;
pub fn fgetc(stream: *mut FILE) -> c_int;
pub fn fgets(buf: *mut c_char, n: c_int, stream: *mut FILE) -> *mut c_char;
pub fn fputc(c: c_int, stream: *mut FILE) -> c_int;
pub fn fputs(s: *const c_char, stream: *mut FILE) -> c_int;
pub fn puts(s: *const c_char) -> c_int;
pub fn ungetc(c: c_int, stream: *mut FILE) -> c_int;
pub fn fread(ptr: *mut c_void, size: size_t, nobj: size_t,
stream: *mut FILE) -> size_t;
pub fn fwrite(ptr: *const c_void, size: size_t, nobj: size_t,
stream: *mut FILE) -> size_t;
pub fn fseek(stream: *mut FILE, offset: c_long, whence: c_int) -> c_int;
pub fn ftell(stream: *mut FILE) -> c_long;
pub fn setvbuf(stream: *mut FILE, buffer: *mut ::c_char, mode: ::c_int,
size: ::size_t) -> ::c_int;
pub fn setbuf(stream: *mut FILE, buf: *mut ::c_char);
pub fn getchar() -> ::c_int;
pub fn putchar(c: ::c_int) -> ::c_int;
pub fn fgetc(stream: *mut FILE) -> ::c_int;
pub fn fgets(buf: *mut ::c_char, n: ::c_int,
stream: *mut FILE) -> *mut ::c_char;
pub fn fputc(c: ::c_int, stream: *mut FILE) -> ::c_int;
pub fn fputs(s: *const ::c_char, stream: *mut FILE) -> ::c_int;
pub fn puts(s: *const ::c_char) -> ::c_int;
pub fn ungetc(c: ::c_int, stream: *mut FILE) -> ::c_int;
pub fn fread(ptr: *mut ::c_void, size: ::size_t, nobj: ::size_t,
stream: *mut FILE) -> ::size_t;
pub fn fwrite(ptr: *const ::c_void, size: ::size_t, nobj: ::size_t,
stream: *mut FILE) -> ::size_t;
pub fn fseek(stream: *mut FILE, offset: ::c_long,
whence: ::c_int) -> ::c_int;
pub fn ftell(stream: *mut FILE) -> ::c_long;
pub fn rewind(stream: *mut FILE);
pub fn fgetpos(stream: *mut FILE, ptr: *mut fpos_t) -> c_int;
pub fn fsetpos(stream: *mut FILE, ptr: *const fpos_t) -> c_int;
pub fn feof(stream: *mut FILE) -> c_int;
pub fn ferror(stream: *mut FILE) -> c_int;
pub fn perror(s: *const c_char);
pub fn atoi(s: *const c_char) -> c_int;
pub fn strtod(s: *const c_char, endp: *mut *mut c_char) -> c_double;
pub fn strtol(s: *const c_char, endp: *mut *mut c_char,
base: c_int) -> c_long;
pub fn strtoul(s: *const c_char, endp: *mut *mut c_char,
base: c_int) -> c_ulong;
pub fn calloc(nobj: size_t, size: size_t) -> *mut c_void;
pub fn malloc(size: size_t) -> *mut c_void;
pub fn realloc(p: *mut c_void, size: size_t) -> *mut c_void;
pub fn free(p: *mut c_void);
pub fn fgetpos(stream: *mut FILE, ptr: *mut fpos_t) -> ::c_int;
pub fn fsetpos(stream: *mut FILE, ptr: *const fpos_t) -> ::c_int;
pub fn feof(stream: *mut FILE) -> ::c_int;
pub fn ferror(stream: *mut FILE) -> ::c_int;
pub fn perror(s: *const ::c_char);
pub fn atoi(s: *const ::c_char) -> ::c_int;
pub fn strtod(s: *const ::c_char, endp: *mut *mut ::c_char) -> ::c_double;
pub fn strtol(s: *const ::c_char, endp: *mut *mut ::c_char,
base: ::c_int) -> ::c_long;
pub fn strtoul(s: *const ::c_char, endp: *mut *mut ::c_char,
base: ::c_int) -> ::c_ulong;
pub fn calloc(nobj: ::size_t, size: ::size_t) -> *mut ::c_void;
pub fn malloc(size: ::size_t) -> *mut ::c_void;
pub fn realloc(p: *mut ::c_void, size: ::size_t) -> *mut ::c_void;
pub fn free(p: *mut ::c_void);
pub fn abort() -> !;
pub fn exit(status: c_int) -> !;
pub fn _exit(status: c_int) -> !;
pub fn atexit(cb: extern fn()) -> c_int;
pub fn system(s: *const c_char) -> c_int;
pub fn getenv(s: *const c_char) -> *mut c_char;
pub fn getline (lineptr: *mut *mut c_char, n: *mut size_t,
stream: *mut FILE) -> ssize_t;
pub fn exit(status: ::c_int) -> !;
pub fn _exit(status: ::c_int) -> !;
pub fn atexit(cb: extern fn()) -> ::c_int;
pub fn system(s: *const ::c_char) -> ::c_int;
pub fn getenv(s: *const ::c_char) -> *mut ::c_char;
pub fn getline (lineptr: *mut *mut ::c_char, n: *mut ::size_t,
stream: *mut FILE) -> ::ssize_t;

pub fn strcpy(dst: *mut c_char, src: *const c_char) -> *mut c_char;
pub fn strncpy(dst: *mut c_char, src: *const c_char,
n: size_t) -> *mut c_char;
pub fn strcat(s: *mut c_char, ct: *const c_char) -> *mut c_char;
pub fn strncat(s: *mut c_char, ct: *const c_char, n: size_t) -> *mut c_char;
pub fn strcmp(cs: *const c_char, ct: *const c_char) -> c_int;
pub fn strncmp(cs: *const c_char, ct: *const c_char, n: size_t) -> c_int;
pub fn strcoll(cs: *const c_char, ct: *const c_char) -> c_int;
pub fn strchr(cs: *const c_char, c: c_int) -> *mut c_char;
pub fn strrchr(cs: *const c_char, c: c_int) -> *mut c_char;
pub fn strspn(cs: *const c_char, ct: *const c_char) -> size_t;
pub fn strcspn(cs: *const c_char, ct: *const c_char) -> size_t;
pub fn strdup(cs: *const c_char) -> *mut c_char;
pub fn strpbrk(cs: *const c_char, ct: *const c_char) -> *mut c_char;
pub fn strstr(cs: *const c_char, ct: *const c_char) -> *mut c_char;
pub fn strcasecmp(s1: *const c_char, s2: *const c_char) -> c_int;
pub fn strncasecmp(s1: *const c_char, s2: *const c_char,
n: size_t) -> c_int;
pub fn strlen(cs: *const c_char) -> size_t;
pub fn strnlen(cs: *const c_char, maxlen: size_t) -> size_t;
pub fn strerror(n: c_int) -> *mut c_char;
pub fn strtok(s: *mut c_char, t: *const c_char) -> *mut c_char;
pub fn strxfrm(s: *mut c_char, ct: *const c_char, n: size_t) -> size_t;
pub fn wcslen(buf: *const wchar_t) -> size_t;
pub fn wcstombs(dest: *mut c_char, src: *const wchar_t,
n: size_t) -> ::size_t;
pub fn strcpy(dst: *mut ::c_char, src: *const ::c_char) -> *mut ::c_char;
pub fn strncpy(dst: *mut ::c_char, src: *const ::c_char,
n: ::size_t) -> *mut ::c_char;
pub fn strcat(s: *mut ::c_char, ct: *const ::c_char) -> *mut ::c_char;
pub fn strncat(s: *mut ::c_char, ct: *const ::c_char,
n: ::size_t) -> *mut ::c_char;
pub fn strcmp(cs: *const ::c_char, ct: *const ::c_char) -> ::c_int;
pub fn strncmp(cs: *const ::c_char, ct: *const ::c_char,
n: ::size_t) -> ::c_int;
pub fn strcoll(cs: *const ::c_char, ct: *const ::c_char) -> ::c_int;
pub fn strchr(cs: *const ::c_char, c: ::c_int) -> *mut ::c_char;
pub fn strrchr(cs: *const ::c_char, c: ::c_int) -> *mut ::c_char;
pub fn strspn(cs: *const ::c_char, ct: *const ::c_char) -> ::size_t;
pub fn strcspn(cs: *const ::c_char, ct: *const ::c_char) -> ::size_t;
pub fn strdup(cs: *const ::c_char) -> *mut ::c_char;
pub fn strpbrk(cs: *const ::c_char, ct: *const ::c_char) -> *mut ::c_char;
pub fn strstr(cs: *const ::c_char, ct: *const ::c_char) -> *mut ::c_char;
pub fn strcasecmp(s1: *const ::c_char, s2: *const ::c_char) -> ::c_int;
pub fn strncasecmp(s1: *const ::c_char, s2: *const ::c_char,
n: ::size_t) -> ::c_int;
pub fn strlen(cs: *const ::c_char) -> ::size_t;
pub fn strnlen(cs: *const ::c_char, maxlen: ::size_t) -> ::size_t;
pub fn strerror(n: ::c_int) -> *mut ::c_char;
pub fn strtok(s: *mut ::c_char, t: *const ::c_char) -> *mut ::c_char;
pub fn strxfrm(s: *mut ::c_char, ct: *const ::c_char,
n: ::size_t) -> ::size_t;
pub fn wcslen(buf: *const wchar_t) -> ::size_t;
pub fn wcstombs(dest: *mut ::c_char, src: *const wchar_t,
n: ::size_t) -> ::size_t;

pub fn memchr(cx: *const c_void, c: c_int, n: size_t) -> *mut c_void;
pub fn memcmp(cx: *const c_void, ct: *const c_void, n: size_t) -> c_int;
pub fn memcpy(dest: *mut c_void, src: *const c_void,
n: size_t) -> *mut c_void;
pub fn memmove(dest: *mut c_void, src: *const c_void,
n: size_t) -> *mut c_void;
pub fn memset(dest: *mut c_void, c: c_int, n: size_t) -> *mut c_void;
pub fn memchr(cx: *const ::c_void, c: ::c_int,
n: ::size_t) -> *mut ::c_void;
pub fn memcmp(cx: *const ::c_void, ct: *const ::c_void,
n: ::size_t) -> ::c_int;
pub fn memcpy(dest: *mut ::c_void, src: *const ::c_void,
n: ::size_t) -> *mut ::c_void;
pub fn memmove(dest: *mut ::c_void, src: *const ::c_void,
n: ::size_t) -> *mut ::c_void;
pub fn memset(dest: *mut ::c_void, c: ::c_int,
n: ::size_t) -> *mut ::c_void;

pub fn abs(i: c_int) -> c_int;
pub fn atof(s: *const c_char) -> c_double;
pub fn labs(i: c_long) -> c_long;
pub fn rand() -> c_int;
pub fn srand(seed: c_uint);
pub fn abs(i: ::c_int) -> ::c_int;
pub fn atof(s: *const ::c_char) -> ::c_double;
pub fn labs(i: ::c_long) -> ::c_long;
pub fn rand() -> ::c_int;
pub fn srand(seed: ::c_uint);

pub fn arc4random_buf(buf: *const ::c_void, len: ::size_t);
pub fn freeaddrinfo(res: *mut addrinfo);
pub fn gai_strerror(errcode: ::c_int) -> *const ::c_char;
pub fn getaddrinfo(
node: *const c_char,
service: *const c_char,
node: *const ::c_char,
service: *const ::c_char,
hints: *const addrinfo,
res: *mut *mut addrinfo,
) -> ::c_int;
Expand Down Expand Up @@ -314,22 +309,3 @@ cfg_if! {
// Unknown target_arch
}
}

cfg_if! {
if #[cfg(core_cvoid)] {
pub use core::ffi::c_void;
} else {
// Use repr(u8) as LLVM expects `void*` to be the same as `i8*` to help
// enable more optimization opportunities around it recognizing things
// like malloc/free.
#[repr(u8)]
#[allow(missing_copy_implementations)]
pub enum c_void {
// Two dummy variants so the #[repr] attribute can be used.
#[doc(hidden)]
__variant1,
#[doc(hidden)]
__variant2,
}
}
}