42 breaking releases

0.48.0 Dec 15, 2023
0.47.0 Jun 20, 2023
0.46.0 May 8, 2023
0.42.0 Mar 27, 2023
0.9.0 Jul 25, 2022

#538 in Math

Download history 120/week @ 2023-10-23 106/week @ 2023-10-30 67/week @ 2023-11-06 106/week @ 2023-11-13 119/week @ 2023-11-20 188/week @ 2023-11-27 51/week @ 2023-12-04 161/week @ 2023-12-11 72/week @ 2023-12-18 204/week @ 2023-12-25 41/week @ 2024-01-01 50/week @ 2024-01-08 101/week @ 2024-01-15 38/week @ 2024-01-22 214/week @ 2024-01-29 50/week @ 2024-02-05

412 downloads per month
Used in 10 crates (9 directly)

0BSD license



Blog | Community | Contribution Guide


Fornjot is an early-stage b-rep CAD kernel written in the Rust programming language.

For an introduction of what the project aims to achieve, please check out the website.


Fornjot is supported by @MitchellHansen, @webtrax-oz, @seanjensengrey, @reivilibre, @lthiery, @ahdinosaur, @martindederer, @bollian, @nullstyle, @tachiniererin, @HalfVoxel, @sucaba, @Kethku, @jessebraham, @MattOslin, @jminer, @jeevcat, @voxpelli, @U007D, @guillaumechauvat, @mayfieldiv, @bglw, @hansihe, and my other awesome sponsors. Thank you!

Please consider supporting me too, to help make Fornjot sustainable long-term.

Table of Contents


Fornjot is usable for some toy examples, but currently lacks the features for something more advanced. Work to change that is underway.


This is a list of the crates that make up Fornjot, along with a short description for each, starting with the most basic ones and leading up to the high-level ones:

  • fj: All-in-one API that re-exports all of the following crates.
  • fj-math: Math primitives used by the rest of Fornjot.
  • fj-interop: Basic types that allow other crates to interoperate, without depending on each other.
  • fj-core: Core primitives and code operating on those primitives.
  • fj-export: Exports Fornjot models to external data formats.
  • fj-viewer: Displays Fornjot models.
  • fj-window: Simple windowing abstraction for use with fj-viewer.


Fornjot is a set of Rust libraries (see list above). The definitive documentation on how to use those is their reference documentation. The crates.io pages of each library (see list above) link to those.

If you want to use Fornjot to create a specific model in Rust, the best starting point are the example models in this repository:

  • To display a model, run cargo run -p cuboid (replace cuboid with name of model you want to display).
  • To export a model, run cargo run -p cuboid -- --export model.3mf (replace cuboid with name of model you want to export; optionally replace 3mf with another supported file format).
  • To see full set of CLI options, run cargo run -p cuboid -- --help (all models have the same CLI interface, so this shouldn't differ much between them).


If you are interested in Fornjot, please consider joining the community. We'd love to have you!

Please check out the community page on the website for information on where to find us!

Get Involved

If you are interested in helping out, just fork one of the GitHub repositories and submit a pull request:

If you don't know what to work on, check out the good first issues. If you need some more guidance, check out the contribution guide, or just ask!


This project is open source, licensed under the terms of the Zero Clause BSD License (0BSD, for short). This basically means you can do anything with it, without any restrictions, but you can't hold the authors liable for problems.

See LICENSE.md for full details.


~156K SLoC