/* * Copyright (c) 2023, Aliaksandr Kalenik * * SPDX-License-Identifier: BSD-2-Clause */ #include namespace Gfx { void FontCascadeList::add(NonnullRefPtr font) { m_fonts.append({ move(font), {} }); } void FontCascadeList::add(NonnullRefPtr font, Vector unicode_ranges) { if (unicode_ranges.is_empty()) { m_fonts.append({ move(font), {} }); return; } u32 lowest_code_point = 0xFFFFFFFF; u32 highest_code_point = 0; for (auto& range : unicode_ranges) { lowest_code_point = min(lowest_code_point, range.min_code_point()); highest_code_point = max(highest_code_point, range.max_code_point()); } m_fonts.append({ move(font), Entry::RangeData { { lowest_code_point, highest_code_point }, move(unicode_ranges), } }); } void FontCascadeList::extend(FontCascadeList const& other) { m_fonts.extend(other.m_fonts); } Gfx::Font const& FontCascadeList::font_for_code_point(u32 code_point) const { for (auto const& entry : m_fonts) { if (entry.range_data.has_value()) { if (!entry.range_data->enclosing_range.contains(code_point)) continue; for (auto const& range : entry.range_data->unicode_ranges) { if (range.contains(code_point) && entry.font->contains_glyph(code_point)) return entry.font; } } else if (entry.font->contains_glyph(code_point)) { return entry.font; } } return *m_last_resort_font; } bool FontCascadeList::equals(FontCascadeList const& other) const { if (m_fonts.size() != other.m_fonts.size()) return false; for (size_t i = 0; i < m_fonts.size(); ++i) { if (m_fonts[i].font != other.m_fonts[i].font) return false; } return true; } }