diff options
Diffstat (limited to 'include/vcl/kernarray.hxx')
-rw-r--r-- | include/vcl/kernarray.hxx | 93 |
1 files changed, 2 insertions, 91 deletions
diff --git a/include/vcl/kernarray.hxx b/include/vcl/kernarray.hxx index e9e5462faf95..43b6647524b7 100644 --- a/include/vcl/kernarray.hxx +++ b/include/vcl/kernarray.hxx @@ -10,99 +10,10 @@ #include <sal/config.h> -#include <sal/types.h> -#include <cmath> #include <span> #include <vector> -class KernArraySpan final -{ -private: - int m_nSubUnitFactor; - std::span<const sal_Int32> m_DXArray; - -public: - KernArraySpan() - : m_nSubUnitFactor(1) - { - } - - KernArraySpan(std::span<const sal_Int32> DXArray, int nSubUnitFactor = 1) - : m_nSubUnitFactor(nSubUnitFactor) - , m_DXArray(DXArray) - { - } - size_t size() const { return m_DXArray.size(); } - bool empty() const { return m_DXArray.empty(); } - sal_Int32 operator[](size_t nIndex) const { return get(nIndex); } - sal_Int32 get(size_t nIndex) const - { - return std::round(static_cast<double>(m_DXArray[nIndex]) / m_nSubUnitFactor); - } - - int get_factor() const { return m_nSubUnitFactor; } - sal_Int32 get_subunit(size_t nIndex) const { return m_DXArray[nIndex]; } -}; - -class KernArray final -{ -private: - int m_nSubUnitFactor; - std::vector<sal_Int32> m_aDXArray; - -public: - KernArray(int nSubUnitFactor = 1) - : m_nSubUnitFactor(nSubUnitFactor) - { - } - - sal_Int32 operator[](size_t nIndex) const { return get(nIndex); } - sal_Int32 get(size_t nIndex) const - { - return std::round(static_cast<double>(m_aDXArray[nIndex]) / m_nSubUnitFactor); - } - - int get_factor() const { return m_nSubUnitFactor; } - sal_Int32 get_subunit(size_t nIndex) const { return m_aDXArray[nIndex]; } - - void set_subunit(size_t nIndex, sal_Int32 nValue) { m_aDXArray[nIndex] = nValue; } - std::vector<sal_Int32>& get_subunit_array() { return m_aDXArray; } - - void adjust(size_t nIndex, sal_Int32 nDiff) { m_aDXArray[nIndex] += nDiff * m_nSubUnitFactor; } - void set(size_t nIndex, sal_Int32 nValue) { m_aDXArray[nIndex] = nValue * m_nSubUnitFactor; } - void push_back(sal_Int32 nUnit) { m_aDXArray.push_back(nUnit * m_nSubUnitFactor); } - sal_Int32 back() const { return m_aDXArray.back() * m_nSubUnitFactor; } - size_t size() const { return m_aDXArray.size(); } - bool empty() const { return m_aDXArray.empty(); } - void clear() { m_aDXArray.clear(); } - void assign(KernArraySpan other) - { - m_nSubUnitFactor = other.get_factor(); - m_aDXArray.clear(); - size_t nLen = other.size(); - m_aDXArray.reserve(nLen); - for (size_t i = 0; i < nLen; ++i) - m_aDXArray.push_back(other.get_subunit(i)); - } - void resize(size_t nSize) { m_aDXArray.resize(nSize); } - void resize(size_t nSize, sal_Int32 nDefault) - { - m_aDXArray.resize(nSize, nDefault * m_nSubUnitFactor); - } - void reserve(size_t nCapacity) { m_aDXArray.reserve(nCapacity); } - - bool operator==(const KernArray& rOther) const - { - size_t nSize = size(); - if (nSize != rOther.size()) - return false; - for (size_t i = 0; i < nSize; ++i) - if (m_aDXArray[i] != rOther.m_aDXArray[i]) - return false; - return true; - } - - operator KernArraySpan() const { return KernArraySpan(m_aDXArray, m_nSubUnitFactor); } -}; +using KernArraySpan = std::span<const double>; +using KernArray = std::vector<double>; /* vim:set shiftwidth=4 softtabstop=4 expandtab cinoptions=b1,g0,N-s cinkeys+=0=break: */ |