/* * Copyright 2018 Google Inc. * * Use of this source code is governed by a BSD-style license that can be * found in the LICENSE file. */ #ifndef SkClusterator_DEFINED #define SkClusterator_DEFINED #include <vector> #include <cstdint> class SkGlyphRun; /** Given the m-to-n glyph-to-character mapping data (as returned by harfbuzz), iterate over the clusters. */ class SkClusterator { public: SkClusterator(const SkGlyphRun& run); uint32_t glyphCount() const { return fGlyphCount; } bool reversedChars() const { return fReversedChars; } struct Cluster { const char* fUtf8Text; uint32_t fTextByteLength; uint32_t fGlyphIndex; uint32_t fGlyphCount; explicit operator bool() const { return fGlyphCount != 0; } bool operator==(const SkClusterator::Cluster& o) { return fUtf8Text == o.fUtf8Text && fTextByteLength == o.fTextByteLength && fGlyphIndex == o.fGlyphIndex && fGlyphCount == o.fGlyphCount; } }; Cluster next(); private: const uint32_t* fClusters; const char* fUtf8Text; uint32_t fGlyphCount; uint32_t fTextByteLength; uint32_t fCurrentGlyphIndex = 0; bool fReversedChars = false; }; #endif // SkClusterator_DEFINED