Browse Source

Fix crash in text layout (#1468)

Fix text layout bug added in https://github.com/emilk/egui/pull/1291
pull/1475/head
Emil Ernerfeldt 3 years ago
committed by GitHub
parent
commit
c2ab0404b7
No known key found for this signature in database GPG Key ID: 4AEE18F83AFDEB23
  1. 13
      epaint/src/text/text_layout.rs

13
epaint/src/text/text_layout.rs

@ -249,7 +249,7 @@ fn line_break(
}
if row_start_idx < paragraph.glyphs.len() {
if non_empty_rows == job.wrap.max_rows {
if job.wrap.max_rows > 0 && non_empty_rows == job.wrap.max_rows {
if let Some(last_row) = out_rows.last_mut() {
replace_last_glyph_with_overflow_character(fonts, job, last_row);
}
@ -773,3 +773,14 @@ fn is_chinese(c: char) -> bool {
|| ('\u{3400}' <= c && c <= '\u{4DBF}')
|| ('\u{2B740}' <= c && c <= '\u{2B81F}')
}
// ----------------------------------------------------------------------------
#[test]
fn test_zero_max_width() {
let mut fonts = FontsImpl::new(1.0, 1024, super::FontDefinitions::default());
let mut layout_job = LayoutJob::single_section("W".into(), super::TextFormat::default());
layout_job.wrap.max_width = 0.0;
let galley = super::layout(&mut fonts, layout_job.into());
assert_eq!(galley.rows.len(), 1);
}

Loading…
Cancel
Save