summaryrefslogtreecommitdiffstats
path: root/thirdparty/msdfgen/core
diff options
context:
space:
mode:
authorbruvzg <7645683+bruvzg@users.noreply.github.com>2024-03-12 10:26:55 +0200
committerbruvzg <7645683+bruvzg@users.noreply.github.com>2024-03-13 09:12:50 +0200
commit0d02568ff8bd59cd9be9f7e09a444e9cf6689ae2 (patch)
tree122fe5b3e0f4ddb739602a0fbb218f7f27584920 /thirdparty/msdfgen/core
parent22c20cea6e59a8a95585adb866c007a55c428806 (diff)
downloadredot-engine-0d02568ff8bd59cd9be9f7e09a444e9cf6689ae2.tar.gz
Update ICU and msdfgen.
Diffstat (limited to 'thirdparty/msdfgen/core')
-rw-r--r--thirdparty/msdfgen/core/Bitmap.h10
-rw-r--r--thirdparty/msdfgen/core/Bitmap.hpp10
-rw-r--r--thirdparty/msdfgen/core/BitmapRef.hpp8
-rw-r--r--thirdparty/msdfgen/core/Contour.cpp2
-rw-r--r--thirdparty/msdfgen/core/Contour.h2
-rw-r--r--thirdparty/msdfgen/core/EdgeColor.h2
-rw-r--r--thirdparty/msdfgen/core/EdgeHolder.cpp12
-rw-r--r--thirdparty/msdfgen/core/EdgeHolder.h12
-rw-r--r--thirdparty/msdfgen/core/MSDFErrorCorrection.cpp8
-rw-r--r--thirdparty/msdfgen/core/Projection.h2
-rw-r--r--thirdparty/msdfgen/core/Scanline.cpp2
-rw-r--r--thirdparty/msdfgen/core/Scanline.h1
-rw-r--r--thirdparty/msdfgen/core/Shape.cpp41
-rw-r--r--thirdparty/msdfgen/core/Shape.h2
-rw-r--r--thirdparty/msdfgen/core/ShapeDistanceFinder.h2
-rw-r--r--thirdparty/msdfgen/core/ShapeDistanceFinder.hpp6
-rw-r--r--thirdparty/msdfgen/core/SignedDistance.cpp29
-rw-r--r--thirdparty/msdfgen/core/SignedDistance.h23
-rw-r--r--thirdparty/msdfgen/core/SignedDistance.hpp38
-rw-r--r--thirdparty/msdfgen/core/Vector2.cpp146
-rw-r--r--thirdparty/msdfgen/core/Vector2.h66
-rw-r--r--thirdparty/msdfgen/core/Vector2.hpp167
-rw-r--r--thirdparty/msdfgen/core/arithmetics.hpp2
-rw-r--r--thirdparty/msdfgen/core/base.h16
-rw-r--r--thirdparty/msdfgen/core/bitmap-interpolation.hpp2
-rw-r--r--thirdparty/msdfgen/core/contour-combiners.cpp4
-rw-r--r--thirdparty/msdfgen/core/contour-combiners.h4
-rw-r--r--thirdparty/msdfgen/core/edge-coloring.cpp11
-rw-r--r--thirdparty/msdfgen/core/edge-segments.cpp32
-rw-r--r--thirdparty/msdfgen/core/edge-segments.h36
-rw-r--r--thirdparty/msdfgen/core/edge-selectors.h4
-rw-r--r--thirdparty/msdfgen/core/equation-solver.cpp2
-rw-r--r--thirdparty/msdfgen/core/equation-solver.h2
-rw-r--r--thirdparty/msdfgen/core/generator-config.h1
-rw-r--r--thirdparty/msdfgen/core/msdf-error-correction.h2
-rw-r--r--thirdparty/msdfgen/core/pixel-conversion.hpp2
-rw-r--r--thirdparty/msdfgen/core/rasterization.h2
-rw-r--r--thirdparty/msdfgen/core/render-sdf.h2
-rw-r--r--thirdparty/msdfgen/core/sdf-error-estimation.h2
-rw-r--r--thirdparty/msdfgen/core/shape-description.cpp59
-rw-r--r--thirdparty/msdfgen/core/shape-description.h1
41 files changed, 393 insertions, 384 deletions
diff --git a/thirdparty/msdfgen/core/Bitmap.h b/thirdparty/msdfgen/core/Bitmap.h
index 14407d6c34..9a08749f47 100644
--- a/thirdparty/msdfgen/core/Bitmap.h
+++ b/thirdparty/msdfgen/core/Bitmap.h
@@ -18,17 +18,17 @@ public:
Bitmap(Bitmap<T, N> &&orig);
#endif
~Bitmap();
- Bitmap<T, N> & operator=(const BitmapConstRef<T, N> &orig);
- Bitmap<T, N> & operator=(const Bitmap<T, N> &orig);
+ Bitmap<T, N> &operator=(const BitmapConstRef<T, N> &orig);
+ Bitmap<T, N> &operator=(const Bitmap<T, N> &orig);
#ifdef MSDFGEN_USE_CPP11
- Bitmap<T, N> & operator=(Bitmap<T, N> &&orig);
+ Bitmap<T, N> &operator=(Bitmap<T, N> &&orig);
#endif
/// Bitmap width in pixels.
int width() const;
/// Bitmap height in pixels.
int height() const;
- T * operator()(int x, int y);
- const T * operator()(int x, int y) const;
+ T *operator()(int x, int y);
+ const T *operator()(int x, int y) const;
#ifdef MSDFGEN_USE_CPP11
explicit operator T *();
explicit operator const T *() const;
diff --git a/thirdparty/msdfgen/core/Bitmap.hpp b/thirdparty/msdfgen/core/Bitmap.hpp
index cb16cac8d4..9404357788 100644
--- a/thirdparty/msdfgen/core/Bitmap.hpp
+++ b/thirdparty/msdfgen/core/Bitmap.hpp
@@ -40,7 +40,7 @@ Bitmap<T, N>::~Bitmap() {
}
template <typename T, int N>
-Bitmap<T, N> & Bitmap<T, N>::operator=(const BitmapConstRef<T, N> &orig) {
+Bitmap<T, N> &Bitmap<T, N>::operator=(const BitmapConstRef<T, N> &orig) {
if (pixels != orig.pixels) {
delete [] pixels;
w = orig.width, h = orig.height;
@@ -51,7 +51,7 @@ Bitmap<T, N> & Bitmap<T, N>::operator=(const BitmapConstRef<T, N> &orig) {
}
template <typename T, int N>
-Bitmap<T, N> & Bitmap<T, N>::operator=(const Bitmap<T, N> &orig) {
+Bitmap<T, N> &Bitmap<T, N>::operator=(const Bitmap<T, N> &orig) {
if (this != &orig) {
delete [] pixels;
w = orig.w, h = orig.h;
@@ -63,7 +63,7 @@ Bitmap<T, N> & Bitmap<T, N>::operator=(const Bitmap<T, N> &orig) {
#ifdef MSDFGEN_USE_CPP11
template <typename T, int N>
-Bitmap<T, N> & Bitmap<T, N>::operator=(Bitmap<T, N> &&orig) {
+Bitmap<T, N> &Bitmap<T, N>::operator=(Bitmap<T, N> &&orig) {
if (this != &orig) {
delete [] pixels;
pixels = orig.pixels;
@@ -85,12 +85,12 @@ int Bitmap<T, N>::height() const {
}
template <typename T, int N>
-T * Bitmap<T, N>::operator()(int x, int y) {
+T *Bitmap<T, N>::operator()(int x, int y) {
return pixels+N*(w*y+x);
}
template <typename T, int N>
-const T * Bitmap<T, N>::operator()(int x, int y) const {
+const T *Bitmap<T, N>::operator()(int x, int y) const {
return pixels+N*(w*y+x);
}
diff --git a/thirdparty/msdfgen/core/BitmapRef.hpp b/thirdparty/msdfgen/core/BitmapRef.hpp
index 6f9620dcdf..cb17f95dcb 100644
--- a/thirdparty/msdfgen/core/BitmapRef.hpp
+++ b/thirdparty/msdfgen/core/BitmapRef.hpp
@@ -1,12 +1,10 @@
#pragma once
-#include <cstdlib>
+#include "base.h"
namespace msdfgen {
-typedef unsigned char byte;
-
/// Reference to a 2D image bitmap or a buffer acting as one. Pixel storage not owned or managed by the object.
template <typename T, int N = 1>
struct BitmapRef {
@@ -17,7 +15,7 @@ struct BitmapRef {
inline BitmapRef() : pixels(NULL), width(0), height(0) { }
inline BitmapRef(T *pixels, int width, int height) : pixels(pixels), width(width), height(height) { }
- inline T * operator()(int x, int y) const {
+ inline T *operator()(int x, int y) const {
return pixels+N*(width*y+x);
}
@@ -34,7 +32,7 @@ struct BitmapConstRef {
inline BitmapConstRef(const T *pixels, int width, int height) : pixels(pixels), width(width), height(height) { }
inline BitmapConstRef(const BitmapRef<T, N> &orig) : pixels(orig.pixels), width(orig.width), height(orig.height) { }
- inline const T * operator()(int x, int y) const {
+ inline const T *operator()(int x, int y) const {
return pixels+N*(width*y+x);
}
diff --git a/thirdparty/msdfgen/core/Contour.cpp b/thirdparty/msdfgen/core/Contour.cpp
index ca80d3c55a..57293dc58b 100644
--- a/thirdparty/msdfgen/core/Contour.cpp
+++ b/thirdparty/msdfgen/core/Contour.cpp
@@ -19,7 +19,7 @@ void Contour::addEdge(EdgeHolder &&edge) {
}
#endif
-EdgeHolder & Contour::addEdge() {
+EdgeHolder &Contour::addEdge() {
edges.resize(edges.size()+1);
return edges.back();
}
diff --git a/thirdparty/msdfgen/core/Contour.h b/thirdparty/msdfgen/core/Contour.h
index f79b269582..4cae48fad7 100644
--- a/thirdparty/msdfgen/core/Contour.h
+++ b/thirdparty/msdfgen/core/Contour.h
@@ -19,7 +19,7 @@ public:
void addEdge(EdgeHolder &&edge);
#endif
/// Creates a new edge in the contour and returns its reference.
- EdgeHolder & addEdge();
+ EdgeHolder &addEdge();
/// Adjusts the bounding box to fit the contour.
void bound(double &l, double &b, double &r, double &t) const;
/// Adjusts the bounding box to fit the contour border's mitered corners.
diff --git a/thirdparty/msdfgen/core/EdgeColor.h b/thirdparty/msdfgen/core/EdgeColor.h
index 9d49a5a89e..5d3730c9a6 100644
--- a/thirdparty/msdfgen/core/EdgeColor.h
+++ b/thirdparty/msdfgen/core/EdgeColor.h
@@ -1,6 +1,8 @@
#pragma once
+#include "base.h"
+
namespace msdfgen {
/// Edge color specifies which color channels an edge belongs to.
diff --git a/thirdparty/msdfgen/core/EdgeHolder.cpp b/thirdparty/msdfgen/core/EdgeHolder.cpp
index 1a8c5f66e9..cffcff46d3 100644
--- a/thirdparty/msdfgen/core/EdgeHolder.cpp
+++ b/thirdparty/msdfgen/core/EdgeHolder.cpp
@@ -31,7 +31,7 @@ EdgeHolder::~EdgeHolder() {
delete edgeSegment;
}
-EdgeHolder & EdgeHolder::operator=(const EdgeHolder &orig) {
+EdgeHolder &EdgeHolder::operator=(const EdgeHolder &orig) {
if (this != &orig) {
delete edgeSegment;
edgeSegment = orig.edgeSegment ? orig.edgeSegment->clone() : NULL;
@@ -40,7 +40,7 @@ EdgeHolder & EdgeHolder::operator=(const EdgeHolder &orig) {
}
#ifdef MSDFGEN_USE_CPP11
-EdgeHolder & EdgeHolder::operator=(EdgeHolder &&orig) {
+EdgeHolder &EdgeHolder::operator=(EdgeHolder &&orig) {
if (this != &orig) {
delete edgeSegment;
edgeSegment = orig.edgeSegment;
@@ -50,19 +50,19 @@ EdgeHolder & EdgeHolder::operator=(EdgeHolder &&orig) {
}
#endif
-EdgeSegment & EdgeHolder::operator*() {
+EdgeSegment &EdgeHolder::operator*() {
return *edgeSegment;
}
-const EdgeSegment & EdgeHolder::operator*() const {
+const EdgeSegment &EdgeHolder::operator*() const {
return *edgeSegment;
}
-EdgeSegment * EdgeHolder::operator->() {
+EdgeSegment *EdgeHolder::operator->() {
return edgeSegment;
}
-const EdgeSegment * EdgeHolder::operator->() const {
+const EdgeSegment *EdgeHolder::operator->() const {
return edgeSegment;
}
diff --git a/thirdparty/msdfgen/core/EdgeHolder.h b/thirdparty/msdfgen/core/EdgeHolder.h
index c4c5be7616..50a59b2189 100644
--- a/thirdparty/msdfgen/core/EdgeHolder.h
+++ b/thirdparty/msdfgen/core/EdgeHolder.h
@@ -22,14 +22,14 @@ public:
EdgeHolder(EdgeHolder &&orig);
#endif
~EdgeHolder();
- EdgeHolder & operator=(const EdgeHolder &orig);
+ EdgeHolder &operator=(const EdgeHolder &orig);
#ifdef MSDFGEN_USE_CPP11
- EdgeHolder & operator=(EdgeHolder &&orig);
+ EdgeHolder &operator=(EdgeHolder &&orig);
#endif
- EdgeSegment & operator*();
- const EdgeSegment & operator*() const;
- EdgeSegment * operator->();
- const EdgeSegment * operator->() const;
+ EdgeSegment &operator*();
+ const EdgeSegment &operator*() const;
+ EdgeSegment *operator->();
+ const EdgeSegment *operator->() const;
operator EdgeSegment *();
operator const EdgeSegment *() const;
diff --git a/thirdparty/msdfgen/core/MSDFErrorCorrection.cpp b/thirdparty/msdfgen/core/MSDFErrorCorrection.cpp
index 7918597fd2..9a5cefe128 100644
--- a/thirdparty/msdfgen/core/MSDFErrorCorrection.cpp
+++ b/thirdparty/msdfgen/core/MSDFErrorCorrection.cpp
@@ -19,8 +19,8 @@ namespace msdfgen {
#define CLASSIFIER_FLAG_CANDIDATE 0x01
#define CLASSIFIER_FLAG_ARTIFACT 0x02
-const double ErrorCorrectionConfig::defaultMinDeviationRatio = 1.11111111111111111;
-const double ErrorCorrectionConfig::defaultMinImproveRatio = 1.11111111111111111;
+MSDFGEN_PUBLIC const double ErrorCorrectionConfig::defaultMinDeviationRatio = 1.11111111111111111;
+MSDFGEN_PUBLIC const double ErrorCorrectionConfig::defaultMinImproveRatio = 1.11111111111111111;
/// The base artifact classifier recognizes artifacts based on the contents of the SDF alone.
class BaseArtifactClassifier {
@@ -317,7 +317,7 @@ static bool hasDiagonalArtifactInner(const ArtifactClassifier &artifactClassifie
em[0] = am, em[1] = dm;
tEnd[tEx0 > t[i]] = tEx0;
em[tEx0 > t[i]] = interpolatedMedian(a, l, q, tEx0);
- rangeFlags |= artifactClassifier.rangeTest(tEnd[0], tEnd[1], t[i], am, dm, xm);
+ rangeFlags |= artifactClassifier.rangeTest(tEnd[0], tEnd[1], t[i], em[0], em[1], xm);
}
// tEx1
if (tEx1 > 0 && tEx1 < 1) {
@@ -325,7 +325,7 @@ static bool hasDiagonalArtifactInner(const ArtifactClassifier &artifactClassifie
em[0] = am, em[1] = dm;
tEnd[tEx1 > t[i]] = tEx1;
em[tEx1 > t[i]] = interpolatedMedian(a, l, q, tEx1);
- rangeFlags |= artifactClassifier.rangeTest(tEnd[0], tEnd[1], t[i], am, dm, xm);
+ rangeFlags |= artifactClassifier.rangeTest(tEnd[0], tEnd[1], t[i], em[0], em[1], xm);
}
if (artifactClassifier.evaluate(t[i], xm, rangeFlags))
return true;
diff --git a/thirdparty/msdfgen/core/Projection.h b/thirdparty/msdfgen/core/Projection.h
index 7cdb1c307a..3c457776ac 100644
--- a/thirdparty/msdfgen/core/Projection.h
+++ b/thirdparty/msdfgen/core/Projection.h
@@ -1,7 +1,7 @@
#pragma once
-#include "Vector2.h"
+#include "Vector2.hpp"
namespace msdfgen {
diff --git a/thirdparty/msdfgen/core/Scanline.cpp b/thirdparty/msdfgen/core/Scanline.cpp
index 8e5352dbf6..7407be41b5 100644
--- a/thirdparty/msdfgen/core/Scanline.cpp
+++ b/thirdparty/msdfgen/core/Scanline.cpp
@@ -1,7 +1,7 @@
#include "Scanline.h"
-#include <algorithm>
+#include <cstdlib>
#include "arithmetics.hpp"
namespace msdfgen {
diff --git a/thirdparty/msdfgen/core/Scanline.h b/thirdparty/msdfgen/core/Scanline.h
index 9c8f34044b..c0abc68642 100644
--- a/thirdparty/msdfgen/core/Scanline.h
+++ b/thirdparty/msdfgen/core/Scanline.h
@@ -2,6 +2,7 @@
#pragma once
#include <vector>
+#include "base.h"
namespace msdfgen {
diff --git a/thirdparty/msdfgen/core/Shape.cpp b/thirdparty/msdfgen/core/Shape.cpp
index 8d6f47c807..cf99bd0f0c 100644
--- a/thirdparty/msdfgen/core/Shape.cpp
+++ b/thirdparty/msdfgen/core/Shape.cpp
@@ -1,7 +1,7 @@
#include "Shape.h"
-#include <algorithm>
+#include <cstdlib>
#include "arithmetics.hpp"
namespace msdfgen {
@@ -18,7 +18,7 @@ void Shape::addContour(Contour &&contour) {
}
#endif
-Contour & Shape::addContour() {
+Contour &Shape::addContour() {
contours.resize(contours.size()+1);
return contours.back();
}
@@ -40,15 +40,12 @@ bool Shape::validate() const {
}
static void deconvergeEdge(EdgeHolder &edgeHolder, int param) {
- {
- const QuadraticSegment *quadraticSegment = dynamic_cast<const QuadraticSegment *>(&*edgeHolder);
- if (quadraticSegment)
- edgeHolder = quadraticSegment->convertToCubic();
- }
- {
- CubicSegment *cubicSegment = dynamic_cast<CubicSegment *>(&*edgeHolder);
- if (cubicSegment)
- cubicSegment->deconverge(param, MSDFGEN_DECONVERGENCE_FACTOR);
+ switch (edgeHolder->type()) {
+ case (int) QuadraticSegment::EDGE_TYPE:
+ edgeHolder = static_cast<const QuadraticSegment *>(&*edgeHolder)->convertToCubic();
+ // fallthrough
+ case (int) CubicSegment::EDGE_TYPE:
+ static_cast<CubicSegment *>(&*edgeHolder)->deconverge(param, MSDFGEN_DECONVERGENCE_FACTOR);
}
}
@@ -162,16 +159,18 @@ void Shape::orientContours() {
}
}
}
- qsort(&intersections[0], intersections.size(), sizeof(Intersection), &Intersection::compare);
- // Disqualify multiple intersections
- for (int j = 1; j < (int) intersections.size(); ++j)
- if (intersections[j].x == intersections[j-1].x)
- intersections[j].direction = intersections[j-1].direction = 0;
- // Inspect scanline and deduce orientations of intersected contours
- for (int j = 0; j < (int) intersections.size(); ++j)
- if (intersections[j].direction)
- orientations[intersections[j].contourIndex] += 2*((j&1)^(intersections[j].direction > 0))-1;
- intersections.clear();
+ if (!intersections.empty()) {
+ qsort(&intersections[0], intersections.size(), sizeof(Intersection), &Intersection::compare);
+ // Disqualify multiple intersections
+ for (int j = 1; j < (int) intersections.size(); ++j)
+ if (intersections[j].x == intersections[j-1].x)
+ intersections[j].direction = intersections[j-1].direction = 0;
+ // Inspect scanline and deduce orientations of intersected contours
+ for (int j = 0; j < (int) intersections.size(); ++j)
+ if (intersections[j].direction)
+ orientations[intersections[j].contourIndex] += 2*((j&1)^(intersections[j].direction > 0))-1;
+ intersections.clear();
+ }
}
}
// Reverse contours that have the opposite orientation
diff --git a/thirdparty/msdfgen/core/Shape.h b/thirdparty/msdfgen/core/Shape.h
index 7539921ce7..fd9222dbc4 100644
--- a/thirdparty/msdfgen/core/Shape.h
+++ b/thirdparty/msdfgen/core/Shape.h
@@ -32,7 +32,7 @@ public:
void addContour(Contour &&contour);
#endif
/// Adds a blank contour and returns its reference.
- Contour & addContour();
+ Contour &addContour();
/// Normalizes the shape geometry for distance field generation.
void normalize();
/// Performs basic checks to determine if the object represents a valid shape.
diff --git a/thirdparty/msdfgen/core/ShapeDistanceFinder.h b/thirdparty/msdfgen/core/ShapeDistanceFinder.h
index 57df8d8e72..d8a584f645 100644
--- a/thirdparty/msdfgen/core/ShapeDistanceFinder.h
+++ b/thirdparty/msdfgen/core/ShapeDistanceFinder.h
@@ -2,7 +2,7 @@
#pragma once
#include <vector>
-#include "Vector2.h"
+#include "Vector2.hpp"
#include "edge-selectors.h"
#include "contour-combiners.h"
diff --git a/thirdparty/msdfgen/core/ShapeDistanceFinder.hpp b/thirdparty/msdfgen/core/ShapeDistanceFinder.hpp
index 028738e5c3..07fb5cdc0e 100644
--- a/thirdparty/msdfgen/core/ShapeDistanceFinder.hpp
+++ b/thirdparty/msdfgen/core/ShapeDistanceFinder.hpp
@@ -9,7 +9,11 @@ ShapeDistanceFinder<ContourCombiner>::ShapeDistanceFinder(const Shape &shape) :
template <class ContourCombiner>
typename ShapeDistanceFinder<ContourCombiner>::DistanceType ShapeDistanceFinder<ContourCombiner>::distance(const Point2 &origin) {
contourCombiner.reset(origin);
- typename ContourCombiner::EdgeSelectorType::EdgeCache *edgeCache = &shapeEdgeCache[0];
+#ifdef MSDFGEN_USE_CPP11
+ typename ContourCombiner::EdgeSelectorType::EdgeCache *edgeCache = shapeEdgeCache.data();
+#else
+ typename ContourCombiner::EdgeSelectorType::EdgeCache *edgeCache = shapeEdgeCache.empty() ? NULL : &shapeEdgeCache[0];
+#endif
for (std::vector<Contour>::const_iterator contour = shape.contours.begin(); contour != shape.contours.end(); ++contour) {
if (!contour->edges.empty()) {
diff --git a/thirdparty/msdfgen/core/SignedDistance.cpp b/thirdparty/msdfgen/core/SignedDistance.cpp
deleted file mode 100644
index be956d953e..0000000000
--- a/thirdparty/msdfgen/core/SignedDistance.cpp
+++ /dev/null
@@ -1,29 +0,0 @@
-
-#include "SignedDistance.h"
-
-#include <cmath>
-#include <cfloat>
-
-namespace msdfgen {
-
-SignedDistance::SignedDistance() : distance(-DBL_MAX), dot(1) { }
-
-SignedDistance::SignedDistance(double dist, double d) : distance(dist), dot(d) { }
-
-bool operator<(SignedDistance a, SignedDistance b) {
- return fabs(a.distance) < fabs(b.distance) || (fabs(a.distance) == fabs(b.distance) && a.dot < b.dot);
-}
-
-bool operator>(SignedDistance a, SignedDistance b) {
- return fabs(a.distance) > fabs(b.distance) || (fabs(a.distance) == fabs(b.distance) && a.dot > b.dot);
-}
-
-bool operator<=(SignedDistance a, SignedDistance b) {
- return fabs(a.distance) < fabs(b.distance) || (fabs(a.distance) == fabs(b.distance) && a.dot <= b.dot);
-}
-
-bool operator>=(SignedDistance a, SignedDistance b) {
- return fabs(a.distance) > fabs(b.distance) || (fabs(a.distance) == fabs(b.distance) && a.dot >= b.dot);
-}
-
-}
diff --git a/thirdparty/msdfgen/core/SignedDistance.h b/thirdparty/msdfgen/core/SignedDistance.h
deleted file mode 100644
index 91fee97600..0000000000
--- a/thirdparty/msdfgen/core/SignedDistance.h
+++ /dev/null
@@ -1,23 +0,0 @@
-
-#pragma once
-
-namespace msdfgen {
-
-/// Represents a signed distance and alignment, which together can be compared to uniquely determine the closest edge segment.
-class SignedDistance {
-
-public:
- double distance;
- double dot;
-
- SignedDistance();
- SignedDistance(double dist, double d);
-
- friend bool operator<(SignedDistance a, SignedDistance b);
- friend bool operator>(SignedDistance a, SignedDistance b);
- friend bool operator<=(SignedDistance a, SignedDistance b);
- friend bool operator>=(SignedDistance a, SignedDistance b);
-
-};
-
-}
diff --git a/thirdparty/msdfgen/core/SignedDistance.hpp b/thirdparty/msdfgen/core/SignedDistance.hpp
new file mode 100644
index 0000000000..62e73c03aa
--- /dev/null
+++ b/thirdparty/msdfgen/core/SignedDistance.hpp
@@ -0,0 +1,38 @@
+
+#pragma once
+
+#include <cmath>
+#include <cfloat>
+#include "base.h"
+
+namespace msdfgen {
+
+/// Represents a signed distance and alignment, which together can be compared to uniquely determine the closest edge segment.
+class SignedDistance {
+
+public:
+ double distance;
+ double dot;
+
+ inline SignedDistance() : distance(-DBL_MAX), dot(0) { }
+ inline SignedDistance(double dist, double d) : distance(dist), dot(d) { }
+
+};
+
+inline bool operator<(const SignedDistance a, const SignedDistance b) {
+ return fabs(a.distance) < fabs(b.distance) || (fabs(a.distance) == fabs(b.distance) && a.dot < b.dot);
+}
+
+inline bool operator>(const SignedDistance a, const SignedDistance b) {
+ return fabs(a.distance) > fabs(b.distance) || (fabs(a.distance) == fabs(b.distance) && a.dot > b.dot);
+}
+
+inline bool operator<=(const SignedDistance a, const SignedDistance b) {
+ return fabs(a.distance) < fabs(b.distance) || (fabs(a.distance) == fabs(b.distance) && a.dot <= b.dot);
+}
+
+inline bool operator>=(const SignedDistance a, const SignedDistance b) {
+ return fabs(a.distance) > fabs(b.distance) || (fabs(a.distance) == fabs(b.distance) && a.dot >= b.dot);
+}
+
+}
diff --git a/thirdparty/msdfgen/core/Vector2.cpp b/thirdparty/msdfgen/core/Vector2.cpp
deleted file mode 100644
index 896963ff2c..0000000000
--- a/thirdparty/msdfgen/core/Vector2.cpp
+++ /dev/null
@@ -1,146 +0,0 @@
-
-#include "Vector2.h"
-
-namespace msdfgen {
-
-Vector2::Vector2(double val) : x(val), y(val) { }
-
-Vector2::Vector2(double x, double y) : x(x), y(y) { }
-
-void Vector2::reset() {
- x = 0, y = 0;
-}
-
-void Vector2::set(double x, double y) {
- Vector2::x = x, Vector2::y = y;
-}
-
-double Vector2::length() const {
- return sqrt(x*x+y*y);
-}
-
-double Vector2::direction() const {
- return atan2(y, x);
-}
-
-Vector2 Vector2::normalize(bool allowZero) const {
- double len = length();
- if (len == 0)
- return Vector2(0, !allowZero);
- return Vector2(x/len, y/len);
-}
-
-Vector2 Vector2::getOrthogonal(bool polarity) const {
- return polarity ? Vector2(-y, x) : Vector2(y, -x);
-}
-
-Vector2 Vector2::getOrthonormal(bool polarity, bool allowZero) const {
- double len = length();
- if (len == 0)
- return polarity ? Vector2(0, !allowZero) : Vector2(0, -!allowZero);
- return polarity ? Vector2(-y/len, x/len) : Vector2(y/len, -x/len);
-}
-
-Vector2 Vector2::project(const Vector2 &vector, bool positive) const {
- Vector2 n = normalize(true);
- double t = dotProduct(vector, n);
- if (positive && t <= 0)
- return Vector2();
- return t*n;
-}
-
-Vector2::operator const void*() const {
- return x || y ? this : NULL;
-}
-
-bool Vector2::operator!() const {
- return !x && !y;
-}
-
-bool Vector2::operator==(const Vector2 &other) const {
- return x == other.x && y == other.y;
-}
-
-bool Vector2::operator!=(const Vector2 &other) const {
- return x != other.x || y != other.y;
-}
-
-Vector2 Vector2::operator+() const {
- return *this;
-}
-
-Vector2 Vector2::operator-() const {
- return Vector2(-x, -y);
-}
-
-Vector2 Vector2::operator+(const Vector2 &other) const {
- return Vector2(x+other.x, y+other.y);
-}
-
-Vector2 Vector2::operator-(const Vector2 &other) const {
- return Vector2(x-other.x, y-other.y);
-}
-
-Vector2 Vector2::operator*(const Vector2 &other) const {
- return Vector2(x*other.x, y*other.y);
-}
-
-Vector2 Vector2::operator/(const Vector2 &other) const {
- return Vector2(x/other.x, y/other.y);
-}
-
-Vector2 Vector2::operator*(double value) const {
- return Vector2(x*value, y*value);
-}
-
-Vector2 Vector2::operator/(double value) const {
- return Vector2(x/value, y/value);
-}
-
-Vector2 & Vector2::operator+=(const Vector2 &other) {
- x += other.x, y += other.y;
- return *this;
-}
-
-Vector2 & Vector2::operator-=(const Vector2 &other) {
- x -= other.x, y -= other.y;
- return *this;
-}
-
-Vector2 & Vector2::operator*=(const Vector2 &other) {
- x *= other.x, y *= other.y;
- return *this;
-}
-
-Vector2 & Vector2::operator/=(const Vector2 &other) {
- x /= other.x, y /= other.y;
- return *this;
-}
-
-Vector2 & Vector2::operator*=(double value) {
- x *= value, y *= value;
- return *this;
-}
-
-Vector2 & Vector2::operator/=(double value) {
- x /= value, y /= value;
- return *this;
-}
-
-double dotProduct(const Vector2 &a, const Vector2 &b) {
- return a.x*b.x+a.y*b.y;
-}
-
-double crossProduct(const Vector2 &a, const Vector2 &b) {
- return a.x*b.y-a.y*b.x;
-}
-
-Vector2 operator*(double value, const Vector2 &vector) {
- return Vector2(value*vector.x, value*vector.y);
-}
-
-Vector2 operator/(double value, const Vector2 &vector) {
- return Vector2(value/vector.x, value/vector.y);
-}
-
-}
diff --git a/thirdparty/msdfgen/core/Vector2.h b/thirdparty/msdfgen/core/Vector2.h
deleted file mode 100644
index 47ca637c3d..0000000000
--- a/thirdparty/msdfgen/core/Vector2.h
+++ /dev/null
@@ -1,66 +0,0 @@
-
-#pragma once
-
-#include <cstdlib>
-#include <cmath>
-
-namespace msdfgen {
-
-/**
-* A 2-dimensional euclidean vector with double precision.
-* Implementation based on the Vector2 template from Artery Engine.
-* @author Viktor Chlumsky
-*/
-struct Vector2 {
-
- double x, y;
-
- Vector2(double val = 0);
- Vector2(double x, double y);
- /// Sets the vector to zero.
- void reset();
- /// Sets individual elements of the vector.
- void set(double x, double y);
- /// Returns the vector's length.
- double length() const;
- /// Returns the angle of the vector in radians (atan2).
- double direction() const;
- /// Returns the normalized vector - one that has the same direction but unit length.
- Vector2 normalize(bool allowZero = false) const;
- /// Returns a vector with the same length that is orthogonal to this one.
- Vector2 getOrthogonal(bool polarity = true) const;
- /// Returns a vector with unit length that is orthogonal to this one.
- Vector2 getOrthonormal(bool polarity = true, bool allowZero = false) const;
- /// Returns a vector projected along this one.
- Vector2 project(const Vector2 &vector, bool positive = false) const;
- operator const void *() const;
- bool operator!() const;
- bool operator==(const Vector2 &other) const;
- bool operator!=(const Vector2 &other) const;
- Vector2 operator+() const;
- Vector2 operator-() const;
- Vector2 operator+(const Vector2 &other) const;
- Vector2 operator-(const Vector2 &other) const;
- Vector2 operator*(const Vector2 &other) const;
- Vector2 operator/(const Vector2 &other) const;
- Vector2 operator*(double value) const;
- Vector2 operator/(double value) const;
- Vector2 & operator+=(const Vector2 &other);
- Vector2 & operator-=(const Vector2 &other);
- Vector2 & operator*=(const Vector2 &other);
- Vector2 & operator/=(const Vector2 &other);
- Vector2 & operator*=(double value);
- Vector2 & operator/=(double value);
- /// Dot product of two vectors.
- friend double dotProduct(const Vector2 &a, const Vector2 &b);
- /// A special version of the cross product for 2D vectors (returns scalar value).
- friend double crossProduct(const Vector2 &a, const Vector2 &b);
- friend Vector2 operator*(double value, const Vector2 &vector);
- friend Vector2 operator/(double value, const Vector2 &vector);
-
-};
-
-/// A vector may also represent a point, which shall be differentiated semantically using the alias Point2.
-typedef Vector2 Point2;
-
-}
diff --git a/thirdparty/msdfgen/core/Vector2.hpp b/thirdparty/msdfgen/core/Vector2.hpp
new file mode 100644
index 0000000000..0208c61497
--- /dev/null
+++ b/thirdparty/msdfgen/core/Vector2.hpp
@@ -0,0 +1,167 @@
+
+#pragma once
+
+#include <cmath>
+#include "base.h"
+
+namespace msdfgen {
+
+/**
+ * A 2-dimensional euclidean floating-point vector.
+ * @author Viktor Chlumsky
+ */
+struct Vector2 {
+
+ double x, y;
+
+ inline Vector2(double val = 0) : x(val), y(val) { }
+
+ inline Vector2(double x, double y) : x(x), y(y) { }
+
+ /// Sets the vector to zero.
+ inline void reset() {
+ x = 0, y = 0;
+ }
+
+ /// Sets individual elements of the vector.
+ inline void set(double x, double y) {
+ this->x = x, this->y = y;
+ }
+
+ /// Returns the vector's squared length.
+ inline double squaredLength() const {
+ return x*x+y*y;
+ }
+
+ /// Returns the vector's length.
+ inline double length() const {
+ return sqrt(x*x+y*y);
+ }
+
+ /// Returns the normalized vector - one that has the same direction but unit length.
+ inline Vector2 normalize(bool allowZero = false) const {
+ if (double len = length())
+ return Vector2(x/len, y/len);
+ return Vector2(0, !allowZero);
+ }
+
+ /// Returns a vector with the same length that is orthogonal to this one.
+ inline Vector2 getOrthogonal(bool polarity = true) const {
+ return polarity ? Vector2(-y, x) : Vector2(y, -x);
+ }
+
+ /// Returns a vector with unit length that is orthogonal to this one.
+ inline Vector2 getOrthonormal(bool polarity = true, bool allowZero = false) const {
+ if (double len = length())
+ return polarity ? Vector2(-y/len, x/len) : Vector2(y/len, -x/len);
+ return polarity ? Vector2(0, !allowZero) : Vector2(0, -!allowZero);
+ }
+
+#ifdef MSDFGEN_USE_CPP11
+ inline explicit operator bool() const {
+ return x || y;
+ }
+#else
+ inline operator const void *() const {
+ return x || y ? this : NULL;
+ }
+#endif
+
+ inline Vector2 &operator+=(const Vector2 other) {
+ x += other.x, y += other.y;
+ return *this;
+ }
+
+ inline Vector2 &operator-=(const Vector2 other) {
+ x -= other.x, y -= other.y;
+ return *this;
+ }
+
+ inline Vector2 &operator*=(const Vector2 other) {
+ x *= other.x, y *= other.y;
+ return *this;
+ }
+
+ inline Vector2 &operator/=(const Vector2 other) {
+ x /= other.x, y /= other.y;
+ return *this;
+ }
+
+ inline Vector2 &operator*=(double value) {
+ x *= value, y *= value;
+ return *this;
+ }
+
+ inline Vector2 &operator/=(double value) {
+ x /= value, y /= value;
+ return *this;
+ }
+
+};
+
+/// A vector may also represent a point, which shall be differentiated semantically using the alias Point2.
+typedef Vector2 Point2;
+
+/// Dot product of two vectors.
+inline double dotProduct(const Vector2 a, const Vector2 b) {
+ return a.x*b.x+a.y*b.y;
+}
+
+/// A special version of the cross product for 2D vectors (returns scalar value).
+inline double crossProduct(const Vector2 a, const Vector2 b) {
+ return a.x*b.y-a.y*b.x;
+}
+
+inline bool operator==(const Vector2 a, const Vector2 b) {
+ return a.x == b.x && a.y == b.y;
+}
+
+inline bool operator!=(const Vector2 a, const Vector2 b) {
+ return a.x != b.x || a.y != b.y;
+}
+
+inline Vector2 operator+(const Vector2 v) {
+ return v;
+}
+
+inline Vector2 operator-(const Vector2 v) {
+ return Vector2(-v.x, -v.y);
+}
+
+inline bool operator!(const Vector2 v) {
+ return !v.x && !v.y;
+}
+
+inline Vector2 operator+(const Vector2 a, const Vector2 b) {
+ return Vector2(a.x+b.x, a.y+b.y);
+}
+
+inline Vector2 operator-(const Vector2 a, const Vector2 b) {
+ return Vector2(a.x-b.x, a.y-b.y);
+}
+
+inline Vector2 operator*(const Vector2 a, const Vector2 b) {
+ return Vector2(a.x*b.x, a.y*b.y);
+}
+
+inline Vector2 operator/(const Vector2 a, const Vector2 b) {
+ return Vector2(a.x/b.x, a.y/b.y);
+}
+
+inline Vector2 operator*(double a, const Vector2 b) {
+ return Vector2(a*b.x, a*b.y);
+}
+
+inline Vector2 operator/(double a, const Vector2 b) {
+ return Vector2(a/b.x, a/b.y);
+}
+
+inline Vector2 operator*(const Vector2 a, double b) {
+ return Vector2(a.x*b, a.y*b);
+}
+
+inline Vector2 operator/(const Vector2 a, double b) {
+ return Vector2(a.x/b, a.y/b);
+}
+
+}
diff --git a/thirdparty/msdfgen/core/arithmetics.hpp b/thirdparty/msdfgen/core/arithmetics.hpp
index 78c21d658e..d5158ad0d3 100644
--- a/thirdparty/msdfgen/core/arithmetics.hpp
+++ b/thirdparty/msdfgen/core/arithmetics.hpp
@@ -1,8 +1,8 @@
#pragma once
-#include <cstdlib>
#include <cmath>
+#include "base.h"
namespace msdfgen {
diff --git a/thirdparty/msdfgen/core/base.h b/thirdparty/msdfgen/core/base.h
new file mode 100644
index 0000000000..ab85c136e1
--- /dev/null
+++ b/thirdparty/msdfgen/core/base.h
@@ -0,0 +1,16 @@
+
+#pragma once
+
+// This file needs to be included first for all MSDFgen sources
+
+#ifndef MSDFGEN_PUBLIC
+#include <msdfgen/msdfgen-config.h>
+#endif
+
+#include <cstddef>
+
+namespace msdfgen {
+
+typedef unsigned char byte;
+
+}
diff --git a/thirdparty/msdfgen/core/bitmap-interpolation.hpp b/thirdparty/msdfgen/core/bitmap-interpolation.hpp
index a14b0fb534..ca2e48c080 100644
--- a/thirdparty/msdfgen/core/bitmap-interpolation.hpp
+++ b/thirdparty/msdfgen/core/bitmap-interpolation.hpp
@@ -2,7 +2,7 @@
#pragma once
#include "arithmetics.hpp"
-#include "Vector2.h"
+#include "Vector2.hpp"
#include "BitmapRef.hpp"
namespace msdfgen {
diff --git a/thirdparty/msdfgen/core/contour-combiners.cpp b/thirdparty/msdfgen/core/contour-combiners.cpp
index 31f4c5da71..bac5534810 100644
--- a/thirdparty/msdfgen/core/contour-combiners.cpp
+++ b/thirdparty/msdfgen/core/contour-combiners.cpp
@@ -33,7 +33,7 @@ void SimpleContourCombiner<EdgeSelector>::reset(const Point2 &p) {
}
template <class EdgeSelector>
-EdgeSelector & SimpleContourCombiner<EdgeSelector>::edgeSelector(int) {
+EdgeSelector &SimpleContourCombiner<EdgeSelector>::edgeSelector(int) {
return shapeEdgeSelector;
}
@@ -63,7 +63,7 @@ void OverlappingContourCombiner<EdgeSelector>::reset(const Point2 &p) {
}
template <class EdgeSelector>
-EdgeSelector & OverlappingContourCombiner<EdgeSelector>::edgeSelector(int i) {
+EdgeSelector &OverlappingContourCombiner<EdgeSelector>::edgeSelector(int i) {
return edgeSelectors[i];
}
diff --git a/thirdparty/msdfgen/core/contour-combiners.h b/thirdparty/msdfgen/core/contour-combiners.h
index 944b119aba..04dbc34230 100644
--- a/thirdparty/msdfgen/core/contour-combiners.h
+++ b/thirdparty/msdfgen/core/contour-combiners.h
@@ -16,7 +16,7 @@ public:
explicit SimpleContourCombiner(const Shape &shape);
void reset(const Point2 &p);
- EdgeSelector & edgeSelector(int i);
+ EdgeSelector &edgeSelector(int i);
DistanceType distance() const;
private:
@@ -34,7 +34,7 @@ public:
explicit OverlappingContourCombiner(const Shape &shape);
void reset(const Point2 &p);
- EdgeSelector & edgeSelector(int i);
+ EdgeSelector &edgeSelector(int i);
DistanceType distance() const;
private:
diff --git a/thirdparty/msdfgen/core/edge-coloring.cpp b/thirdparty/msdfgen/core/edge-coloring.cpp
index 6a87bba54d..da9b037735 100644
--- a/thirdparty/msdfgen/core/edge-coloring.cpp
+++ b/thirdparty/msdfgen/core/edge-coloring.cpp
@@ -5,6 +5,7 @@
#include <cmath>
#include <cstring>
#include <cfloat>
+#include <vector>
#include <queue>
#include "arithmetics.hpp"
@@ -244,7 +245,7 @@ static double edgeToEdgeDistance(const EdgeSegment &a, const EdgeSegment &b, int
return minDistance;
}
-static double splineToSplineDistance(EdgeSegment * const *edgeSegments, int aStart, int aEnd, int bStart, int bEnd, int precision) {
+static double splineToSplineDistance(EdgeSegment *const *edgeSegments, int aStart, int aEnd, int bStart, int bEnd, int precision) {
double minDistance = DBL_MAX;
for (int ai = aStart; ai < aEnd; ++ai)
for (int bi = bStart; bi < bEnd && minDistance; ++bi) {
@@ -254,7 +255,7 @@ static double splineToSplineDistance(EdgeSegment * const *edgeSegments, int aSta
return minDistance;
}
-static void colorSecondDegreeGraph(int *coloring, const int * const *edgeMatrix, int vertexCount, unsigned long long seed) {
+static void colorSecondDegreeGraph(int *coloring, const int *const *edgeMatrix, int vertexCount, unsigned long long seed) {
for (int i = 0; i < vertexCount; ++i) {
int possibleColors = 7;
for (int j = 0; j < i; ++j) {
@@ -301,7 +302,7 @@ static int vertexPossibleColors(const int *coloring, const int *edgeVector, int
return 7&~usedColors;
}
-static void uncolorSameNeighbors(std::queue<int> &uncolored, int *coloring, const int * const *edgeMatrix, int vertex, int vertexCount) {
+static void uncolorSameNeighbors(std::queue<int> &uncolored, int *coloring, const int *const *edgeMatrix, int vertex, int vertexCount) {
for (int i = vertex+1; i < vertexCount; ++i) {
if (edgeMatrix[vertex][i] && coloring[i] == coloring[vertex]) {
coloring[i] = -1;
@@ -316,7 +317,7 @@ static void uncolorSameNeighbors(std::queue<int> &uncolored, int *coloring, cons
}
}
-static bool tryAddEdge(int *coloring, int * const *edgeMatrix, int vertexCount, int vertexA, int vertexB, int *coloringBuffer) {
+static bool tryAddEdge(int *coloring, int *const *edgeMatrix, int vertexCount, int vertexA, int vertexB, int *coloringBuffer) {
static const int FIRST_POSSIBLE_COLOR[8] = { -1, 0, 1, 0, 2, 2, 1, 0 };
edgeMatrix[vertexA][vertexB] = 1;
edgeMatrix[vertexB][vertexA] = 1;
@@ -358,7 +359,7 @@ static bool tryAddEdge(int *coloring, int * const *edgeMatrix, int vertexCount,
}
static int cmpDoublePtr(const void *a, const void *b) {
- return sign(**reinterpret_cast<const double * const *>(a)-**reinterpret_cast<const double * const *>(b));
+ return sign(**reinterpret_cast<const double *const *>(a)-**reinterpret_cast<const double *const *>(b));
}
void edgeColoringByDistance(Shape &shape, double angleThreshold, unsigned long long seed) {
diff --git a/thirdparty/msdfgen/core/edge-segments.cpp b/thirdparty/msdfgen/core/edge-segments.cpp
index 5274a9a5a1..4fef89b95b 100644
--- a/thirdparty/msdfgen/core/edge-segments.cpp
+++ b/thirdparty/msdfgen/core/edge-segments.cpp
@@ -56,18 +56,42 @@ CubicSegment::CubicSegment(Point2 p0, Point2 p1, Point2 p2, Point2 p3, EdgeColor
p[3] = p3;
}
-LinearSegment * LinearSegment::clone() const {
+LinearSegment *LinearSegment::clone() const {
return new LinearSegment(p[0], p[1], color);
}
-QuadraticSegment * QuadraticSegment::clone() const {
+QuadraticSegment *QuadraticSegment::clone() const {
return new QuadraticSegment(p[0], p[1], p[2], color);
}
-CubicSegment * CubicSegment::clone() const {
+CubicSegment *CubicSegment::clone() const {
return new CubicSegment(p[0], p[1], p[2], p[3], color);
}
+int LinearSegment::type() const {
+ return (int) EDGE_TYPE;
+}
+
+int QuadraticSegment::type() const {
+ return (int) EDGE_TYPE;
+}
+
+int CubicSegment::type() const {
+ return (int) EDGE_TYPE;
+}
+
+const Point2 *LinearSegment::controlPoints() const {
+ return p;
+}
+
+const Point2 *QuadraticSegment::controlPoints() const {
+ return p;
+}
+
+const Point2 *CubicSegment::controlPoints() const {
+ return p;
+}
+
Point2 LinearSegment::point(double param) const {
return mix(p[0], p[1], param);
}
@@ -483,7 +507,7 @@ void CubicSegment::splitInThirds(EdgeSegment *&part1, EdgeSegment *&part2, EdgeS
part3 = new CubicSegment(point(2/3.), mix(mix(p[1], p[2], 2/3.), mix(p[2], p[3], 2/3.), 2/3.), p[2] == p[3] ? p[3] : mix(p[2], p[3], 2/3.), p[3], color);
}
-EdgeSegment * QuadraticSegment::convertToCubic() const {
+EdgeSegment *QuadraticSegment::convertToCubic() const {
return new CubicSegment(p[0], mix(p[0], p[1], 2/3.), mix(p[1], p[2], 1/3.), p[2], color);
}
diff --git a/thirdparty/msdfgen/core/edge-segments.h b/thirdparty/msdfgen/core/edge-segments.h
index 1c8fb599ff..71ce8fc4ab 100644
--- a/thirdparty/msdfgen/core/edge-segments.h
+++ b/thirdparty/msdfgen/core/edge-segments.h
@@ -1,8 +1,8 @@
#pragma once
-#include "Vector2.h"
-#include "SignedDistance.h"
+#include "Vector2.hpp"
+#include "SignedDistance.hpp"
#include "EdgeColor.h"
namespace msdfgen {
@@ -20,7 +20,11 @@ public:
EdgeSegment(EdgeColor edgeColor = WHITE) : color(edgeColor) { }
virtual ~EdgeSegment() { }
/// Creates a copy of the edge segment.
- virtual EdgeSegment * clone() const = 0;
+ virtual EdgeSegment *clone() const = 0;
+ /// Returns the numeric code of the edge segment's type.
+ virtual int type() const = 0;
+ /// Returns the array of control points.
+ virtual const Point2 *controlPoints() const = 0;
/// Returns the point on the edge specified by the parameter (between 0 and 1).
virtual Point2 point(double param) const = 0;
/// Returns the direction the edge has at the point specified by the parameter.
@@ -51,10 +55,16 @@ public:
class LinearSegment : public EdgeSegment {
public:
+ enum EdgeType {
+ EDGE_TYPE = 1
+ };
+
Point2 p[2];
LinearSegment(Point2 p0, Point2 p1, EdgeColor edgeColor = WHITE);
- LinearSegment * clone() const;
+ LinearSegment *clone() const;
+ int type() const;
+ const Point2 *controlPoints() const;
Point2 point(double param) const;
Vector2 direction(double param) const;
Vector2 directionChange(double param) const;
@@ -74,10 +84,16 @@ public:
class QuadraticSegment : public EdgeSegment {
public:
+ enum EdgeType {
+ EDGE_TYPE = 2
+ };
+
Point2 p[3];
QuadraticSegment(Point2 p0, Point2 p1, Point2 p2, EdgeColor edgeColor = WHITE);
- QuadraticSegment * clone() const;
+ QuadraticSegment *clone() const;
+ int type() const;
+ const Point2 *controlPoints() const;
Point2 point(double param) const;
Vector2 direction(double param) const;
Vector2 directionChange(double param) const;
@@ -91,7 +107,7 @@ public:
void moveEndPoint(Point2 to);
void splitInThirds(EdgeSegment *&part1, EdgeSegment *&part2, EdgeSegment *&part3) const;
- EdgeSegment * convertToCubic() const;
+ EdgeSegment *convertToCubic() const;
};
@@ -99,10 +115,16 @@ public:
class CubicSegment : public EdgeSegment {
public:
+ enum EdgeType {
+ EDGE_TYPE = 3
+ };
+
Point2 p[4];
CubicSegment(Point2 p0, Point2 p1, Point2 p2, Point2 p3, EdgeColor edgeColor = WHITE);
- CubicSegment * clone() const;
+ CubicSegment *clone() const;
+ int type() const;
+ const Point2 *controlPoints() const;
Point2 point(double param) const;
Vector2 direction(double param) const;
Vector2 directionChange(double param) const;
diff --git a/thirdparty/msdfgen/core/edge-selectors.h b/thirdparty/msdfgen/core/edge-selectors.h
index 3620999f82..6b8e2d943f 100644
--- a/thirdparty/msdfgen/core/edge-selectors.h
+++ b/thirdparty/msdfgen/core/edge-selectors.h
@@ -1,8 +1,8 @@
#pragma once
-#include "Vector2.h"
-#include "SignedDistance.h"
+#include "Vector2.hpp"
+#include "SignedDistance.hpp"
#include "edge-segments.h"
namespace msdfgen {
diff --git a/thirdparty/msdfgen/core/equation-solver.cpp b/thirdparty/msdfgen/core/equation-solver.cpp
index 4144fa3340..7c1cbb39f8 100644
--- a/thirdparty/msdfgen/core/equation-solver.cpp
+++ b/thirdparty/msdfgen/core/equation-solver.cpp
@@ -49,7 +49,7 @@ static int solveCubicNormed(double x[3], double a, double b, double c) {
x[2] = q*cos(1/3.*(t-2*M_PI))-a;
return 3;
} else {
- double u = (r < 0 ? 1 : -1)*pow(fabs(r)+sqrt(r2-q3), 1/3.);
+ double u = (r < 0 ? 1 : -1)*pow(fabs(r)+sqrt(r2-q3), 1/3.);
double v = u == 0 ? 0 : q/u;
x[0] = (u+v)-a;
if (u == v || fabs(u-v) < 1e-12*fabs(u+v)) {
diff --git a/thirdparty/msdfgen/core/equation-solver.h b/thirdparty/msdfgen/core/equation-solver.h
index bae097b2b9..bfeeb15823 100644
--- a/thirdparty/msdfgen/core/equation-solver.h
+++ b/thirdparty/msdfgen/core/equation-solver.h
@@ -1,6 +1,8 @@
#pragma once
+#include "base.h"
+
namespace msdfgen {
// ax^2 + bx + c = 0
diff --git a/thirdparty/msdfgen/core/generator-config.h b/thirdparty/msdfgen/core/generator-config.h
index b430d37f3c..b7b153477f 100644
--- a/thirdparty/msdfgen/core/generator-config.h
+++ b/thirdparty/msdfgen/core/generator-config.h
@@ -1,7 +1,6 @@
#pragma once
-#include <cstdlib>
#include "BitmapRef.hpp"
#ifndef MSDFGEN_PUBLIC
diff --git a/thirdparty/msdfgen/core/msdf-error-correction.h b/thirdparty/msdfgen/core/msdf-error-correction.h
index d5384c9329..6318f184bb 100644
--- a/thirdparty/msdfgen/core/msdf-error-correction.h
+++ b/thirdparty/msdfgen/core/msdf-error-correction.h
@@ -1,7 +1,7 @@
#pragma once
-#include "Vector2.h"
+#include "Vector2.hpp"
#include "Projection.h"
#include "Shape.h"
#include "BitmapRef.hpp"
diff --git a/thirdparty/msdfgen/core/pixel-conversion.hpp b/thirdparty/msdfgen/core/pixel-conversion.hpp
index 7e9b6d08f0..3ef8a2d1da 100644
--- a/thirdparty/msdfgen/core/pixel-conversion.hpp
+++ b/thirdparty/msdfgen/core/pixel-conversion.hpp
@@ -5,8 +5,6 @@
namespace msdfgen {
-typedef unsigned char byte;
-
inline byte pixelFloatToByte(float x) {
return byte(clamp(256.f*x, 255.f));
}
diff --git a/thirdparty/msdfgen/core/rasterization.h b/thirdparty/msdfgen/core/rasterization.h
index 82d0c73d95..8ba41cd645 100644
--- a/thirdparty/msdfgen/core/rasterization.h
+++ b/thirdparty/msdfgen/core/rasterization.h
@@ -1,7 +1,7 @@
#pragma once
-#include "Vector2.h"
+#include "Vector2.hpp"
#include "Shape.h"
#include "Projection.h"
#include "Scanline.h"
diff --git a/thirdparty/msdfgen/core/render-sdf.h b/thirdparty/msdfgen/core/render-sdf.h
index 7f2d270b67..0fa695acf6 100644
--- a/thirdparty/msdfgen/core/render-sdf.h
+++ b/thirdparty/msdfgen/core/render-sdf.h
@@ -1,7 +1,7 @@
#pragma once
-#include "Vector2.h"
+#include "Vector2.hpp"
#include "BitmapRef.hpp"
namespace msdfgen {
diff --git a/thirdparty/msdfgen/core/sdf-error-estimation.h b/thirdparty/msdfgen/core/sdf-error-estimation.h
index d2fd40d2b8..f9008222ab 100644
--- a/thirdparty/msdfgen/core/sdf-error-estimation.h
+++ b/thirdparty/msdfgen/core/sdf-error-estimation.h
@@ -1,7 +1,7 @@
#pragma once
-#include "Vector2.h"
+#include "Vector2.hpp"
#include "Shape.h"
#include "Projection.h"
#include "Scanline.h"
diff --git a/thirdparty/msdfgen/core/shape-description.cpp b/thirdparty/msdfgen/core/shape-description.cpp
index a096fa2541..32c515d120 100644
--- a/thirdparty/msdfgen/core/shape-description.cpp
+++ b/thirdparty/msdfgen/core/shape-description.cpp
@@ -244,34 +244,37 @@ bool writeShapeDescription(FILE *output, const Shape &shape) {
default:;
}
}
- if (const LinearSegment *e = dynamic_cast<const LinearSegment *>(&**edge)) {
- fprintf(output, "\t");
- writeCoord(output, e->p[0]);
- fprintf(output, ";\n");
- if (colorCode)
- fprintf(output, "\t\t%c;\n", colorCode);
- }
- if (const QuadraticSegment *e = dynamic_cast<const QuadraticSegment *>(&**edge)) {
- fprintf(output, "\t");
- writeCoord(output, e->p[0]);
- fprintf(output, ";\n\t\t");
- if (colorCode)
- fprintf(output, "%c", colorCode);
- fprintf(output, "(");
- writeCoord(output, e->p[1]);
- fprintf(output, ");\n");
- }
- if (const CubicSegment *e = dynamic_cast<const CubicSegment *>(&**edge)) {
- fprintf(output, "\t");
- writeCoord(output, e->p[0]);
- fprintf(output, ";\n\t\t");
- if (colorCode)
- fprintf(output, "%c", colorCode);
- fprintf(output, "(");
- writeCoord(output, e->p[1]);
- fprintf(output, "; ");
- writeCoord(output, e->p[2]);
- fprintf(output, ");\n");
+ const Point2 *p = (*edge)->controlPoints();
+ switch ((*edge)->type()) {
+ case (int) LinearSegment::EDGE_TYPE:
+ fprintf(output, "\t");
+ writeCoord(output, p[0]);
+ fprintf(output, ";\n");
+ if (colorCode)
+ fprintf(output, "\t\t%c;\n", colorCode);
+ break;
+ case (int) QuadraticSegment::EDGE_TYPE:
+ fprintf(output, "\t");
+ writeCoord(output, p[0]);
+ fprintf(output, ";\n\t\t");
+ if (colorCode)
+ fprintf(output, "%c", colorCode);
+ fprintf(output, "(");
+ writeCoord(output, p[1]);
+ fprintf(output, ");\n");
+ break;
+ case (int) CubicSegment::EDGE_TYPE:
+ fprintf(output, "\t");
+ writeCoord(output, p[0]);
+ fprintf(output, ";\n\t\t");
+ if (colorCode)
+ fprintf(output, "%c", colorCode);
+ fprintf(output, "(");
+ writeCoord(output, p[1]);
+ fprintf(output, "; ");
+ writeCoord(output, p[2]);
+ fprintf(output, ");\n");
+ break;
}
}
fprintf(output, "\t#\n");
diff --git a/thirdparty/msdfgen/core/shape-description.h b/thirdparty/msdfgen/core/shape-description.h
index 5df7c50a03..6e2e223674 100644
--- a/thirdparty/msdfgen/core/shape-description.h
+++ b/thirdparty/msdfgen/core/shape-description.h
@@ -1,7 +1,6 @@
#pragma once
-#include <cstdlib>
#include <cstdio>
#include "Shape.h"