Files
comaps/coding/move_to_front.hpp
Konstantin Pastbin e3e4a1985a Organic Maps sources as of 02.04.2025 (fad26bbf22ac3da75e01e62aa01e5c8e11861005)
To expand with full Organic Maps and Maps.ME commits history run:
  git remote add om-historic [om-historic.git repo url]
  git fetch --tags om-historic
  git replace squashed-history historic-commits
2025-05-08 21:10:51 +07:00

27 lines
538 B
C++

#pragma once
#include <array>
#include <cstddef>
#include <cstdint>
#include <limits>
namespace coding
{
class MoveToFront
{
public:
static size_t constexpr kNumBytes = static_cast<size_t>(std::numeric_limits<uint8_t>::max()) + 1;
MoveToFront();
// Returns index of the byte |b| in the current sequence of bytes,
// then moves |b| to the first position.
uint8_t Transform(uint8_t b);
uint8_t operator[](uint8_t i) const { return m_order[i]; }
private:
std::array<uint8_t, kNumBytes> m_order;
};
} // namespace coding