diff options
| author | bors <bors@rust-lang.org> | 2016-10-02 17:33:34 -0700 |
|---|---|---|
| committer | GitHub <noreply@github.com> | 2016-10-02 17:33:34 -0700 |
| commit | 144af3e97aa30feba3d36a98ac04c0f1b2bc0bea (patch) | |
| tree | 16465fa1e28268c64ee631a0dc282564c151521c /src/test/run-pass/thinlto | |
| parent | 1cdc0fb11af12c04fb4b1984615f03b11a60decc (diff) | |
| parent | 4d76ac84922bec9ea790c1394f6959ad399d7aa1 (diff) | |
| download | rust-144af3e97aa30feba3d36a98ac04c0f1b2bc0bea.tar.gz rust-144af3e97aa30feba3d36a98ac04c0f1b2bc0bea.zip | |
Auto merge of #36807 - brson:pal, r=brson
Restrict where in the tree platform-specific cfgs may be mentioned With the ports of Rust never ending, it's important that we keep things tidy. The main thing this PR does is introduce a new "pal" (platform abstraction layer) tidy check that limits where platform-specific CFGs may appear. This is intended to maintain existing standards of code organization in hopes that the standard library will continue to be refactored to isolate platform-specific bits, making porting easier; where "standard library" roughly means "all the dependencies of the std and test crates". This generally means placing restrictions on where `cfg(unix)`, `cfg(windows)`, `cfg(target_os)` and `cfg(target_env)` may appear, the basic objective being to isolate platform-specific code to the platform-specific `std::sys` modules, and to the allocation, unwinding, and libc crates. Following are the basic rules, though there are currently exceptions: - core may not have platform-specific code - liballoc_system may have platform-specific code - liballoc_jemalloc may have platform-specific code - libpanic_abort may have platform-specific code - libpanic_unwind may have platform-specific code - other crates in the std facade may not - std may have platform-specific code in the following places - sys/unix/ - sys/windows/ - os/ There are plenty of exceptions today though, noted in the whitelist. The end-state, IMO, is for the standard library to be portable by porting only `std::sys` (possibly extracted to its own crate), an allocator crate, an unwinder crate, and possibly a libc crate (if std depends on it); but that outcome is far off and independent of the utility of enforcing where such code lives today. cc @rust-lang/libs
Diffstat (limited to 'src/test/run-pass/thinlto')
0 files changed, 0 insertions, 0 deletions
