mirror of
https://github.com/PabloMK7/citra.git
synced 2025-01-18 09:53:05 +01:00
Fix gcc 13+ compilation and update fmt. (#142)
* Soc and artic_bass: gcc 13+ compatibility fix. * externals/fmt: update to HEAD fcd3e1e19. It will fix error. integer_sequence<bool, (Is == Is)...> [-Werror=tautological-compare] The updating is helpful and needed. Fmt has gone through two public versions since its last update and has fixed many bugs, including new compiler optimizations. But neither of these two public versions can fix the errors encountered above. We need to switch to a working version. It can be fixed after fmt/8e62172.There are still many optimizations, Such as this one: Std. h c++23 build fix (# 3856) And these: C++23 compatibility: basicstring_view cannot be constructed from nullptr (# 3846) Fix warning C4702 emitted from format.h (MSVC) (#3866) Of course, there are other functional improvements as well. Very helpful. The selected version is the one that has been checked and works well. And synchronously updating local code. * citra_qt/ui: clean up duplicate naming warnings.
This commit is contained in:
parent
de1f082e75
commit
09dc3a5592
14 changed files with 24 additions and 24 deletions
2
externals/fmt
vendored
2
externals/fmt
vendored
|
@ -1 +1 @@
|
||||||
Subproject commit 2dd4fa8742fdac36468f8d8ea3e06e78215551f8
|
Subproject commit fcd3e1e19c8d2df94bb6cb40d7f1c97a9872cf2b
|
|
@ -86,7 +86,7 @@
|
||||||
</layout>
|
</layout>
|
||||||
</item>
|
</item>
|
||||||
<item>
|
<item>
|
||||||
<layout class="QHBoxLayout" name="horizontalLayout">
|
<layout class="QHBoxLayout" name="horizontalLayout1">
|
||||||
<item>
|
<item>
|
||||||
<widget class="QLabel" name="label_3">
|
<widget class="QLabel" name="label_3">
|
||||||
<property name="text">
|
<property name="text">
|
||||||
|
@ -100,7 +100,7 @@
|
||||||
</layout>
|
</layout>
|
||||||
</item>
|
</item>
|
||||||
<item>
|
<item>
|
||||||
<layout class="QHBoxLayout" name="horizontalLayout_2">
|
<layout class="QHBoxLayout" name="horizontalLayout2">
|
||||||
<item>
|
<item>
|
||||||
<widget class="QCheckBox" name="toggle_console">
|
<widget class="QCheckBox" name="toggle_console">
|
||||||
<property name="text">
|
<property name="text">
|
||||||
|
@ -125,7 +125,7 @@
|
||||||
<property name="title">
|
<property name="title">
|
||||||
<string>CPU</string>
|
<string>CPU</string>
|
||||||
</property>
|
</property>
|
||||||
<layout class="QGridLayout" name="gridLayout_2">
|
<layout class="QGridLayout" name="clock_speed_GLayout">
|
||||||
<item row="1" column="0">
|
<item row="1" column="0">
|
||||||
<widget class="QWidget" name="clock_speed_widget" native="true">
|
<widget class="QWidget" name="clock_speed_widget" native="true">
|
||||||
<layout class="QHBoxLayout" name="clock_speed_layout">
|
<layout class="QHBoxLayout" name="clock_speed_layout">
|
||||||
|
|
|
@ -12,9 +12,9 @@
|
||||||
#if FMT_VERSION >= 80100
|
#if FMT_VERSION >= 80100
|
||||||
template <typename T>
|
template <typename T>
|
||||||
struct fmt::formatter<T, std::enable_if_t<std::is_enum_v<T>, char>>
|
struct fmt::formatter<T, std::enable_if_t<std::is_enum_v<T>, char>>
|
||||||
: formatter<std::underlying_type_t<T>> {
|
: fmt::formatter<std::underlying_type_t<T>> {
|
||||||
template <typename FormatContext>
|
template <typename FormatContext>
|
||||||
auto format(const T& value, FormatContext& ctx) -> decltype(ctx.out()) {
|
auto format(const T& value, FormatContext& ctx) const -> decltype(ctx.out()) {
|
||||||
return fmt::formatter<std::underlying_type_t<T>>::format(
|
return fmt::formatter<std::underlying_type_t<T>>::format(
|
||||||
static_cast<std::underlying_type_t<T>>(value), ctx);
|
static_cast<std::underlying_type_t<T>>(value), ctx);
|
||||||
}
|
}
|
||||||
|
|
|
@ -9,7 +9,7 @@
|
||||||
#include <boost/serialization/unique_ptr.hpp>
|
#include <boost/serialization/unique_ptr.hpp>
|
||||||
#include <cryptopp/osrng.h>
|
#include <cryptopp/osrng.h>
|
||||||
#include <cryptopp/sha.h>
|
#include <cryptopp/sha.h>
|
||||||
#include <fmt/format.h>
|
#include <fmt/ranges.h>
|
||||||
#include "common/archives.h"
|
#include "common/archives.h"
|
||||||
#include "common/file_util.h"
|
#include "common/file_util.h"
|
||||||
#include "common/logging/log.h"
|
#include "common/logging/log.h"
|
||||||
|
|
|
@ -2,7 +2,7 @@
|
||||||
// Licensed under GPLv2 or any later version
|
// Licensed under GPLv2 or any later version
|
||||||
// Refer to the license.txt file included.
|
// Refer to the license.txt file included.
|
||||||
|
|
||||||
#include <fmt/format.h>
|
#include <fmt/ranges.h>
|
||||||
#include "common/alignment.h"
|
#include "common/alignment.h"
|
||||||
#include "common/settings.h"
|
#include "common/settings.h"
|
||||||
#include "core/core_timing.h"
|
#include "core/core_timing.h"
|
||||||
|
|
|
@ -8,7 +8,7 @@
|
||||||
#include <boost/serialization/base_object.hpp>
|
#include <boost/serialization/base_object.hpp>
|
||||||
#include <boost/serialization/shared_ptr.hpp>
|
#include <boost/serialization/shared_ptr.hpp>
|
||||||
#include <boost/serialization/unique_ptr.hpp>
|
#include <boost/serialization/unique_ptr.hpp>
|
||||||
#include <fmt/format.h>
|
#include <fmt/ranges.h>
|
||||||
#include "common/archives.h"
|
#include "common/archives.h"
|
||||||
#include "common/swap.h"
|
#include "common/swap.h"
|
||||||
#include "core/core.h"
|
#include "core/core.h"
|
||||||
|
|
|
@ -2236,18 +2236,15 @@ std::optional<SOC_U::InterfaceInfo> SOC_U::GetDefaultInterfaceInfo() {
|
||||||
}
|
}
|
||||||
|
|
||||||
InterfaceInfo ret;
|
InterfaceInfo ret;
|
||||||
#ifdef _WIN32
|
|
||||||
SOCKET sock_fd = -1;
|
SocketHolder::SOCKET sock_fd = -1;
|
||||||
#else
|
|
||||||
int sock_fd = -1;
|
|
||||||
#endif
|
|
||||||
bool interface_found = false;
|
bool interface_found = false;
|
||||||
struct sockaddr_in s_in = {.sin_family = AF_INET, .sin_port = htons(53), .sin_addr = {}};
|
struct sockaddr_in s_in = {.sin_family = AF_INET, .sin_port = htons(53), .sin_addr = {}};
|
||||||
s_in.sin_addr.s_addr = inet_addr("8.8.8.8");
|
s_in.sin_addr.s_addr = inet_addr("8.8.8.8");
|
||||||
socklen_t s_info_len = sizeof(struct sockaddr_in);
|
socklen_t s_info_len = sizeof(struct sockaddr_in);
|
||||||
sockaddr_in s_info;
|
sockaddr_in s_info;
|
||||||
|
|
||||||
if (static_cast<int>(sock_fd = ::socket(AF_INET, SOCK_STREAM, 0)) == -1) {
|
if ((sock_fd = ::socket(AF_INET, SOCK_STREAM, 0)) == static_cast<SocketHolder::SOCKET>(-1)) {
|
||||||
return std::nullopt;
|
return std::nullopt;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -2265,7 +2262,7 @@ std::optional<SOC_U::InterfaceInfo> SOC_U::GetDefaultInterfaceInfo() {
|
||||||
|
|
||||||
#ifdef _WIN32
|
#ifdef _WIN32
|
||||||
sock_fd = WSASocket(AF_INET, SOCK_DGRAM, 0, 0, 0, 0);
|
sock_fd = WSASocket(AF_INET, SOCK_DGRAM, 0, 0, 0, 0);
|
||||||
if (static_cast<int>(sock_fd) == SOCKET_ERROR) {
|
if (sock_fd == static_cast<SocketHolder::SOCKET>(SOCKET_ERROR)) {
|
||||||
return std::nullopt;
|
return std::nullopt;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -25,11 +25,11 @@ namespace Service::SOC {
|
||||||
struct SocketHolder {
|
struct SocketHolder {
|
||||||
#ifdef _WIN32
|
#ifdef _WIN32
|
||||||
using SOCKET = unsigned long long;
|
using SOCKET = unsigned long long;
|
||||||
SOCKET socket_fd; ///< The socket descriptor
|
|
||||||
#else
|
#else
|
||||||
int socket_fd; ///< The socket descriptor
|
using SOCKET = int;
|
||||||
#endif // _WIN32
|
#endif // _WIN32
|
||||||
|
|
||||||
|
SOCKET socket_fd; ///< The socket descriptor
|
||||||
bool blocking = true; ///< Whether the socket is blocking or not.
|
bool blocking = true; ///< Whether the socket is blocking or not.
|
||||||
bool isGlobal = false;
|
bool isGlobal = false;
|
||||||
bool shutdown_rd = false;
|
bool shutdown_rd = false;
|
||||||
|
|
|
@ -10,6 +10,7 @@
|
||||||
#include <boost/optional.hpp>
|
#include <boost/optional.hpp>
|
||||||
#include <cryptopp/hex.h>
|
#include <cryptopp/hex.h>
|
||||||
#include <cryptopp/osrng.h>
|
#include <cryptopp/osrng.h>
|
||||||
|
#include <fmt/ranges.h>
|
||||||
#include "common/archives.h"
|
#include "common/archives.h"
|
||||||
#include "common/bit_field.h"
|
#include "common/bit_field.h"
|
||||||
#include "common/file_util.h"
|
#include "common/file_util.h"
|
||||||
|
|
|
@ -5,7 +5,7 @@
|
||||||
#include <chrono>
|
#include <chrono>
|
||||||
#include <sstream>
|
#include <sstream>
|
||||||
#include <cryptopp/hex.h>
|
#include <cryptopp/hex.h>
|
||||||
#include <fmt/format.h>
|
#include <fmt/ranges.h>
|
||||||
#include "common/archives.h"
|
#include "common/archives.h"
|
||||||
#include "common/file_util.h"
|
#include "common/file_util.h"
|
||||||
#include "common/logging/log.h"
|
#include "common/logging/log.h"
|
||||||
|
|
|
@ -163,7 +163,7 @@ bool Client::Connect() {
|
||||||
}
|
}
|
||||||
|
|
||||||
main_socket = ::socket(AF_INET, SOCK_STREAM, 0);
|
main_socket = ::socket(AF_INET, SOCK_STREAM, 0);
|
||||||
if (main_socket == -1) {
|
if (main_socket == static_cast<SocketHolder>(-1)) {
|
||||||
LOG_ERROR(Network, "Failed to create socket");
|
LOG_ERROR(Network, "Failed to create socket");
|
||||||
SignalCommunicationError();
|
SignalCommunicationError();
|
||||||
return false;
|
return false;
|
||||||
|
@ -249,7 +249,7 @@ bool Client::Connect() {
|
||||||
std::stringstream ss_port(worker_ports.value());
|
std::stringstream ss_port(worker_ports.value());
|
||||||
while (std::getline(ss_port, str_port, ',')) {
|
while (std::getline(ss_port, str_port, ',')) {
|
||||||
int port = str_to_int(str_port);
|
int port = str_to_int(str_port);
|
||||||
if (port < 0 || port > USHRT_MAX) {
|
if (port < 0 || port > static_cast<int>(USHRT_MAX)) {
|
||||||
shutdown(main_socket, SHUT_RDWR);
|
shutdown(main_socket, SHUT_RDWR);
|
||||||
closesocket(main_socket);
|
closesocket(main_socket);
|
||||||
LOG_ERROR(Network, "Couldn't parse server worker ports");
|
LOG_ERROR(Network, "Couldn't parse server worker ports");
|
||||||
|
@ -518,7 +518,7 @@ std::optional<ArticBaseCommon::DataPacket> Client::SendRequestPacket(
|
||||||
const std::chrono::nanoseconds& read_timeout) {
|
const std::chrono::nanoseconds& read_timeout) {
|
||||||
std::scoped_lock<std::mutex> l(send_mutex);
|
std::scoped_lock<std::mutex> l(send_mutex);
|
||||||
|
|
||||||
if (main_socket == -1) {
|
if (main_socket == static_cast<SocketHolder>(-1)) {
|
||||||
return std::nullopt;
|
return std::nullopt;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -586,7 +586,7 @@ Client::Handler::Handler(Client& _client, u32 _addr, u16 _port, int _id)
|
||||||
|
|
||||||
void Client::Handler::RunLoop() {
|
void Client::Handler::RunLoop() {
|
||||||
handler_socket = ::socket(AF_INET, SOCK_STREAM, 0);
|
handler_socket = ::socket(AF_INET, SOCK_STREAM, 0);
|
||||||
if (handler_socket == -1) {
|
if (handler_socket == static_cast<SocketHolder>(-1)) {
|
||||||
LOG_ERROR(Network, "Failed to create socket");
|
LOG_ERROR(Network, "Failed to create socket");
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
|
@ -4,6 +4,7 @@
|
||||||
|
|
||||||
#include <array>
|
#include <array>
|
||||||
#include <cstddef>
|
#include <cstddef>
|
||||||
|
#include <tuple>
|
||||||
#include "video_core/pica/regs_texturing.h"
|
#include "video_core/pica/regs_texturing.h"
|
||||||
#include "video_core/renderer_software/sw_clipper.h"
|
#include "video_core/renderer_software/sw_clipper.h"
|
||||||
|
|
||||||
|
|
|
@ -4,7 +4,7 @@
|
||||||
|
|
||||||
#include <span>
|
#include <span>
|
||||||
#include <boost/container/static_vector.hpp>
|
#include <boost/container/static_vector.hpp>
|
||||||
#include <fmt/format.h>
|
#include <fmt/ranges.h>
|
||||||
|
|
||||||
#include "common/assert.h"
|
#include "common/assert.h"
|
||||||
#include "common/settings.h"
|
#include "common/settings.h"
|
||||||
|
|
|
@ -2,6 +2,7 @@
|
||||||
// Licensed under GPLv2 or any later version
|
// Licensed under GPLv2 or any later version
|
||||||
// Refer to the license.txt file included.
|
// Refer to the license.txt file included.
|
||||||
|
|
||||||
|
#include <memory>
|
||||||
#include <SPIRV/GlslangToSpv.h>
|
#include <SPIRV/GlslangToSpv.h>
|
||||||
#include <glslang/Include/ResourceLimits.h>
|
#include <glslang/Include/ResourceLimits.h>
|
||||||
#include <glslang/Public/ShaderLang.h>
|
#include <glslang/Public/ShaderLang.h>
|
||||||
|
|
Loading…
Reference in a new issue