mirror of https://github.com/stella-emu/stella.git
More C++20 additions, fix Windows build failures.
This commit is contained in:
parent
06370ecffd
commit
7e6880908b
|
@ -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();
|
||||||
|
|
|
@ -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;
|
||||||
|
|
|
@ -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>
|
||||||
|
|
Loading…
Reference in New Issue