8 releases (4 breaking)

new 0.5.0 Jan 16, 2025
0.4.1 Jan 16, 2025
0.4.0 Dec 20, 2022
0.3.1 Jan 16, 2019
0.1.1 Oct 12, 2017

#179 in GUI

Download history 17/week @ 2024-09-29 23/week @ 2024-10-06 33/week @ 2024-10-20 1/week @ 2024-10-27 6/week @ 2024-11-03 13/week @ 2024-11-10 12/week @ 2024-11-17 1/week @ 2024-11-24 152/week @ 2024-12-01 159/week @ 2024-12-08 69/week @ 2024-12-15 114/week @ 2024-12-22 83/week @ 2024-12-29 130/week @ 2025-01-05 247/week @ 2025-01-12

577 downloads per month

MIT license

6MB
121K SLoC

C++ 44K SLoC // 0.0% comments TypeScript 36K SLoC // 0.0% comments Java 35K SLoC // 0.0% comments JavaScript 3.5K SLoC // 0.0% comments Rust 1K SLoC // 0.0% comments TSX 438 SLoC // 0.1% comments Python 252 SLoC // 0.1% comments C 145 SLoC // 0.0% comments Kotlin 114 SLoC // 0.1% comments Batch 93 SLoC Swift 21 SLoC // 0.3% comments Prolog 9 SLoC

Contains (JAR file, 63KB) gradle-wrapper.jar, (Zip file, 59KB) src/yoga/lib/soloader/soloader-0.5.1.aar, (JAR file, 32KB) src/yoga/lib/jsr-305/jsr305.jar

Yoga-rs

Build Status

A Rust wrapper for Facebook's Yoga layout library.

You may also want to check out taffy (a revived fork of the abandoned stretch) as it is a pure Rust implementation.

Dependencies

  • cargo
  • rustc
  • libc++-dev (LLVM’s libc++)

Build

$ cargo build --release

Run Example

$ cargo run --release --example layout

Format Code

$ cargo +nightly fmt

Example Code

#[macro_use]
extern crate yoga;

use yoga::prelude::*;
use yoga::Node;
use yoga::StyleUnit::{Auto, UndefinedValue};

fn main() {
	let mut node = Node::new();

	let mut child = Node::new();
	let mut other_child = Node::new();

	node.insert_child(&mut child, 0);
	node.insert_child(&mut other_child, 1);

	style!(node,
		Margin(10 pt),
		MarginLeft(Auto),
		PaddingHorizontal(4 pt),
		Left(16 %),
		Bottom(UndefinedValue)
	);

	let child_styles = make_styles!(
		Width(32 pt),
		Height(32 pt),
		FlexGrow(1.0),
		Margin(Auto)
	);

	child.apply_styles(&child_styles);
	other_child.apply_styles(&child_styles);

	node.calculate_layout(512.0, 512.0, yoga::Direction::LTR);

	println!("Layout is {:#?}", child.get_layout());
}

Testing

The unit tests are automatically generated based on upstream fixtures and should not be edited manually.

$ cargo test

To generate the test cases: Download the ChromeDriver binary and put it somewhere in your $PATH. Linux/MacOS example:

$ cp chromedriver /usr/local/bin

Then run the following

$ cd gentest
$ bundle install # Install the required ruby gems
$ ruby gentest/gentest.rb # Generate the tests
$ cargo +nightly fmt # Format the tests for consistency

Dependencies