rename widget fn macros

This commit is contained in:
2025-08-29 00:11:41 -04:00
parent 42f5a8d01b
commit d4690401eb
6 changed files with 32 additions and 34 deletions

View File

@@ -15,7 +15,7 @@ impl Widget for Image {
} }
} }
pub fn image(image: impl LoadableImage) -> WidgetFnRet!(Image) { pub fn image(image: impl LoadableImage) -> WidgetFn!(Image) {
let image = image.get_image().expect("Failed to load image"); let image = image.get_image().expect("Failed to load image");
move |ui| Image { move |ui| Image {
handle: ui.add_texture(image), handle: ui.add_texture(image),

View File

@@ -1,21 +1,21 @@
use crate::prelude::*; use crate::prelude::*;
pub trait Sensable<W, Tag> { pub trait Sensable<W, Tag> {
fn on(self, sense: Senses, f: impl SenseFn) -> WidgetIdFnRet!(W); fn on(self, sense: Senses, f: impl SenseFn) -> WidgetIdFn!(W);
fn id_on( fn id_on(
self, self,
senses: Senses, senses: Senses,
f: impl FnMut(&WidgetId<W>, &mut Ui) + 'static + Clone, f: impl FnMut(&WidgetId<W>, &mut Ui) + 'static + Clone,
) -> WidgetIdFnRet!(W) ) -> WidgetIdFn!(W)
where where
W: Widget; W: Widget;
fn edit_on(self, senses: Senses, f: impl FnMut(&mut W) + 'static + Clone) -> WidgetIdFnRet!(W) fn edit_on(self, senses: Senses, f: impl FnMut(&mut W) + 'static + Clone) -> WidgetIdFn!(W)
where where
W: Widget; W: Widget;
} }
impl<W: WidgetLike<Tag>, Tag> Sensable<W::Widget, Tag> for W { impl<W: WidgetLike<Tag>, Tag> Sensable<W::Widget, Tag> for W {
fn on(self, senses: Senses, f: impl SenseFn) -> WidgetIdFnRet!(W::Widget) { fn on(self, senses: Senses, f: impl SenseFn) -> WidgetIdFn!(W::Widget) {
move |ui| { move |ui| {
let id = self.add(ui); let id = self.add(ui);
ui.add_sensor( ui.add_sensor(
@@ -32,7 +32,7 @@ impl<W: WidgetLike<Tag>, Tag> Sensable<W::Widget, Tag> for W {
self, self,
senses: Senses, senses: Senses,
mut f: impl FnMut(&WidgetId<W::Widget>, &mut Ui) + 'static + Clone, mut f: impl FnMut(&WidgetId<W::Widget>, &mut Ui) + 'static + Clone,
) -> WidgetIdFnRet!(W::Widget) ) -> WidgetIdFn!(W::Widget)
where where
W::Widget: Widget, W::Widget: Widget,
{ {
@@ -45,7 +45,7 @@ impl<W: WidgetLike<Tag>, Tag> Sensable<W::Widget, Tag> for W {
self, self,
senses: Senses, senses: Senses,
mut f: impl FnMut(&mut W::Widget) + 'static + Clone, mut f: impl FnMut(&mut W::Widget) + 'static + Clone,
) -> WidgetIdFnRet!(W::Widget) ) -> WidgetIdFn!(W::Widget)
where where
W::Widget: Widget, W::Widget: Widget,
{ {

View File

@@ -2,41 +2,41 @@ use super::*;
use crate::prelude::*; use crate::prelude::*;
pub trait CoreWidget<W, Tag> { pub trait CoreWidget<W, Tag> {
fn pad(self, padding: impl Into<Padding>) -> WidgetFnRet!(Regioned); fn pad(self, padding: impl Into<Padding>) -> WidgetFn!(Regioned);
fn align(self, align: Align) -> WidgetFnRet!(Aligned); fn align(self, align: Align) -> WidgetFn!(Aligned);
fn center(self) -> WidgetFnRet!(Aligned); fn center(self) -> WidgetFn!(Aligned);
fn region(self, region: UiRegion) -> WidgetFnRet!(Regioned); fn region(self, region: UiRegion) -> WidgetFn!(Regioned);
fn label(self, label: impl Into<String>) -> WidgetIdFnRet!(W); fn label(self, label: impl Into<String>) -> WidgetIdFn!(W);
fn size(self, size: impl Into<Vec2>) -> WidgetFnRet!(Sized); fn size(self, size: impl Into<Vec2>) -> WidgetFn!(Sized);
} }
impl<W: WidgetLike<Tag>, Tag> CoreWidget<W::Widget, Tag> for W { impl<W: WidgetLike<Tag>, Tag> CoreWidget<W::Widget, Tag> for W {
fn pad(self, padding: impl Into<Padding>) -> WidgetFnRet!(Regioned) { fn pad(self, padding: impl Into<Padding>) -> WidgetFn!(Regioned) {
|ui| Regioned { |ui| Regioned {
region: padding.into().region(), region: padding.into().region(),
inner: self.add(ui).erase_type(), inner: self.add(ui).erase_type(),
} }
} }
fn align(self, align: Align) -> WidgetFnRet!(Aligned) { fn align(self, align: Align) -> WidgetFn!(Aligned) {
move |ui| Aligned { move |ui| Aligned {
inner: self.add(ui).erase_type(), inner: self.add(ui).erase_type(),
align, align,
} }
} }
fn center(self) -> WidgetFnRet!(Aligned) { fn center(self) -> WidgetFn!(Aligned) {
self.align(Align::Center) self.align(Align::Center)
} }
fn region(self, region: UiRegion) -> WidgetFnRet!(Regioned) { fn region(self, region: UiRegion) -> WidgetFn!(Regioned) {
move |ui| Regioned { move |ui| Regioned {
region, region,
inner: self.add(ui).erase_type(), inner: self.add(ui).erase_type(),
} }
} }
fn label(self, label: impl Into<String>) -> WidgetIdFnRet!(W::Widget) { fn label(self, label: impl Into<String>) -> WidgetIdFn!(W::Widget) {
|ui| { |ui| {
let id = self.add(ui); let id = self.add(ui);
ui.set_label(&id, label.into()); ui.set_label(&id, label.into());
@@ -44,7 +44,7 @@ impl<W: WidgetLike<Tag>, Tag> CoreWidget<W::Widget, Tag> for W {
} }
} }
fn size(self, size: impl Into<Vec2>) -> WidgetFnRet!(Sized) { fn size(self, size: impl Into<Vec2>) -> WidgetFn!(Sized) {
move |ui| Sized { move |ui| Sized {
inner: self.add(ui).erase_type(), inner: self.add(ui).erase_type(),
size: size.into(), size: size.into(),
@@ -53,19 +53,19 @@ impl<W: WidgetLike<Tag>, Tag> CoreWidget<W::Widget, Tag> for W {
} }
pub trait CoreWidgetArr<const LEN: usize, Tag> { pub trait CoreWidgetArr<const LEN: usize, Tag> {
fn span(self, dir: Dir, lengths: impl IntoSpanLens<LEN>) -> WidgetFnRet!(Span); fn span(self, dir: Dir, lengths: impl IntoSpanLens<LEN>) -> WidgetFn!(Span);
fn stack(self) -> WidgetFnRet!(Stack); fn stack(self) -> WidgetFn!(Stack);
} }
impl<const LEN: usize, Wa: WidgetArrLike<LEN, Tag>, Tag> CoreWidgetArr<LEN, Tag> for Wa { impl<const LEN: usize, Wa: WidgetArrLike<LEN, Tag>, Tag> CoreWidgetArr<LEN, Tag> for Wa {
fn span(self, dir: Dir, lengths: impl IntoSpanLens<LEN>) -> WidgetFnRet!(Span) { fn span(self, dir: Dir, lengths: impl IntoSpanLens<LEN>) -> WidgetFn!(Span) {
let lengths = lengths.into_lens(); let lengths = lengths.into_lens();
move |ui| Span { move |ui| Span {
children: self.ui(ui).arr.into_iter().zip(lengths).collect(), children: self.ui(ui).arr.into_iter().zip(lengths).collect(),
dir, dir,
} }
} }
fn stack(self) -> WidgetFnRet!(Stack) { fn stack(self) -> WidgetFn!(Stack) {
move |ui| Stack { move |ui| Stack {
children: self.ui(ui).arr.to_vec(), children: self.ui(ui).arr.to_vec(),
} }

View File

@@ -120,7 +120,7 @@ pub struct IdTag;
pub struct IdFnTag; pub struct IdFnTag;
// pub trait WidgetIdFn<W, Ctx> = FnOnce(&mut Ui) -> WidgetId<W>; // pub trait WidgetIdFn<W, Ctx> = FnOnce(&mut Ui) -> WidgetId<W>;
macro_rules! WidgetIdFnRet { macro_rules! WidgetIdFn {
($W:ty) => { ($W:ty) => {
impl FnOnce(&mut $crate::layout::Ui) -> $crate::layout::WidgetId<$W> impl FnOnce(&mut $crate::layout::Ui) -> $crate::layout::WidgetId<$W>
}; };
@@ -128,15 +128,12 @@ macro_rules! WidgetIdFnRet {
impl FnOnce(&mut $crate::layout::Ui) -> $crate::layout::WidgetId<$W> + use<$($use)*> impl FnOnce(&mut $crate::layout::Ui) -> $crate::layout::WidgetId<$W> + use<$($use)*>
}; };
} }
pub(crate) use WidgetIdFnRet; pub(crate) use WidgetIdFn;
pub trait Idable<Tag> { pub trait Idable<Tag> {
type Widget: Widget; type Widget: Widget;
fn set(self, ui: &mut Ui, id: &WidgetId<Self::Widget>); fn set(self, ui: &mut Ui, id: &WidgetId<Self::Widget>);
fn id<'a>( fn id<'a>(self, id: &WidgetId<Self::Widget>) -> WidgetIdFn!(Self::Widget, 'a, Self, Tag)
self,
id: &WidgetId<Self::Widget>,
) -> WidgetIdFnRet!(Self::Widget, 'a, Self, Tag)
where where
Self: Sized, Self: Sized,
{ {
@@ -149,7 +146,7 @@ pub trait Idable<Tag> {
fn id_static<'a>( fn id_static<'a>(
self, self,
id: StaticWidgetId<Self::Widget>, id: StaticWidgetId<Self::Widget>,
) -> WidgetIdFnRet!(Self::Widget, 'a, Self, Tag) ) -> WidgetIdFn!(Self::Widget, 'a, Self, Tag)
where where
Self: Sized, Self: Sized,
{ {

View File

@@ -1,4 +1,4 @@
use crate::layout::{Painter, TextData, Textures, Ui, Vec2, WidgetId, WidgetIdFnRet, Widgets}; use crate::layout::{Painter, TextData, Textures, Ui, Vec2, WidgetId, WidgetIdFn, Widgets};
use std::{any::Any, marker::PhantomData}; use std::{any::Any, marker::PhantomData};
@@ -31,7 +31,7 @@ pub trait WidgetLike<Tag> {
fn with_id<W2>( fn with_id<W2>(
self, self,
f: impl FnOnce(&mut Ui, WidgetId<Self::Widget>) -> WidgetId<W2>, f: impl FnOnce(&mut Ui, WidgetId<Self::Widget>) -> WidgetId<W2>,
) -> WidgetIdFnRet!(W2) ) -> WidgetIdFn!(W2)
where where
Self: Sized, Self: Sized,
{ {
@@ -48,12 +48,12 @@ pub trait WidgetLike<Tag> {
/// Useful for defining trait functions on widgets that create a parent widget so that the children /// Useful for defining trait functions on widgets that create a parent widget so that the children
/// don't need to be IDs yet /// don't need to be IDs yet
/// currently a macro for rust analyzer (doesn't support trait aliases atm) /// currently a macro for rust analyzer (doesn't support trait aliases atm)
macro_rules! WidgetFnRet { macro_rules! WidgetFn {
($W:ty) => { ($W:ty) => {
impl FnOnce(&mut $crate::layout::Ui) -> $W impl FnOnce(&mut $crate::layout::Ui) -> $W
}; };
} }
pub(crate) use WidgetFnRet; pub(crate) use WidgetFn;
impl<W: Widget, F: FnOnce(&mut Ui) -> W> WidgetLike<FnTag> for F { impl<W: Widget, F: FnOnce(&mut Ui) -> W> WidgetLike<FnTag> for F {
type Widget = W; type Widget = W;

View File

@@ -3,6 +3,7 @@
#![feature(const_trait_impl)] #![feature(const_trait_impl)]
#![feature(const_from)] #![feature(const_from)]
#![feature(map_try_insert)] #![feature(map_try_insert)]
#![feature(trait_alias)]
pub mod core; pub mod core;
pub mod layout; pub mod layout;