diff --git a/Userland/Libraries/LibGUI/GlyphMapWidget.cpp b/Userland/Libraries/LibGUI/GlyphMapWidget.cpp index 80fbb4eb67..b529f7c7df 100644 --- a/Userland/Libraries/LibGUI/GlyphMapWidget.cpp +++ b/Userland/Libraries/LibGUI/GlyphMapWidget.cpp @@ -89,6 +89,14 @@ void GlyphMapWidget::set_active_glyph(int glyph, ShouldResetSelection should_res update(); } +void GlyphMapWidget::set_selection(int start, int size, Optional active_glyph) +{ + m_selection.set_start(start); + m_selection.set_size(size); + if (active_glyph.has_value()) + set_active_glyph(active_glyph.value(), ShouldResetSelection::No); +} + Gfx::IntRect GlyphMapWidget::get_outer_rect(int glyph) const { glyph -= m_active_range.first; diff --git a/Userland/Libraries/LibGUI/GlyphMapWidget.h b/Userland/Libraries/LibGUI/GlyphMapWidget.h index 9d1dfe2b3c..66afecf806 100644 --- a/Userland/Libraries/LibGUI/GlyphMapWidget.h +++ b/Userland/Libraries/LibGUI/GlyphMapWidget.h @@ -55,6 +55,7 @@ public: void set_active_range(Unicode::CodePointRange); void set_active_glyph(int, ShouldResetSelection = ShouldResetSelection::Yes); + void set_selection(int start, int size, Optional active_glyph = {}); void clear_selection() { m_selection.set_size(0); } void scroll_to_glyph(int); void update_glyph(int);