[![Crates.io](https://img.shields.io/crates/v/interprocess)](https://crates.io/crates/interprocess "Interprocess on Crates.io") [![Docs.rs](https://img.shields.io/badge/documentation-docs.rs-informational)](https://docs.rs/interprocess "interprocess on Docs.rs") [![Build status](https://github.com/kotauskas/interprocess/actions/workflows/checks_and_tests.yml/badge.svg)](https://github.com/kotauskas/interprocess/actions/workflows/checks_and_tests.yml) ![maintenance-status](https://img.shields.io/badge/maintenance-actively%20developed-brightgreen) [![Rust version: 1.75+](https://img.shields.io/badge/rust%20version-1.75+-orange)][blogpost] Interprocess communication toolkit for Rust programs that aims to expose as many platform-specific features as possible while maintaining a uniform interface for all platforms and encouraging portable, correct code. ## Interprocess communication primitives Interprocess provides both OS-specific IPC interfaces and cross-platform abstractions for them. ##### Cross-platform IPC APIs - **Local sockets** – similar to TCP sockets, but use filesystem or namespaced paths instead of ports on `localhost`, depending on the OS, bypassing the network stack entirely; implemented using named pipes on Windows and Unix domain sockets on Unix ##### Platform-specific, but present on both Unix-like systems and Windows - **Unnamed pipes** – anonymous file-like objects for communicating privately in one direction, most commonly used to communicate between a child process and its parent ##### Unix-only - **FIFO files** – special type of file which is similar to unnamed pipes but exists on the filesystem, often referred to as "named pipes" but completely different from Windows named pipes - *Unix domain sockets* – Interprocess no longer provides those, as they are present in the standard library; they are, however, exposed as local sockets ##### Windows-only - **Named pipes** – resemble Unix domain sockets, use a separate namespace instead of on-drive paths ## Asynchronous I/O Currently, only Tokio for local sockets, Unix domain sockets and Windows named pipes is supported. Support for `async-std` is planned. ## Platform support Interprocess supports Windows and all generic Unix-like systems. Additionally, platform-specific extensions are supported on select systems. The policy with those extensions is to put them behind `#[cfg]` gates and only expose on the supporting platforms, producing compile errors instead of runtime errors on platforms that have no support for those features. Four levels of support (not called *tiers* to prevent confusion with Rust target tiers, since those work completely differently) are provided by Interprocess. It would be a breaking change for a platform to be demoted, although promotions quite obviously can happen as minor or patch releases. ##### Explicit support *OSes at this level: **Windows**, **Linux**, **macOS*** - Interprocess is guaranteed to compile and succeed in running all tests – it would be a critical bug for it not to - CI, currently provided by GitHub Actions, runs on all of those platforms and displays an ugly red badge if anything is wrong on any of those systems - Certain `#[cfg]`-gated platform-specific features are supported with stable public APIs ##### Explicit support with incomplete CI *OSes at this level: **FreeBSD**, **Android*** - Interprocess is expected to compile and succeed in running all tests – it would be a bug for it not to - GitHub Actions only allows Clippy and Rustdoc to be run for those targets in CI (via cross-compilation) due to a lack of native VMs - Certain `#[cfg]`-gated platform-specific features are supported with stable public APIs ##### Explicit support without CI *OSes at this level: currently none* - Interprocess is expected to compile and succeed in running all tests – it would be a bug for it not to - Manual testing on local VMs is usually done before every release; no CI happens because those targets' standard library `.rlib`s cannot be installed via `rustup target add` - Certain `#[cfg]`-gated platform-specific features are supported with stable public APIs ##### Support by association *OSes at this level: **Dragonfly BSD**, **OpenBSD**, **NetBSD**, **Redox**, **Android**, **Fuchsia**, **iOS**, **tvOS**, **watchOS*** - Interprocess is expected to compile and succeed in running all tests – it would be a bug for it not to - No manual testing is performed, and CI is unavailable because GitHub Actions does not provide it - Certain `#[cfg]`-gated platform-specific features that originate from other platforms are supported with stable public APIs because they behave here identically to how they do on an OS with a higher support level ##### Assumed support *OSes at this level: POSIX-conformant `#[cfg(unix)]` systems not listed above for which the `libc` crate compiles* - Interprocess is expected to compile and succeed in running all tests – it would be a bug for it not to - Because this level encompasses a practically infinite amount of systems, no manual testing or CI can exist ## Feature gates - **`tokio`**, *off* by default – enables support for Tokio-powered efficient asynchronous IPC. ## License This crate, along with all community contributions made to it, is dual-licensed under [MIT] and [Apache 2.0]. [MIT]: https://choosealicense.com/licenses/mit/ [Apache 2.0]: https://choosealicense.com/licenses/apache-2.0/ [blogpost]: https://blog.rust-lang.org/2023/12/28/Rust-1.75.0.html