summaryrefslogtreecommitdiff
path: root/include/vcl/kernarray.hxx
diff options
context:
space:
mode:
Diffstat (limited to 'include/vcl/kernarray.hxx')
-rw-r--r--include/vcl/kernarray.hxx93
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: */