lvgl-rs/lvgl/src/lib.rs

69 lines
3.1 KiB
Rust
Raw Normal View History

//! [![github]](https://github.com/rafaelcaricio/lvgl-rs) [![crates-io]](https://crates.io/crates/lvgl) [![docs-rs]](crate)
//!
//! [github]: https://img.shields.io/badge/github-8da0cb?style=for-the-badge&labelColor=555555&logo=github
//! [crates-io]: https://img.shields.io/badge/crates.io-fc8d62?style=for-the-badge&labelColor=555555&logo=rust
//! [docs-rs]: https://img.shields.io/badge/docs.rs-66c2a5?style=for-the-badge&labelColor=555555&logoColor=white&logo=
//!
//! <br>
//!
//! [LVGL][1] bindings for Rust. A powerful and easy-to-use embedded GUI with many widgets, advanced visual effects, and
//! low memory footprint. This crate is compatible with `#![no_std]` environments by default.
//!
//! [1]: https://docs.lvgl.io/v7/en/html/get-started/quick-overview.html
//!
#![cfg_attr(not(test), no_std)]
2020-04-11 18:35:33 +00:00
2020-06-01 20:45:33 +00:00
#[macro_use]
extern crate bitflags;
2020-04-12 10:19:28 +00:00
2021-05-25 23:03:07 +00:00
#[cfg(feature = "lvgl_alloc")]
extern crate alloc;
2021-05-26 13:21:28 +00:00
// We can ONLY use `alloc::boxed::Box` if `lvgl_alloc` is enabled.
// That is because we use `Box` to send memory references to LVGL. Since the global allocator, when
// `lvgl_alloc` feature is enabled, is the LVGL memory manager then everything is in LVGL
// managed memory anyways. In that case we can use the Rust's provided Box definition.
//
#[cfg(feature = "lvgl_alloc")]
use ::alloc::boxed::Box;
#[cfg(feature = "lvgl_alloc")]
mod allocator;
mod support;
2020-06-16 21:19:26 +00:00
mod ui;
#[macro_use]
2020-06-04 00:00:31 +00:00
mod lv_core;
pub mod widgets;
2021-05-25 23:03:07 +00:00
#[cfg(not(feature = "lvgl_alloc"))]
pub(crate) mod mem;
2021-05-26 13:21:28 +00:00
// When LVGL allocator is not used on the Rust code, we need a way to add objects to the LVGL
// managed memory. We implement a very simple `Box` that has the minimal features to copy memory
// safely to the LVGL managed memory.
//
2021-05-25 23:03:07 +00:00
#[cfg(not(feature = "lvgl_alloc"))]
use crate::mem::Box;
2020-06-04 00:00:31 +00:00
pub use lv_core::*;
pub use support::*;
2020-06-16 21:19:26 +00:00
pub use ui::*;
2021-05-25 23:03:07 +00:00
2021-05-26 13:21:28 +00:00
use core::sync::atomic::{AtomicBool, Ordering};
2021-05-25 23:03:07 +00:00
// Initialize LVGL only once.
2021-05-26 13:21:28 +00:00
static LVGL_INITIALIZED: AtomicBool = AtomicBool::new(false);
pub(crate) fn lvgl_init() {
if LVGL_INITIALIZED
.compare_exchange(false, true, Ordering::Relaxed, Ordering::Relaxed)
.is_ok()
{
2021-05-25 23:03:07 +00:00
unsafe {
lvgl_sys::lv_init();
}
2021-05-26 13:21:28 +00:00
}
2021-05-25 23:03:07 +00:00
}