Home

Awesome

Fruity

<img alt="github" src="https://img.shields.io/badge/github-nvzqz/fruity-8da0cb?style=for-the-badge&labelColor=555555&logo=github" height="24"> <img alt="crates.io" src="https://img.shields.io/crates/v/fruity.svg?style=for-the-badge&color=fc8d62&logo=rust" height="24"> <img alt="docs.rs" src="https://img.shields.io/badge/docs.rs-fruity-66c2a5?style=for-the-badge&labelColor=555555&logoColor=white&logo=" height="24">

Rusty bindings for Apple libraries, brought to you by @NikolaiVazquez.

Index

  1. Donate
  2. Usage
    1. Feature Flags
  3. Goals
    1. Idiomatic Rust
    2. Zero Cost
  4. License

Donate

If this project is useful to you, consider sponsoring me or donating directly!

Doing so enables me to create high-quality open source software like this. ❤️

Usage

This library is available on crates.io and can be used in your project by adding the following to your project's Cargo.toml:

[dependencies.fruity]
version = "0.3.0"

Feature Flags

Each module for a library or framework has its own feature flag with the same name.

For example, this is how you enable the foundation module:

[dependencies.fruity]
version = "0.3.0"
features = ["foundation"]

This feature transitively enables the objc feature/module.

Goals

Idiomatic Rust

Fruity makes interfacing with these C and Objective-C APIs feel natural in Rust.

Zero Cost

Using Fruity to interface with Objective-C libraries should have as little runtime cost as writing the same code directly in Objective-C.

This is true for the following:

Some parts of this library still aren't zero cost. Your help would be much appreciated here!

These are:

License

This project is released under either the MIT License or Apache License (Version 2.0), at your choosing.