diff options
author | Peter Keresztes Schmidt <carbenium@outlook.com> | 2020-09-07 00:22:37 +0200 |
---|---|---|
committer | GitHub <noreply@github.com> | 2020-09-07 00:22:37 +0200 |
commit | 68a4085427a898046b4afb73f6c369640418b848 (patch) | |
tree | 333bff35f8e71b0e5567b62bb8c3be7b03c32bd5 | |
parent | b63d655e20a0facf14fc77798c52ea67d8551fa7 (diff) |
Core/ChatCommands: Move ostream operator into Variant class so we don't pollute std:: (PR #25413)
-rw-r--r-- | src/server/game/Chat/ChatCommands/ChatCommandTags.h | 16 |
1 files changed, 6 insertions, 10 deletions
diff --git a/src/server/game/Chat/ChatCommands/ChatCommandTags.h b/src/server/game/Chat/ChatCommands/ChatCommandTags.h index f2bda962f51..84168a80d85 100644 --- a/src/server/game/Chat/ChatCommands/ChatCommandTags.h +++ b/src/server/game/Chat/ChatCommands/ChatCommandTags.h @@ -257,17 +257,13 @@ namespace Trinity::ChatCommands template <typename T> constexpr bool holds_alternative() const { return std::holds_alternative<T>(static_cast<base const&>(*this)); } - }; -} -/* make the correct operator<< to use explicit, because otherwise the compiler gets confused with the implicit std::variant conversion */ -namespace std -{ - template <typename... Ts> - auto operator<<(std::ostream& os, Trinity::ChatCommands::Variant<Ts...> const& v) -> std::enable_if_t<Trinity::ChatCommands::Variant<Ts...>::have_operators, std::ostream&> - { - return (os << *v); - } + template <bool C = have_operators> + friend std::enable_if_t<C, std::ostream&> operator<<(std::ostream& os, Trinity::ChatCommands::Variant<T1, Ts...> const& v) + { + return (os << *v); + } + }; } #endif |