More C++20 additions, fix Windows build failures.

This commit is contained in:
Stephen Anthony 2024-05-09 19:50:19 -02:30
parent 06370ecffd
commit 7e6880908b
3 changed files with 7 additions and 9 deletions

View File

@ -39,13 +39,12 @@ struct Point
explicit constexpr Point(Int32 x1, Int32 y1) : x{x1}, y{y1} { } explicit constexpr Point(Int32 x1, Int32 y1) : x{x1}, y{y1} { }
explicit Point(string_view p) { explicit Point(string_view p) {
char c = '\0'; char c = '\0';
istringstream buf(string{p}); // TODO: fixed in C++20 istringstream buf(string{p}); // TODO: fixed in C++23
buf >> x >> c >> y; buf >> x >> c >> y;
if(c != 'x') if(c != 'x')
x = y = 0; x = y = 0;
} }
bool operator==(const Point& p) const { return x == p.x && y == p.y; } std::strong_ordering operator<=>(const Point& p) const = default;
bool operator!=(const Point& p) const { return !(*this == p); }
friend ostream& operator<<(ostream& os, const Point& p) { friend ostream& operator<<(ostream& os, const Point& p) {
os << p.x << "x" << p.y; os << p.x << "x" << p.y;
@ -62,7 +61,7 @@ struct Size
explicit constexpr Size(uInt32 w1, uInt32 h1) : w{w1}, h{h1} { } explicit constexpr Size(uInt32 w1, uInt32 h1) : w{w1}, h{h1} { }
explicit Size(string_view s) { explicit Size(string_view s) {
char c = '\0'; char c = '\0';
istringstream buf(string{s}); // TODO: fixed in C++20 istringstream buf(string{s}); // TODO: fixed in C++23
buf >> w >> c >> h; buf >> w >> c >> h;
if(c != 'x') if(c != 'x')
w = h = 0; w = h = 0;
@ -74,6 +73,7 @@ struct Size
h = BSPF::clamp(h, lower_h, upper_h); h = BSPF::clamp(h, lower_h, upper_h);
} }
// TODO: can this be replaced by <=> operator?
bool operator==(const Size& s) const { return w == s.w && h == s.h; } bool operator==(const Size& s) const { return w == s.w && h == s.h; }
bool operator< (const Size& s) const { return w < s.w && h < s.h; } bool operator< (const Size& s) const { return w < s.w && h < s.h; }
bool operator> (const Size& s) const { return w > s.w || h > s.h; } bool operator> (const Size& s) const { return w > s.w || h > s.h; }
@ -175,10 +175,7 @@ public:
return r.left != x || r.top != y; return r.left != x || r.top != y;
} }
bool operator==(const Rect& r) const { std::strong_ordering operator<=>(const Rect& r) const = default;
return top == r.top && left == r.left && bottom == r.bottom && right == r.right;
}
bool operator!=(const Rect& r) const { return !(*this == r); }
friend ostream& operator<<(ostream& os, const Rect& r) { friend ostream& operator<<(ostream& os, const Rect& r) {
os << r.point() << "," << r.size(); os << r.point() << "," << r.size();

View File

@ -70,7 +70,7 @@ class Variant
Common::Point toPoint() const { return Common::Point(data); } Common::Point toPoint() const { return Common::Point(data); }
// Comparison // Comparison
bool operator<=>(const Variant& v) const = default; std::strong_ordering operator<=>(const Variant& v) const = default;
friend ostream& operator<<(ostream& os, const Variant& v) { friend ostream& operator<<(ostream& os, const Variant& v) {
return os << v.data; return os << v.data;

View File

@ -41,6 +41,7 @@ using uInt64 = uint64_t;
// types: cout, cerr, string, ostream, istream, etc. // types: cout, cerr, string, ostream, istream, etc.
#include <array> #include <array>
#include <algorithm> #include <algorithm>
#include <compare>
#include <iostream> #include <iostream>
#include <fstream> #include <fstream>
#include <functional> #include <functional>