// Header for SFML unit tests. // // For a new system module test case, include this header. // This ensures that string conversions are visible and can be used by doctest for debug output. #pragma once #include #include #include #include #include // String conversions for doctest framework namespace sf { class Angle; class String; class Time; std::ostream& operator<<(std::ostream& os, const Angle& angle); std::ostream& operator<<(std::ostream& os, const String& string); std::ostream& operator<<(std::ostream& os, Time time); template std::ostream& operator<<(std::ostream& os, const Vector2& vector) { os << std::fixed << std::setprecision(std::numeric_limits::max_digits10); return os << "(" << vector.x << ", " << vector.y << ")"; } template std::ostream& operator<<(std::ostream& os, const Vector3& vector) { return os << "(" << vector.x << ", " << vector.y << ", " << vector.z << ")"; } } // namespace sf //////////////////////////////////////////////////////////// /// Class template for creating custom approximate comparisons. /// To register a new type, simply implement a custom operator== /// overload for that type. //////////////////////////////////////////////////////////// template struct Approx { explicit Approx(const T& t) : value(t) { } const T& value; }; bool operator==(const float& lhs, const Approx& rhs); bool operator==(const sf::Vector2f& lhs, const Approx& rhs); bool operator==(const sf::Vector3f& lhs, const Approx& rhs); bool operator==(const sf::Angle& lhs, const Approx& rhs); template std::ostream& operator<<(std::ostream& os, const Approx& approx) { return os << approx.value; }