Skip to content

Commit

Permalink
Use text::Span::new in window_manager
Browse files Browse the repository at this point in the history
  • Loading branch information
hecrj committed Feb 3, 2025
1 parent c83809a commit c9abe25
Show file tree
Hide file tree
Showing 2 changed files with 27 additions and 52 deletions.
44 changes: 18 additions & 26 deletions core/src/text.rs
Original file line number Diff line number Diff line change
Expand Up @@ -270,23 +270,6 @@ pub struct Span<'a, Link = (), Font = crate::Font> {
pub strikethrough: bool,
}

impl<Link, Font> Default for Span<'_, Link, Font> {
fn default() -> Self {
Self {
text: Cow::default(),
size: None,
line_height: None,
font: None,
color: None,
link: None,
highlight: None,
padding: Padding::default(),
underline: false,
strikethrough: false,
}
}
}

/// A text highlight.
#[derive(Debug, Clone, Copy, PartialEq)]
pub struct Highlight {
Expand All @@ -301,15 +284,7 @@ impl<'a, Link, Font> Span<'a, Link, Font> {
pub fn new(fragment: impl IntoFragment<'a>) -> Self {
Self {
text: fragment.into_fragment(),
size: None,
line_height: None,
font: None,
color: None,
highlight: None,
link: None,
padding: Padding::ZERO,
underline: false,
strikethrough: false,
..Self::default()
}
}

Expand Down Expand Up @@ -457,6 +432,23 @@ impl<'a, Link, Font> Span<'a, Link, Font> {
}
}

impl<Link, Font> Default for Span<'_, Link, Font> {
fn default() -> Self {
Self {
text: Cow::default(),
size: None,
line_height: None,
font: None,
color: None,
link: None,
highlight: None,
padding: Padding::default(),
underline: false,
strikethrough: false,
}
}
}

impl<'a, Link, Font> From<&'a str> for Span<'a, Link, Font> {
fn from(value: &'a str) -> Self {
Span::new(value)
Expand Down
35 changes: 9 additions & 26 deletions winit/src/program/window_manager.rs
Original file line number Diff line number Diff line change
Expand Up @@ -16,7 +16,6 @@ use crate::program::{Program, State};
use winit::dpi::{LogicalPosition, LogicalSize};
use winit::monitor::MonitorHandle;

use std::borrow::Cow;
use std::collections::BTreeMap;
use std::sync::Arc;

Expand Down Expand Up @@ -304,33 +303,17 @@ where
let spans = match &preedit.selection {
Some(selection) => {
vec![
text::Span {
text: Cow::Borrowed(
&preedit.content[..selection.start],
),
..text::Span::default()
},
text::Span {
text: Cow::Borrowed(
if selection.start == selection.end {
"\u{200A}"
} else {
&preedit.content[selection.start..selection.end]
},
),
color: Some(background),
..text::Span::default()
},
text::Span {
text: Cow::Borrowed(&preedit.content[selection.end..]),
..text::Span::default()
},
text::Span::new(&preedit.content[..selection.start]),
text::Span::new(if selection.start == selection.end {
"\u{200A}"
} else {
&preedit.content[selection.start..selection.end]
})
.color(background),
text::Span::new(&preedit.content[selection.end..]),
]
}
_ => vec![text::Span {
text: Cow::Borrowed(&preedit.content),
..text::Span::default()
}],
_ => vec![text::Span::new(&preedit.content)],
};

if spans != self.spans.as_slice() {
Expand Down

0 comments on commit c9abe25

Please sign in to comment.