2015-01-13 16:53:42 +01:00
|
|
|
libc
|
|
|
|
====
|
|
|
|
|
2018-11-22 19:05:49 +01:00
|
|
|
Raw FFI bindings to platform libraries like `libc`.
|
2015-01-13 16:53:42 +01:00
|
|
|
|
2016-02-11 18:33:17 +01:00
|
|
|
[![Build Status](https://travis-ci.org/rust-lang/libc.svg?branch=master)](https://travis-ci.org/rust-lang/libc)
|
2016-11-26 19:49:49 +01:00
|
|
|
[![Build status](https://ci.appveyor.com/api/projects/status/github/rust-lang/libc?svg=true)](https://ci.appveyor.com/project/rust-lang-libs/libc)
|
2019-01-02 03:26:36 +01:00
|
|
|
[![Build Status](https://api.cirrus-ci.com/github/rust-lang/libc.svg)](https://cirrus-ci.com/github/rust-lang/libc)
|
2018-07-01 06:48:41 +02:00
|
|
|
[![Latest version](https://img.shields.io/crates/v/libc.svg)](https://crates.io/crates/libc)
|
|
|
|
[![Documentation](https://docs.rs/libc/badge.svg)](https://docs.rs/libc)
|
|
|
|
![License](https://img.shields.io/crates/l/libc.svg)
|
2015-01-13 16:53:42 +01:00
|
|
|
|
2015-10-29 19:54:12 +01:00
|
|
|
## Usage
|
|
|
|
|
|
|
|
First, add the following to your `Cargo.toml`:
|
|
|
|
|
|
|
|
```toml
|
|
|
|
[dependencies]
|
2015-11-03 22:23:16 +01:00
|
|
|
libc = "0.2"
|
2015-10-29 19:54:12 +01:00
|
|
|
```
|
|
|
|
|
|
|
|
Next, add this to your crate root:
|
|
|
|
|
|
|
|
```rust
|
|
|
|
extern crate libc;
|
|
|
|
```
|
|
|
|
|
2016-01-21 01:39:37 +01:00
|
|
|
Currently libc by default links to the standard library, but if you would
|
|
|
|
instead like to use libc in a `#![no_std]` situation or crate you can request
|
|
|
|
this via:
|
|
|
|
|
|
|
|
```toml
|
|
|
|
[dependencies]
|
|
|
|
libc = { version = "0.2", default-features = false }
|
|
|
|
```
|
|
|
|
|
2018-07-30 16:57:55 +02:00
|
|
|
By default libc uses private fields in structs in order to enforce a certain
|
|
|
|
memory alignment on them. These structs can be hard to instantiate outside of
|
|
|
|
libc. To make libc use `#[repr(align(x))]`, instead of the private fields,
|
|
|
|
activate the *align* feature. This requires Rust 1.25 or newer:
|
|
|
|
|
|
|
|
```toml
|
|
|
|
[dependencies]
|
|
|
|
libc = { version = "0.2", features = ["align"] }
|
|
|
|
```
|
|
|
|
|
2015-10-29 19:54:12 +01:00
|
|
|
## What is libc?
|
|
|
|
|
|
|
|
The primary purpose of this crate is to provide all of the definitions necessary
|
|
|
|
to easily interoperate with C code (or "C-like" code) on each of the platforms
|
|
|
|
that Rust supports. This includes type definitions (e.g. `c_int`), constants
|
|
|
|
(e.g. `EINVAL`) as well as function headers (e.g. `malloc`).
|
|
|
|
|
|
|
|
This crate does not strive to have any form of compatibility across platforms,
|
|
|
|
but rather it is simply a straight binding to the system libraries on the
|
|
|
|
platform in question.
|
|
|
|
|
|
|
|
## Public API
|
|
|
|
|
|
|
|
This crate exports all underlying platform types, functions, and constants under
|
|
|
|
the crate root, so all items are accessible as `libc::foo`. The types and values
|
|
|
|
of all the exported APIs match the platform that libc is compiled for.
|
|
|
|
|
2015-10-29 20:28:25 +01:00
|
|
|
More detailed information about the design of this library can be found in its
|
|
|
|
[associated RFC][rfc].
|
|
|
|
|
|
|
|
[rfc]: https://github.com/rust-lang/rfcs/blob/master/text/1291-promote-libc.md
|
|
|
|
|
2015-10-29 19:54:12 +01:00
|
|
|
## Adding an API
|
|
|
|
|
|
|
|
Want to use an API which currently isn't bound in `libc`? It's quite easy to add
|
|
|
|
one!
|
|
|
|
|
|
|
|
The internal structure of this crate is designed to minimize the number of
|
|
|
|
`#[cfg]` attributes in order to easily be able to add new items which apply
|
|
|
|
to all platforms in the future. As a result, the crate is organized
|
|
|
|
hierarchically based on platform. Each module has a number of `#[cfg]`'d
|
|
|
|
children, but only one is ever actually compiled. Each module then reexports all
|
|
|
|
the contents of its children.
|
|
|
|
|
|
|
|
This means that for each platform that libc supports, the path from a
|
|
|
|
leaf module to the root will contain all bindings for the platform in question.
|
|
|
|
Consequently, this indicates where an API should be added! Adding an API at a
|
|
|
|
particular level in the hierarchy means that it is supported on all the child
|
|
|
|
platforms of that level. For example, when adding a Unix API it should be added
|
|
|
|
to `src/unix/mod.rs`, but when adding a Linux-only API it should be added to
|
|
|
|
`src/unix/notbsd/linux/mod.rs`.
|
|
|
|
|
|
|
|
If you're not 100% sure at what level of the hierarchy an API should be added
|
|
|
|
at, fear not! This crate has CI support which tests any binding against all
|
|
|
|
platforms supported, so you'll see failures if an API is added at the wrong
|
|
|
|
level or has different signatures across platforms.
|
|
|
|
|
2015-10-29 19:57:29 +01:00
|
|
|
With that in mind, the steps for adding a new API are:
|
|
|
|
|
|
|
|
1. Determine where in the module hierarchy your API should be added.
|
|
|
|
2. Add the API.
|
|
|
|
3. Send a PR to this repo.
|
|
|
|
4. Wait for CI to pass, fixing errors.
|
|
|
|
5. Wait for a merge!
|
|
|
|
|
2016-04-11 04:47:43 +02:00
|
|
|
### Test before you commit
|
|
|
|
|
|
|
|
We have two automated tests running on [Travis](https://travis-ci.org/rust-lang/libc):
|
|
|
|
|
|
|
|
1. [`libc-test`](https://github.com/alexcrichton/ctest)
|
2017-08-10 19:33:19 +02:00
|
|
|
- `cd libc-test && cargo test`
|
2016-04-11 04:47:43 +02:00
|
|
|
- Use the `skip_*()` functions in `build.rs` if you really need a workaround.
|
|
|
|
2. Style checker
|
|
|
|
- `rustc ci/style.rs && ./style src`
|
|
|
|
|
2017-04-27 00:44:19 +02:00
|
|
|
### Releasing your change to crates.io
|
|
|
|
|
|
|
|
Now that you've done the amazing job of landing your new API or your new
|
|
|
|
platform in this crate, the next step is to get that sweet, sweet usage from
|
|
|
|
crates.io! The only next step is to bump the version of libc and then publish
|
|
|
|
it. If you'd like to get a release out ASAP you can follow these steps:
|
|
|
|
|
|
|
|
1. Update the version number in `Cargo.toml`, you'll just be bumping the patch
|
|
|
|
version number.
|
|
|
|
2. Run `cargo update` to regenerate the lockfile to encode your version bump in
|
|
|
|
the lock file. You may pull in some other updated dependencies, that's ok.
|
|
|
|
3. Send a PR to this repository. It should [look like this][example], but it'd
|
|
|
|
also be nice to fill out the description with a small rationale for the
|
|
|
|
release (any rationale is ok though!)
|
|
|
|
4. Once merged the release will be tagged and published by one of the libc crate
|
|
|
|
maintainers.
|
|
|
|
|
|
|
|
[example]: https://github.com/rust-lang/libc/pull/583
|
|
|
|
|
2015-10-29 19:54:12 +01:00
|
|
|
## Platforms and Documentation
|
|
|
|
|
|
|
|
The following platforms are currently tested and have documentation available:
|
2015-09-19 00:01:16 +02:00
|
|
|
|
|
|
|
Tested:
|
2018-04-21 21:56:52 +02:00
|
|
|
* [`i686-pc-windows-msvc`](https://rust-lang.github.io/libc/i686-pc-windows-msvc/libc/)
|
|
|
|
* [`x86_64-pc-windows-msvc`](https://rust-lang.github.io/libc/x86_64-pc-windows-msvc/libc/)
|
2015-10-29 19:56:13 +01:00
|
|
|
(Windows)
|
2018-04-21 21:56:52 +02:00
|
|
|
* [`i686-pc-windows-gnu`](https://rust-lang.github.io/libc/i686-pc-windows-gnu/libc/)
|
|
|
|
* [`x86_64-pc-windows-gnu`](https://rust-lang.github.io/libc/x86_64-pc-windows-gnu/libc/)
|
|
|
|
* [`i686-apple-darwin`](https://rust-lang.github.io/libc/i686-apple-darwin/libc/)
|
|
|
|
* [`x86_64-apple-darwin`](https://rust-lang.github.io/libc/x86_64-apple-darwin/libc/)
|
2015-10-29 19:56:13 +01:00
|
|
|
(OSX)
|
2017-01-18 02:38:37 +01:00
|
|
|
* `i386-apple-ios`
|
2016-04-02 06:34:09 +02:00
|
|
|
* `x86_64-apple-ios`
|
2018-04-21 21:56:52 +02:00
|
|
|
* [`i686-unknown-linux-gnu`](https://rust-lang.github.io/libc/i686-unknown-linux-gnu/libc/)
|
|
|
|
* [`x86_64-unknown-linux-gnu`](https://rust-lang.github.io/libc/x86_64-unknown-linux-gnu/libc/)
|
2015-10-29 19:56:13 +01:00
|
|
|
(Linux)
|
2018-04-21 21:56:52 +02:00
|
|
|
* [`x86_64-unknown-linux-musl`](https://rust-lang.github.io/libc/x86_64-unknown-linux-musl/libc/)
|
2015-10-29 19:56:13 +01:00
|
|
|
(Linux MUSL)
|
2018-04-21 21:56:52 +02:00
|
|
|
* [`aarch64-unknown-linux-gnu`](https://rust-lang.github.io/libc/aarch64-unknown-linux-gnu/libc/)
|
2017-09-25 19:22:04 +02:00
|
|
|
(Linux)
|
2018-03-10 13:10:50 +01:00
|
|
|
* `aarch64-unknown-linux-musl`
|
2017-09-25 19:22:04 +02:00
|
|
|
(Linux MUSL)
|
2018-04-21 21:56:52 +02:00
|
|
|
* [`sparc64-unknown-linux-gnu`](https://rust-lang.github.io/libc/sparc64-unknown-linux-gnu/libc/)
|
2018-03-10 13:10:50 +01:00
|
|
|
(Linux)
|
2018-04-21 21:56:52 +02:00
|
|
|
* [`mips-unknown-linux-gnu`](https://rust-lang.github.io/libc/mips-unknown-linux-gnu/libc/)
|
|
|
|
* [`arm-unknown-linux-gnueabihf`](https://rust-lang.github.io/libc/arm-unknown-linux-gnueabihf/libc/)
|
|
|
|
* [`arm-linux-androideabi`](https://rust-lang.github.io/libc/arm-linux-androideabi/libc/)
|
2015-10-29 19:56:13 +01:00
|
|
|
(Android)
|
2018-04-21 21:56:52 +02:00
|
|
|
* [`x86_64-unknown-freebsd`](https://rust-lang.github.io/libc/x86_64-unknown-freebsd/libc/)
|
|
|
|
* [`x86_64-unknown-openbsd`](https://rust-lang.github.io/libc/x86_64-unknown-openbsd/libc/)
|
|
|
|
* [`x86_64-rumprun-netbsd`](https://rust-lang.github.io/libc/x86_64-unknown-netbsd/libc/)
|
2015-10-29 19:54:12 +01:00
|
|
|
|
|
|
|
The following may be supported, but are not guaranteed to always work:
|
|
|
|
|
|
|
|
* `i686-unknown-freebsd`
|
2018-04-21 21:56:52 +02:00
|
|
|
* [`x86_64-unknown-bitrig`](https://rust-lang.github.io/libc/x86_64-unknown-bitrig/libc/)
|
|
|
|
* [`x86_64-unknown-dragonfly`](https://rust-lang.github.io/libc/x86_64-unknown-dragonfly/libc/)
|
2016-02-02 21:21:36 +01:00
|
|
|
* `i686-unknown-haiku`
|
|
|
|
* `x86_64-unknown-haiku`
|
2018-04-21 21:56:52 +02:00
|
|
|
* [`x86_64-unknown-netbsd`](https://rust-lang.github.io/libc/x86_64-unknown-netbsd/libc/)
|
|
|
|
* [`x86_64-sun-solaris`](https://rust-lang.github.io/libc/x86_64-sun-solaris/libc/)
|