From f12ffa92a0a28b1ab1f0362bc16d5af9d05e3383 Mon Sep 17 00:00:00 2001 From: Bananymous Date: Fri, 31 May 2024 13:05:07 +0300 Subject: [PATCH] LibFont: Font::get_glyph() now returns nullptr if glyph does not exist This allows getting glyphs with a single hash lookup --- LibFont/Font.cpp | 10 ---------- LibFont/include/LibFont/Font.h | 10 ++++++++-- 2 files changed, 8 insertions(+), 12 deletions(-) diff --git a/LibFont/Font.cpp b/LibFont/Font.cpp index 6a3a742b..00456fa3 100644 --- a/LibFont/Font.cpp +++ b/LibFont/Font.cpp @@ -274,14 +274,4 @@ namespace LibFont return result; } - bool Font::has_glyph(uint32_t codepoint) const - { - return m_glyph_offsets.contains(codepoint); - } - - const uint8_t* Font::glyph(uint32_t codepoint) const - { - return m_glyph_data.data() + m_glyph_offsets[codepoint]; - } - } diff --git a/LibFont/include/LibFont/Font.h b/LibFont/include/LibFont/Font.h index 87d6ad8a..0e7c9260 100644 --- a/LibFont/include/LibFont/Font.h +++ b/LibFont/include/LibFont/Font.h @@ -19,8 +19,14 @@ namespace LibFont uint32_t height() const { return m_height; } uint32_t pitch() const { return m_pitch; } - bool has_glyph(uint32_t) const; - const uint8_t* glyph(uint32_t) const; + bool has_glyph(uint32_t codepoint) const { return glyph(codepoint) != nullptr; } + const uint8_t* glyph(uint32_t codepoint) const + { + auto it = m_glyph_offsets.find(codepoint); + if (it == m_glyph_offsets.end()) + return nullptr; + return m_glyph_data.data() + it->value; + } private: static BAN::ErrorOr parse_psf1(BAN::ConstByteSpan);