#ifndef CodePointRangeIteratorResult_HPP #define CodePointRangeIteratorResult_HPP #include #include #include #include #include #include #include #include "diplomat_runtime.hpp" #include "CodePointRangeIteratorResult.h" /** * Result of a single iteration of [`CodePointRangeIterator`]. * Logically can be considered to be an `Option>`, * * `start` and `end` represent an inclusive range of code points [start, end], * and `done` will be true if the iterator has already finished. The last contentful * iteration will NOT produce a range done=true, in other words `start` and `end` are useful * values if and only if `done=false`. */ struct CodePointRangeIteratorResult { public: uint32_t start; uint32_t end; bool done; }; #endif