From ed5eb49d477354398964e3ced561b9fcdebad2ea Mon Sep 17 00:00:00 2001 From: mitaclaw <140017135+mitaclaw@users.noreply.github.com> Date: Sun, 29 Sep 2024 10:31:49 -0700 Subject: [PATCH 01/17] Modernize `std::for_each` with ranges --- Source/Core/Core/Debugger/BranchWatch.cpp | 3 +-- 1 file changed, 1 insertion(+), 2 deletions(-) diff --git a/Source/Core/Core/Debugger/BranchWatch.cpp b/Source/Core/Core/Debugger/BranchWatch.cpp index 4ea0559cd9..7facfda5d0 100644 --- a/Source/Core/Core/Debugger/BranchWatch.cpp +++ b/Source/Core/Core/Debugger/BranchWatch.cpp @@ -307,8 +307,7 @@ void BranchWatch::UpdateHitsSnapshot() void BranchWatch::ClearSelectionInspection() { - std::for_each(m_selection.begin(), m_selection.end(), - [](Selection::value_type& value) { value.inspection = {}; }); + std::ranges::for_each(m_selection, [](Selection::value_type& value) { value.inspection = {}; }); } void BranchWatch::SetSelectedInspected(std::size_t idx, SelectionInspection inspection) From c46060e2985f24a6668db1061681009997aef896 Mon Sep 17 00:00:00 2001 From: mitaclaw <140017135+mitaclaw@users.noreply.github.com> Date: Sat, 21 Sep 2024 18:13:21 -0700 Subject: [PATCH 02/17] Modernize `std::count` with ranges --- Source/Core/Core/IOS/FS/FileSystemProxy.cpp | 2 +- Source/Core/Core/IOS/FS/HostBackend/FS.cpp | 2 +- Source/UnitTests/Core/IOS/FS/FileSystemTest.cpp | 2 +- 3 files changed, 3 insertions(+), 3 deletions(-) diff --git a/Source/Core/Core/IOS/FS/FileSystemProxy.cpp b/Source/Core/Core/IOS/FS/FileSystemProxy.cpp index f69da2f9b5..f2cb61e199 100644 --- a/Source/Core/Core/IOS/FS/FileSystemProxy.cpp +++ b/Source/Core/Core/IOS/FS/FileSystemProxy.cpp @@ -143,7 +143,7 @@ enum class FileLookupMode static SystemTimers::TimeBaseTick EstimateFileLookupTicks(const std::string& path, FileLookupMode mode) { - const size_t number_of_path_components = std::count(path.cbegin(), path.cend(), '/'); + const size_t number_of_path_components = std::ranges::count(path, '/'); if (number_of_path_components == 0) return 0_tbticks; diff --git a/Source/Core/Core/IOS/FS/HostBackend/FS.cpp b/Source/Core/Core/IOS/FS/HostBackend/FS.cpp index da5fa6d983..2d1e1143c9 100644 --- a/Source/Core/Core/IOS/FS/HostBackend/FS.cpp +++ b/Source/Core/Core/IOS/FS/HostBackend/FS.cpp @@ -467,7 +467,7 @@ ResultCode HostFileSystem::CreateFileOrDirectory(Uid uid, Gid gid, const std::st return ResultCode::Invalid; } - if (!is_file && std::count(path.begin(), path.end(), '/') > int(MaxPathDepth)) + if (!is_file && std::ranges::count(path, '/') > int(MaxPathDepth)) return ResultCode::TooManyPathComponents; const auto split_path = SplitPathAndBasename(path); diff --git a/Source/UnitTests/Core/IOS/FS/FileSystemTest.cpp b/Source/UnitTests/Core/IOS/FS/FileSystemTest.cpp index b1e6997e34..513f86d4c9 100644 --- a/Source/UnitTests/Core/IOS/FS/FileSystemTest.cpp +++ b/Source/UnitTests/Core/IOS/FS/FileSystemTest.cpp @@ -121,7 +121,7 @@ TEST_F(FileSystemTest, CreateFile) const Result> tmp_files = m_fs->ReadDirectory(Uid{0}, Gid{0}, "/tmp"); ASSERT_TRUE(tmp_files.Succeeded()); - EXPECT_EQ(std::count(tmp_files->begin(), tmp_files->end(), "f"), 1u); + EXPECT_EQ(std::ranges::count(*tmp_files, "f"), 1u); // Test invalid paths // Unprintable characters From 4cc5e1972ae5643af001276758c4456ee7292f41 Mon Sep 17 00:00:00 2001 From: mitaclaw <140017135+mitaclaw@users.noreply.github.com> Date: Sat, 21 Sep 2024 18:24:22 -0700 Subject: [PATCH 03/17] Modernize `std::count_if` with ranges --- Source/Core/Common/StringUtil.cpp | 3 +-- Source/Core/Core/IOS/ES/NandUtils.cpp | 9 ++++----- .../ControllerInterface/DInput/DInputJoystick.cpp | 5 ++--- 3 files changed, 7 insertions(+), 10 deletions(-) diff --git a/Source/Core/Common/StringUtil.cpp b/Source/Core/Common/StringUtil.cpp index 508ba8baf8..9881708a27 100644 --- a/Source/Core/Common/StringUtil.cpp +++ b/Source/Core/Common/StringUtil.cpp @@ -403,8 +403,7 @@ void StringPopBackIf(std::string* s, char c) size_t StringUTF8CodePointCount(std::string_view str) { - return str.size() - - std::count_if(str.begin(), str.end(), [](char c) -> bool { return (c & 0xC0) == 0x80; }); + return str.size() - std::ranges::count_if(str, [](char c) -> bool { return (c & 0xC0) == 0x80; }); } #ifdef _WIN32 diff --git a/Source/Core/Core/IOS/ES/NandUtils.cpp b/Source/Core/Core/IOS/ES/NandUtils.cpp index 7198049462..9c742974b8 100644 --- a/Source/Core/Core/IOS/ES/NandUtils.cpp +++ b/Source/Core/Core/IOS/ES/NandUtils.cpp @@ -219,11 +219,10 @@ ESCore::GetStoredContentsFromTMD(const ES::TMDReader& tmd, u32 ESCore::GetSharedContentsCount() const { const auto entries = m_ios.GetFS()->ReadDirectory(PID_KERNEL, PID_KERNEL, "/shared1"); - return static_cast( - std::count_if(entries->begin(), entries->end(), [this](const std::string& entry) { - return !m_ios.GetFS()->ReadDirectory(PID_KERNEL, PID_KERNEL, "/shared1/" + entry) && - entry.size() == 12 && entry.compare(8, 4, ".app") == 0; - })); + return static_cast(std::ranges::count_if(*entries, [this](const std::string& entry) { + return !m_ios.GetFS()->ReadDirectory(PID_KERNEL, PID_KERNEL, "/shared1/" + entry) && + entry.size() == 12 && entry.compare(8, 4, ".app") == 0; + })); } std::vector> ESCore::GetSharedContents() const diff --git a/Source/Core/InputCommon/ControllerInterface/DInput/DInputJoystick.cpp b/Source/Core/InputCommon/ControllerInterface/DInput/DInputJoystick.cpp index 577bd761d4..5d3e353a0a 100644 --- a/Source/Core/InputCommon/ControllerInterface/DInput/DInputJoystick.cpp +++ b/Source/Core/InputCommon/ControllerInterface/DInput/DInputJoystick.cpp @@ -176,9 +176,8 @@ Joystick::Joystick(const LPDIRECTINPUTDEVICE8 device) : m_device(device) std::list objects; if (SUCCEEDED(m_device->EnumObjects(DIEnumDeviceObjectsCallback, (LPVOID)&objects, DIDFT_AXIS))) { - const int num_ff_axes = - std::count_if(std::begin(objects), std::end(objects), - [](const auto& pdidoi) { return (pdidoi.dwFlags & DIDOI_FFACTUATOR) != 0; }); + const int num_ff_axes = std::ranges::count_if( + objects, [](const auto& pdidoi) { return (pdidoi.dwFlags & DIDOI_FFACTUATOR) != 0; }); InitForceFeedback(m_device, num_ff_axes); } From 249defa72b1da2a806a18cd93c7300c3aa1a844f Mon Sep 17 00:00:00 2001 From: mitaclaw <140017135+mitaclaw@users.noreply.github.com> Date: Sat, 21 Sep 2024 23:46:43 -0700 Subject: [PATCH 04/17] Modernize `std::equal` with ranges --- Source/Core/DolphinQt/FIFO/FIFOAnalyzer.cpp | 3 +-- Source/Core/InputCommon/ControllerEmu/ControllerEmu.h | 3 +-- Source/UnitTests/Common/SettingsHandlerTest.cpp | 8 ++++---- 3 files changed, 6 insertions(+), 8 deletions(-) diff --git a/Source/Core/DolphinQt/FIFO/FIFOAnalyzer.cpp b/Source/Core/DolphinQt/FIFO/FIFOAnalyzer.cpp index e33ba4c214..4651a27a80 100644 --- a/Source/Core/DolphinQt/FIFO/FIFOAnalyzer.cpp +++ b/Source/Core/DolphinQt/FIFO/FIFOAnalyzer.cpp @@ -191,8 +191,7 @@ void FIFOAnalyzer::UpdateTree() // We shouldn't end on a Command (it should end with an EFB copy) ASSERT(part_start == frame_info.parts.size()); // The counts we computed should match the frame's counts - ASSERT(std::equal(frame_info.part_type_counts.begin(), frame_info.part_type_counts.end(), - part_counts.begin())); + ASSERT(std::ranges::equal(frame_info.part_type_counts, part_counts)); } } diff --git a/Source/Core/InputCommon/ControllerEmu/ControllerEmu.h b/Source/Core/InputCommon/ControllerEmu/ControllerEmu.h index b77b2ce3ed..88c14cfdb1 100644 --- a/Source/Core/InputCommon/ControllerEmu/ControllerEmu.h +++ b/Source/Core/InputCommon/ControllerEmu/ControllerEmu.h @@ -53,8 +53,7 @@ struct TwoPointCalibration } else { - return std::equal(std::begin(max.data), std::end(max.data), std::begin(zero.data), - std::not_equal_to<>()); + return std::ranges::equal(max.data, zero.data, std::ranges::not_equal_to{}); } } diff --git a/Source/UnitTests/Common/SettingsHandlerTest.cpp b/Source/UnitTests/Common/SettingsHandlerTest.cpp index f480c0636e..360a2221a5 100644 --- a/Source/UnitTests/Common/SettingsHandlerTest.cpp +++ b/Source/UnitTests/Common/SettingsHandlerTest.cpp @@ -47,7 +47,7 @@ TEST(SettingsHandlerTest, EncryptSingleSetting) handler.AddSetting("key", "val"); Common::SettingsHandler::Buffer buffer = handler.GetBytes(); - EXPECT_TRUE(std::equal(buffer.begin(), buffer.end(), BUFFER_A.begin(), BUFFER_A.end())); + EXPECT_TRUE(std::ranges::equal(buffer, BUFFER_A)); } TEST(SettingsHandlerTest, DecryptSingleSetting) @@ -64,7 +64,7 @@ TEST(SettingsHandlerTest, EncryptMultipleSettings) handler.AddSetting("foo", "bar"); Common::SettingsHandler::Buffer buffer = handler.GetBytes(); - EXPECT_TRUE(std::equal(buffer.begin(), buffer.end(), BUFFER_B.begin(), BUFFER_B.end())); + EXPECT_TRUE(std::ranges::equal(buffer, BUFFER_B)); } TEST(SettingsHandlerTest, DecryptMultipleSettings) @@ -88,7 +88,7 @@ TEST(SettingsHandlerTest, EncryptAddsLFOnNullChar) handler.AddSetting("\xFA", "a"); Common::SettingsHandler::Buffer buffer = handler.GetBytes(); - EXPECT_TRUE(std::equal(buffer.begin(), buffer.end(), BUFFER_C.begin(), BUFFER_C.end())); + EXPECT_TRUE(std::ranges::equal(buffer, BUFFER_C)); } TEST(SettingsHandlerTest, EncryptAddsLFOnNullCharTwice) @@ -97,7 +97,7 @@ TEST(SettingsHandlerTest, EncryptAddsLFOnNullCharTwice) handler.AddSetting("\xFA\xE9", "a"); Common::SettingsHandler::Buffer buffer = handler.GetBytes(); - EXPECT_TRUE(std::equal(buffer.begin(), buffer.end(), BUFFER_D.begin(), BUFFER_D.end())); + EXPECT_TRUE(std::ranges::equal(buffer, BUFFER_D)); } TEST(SettingsHandlerTest, DecryptSingleAddedLF) From 7ce170f1385b114572fb9e71eeedfd5567784096 Mon Sep 17 00:00:00 2001 From: mitaclaw <140017135+mitaclaw@users.noreply.github.com> Date: Fri, 27 Sep 2024 22:30:01 -0700 Subject: [PATCH 05/17] Modernize `std::copy` with ranges --- Source/Core/Common/Crypto/ec.cpp | 4 ++-- Source/Core/Common/Network.cpp | 4 ++-- Source/Core/Core/FifoPlayer/FifoPlayer.cpp | 2 +- Source/Core/Core/HW/SI/SI_DeviceGBAEmu.cpp | 2 +- Source/Core/Core/HW/WiiSave.cpp | 2 +- Source/Core/Core/IOS/Crypto/Sha.cpp | 8 ++++---- Source/Core/Core/IOS/ES/Formats.cpp | 2 +- Source/Core/Core/IOS/ES/TitleManagement.cpp | 2 +- Source/Core/Core/IOS/ES/Views.cpp | 2 +- Source/Core/Core/IOS/IOSC.cpp | 2 +- Source/Core/Core/IOS/USB/Bluetooth/BTEmu.cpp | 4 ++-- Source/Core/Core/IOS/USB/Bluetooth/BTReal.cpp | 6 +++--- Source/Core/Core/Movie.cpp | 2 +- Source/Core/Core/SysConf.cpp | 2 +- 14 files changed, 22 insertions(+), 22 deletions(-) diff --git a/Source/Core/Common/Crypto/ec.cpp b/Source/Core/Common/Crypto/ec.cpp index 4cce6ce5dc..1f1b0e6018 100644 --- a/Source/Core/Common/Crypto/ec.cpp +++ b/Source/Core/Common/Crypto/ec.cpp @@ -252,8 +252,8 @@ Signature Sign(const u8* key, const u8* hash) bn_mul(s.data.data(), minv, kk, ec_N, 30); Signature signature; - std::copy(r.data.cbegin(), r.data.cend(), signature.begin()); - std::copy(s.data.cbegin(), s.data.cend(), signature.begin() + 30); + std::ranges::copy(r.data, signature.begin()); + std::ranges::copy(s.data, signature.begin() + 30); return signature; } diff --git a/Source/Core/Common/Network.cpp b/Source/Core/Common/Network.cpp index d8e60ccf1e..ca40eb3fe1 100644 --- a/Source/Core/Common/Network.cpp +++ b/Source/Core/Common/Network.cpp @@ -36,10 +36,10 @@ MACAddress GenerateMacAddress(const MACConsumer type) switch (type) { case MACConsumer::BBA: - std::copy(oui_bba.begin(), oui_bba.end(), mac.begin()); + std::ranges::copy(oui_bba, mac.begin()); break; case MACConsumer::IOS: - std::copy(oui_ios.begin(), oui_ios.end(), mac.begin()); + std::ranges::copy(oui_ios, mac.begin()); break; } diff --git a/Source/Core/Core/FifoPlayer/FifoPlayer.cpp b/Source/Core/Core/FifoPlayer/FifoPlayer.cpp index a7db428b00..8f6a54916e 100644 --- a/Source/Core/Core/FifoPlayer/FifoPlayer.cpp +++ b/Source/Core/Core/FifoPlayer/FifoPlayer.cpp @@ -500,7 +500,7 @@ void FifoPlayer::WriteMemory(const MemoryUpdate& memUpdate) else mem = &memory.GetRAM()[memUpdate.address & memory.GetRamMask()]; - std::copy(memUpdate.data.begin(), memUpdate.data.end(), mem); + std::ranges::copy(memUpdate.data, mem); } void FifoPlayer::WriteFifo(const u8* data, u32 start, u32 end) diff --git a/Source/Core/Core/HW/SI/SI_DeviceGBAEmu.cpp b/Source/Core/Core/HW/SI/SI_DeviceGBAEmu.cpp index 10522842de..f0b899192d 100644 --- a/Source/Core/Core/HW/SI/SI_DeviceGBAEmu.cpp +++ b/Source/Core/Core/HW/SI/SI_DeviceGBAEmu.cpp @@ -93,7 +93,7 @@ int CSIDevice_GBAEmu::RunBuffer(u8* buffer, int request_length) std::vector response = m_core->GetJoybusResponse(); if (response.empty()) return -1; - std::copy(response.begin(), response.end(), buffer); + std::ranges::copy(response, buffer); #ifdef _DEBUG const Common::Log::LogLevel log_level = diff --git a/Source/Core/Core/HW/WiiSave.cpp b/Source/Core/Core/HW/WiiSave.cpp index e706f19afe..b636fb0b2c 100644 --- a/Source/Core/Core/HW/WiiSave.cpp +++ b/Source/Core/Core/HW/WiiSave.cpp @@ -422,7 +422,7 @@ public: if (data) { std::vector file_data_enc(Common::AlignUp(data->size(), BLOCK_SZ)); - std::copy(data->cbegin(), data->cend(), file_data_enc.begin()); + std::ranges::copy(*data, file_data_enc.begin()); m_iosc.Encrypt(IOS::HLE::IOSC::HANDLE_SD_KEY, file_hdr.iv.data(), file_data_enc.data(), file_data_enc.size(), file_data_enc.data(), IOS::PID_ES); if (!m_file.WriteBytes(file_data_enc.data(), file_data_enc.size())) diff --git a/Source/Core/Core/IOS/Crypto/Sha.cpp b/Source/Core/Core/IOS/Crypto/Sha.cpp index de4415e140..a39927157c 100644 --- a/Source/Core/Core/IOS/Crypto/Sha.cpp +++ b/Source/Core/Core/IOS/Crypto/Sha.cpp @@ -33,14 +33,14 @@ std::optional ShaDevice::Open(const OpenRequest& request) static void ConvertContext(const ShaDevice::ShaContext& src, mbedtls_sha1_context* dest) { - std::copy(std::begin(src.length), std::end(src.length), std::begin(dest->total)); - std::copy(std::begin(src.states), std::end(src.states), std::begin(dest->state)); + std::ranges::copy(src.length, std::begin(dest->total)); + std::ranges::copy(src.states, std::begin(dest->state)); } static void ConvertContext(const mbedtls_sha1_context& src, ShaDevice::ShaContext* dest) { - std::copy(std::begin(src.total), std::end(src.total), std::begin(dest->length)); - std::copy(std::begin(src.state), std::end(src.state), std::begin(dest->states)); + std::ranges::copy(src.total, std::begin(dest->length)); + std::ranges::copy(src.state, std::begin(dest->states)); } HLE::ReturnCode ShaDevice::ProcessShaCommand(ShaIoctlv command, const IOCtlVRequest& request) diff --git a/Source/Core/Core/IOS/ES/Formats.cpp b/Source/Core/Core/IOS/ES/Formats.cpp index 2826f7aed5..41f658f738 100644 --- a/Source/Core/Core/IOS/ES/Formats.cpp +++ b/Source/Core/Core/IOS/ES/Formats.cpp @@ -535,7 +535,7 @@ HLE::ReturnCode TicketReader::Unpersonalise(HLE::IOSC& iosc) sizeof(Ticket::title_key), key.data(), PID_ES); // Finally, IOS copies the decrypted title key back to the ticket buffer. if (ret == IPC_SUCCESS) - std::copy(key.cbegin(), key.cend(), ticket_begin + offsetof(Ticket, title_key)); + std::ranges::copy(key, ticket_begin + offsetof(Ticket, title_key)); return ret; } diff --git a/Source/Core/Core/IOS/ES/TitleManagement.cpp b/Source/Core/Core/IOS/ES/TitleManagement.cpp index 9ff28fc545..df74acd766 100644 --- a/Source/Core/Core/IOS/ES/TitleManagement.cpp +++ b/Source/Core/Core/IOS/ES/TitleManagement.cpp @@ -817,7 +817,7 @@ ReturnCode ESCore::ExportContentData(Context& context, u32 content_fd, u8* data, if (encrypt_ret != IPC_SUCCESS) return encrypt_ret; - std::copy(output.cbegin(), output.cend(), data); + std::ranges::copy(output, data); return IPC_SUCCESS; } diff --git a/Source/Core/Core/IOS/ES/Views.cpp b/Source/Core/Core/IOS/ES/Views.cpp index 71d03ea0ed..988e19d86c 100644 --- a/Source/Core/Core/IOS/ES/Views.cpp +++ b/Source/Core/Core/IOS/ES/Views.cpp @@ -147,7 +147,7 @@ ReturnCode ESCore::GetTicketFromView(const u8* ticket_view, u8* ticket, u32* tic return ES_EACCES; } - std::copy(ticket_bytes.begin(), ticket_bytes.end(), ticket); + std::ranges::copy(ticket_bytes, ticket); return IPC_SUCCESS; } diff --git a/Source/Core/Core/IOS/IOSC.cpp b/Source/Core/Core/IOS/IOSC.cpp index 357aee143e..703cc01443 100644 --- a/Source/Core/Core/IOS/IOSC.cpp +++ b/Source/Core/Core/IOS/IOSC.cpp @@ -551,7 +551,7 @@ void IOSC::Sign(u8* sig_out, u8* ap_cert_out, u64 title_id, const u8* data, u32 // Sign the data. const auto data_digest = Common::SHA1::CalculateDigest(data, data_size); const auto signature = Common::ec::Sign(ap_priv.data(), data_digest.data()); - std::copy(signature.cbegin(), signature.cend(), sig_out); + std::ranges::copy(signature, sig_out); } void IOSC::LoadDefaultEntries() diff --git a/Source/Core/Core/IOS/USB/Bluetooth/BTEmu.cpp b/Source/Core/Core/IOS/USB/Bluetooth/BTEmu.cpp index b0be6bc249..0cca115ac5 100644 --- a/Source/Core/Core/IOS/USB/Bluetooth/BTEmu.cpp +++ b/Source/Core/Core/IOS/USB/Bluetooth/BTEmu.cpp @@ -51,8 +51,8 @@ BluetoothEmuDevice::BluetoothEmuDevice(EmulationKernel& ios, const std::string& const bdaddr_t tmp_bd = {0x11, 0x02, 0x19, 0x79, 0, i}; // Previous records can be safely overwritten, since they are backed up - std::copy(tmp_bd.begin(), tmp_bd.end(), std::rbegin(bt_dinf.active[i].bdaddr)); - std::copy(tmp_bd.begin(), tmp_bd.end(), std::rbegin(bt_dinf.registered[i].bdaddr)); + std::ranges::copy(tmp_bd, std::rbegin(bt_dinf.active[i].bdaddr)); + std::ranges::copy(tmp_bd, std::rbegin(bt_dinf.registered[i].bdaddr)); const auto& wm_name = (i == WIIMOTE_BALANCE_BOARD) ? "Nintendo RVL-WBC-01" : "Nintendo RVL-CNT-01"; diff --git a/Source/Core/Core/IOS/USB/Bluetooth/BTReal.cpp b/Source/Core/Core/IOS/USB/Bluetooth/BTReal.cpp index 81b0e3c223..a0eaa58624 100644 --- a/Source/Core/Core/IOS/USB/Bluetooth/BTReal.cpp +++ b/Source/Core/Core/IOS/USB/Bluetooth/BTReal.cpp @@ -482,9 +482,9 @@ bool BluetoothRealDevice::SendHCIStoreLinkKeyCommand() auto iterator = packet.begin() + sizeof(hci_cmd_hdr_t) + sizeof(hci_write_stored_link_key_cp); for (const auto& entry : m_link_keys) { - std::copy(entry.first.begin(), entry.first.end(), iterator); + std::ranges::copy(entry.first, iterator); iterator += entry.first.size(); - std::copy(entry.second.begin(), entry.second.end(), iterator); + std::ranges::copy(entry.second, iterator); iterator += entry.second.size(); } @@ -737,7 +737,7 @@ void BluetoothRealDevice::HandleBulkOrIntrTransfer(libusb_transfer* tr) hci_link_key_notification_ep notification; std::memcpy(¬ification, tr->buffer + sizeof(hci_event_hdr_t), sizeof(notification)); linkkey_t key; - std::copy(std::begin(notification.key), std::end(notification.key), std::begin(key)); + std::ranges::copy(notification.key, std::begin(key)); m_link_keys[notification.bdaddr] = key; } else if (event == HCI_EVENT_COMMAND_COMPL) diff --git a/Source/Core/Core/Movie.cpp b/Source/Core/Core/Movie.cpp index 325381f0e9..89e6d45d31 100644 --- a/Source/Core/Core/Movie.cpp +++ b/Source/Core/Core/Movie.cpp @@ -1100,7 +1100,7 @@ void MovieManager::LoadInput(const std::string& movie_path) "read-only mode off. Otherwise you'll probably get a desync.", byte_offset, byte_offset); - std::copy(movInput.begin(), movInput.end(), m_temp_input.begin()); + std::ranges::copy(movInput, m_temp_input.begin()); } else { diff --git a/Source/Core/Core/SysConf.cpp b/Source/Core/Core/SysConf.cpp index d9efcaa345..bc5f133f69 100644 --- a/Source/Core/Core/SysConf.cpp +++ b/Source/Core/Core/SysConf.cpp @@ -192,7 +192,7 @@ bool SysConf::Save() const // Make sure the buffer size is 0x4000 bytes now and write the footer. buffer.resize(SYSCONF_SIZE); constexpr std::array footer = {{'S', 'C', 'e', 'd'}}; - std::copy(footer.cbegin(), footer.cend(), buffer.end() - footer.size()); + std::ranges::copy(footer, buffer.end() - footer.size()); // Write the new data. const std::string temp_file = "/tmp/SYSCONF"; From 72436a0d1f0c9c4c67f8763e0ec2f0941a975e02 Mon Sep 17 00:00:00 2001 From: mitaclaw <140017135+mitaclaw@users.noreply.github.com> Date: Sun, 29 Sep 2024 10:44:00 -0700 Subject: [PATCH 06/17] Modernize `std::transform` with ranges In StringUtil.h, the lambdas wrapping `Common::ToLower(char)` and `Common::ToUpper(char)` were only necessary due to the function names being overloaded. --- Source/Core/Common/StringUtil.cpp | 4 ++-- Source/Core/Core/HW/WiimoteEmu/Camera.cpp | 2 +- Source/Core/DolphinQt/Settings/InterfacePane.cpp | 3 +-- Source/Core/DolphinQt/ToolBar.cpp | 4 ++-- 4 files changed, 6 insertions(+), 7 deletions(-) diff --git a/Source/Core/Common/StringUtil.cpp b/Source/Core/Common/StringUtil.cpp index 9881708a27..d3e7caacdf 100644 --- a/Source/Core/Common/StringUtil.cpp +++ b/Source/Core/Common/StringUtil.cpp @@ -655,12 +655,12 @@ std::string GetEscapedHtml(std::string html) void ToLower(std::string* str) { - std::transform(str->begin(), str->end(), str->begin(), [](char c) { return Common::ToLower(c); }); + std::ranges::transform(*str, str->begin(), static_cast(Common::ToLower)); } void ToUpper(std::string* str) { - std::transform(str->begin(), str->end(), str->begin(), [](char c) { return Common::ToUpper(c); }); + std::ranges::transform(*str, str->begin(), static_cast(Common::ToUpper)); } bool CaseInsensitiveEquals(std::string_view a, std::string_view b) diff --git a/Source/Core/Core/HW/WiimoteEmu/Camera.cpp b/Source/Core/Core/HW/WiimoteEmu/Camera.cpp index 7b68ab9d5f..1dcdb77952 100644 --- a/Source/Core/Core/HW/WiimoteEmu/Camera.cpp +++ b/Source/Core/Core/HW/WiimoteEmu/Camera.cpp @@ -70,7 +70,7 @@ CameraLogic::GetCameraPoints(const Common::Matrix44& transform, Common::Vec2 fie std::array camera_points; - std::transform(leds.begin(), leds.end(), camera_points.begin(), [&](const Vec3& v) { + std::ranges::transform(leds, camera_points.begin(), [&](const Vec3& v) { const auto point = camera_view * Vec4(v, 1.0); // Check if LED is behind camera. diff --git a/Source/Core/DolphinQt/Settings/InterfacePane.cpp b/Source/Core/DolphinQt/Settings/InterfacePane.cpp index 1fc0caea71..e52fb69200 100644 --- a/Source/Core/DolphinQt/Settings/InterfacePane.cpp +++ b/Source/Core/DolphinQt/Settings/InterfacePane.cpp @@ -130,8 +130,7 @@ void InterfacePane::CreateUI() Common::DoFileSearch({File::GetUserPath(D_THEMES_IDX), File::GetSysDirectory() + THEMES_DIR}); std::vector theme_names; theme_names.reserve(theme_paths.size()); - std::transform(theme_paths.cbegin(), theme_paths.cend(), std::back_inserter(theme_names), - PathToFileName); + std::ranges::transform(theme_paths, std::back_inserter(theme_names), PathToFileName); // Theme Combobox m_combobox_theme = new ConfigStringChoice(theme_names, Config::MAIN_THEME_NAME); diff --git a/Source/Core/DolphinQt/ToolBar.cpp b/Source/Core/DolphinQt/ToolBar.cpp index 74a31dcfde..9649af6b00 100644 --- a/Source/Core/DolphinQt/ToolBar.cpp +++ b/Source/Core/DolphinQt/ToolBar.cpp @@ -143,8 +143,8 @@ void ToolBar::MakeActions() } std::vector widths; - std::transform(items.begin(), items.end(), std::back_inserter(widths), - [](QWidget* item) { return item->sizeHint().width(); }); + std::ranges::transform(items, std::back_inserter(widths), + [](QWidget* item) { return item->sizeHint().width(); }); const int min_width = *std::max_element(widths.begin(), widths.end()) * 0.85; for (QWidget* widget : items) From 0a80243a926fdab20ef0a57411e80bead989128f Mon Sep 17 00:00:00 2001 From: mitaclaw <140017135+mitaclaw@users.noreply.github.com> Date: Sun, 29 Sep 2024 11:08:08 -0700 Subject: [PATCH 07/17] Modernize `std::replace` with ranges --- Source/Core/Common/FileSearch.cpp | 2 +- Source/Core/Common/FileUtil.cpp | 2 +- Source/Core/Common/StringUtil.cpp | 4 ++-- Source/Core/Core/ConfigManager.cpp | 2 +- Source/Core/UICommon/UICommon.cpp | 2 +- 5 files changed, 6 insertions(+), 6 deletions(-) diff --git a/Source/Core/Common/FileSearch.cpp b/Source/Core/Common/FileSearch.cpp index d022414efc..31b5e3cd37 100644 --- a/Source/Core/Common/FileSearch.cpp +++ b/Source/Core/Common/FileSearch.cpp @@ -107,7 +107,7 @@ std::vector DoFileSearch(const std::vector& directorie if constexpr (os_separator != DIR_SEP_CHR) { for (auto& path : result) - std::replace(path.begin(), path.end(), '\\', DIR_SEP_CHR); + std::ranges::replace(path, '\\', DIR_SEP_CHR); } return result; diff --git a/Source/Core/Common/FileUtil.cpp b/Source/Core/Common/FileUtil.cpp index 545bfaba44..ee2b330812 100644 --- a/Source/Core/Common/FileUtil.cpp +++ b/Source/Core/Common/FileUtil.cpp @@ -446,7 +446,7 @@ FSTEntry ScanDirectoryTree(std::string directory, bool recursive) // about with directory separators (for host paths - emulated paths may require it) and instead // use fs::path to interact with them. auto wpath = path.wstring(); - std::replace(wpath.begin(), wpath.end(), L'\\', L'/'); + std::ranges::replace(wpath, L'\\', L'/'); return WStringToUTF8(wpath); #else return PathToString(path); diff --git a/Source/Core/Common/StringUtil.cpp b/Source/Core/Common/StringUtil.cpp index d3e7caacdf..935db75d2f 100644 --- a/Source/Core/Common/StringUtil.cpp +++ b/Source/Core/Common/StringUtil.cpp @@ -234,8 +234,8 @@ std::string_view StripQuotes(std::string_view s) // Turns "\n\rhello" into " hello". void ReplaceBreaksWithSpaces(std::string& str) { - std::replace(str.begin(), str.end(), '\r', ' '); - std::replace(str.begin(), str.end(), '\n', ' '); + std::ranges::replace(str, '\r', ' '); + std::ranges::replace(str, '\n', ' '); } void TruncateToCString(std::string* s) diff --git a/Source/Core/Core/ConfigManager.cpp b/Source/Core/Core/ConfigManager.cpp index 07ca7498da..7eefe9b945 100644 --- a/Source/Core/Core/ConfigManager.cpp +++ b/Source/Core/Core/ConfigManager.cpp @@ -265,7 +265,7 @@ struct SetGameMetadata std::string executable_path = executable.path; constexpr char BACKSLASH = '\\'; constexpr char FORWARDSLASH = '/'; - std::replace(executable_path.begin(), executable_path.end(), BACKSLASH, FORWARDSLASH); + std::ranges::replace(executable_path, BACKSLASH, FORWARDSLASH); config->SetRunningGameMetadata(SConfig::MakeGameID(PathToFileName(executable_path))); Host_TitleChanged(); diff --git a/Source/Core/UICommon/UICommon.cpp b/Source/Core/UICommon/UICommon.cpp index d0f8345852..382c59d696 100644 --- a/Source/Core/UICommon/UICommon.cpp +++ b/Source/Core/UICommon/UICommon.cpp @@ -225,7 +225,7 @@ void SetLocale(std::string locale_name) if (locale_name == "en") locale_name = "en_GB"; - std::replace(locale_name.begin(), locale_name.end(), OTHER_SEPARATOR, PREFERRED_SEPARATOR); + std::ranges::replace(locale_name, OTHER_SEPARATOR, PREFERRED_SEPARATOR); // Use the specified locale if supported. if (set_locale(locale_name)) From a7160c7b38a59d3a51f4a2d64621515fc5a1cab5 Mon Sep 17 00:00:00 2001 From: mitaclaw <140017135+mitaclaw@users.noreply.github.com> Date: Sun, 29 Sep 2024 11:08:17 -0700 Subject: [PATCH 08/17] Modernize `std::replace_if` with ranges --- Source/Core/Core/IOS/USB/USBV4.cpp | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/Source/Core/Core/IOS/USB/USBV4.cpp b/Source/Core/Core/IOS/USB/USBV4.cpp index 6c8f58ec2b..f2bb54064c 100644 --- a/Source/Core/Core/IOS/USB/USBV4.cpp +++ b/Source/Core/Core/IOS/USB/USBV4.cpp @@ -87,7 +87,7 @@ void V4GetUSStringMessage::OnTransferComplete(s32 return_value) const auto& memory = system.GetMemory(); std::string message = memory.GetString(data_address); - std::replace_if(message.begin(), message.end(), std::not_fn(Common::IsPrintableCharacter), '?'); + std::ranges::replace_if(message, std::not_fn(Common::IsPrintableCharacter), '?'); memory.CopyToEmu(data_address, message.c_str(), message.size()); TransferCommand::OnTransferComplete(return_value); } From 9bd1dae41d8703e70196397722f98364bae63035 Mon Sep 17 00:00:00 2001 From: mitaclaw <140017135+mitaclaw@users.noreply.github.com> Date: Thu, 22 Aug 2024 19:16:36 -0700 Subject: [PATCH 09/17] Modernize `std::fill` with ranges In DSPCore.cpp, there were two `std::fill` uses that could be simplified using `std::fill_n`. Due to their proximity with other `std::fill` algorithms being modernized with ranges, I chose to make these examples into the rare `std::ranges::fill_n`. --- Source/Core/Core/DSP/DSPCore.cpp | 12 ++++++------ Source/Core/Core/DSP/Jit/x64/DSPEmitter.cpp | 2 +- Source/Core/Core/FifoPlayer/FifoRecorder.cpp | 4 ++-- Source/Core/Core/HW/WiimoteEmu/EmuSubroutines.cpp | 2 +- Source/Core/Core/PowerPC/PPCCache.cpp | 6 +++--- Source/Core/Core/PowerPC/PowerPC.cpp | 8 ++++---- .../ControllerInterface/DInput/DInputJoystick.cpp | 2 +- Source/Core/VideoCommon/FramebufferManager.cpp | 4 ++-- 8 files changed, 20 insertions(+), 20 deletions(-) diff --git a/Source/Core/Core/DSP/DSPCore.cpp b/Source/Core/Core/DSP/DSPCore.cpp index dadc8effa6..b6d89064b5 100644 --- a/Source/Core/Core/DSP/DSPCore.cpp +++ b/Source/Core/Core/DSP/DSPCore.cpp @@ -143,20 +143,20 @@ bool SDSP::Initialize(const DSPInitOptions& opts) std::memset(&r, 0, sizeof(r)); - std::fill(std::begin(reg_stack_ptrs), std::end(reg_stack_ptrs), 0); + std::ranges::fill(reg_stack_ptrs, 0); for (auto& stack : reg_stacks) - std::fill(std::begin(stack), std::end(stack), 0); + std::ranges::fill(stack, 0); // Fill IRAM with HALT opcodes. - std::fill(iram, iram + DSP_IRAM_SIZE, 0x0021); + std::ranges::fill_n(iram, DSP_IRAM_SIZE, 0x0021); // Just zero out DRAM. - std::fill(dram, dram + DSP_DRAM_SIZE, 0); + std::ranges::fill_n(dram, DSP_DRAM_SIZE, 0); // Copied from a real console after the custom UCode has been loaded. // These are the indexing wrapping registers. - std::fill(std::begin(r.wr), std::end(r.wr), 0xffff); + std::ranges::fill(r.wr, 0xffff); r.sr |= SR_INT_ENABLE; r.sr |= SR_EXT_INT_ENABLE; @@ -172,7 +172,7 @@ bool SDSP::Initialize(const DSPInitOptions& opts) void SDSP::Reset() { pc = DSP_RESET_VECTOR; - std::fill(std::begin(r.wr), std::end(r.wr), 0xffff); + std::ranges::fill(r.wr, 0xffff); } void SDSP::Shutdown() diff --git a/Source/Core/Core/DSP/Jit/x64/DSPEmitter.cpp b/Source/Core/Core/DSP/Jit/x64/DSPEmitter.cpp index 6d8527f657..7066209530 100644 --- a/Source/Core/Core/DSP/Jit/x64/DSPEmitter.cpp +++ b/Source/Core/Core/DSP/Jit/x64/DSPEmitter.cpp @@ -40,7 +40,7 @@ DSPEmitter::DSPEmitter(DSPCore& dsp) m_stub_entry_point = CompileStub(); // Clear all of the block references - std::fill(m_blocks.begin(), m_blocks.end(), (DSPCompiledCode)m_stub_entry_point); + std::ranges::fill(m_blocks, (DSPCompiledCode)m_stub_entry_point); } DSPEmitter::~DSPEmitter() diff --git a/Source/Core/Core/FifoPlayer/FifoRecorder.cpp b/Source/Core/Core/FifoPlayer/FifoRecorder.cpp index c354a5fdf7..32abaf1997 100644 --- a/Source/Core/Core/FifoPlayer/FifoRecorder.cpp +++ b/Source/Core/Core/FifoPlayer/FifoRecorder.cpp @@ -240,8 +240,8 @@ void FifoRecorder::StartRecording(s32 numFrames, CallbackFunc finishedCb) m_Ram.resize(memory.GetRamSize()); m_ExRam.resize(memory.GetExRamSize()); - std::fill(m_Ram.begin(), m_Ram.end(), 0); - std::fill(m_ExRam.begin(), m_ExRam.end(), 0); + std::ranges::fill(m_Ram, 0); + std::ranges::fill(m_ExRam, 0); m_File->SetIsWii(m_system.IsWii()); diff --git a/Source/Core/Core/HW/WiimoteEmu/EmuSubroutines.cpp b/Source/Core/Core/HW/WiimoteEmu/EmuSubroutines.cpp index fa3121bb6c..2c510fb394 100644 --- a/Source/Core/Core/HW/WiimoteEmu/EmuSubroutines.cpp +++ b/Source/Core/Core/HW/WiimoteEmu/EmuSubroutines.cpp @@ -452,7 +452,7 @@ bool Wiimote::ProcessReadDataRequest() reply.address = Common::swap16(m_read_request.address); // Pre-fill with zeros in case of read-error or read < 16-bytes: - std::fill(std::begin(reply.data), std::end(reply.data), 0x00); + std::ranges::fill(reply.data, 0x00); ErrorCode error_code = ErrorCode::Success; diff --git a/Source/Core/Core/PowerPC/PPCCache.cpp b/Source/Core/Core/PowerPC/PPCCache.cpp index 0213a47c38..3d351f97d1 100644 --- a/Source/Core/Core/PowerPC/PPCCache.cpp +++ b/Source/Core/Core/PowerPC/PPCCache.cpp @@ -100,9 +100,9 @@ void Cache::Reset() valid.fill(0); plru.fill(0); modified.fill(0); - std::fill(lookup_table.begin(), lookup_table.end(), 0xFF); - std::fill(lookup_table_ex.begin(), lookup_table_ex.end(), 0xFF); - std::fill(lookup_table_vmem.begin(), lookup_table_vmem.end(), 0xFF); + std::ranges::fill(lookup_table, 0xFF); + std::ranges::fill(lookup_table_ex, 0xFF); + std::ranges::fill(lookup_table_vmem, 0xFF); } void InstructionCache::Reset(JitInterface& jit_interface) diff --git a/Source/Core/Core/PowerPC/PowerPC.cpp b/Source/Core/Core/PowerPC/PowerPC.cpp index e97db77fc7..fec63c86d5 100644 --- a/Source/Core/Core/PowerPC/PowerPC.cpp +++ b/Source/Core/Core/PowerPC/PowerPC.cpp @@ -128,10 +128,10 @@ void PowerPCManager::DoState(PointerWrap& p) void PowerPCManager::ResetRegisters() { - std::fill(std::begin(m_ppc_state.ps), std::end(m_ppc_state.ps), PairedSingle{}); - std::fill(std::begin(m_ppc_state.sr), std::end(m_ppc_state.sr), 0U); - std::fill(std::begin(m_ppc_state.gpr), std::end(m_ppc_state.gpr), 0U); - std::fill(std::begin(m_ppc_state.spr), std::end(m_ppc_state.spr), 0U); + std::ranges::fill(m_ppc_state.ps, PairedSingle{}); + std::ranges::fill(m_ppc_state.sr, 0U); + std::ranges::fill(m_ppc_state.gpr, 0U); + std::ranges::fill(m_ppc_state.spr, 0U); // Gamecube: // 0x00080200 = lonestar 2.0 diff --git a/Source/Core/InputCommon/ControllerInterface/DInput/DInputJoystick.cpp b/Source/Core/InputCommon/ControllerInterface/DInput/DInputJoystick.cpp index 5d3e353a0a..a78c310f24 100644 --- a/Source/Core/InputCommon/ControllerInterface/DInput/DInputJoystick.cpp +++ b/Source/Core/InputCommon/ControllerInterface/DInput/DInputJoystick.cpp @@ -183,7 +183,7 @@ Joystick::Joystick(const LPDIRECTINPUTDEVICE8 device) : m_device(device) // Set hats to center: // "The center position is normally reported as -1" -MSDN - std::fill(std::begin(m_state_in.rgdwPOV), std::end(m_state_in.rgdwPOV), -1); + std::ranges::fill(m_state_in.rgdwPOV, -1); } Joystick::~Joystick() diff --git a/Source/Core/VideoCommon/FramebufferManager.cpp b/Source/Core/VideoCommon/FramebufferManager.cpp index 3c83bce2c4..044b94a5de 100644 --- a/Source/Core/VideoCommon/FramebufferManager.cpp +++ b/Source/Core/VideoCommon/FramebufferManager.cpp @@ -764,9 +764,9 @@ bool FramebufferManager::CreateReadbackFramebuffer() } m_efb_color_cache.tiles.resize(total_tiles); - std::fill(m_efb_color_cache.tiles.begin(), m_efb_color_cache.tiles.end(), EFBCacheTile{false, 0}); + std::ranges::fill(m_efb_color_cache.tiles, EFBCacheTile{false, 0}); m_efb_depth_cache.tiles.resize(total_tiles); - std::fill(m_efb_depth_cache.tiles.begin(), m_efb_depth_cache.tiles.end(), EFBCacheTile{false, 0}); + std::ranges::fill(m_efb_depth_cache.tiles, EFBCacheTile{false, 0}); return true; } From 78440ca335d4f988092bf524f42fde66a4790abd Mon Sep 17 00:00:00 2001 From: mitaclaw <140017135+mitaclaw@users.noreply.github.com> Date: Sat, 28 Sep 2024 20:20:31 -0700 Subject: [PATCH 10/17] Modernize `std::reverse` with ranges --- Source/Core/Core/Debugger/PPCDebugInterface.cpp | 2 +- Source/Core/Core/HW/WiimoteEmu/MotionPlus.cpp | 2 +- Source/Core/Core/IOS/USB/Bluetooth/BTReal.cpp | 2 +- Source/Core/VideoBackends/OGL/OGLConfig.cpp | 2 +- 4 files changed, 4 insertions(+), 4 deletions(-) diff --git a/Source/Core/Core/Debugger/PPCDebugInterface.cpp b/Source/Core/Core/Debugger/PPCDebugInterface.cpp index 786f95bfa7..626e18c067 100644 --- a/Source/Core/Core/Debugger/PPCDebugInterface.cpp +++ b/Source/Core/Core/Debugger/PPCDebugInterface.cpp @@ -266,7 +266,7 @@ Common::Debug::Threads PPCDebugInterface::GetThreads(const Core::CPUThreadGuard& const u32 prev_addr = active_thread->Data().thread_link.prev; insert_threads(prev_addr, [](const auto& thread) { return thread.Data().thread_link.prev; }); - std::reverse(threads.begin(), threads.end()); + std::ranges::reverse(threads); const u32 next_addr = active_thread->Data().thread_link.next; threads.emplace_back(std::move(active_thread)); diff --git a/Source/Core/Core/HW/WiimoteEmu/MotionPlus.cpp b/Source/Core/Core/HW/WiimoteEmu/MotionPlus.cpp index ad5e899c1e..9dc3b2ad1c 100644 --- a/Source/Core/Core/HW/WiimoteEmu/MotionPlus.cpp +++ b/Source/Core/Core/HW/WiimoteEmu/MotionPlus.cpp @@ -44,7 +44,7 @@ struct MPI : mbedtls_mpi if (mbedtls_mpi_write_binary(this, out_data->data(), out_data->size())) return false; - std::reverse(out_data->begin(), out_data->end()); + std::ranges::reverse(*out_data); return true; } diff --git a/Source/Core/Core/IOS/USB/Bluetooth/BTReal.cpp b/Source/Core/Core/IOS/USB/Bluetooth/BTReal.cpp index a0eaa58624..b8547c9de9 100644 --- a/Source/Core/Core/IOS/USB/Bluetooth/BTReal.cpp +++ b/Source/Core/Core/IOS/USB/Bluetooth/BTReal.cpp @@ -598,7 +598,7 @@ void BluetoothRealDevice::LoadLinkKeys() } auto& mac = address.value(); - std::reverse(mac.begin(), mac.end()); + std::ranges::reverse(mac); const std::string& key_string = pair.substr(index + 1); linkkey_t key{}; diff --git a/Source/Core/VideoBackends/OGL/OGLConfig.cpp b/Source/Core/VideoBackends/OGL/OGLConfig.cpp index db369a157d..387333b898 100644 --- a/Source/Core/VideoBackends/OGL/OGLConfig.cpp +++ b/Source/Core/VideoBackends/OGL/OGLConfig.cpp @@ -660,7 +660,7 @@ bool PopulateConfig(GLContext* m_main_gl_context) } g_Config.backend_info.AAModes.push_back(1); // The UI wants ascending order - std::reverse(g_Config.backend_info.AAModes.begin(), g_Config.backend_info.AAModes.end()); + std::ranges::reverse(g_Config.backend_info.AAModes); } } else From bcaf665d14c5e20ecc88a8978df19ca73e0e29fc Mon Sep 17 00:00:00 2001 From: mitaclaw <140017135+mitaclaw@users.noreply.github.com> Date: Sat, 28 Sep 2024 20:22:58 -0700 Subject: [PATCH 11/17] Modernize `std::reverse_copy` with ranges --- Source/Core/Core/IOS/USB/Bluetooth/BTReal.cpp | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/Source/Core/Core/IOS/USB/Bluetooth/BTReal.cpp b/Source/Core/Core/IOS/USB/Bluetooth/BTReal.cpp index b8547c9de9..e3a6a660ed 100644 --- a/Source/Core/Core/IOS/USB/Bluetooth/BTReal.cpp +++ b/Source/Core/Core/IOS/USB/Bluetooth/BTReal.cpp @@ -621,7 +621,7 @@ void BluetoothRealDevice::SaveLinkKeys() { bdaddr_t address; // Reverse the address so that it is stored in the correct order in the config file - std::reverse_copy(entry.first.begin(), entry.first.end(), address.begin()); + std::ranges::reverse_copy(entry.first, address.begin()); oss << Common::MacAddressToString(address); oss << '='; oss << std::hex; From ebf7cebc32ac9af28dc2383192b7b14f7aea134f Mon Sep 17 00:00:00 2001 From: mitaclaw <140017135+mitaclaw@users.noreply.github.com> Date: Sun, 29 Sep 2024 11:19:05 -0700 Subject: [PATCH 12/17] Modernize `std::sort` with ranges --- Source/Core/Common/FileSearch.cpp | 2 +- Source/Core/DiscIO/DirectoryBlob.cpp | 17 ++++++++--------- Source/Core/DolphinQt/Debugger/WatchWidget.cpp | 2 +- .../ControllerInterface/MappingCommon.cpp | 4 ++-- Source/Core/VideoCommon/BPFunctions.cpp | 2 +- 5 files changed, 13 insertions(+), 14 deletions(-) diff --git a/Source/Core/Common/FileSearch.cpp b/Source/Core/Common/FileSearch.cpp index 31b5e3cd37..4a54c978c9 100644 --- a/Source/Core/Common/FileSearch.cpp +++ b/Source/Core/Common/FileSearch.cpp @@ -97,7 +97,7 @@ std::vector DoFileSearch(const std::vector& directorie // Remove duplicates (occurring because caller gave e.g. duplicate or overlapping directories - // not because std::filesystem returns duplicates). Also note that this pathname-based uniqueness // isn't as thorough as std::filesystem::equivalent. - std::sort(result.begin(), result.end()); + std::ranges::sort(result); result.erase(std::unique(result.begin(), result.end()), result.end()); // Dolphin expects to be able to use "/" (DIR_SEP) everywhere. diff --git a/Source/Core/DiscIO/DirectoryBlob.cpp b/Source/Core/DiscIO/DirectoryBlob.cpp index 7cd7e12def..b9e8b89dd4 100644 --- a/Source/Core/DiscIO/DirectoryBlob.cpp +++ b/Source/Core/DiscIO/DirectoryBlob.cpp @@ -624,16 +624,15 @@ void DirectoryBlobReader::SetWiiRegionData(const std::vector& wii_region_dat void DirectoryBlobReader::SetPartitions(std::vector&& partitions) { - std::sort(partitions.begin(), partitions.end(), - [](const PartitionWithType& lhs, const PartitionWithType& rhs) { - if (lhs.type == rhs.type) - return lhs.partition.GetRootDirectory() < rhs.partition.GetRootDirectory(); + std::ranges::sort(partitions, [](const PartitionWithType& lhs, const PartitionWithType& rhs) { + if (lhs.type == rhs.type) + return lhs.partition.GetRootDirectory() < rhs.partition.GetRootDirectory(); - // Ascending sort by partition type, except Update (1) comes before before Game (0) - return (lhs.type > PartitionType::Update || rhs.type > PartitionType::Update) ? - lhs.type < rhs.type : - lhs.type > rhs.type; - }); + // Ascending sort by partition type, except Update (1) comes before before Game (0) + return (lhs.type > PartitionType::Update || rhs.type > PartitionType::Update) ? + lhs.type < rhs.type : + lhs.type > rhs.type; + }); u32 subtable_1_size = 0; while (subtable_1_size < partitions.size() && subtable_1_size < 3 && diff --git a/Source/Core/DolphinQt/Debugger/WatchWidget.cpp b/Source/Core/DolphinQt/Debugger/WatchWidget.cpp index 170bfcc792..7cc61d1334 100644 --- a/Source/Core/DolphinQt/Debugger/WatchWidget.cpp +++ b/Source/Core/DolphinQt/Debugger/WatchWidget.cpp @@ -481,7 +481,7 @@ void WatchWidget::DeleteSelectedWatches() } // Sort greatest to smallest, so we don't stomp on existing indices - std::sort(row_indices.begin(), row_indices.end(), std::greater{}); + std::ranges::sort(row_indices, std::ranges::greater{}); for (const int row : row_indices) { DeleteWatch(guard, row); diff --git a/Source/Core/InputCommon/ControllerInterface/MappingCommon.cpp b/Source/Core/InputCommon/ControllerInterface/MappingCommon.cpp index 4acee6a970..1877e8294c 100644 --- a/Source/Core/InputCommon/ControllerInterface/MappingCommon.cpp +++ b/Source/Core/InputCommon/ControllerInterface/MappingCommon.cpp @@ -101,7 +101,7 @@ BuildExpression(const std::vector } else { - std::sort(alternation.begin(), alternation.end()); + std::ranges::sort(alternation); alternations.push_back(fmt::to_string(fmt::join(alternation, "&"))); } }; @@ -128,7 +128,7 @@ BuildExpression(const std::vector handle_release(); // Remove duplicates - std::sort(alternations.begin(), alternations.end()); + std::ranges::sort(alternations); alternations.erase(std::unique(alternations.begin(), alternations.end()), alternations.end()); return fmt::to_string(fmt::join(alternations, "|")); diff --git a/Source/Core/VideoCommon/BPFunctions.cpp b/Source/Core/VideoCommon/BPFunctions.cpp index ecb045e6ad..2c6c733710 100644 --- a/Source/Core/VideoCommon/BPFunctions.cpp +++ b/Source/Core/VideoCommon/BPFunctions.cpp @@ -151,7 +151,7 @@ ScissorResult::ScissorResult(const BPMemory& bpmemory, std::pair v } auto cmp = [&](const ScissorRect& lhs, const ScissorRect& rhs) { return IsWorse(lhs, rhs); }; - std::sort(m_result.begin(), m_result.end(), cmp); + std::ranges::sort(m_result, cmp); } ScissorRect ScissorResult::Best() const From 01d0bdf1bbb4ad3604a6d261b8648b870b1f0131 Mon Sep 17 00:00:00 2001 From: mitaclaw <140017135+mitaclaw@users.noreply.github.com> Date: Sat, 28 Sep 2024 22:23:45 -0700 Subject: [PATCH 13/17] Modernize `std::is_sorted` with ranges In OGLConfig.cpp, `std::views::reverse` is used rather than sorting using `std::ranges::greater` in order to parallel other instances of reverse iteration in the function. --- Source/Core/UICommon/GameFile.cpp | 2 +- Source/Core/VideoBackends/OGL/OGLConfig.cpp | 5 +++-- 2 files changed, 4 insertions(+), 3 deletions(-) diff --git a/Source/Core/UICommon/GameFile.cpp b/Source/Core/UICommon/GameFile.cpp index 7603463138..9151aec796 100644 --- a/Source/Core/UICommon/GameFile.cpp +++ b/Source/Core/UICommon/GameFile.cpp @@ -613,7 +613,7 @@ bool GameFile::CheckIfTwoDiscGame(const std::string& game_id) const "S6T", "SDQ", }; - static_assert(std::is_sorted(two_disc_game_id_prefixes.begin(), two_disc_game_id_prefixes.end())); + static_assert(std::ranges::is_sorted(two_disc_game_id_prefixes)); std::string_view game_id_prefix(game_id.data(), GAME_ID_PREFIX_SIZE); return std::binary_search(two_disc_game_id_prefixes.begin(), two_disc_game_id_prefixes.end(), diff --git a/Source/Core/VideoBackends/OGL/OGLConfig.cpp b/Source/Core/VideoBackends/OGL/OGLConfig.cpp index 387333b898..f53d38645b 100644 --- a/Source/Core/VideoBackends/OGL/OGLConfig.cpp +++ b/Source/Core/VideoBackends/OGL/OGLConfig.cpp @@ -4,6 +4,7 @@ #include "VideoBackends/OGL/OGLConfig.h" #include +#include #include #include @@ -585,7 +586,7 @@ bool PopulateConfig(GLContext* m_main_gl_context) glGetInternalformativ(GL_TEXTURE_2D_MULTISAMPLE_ARRAY, colorInternalFormat, GL_SAMPLES, num_color_sample_counts, reinterpret_cast(color_aa_modes.data())); - ASSERT_MSG(VIDEO, std::is_sorted(color_aa_modes.rbegin(), color_aa_modes.rend()), + ASSERT_MSG(VIDEO, std::ranges::is_sorted(color_aa_modes | std::views::reverse), "GPU driver didn't return sorted color AA modes: [{}]", fmt::join(color_aa_modes, ", ")); } @@ -614,7 +615,7 @@ bool PopulateConfig(GLContext* m_main_gl_context) glGetInternalformativ(GL_TEXTURE_2D_MULTISAMPLE_ARRAY, depthInternalFormat, GL_SAMPLES, num_depth_sample_counts, reinterpret_cast(depth_aa_modes.data())); - ASSERT_MSG(VIDEO, std::is_sorted(depth_aa_modes.rbegin(), depth_aa_modes.rend()), + ASSERT_MSG(VIDEO, std::ranges::is_sorted(depth_aa_modes | std::views::reverse), "GPU driver didn't return sorted depth AA modes: [{}]", fmt::join(depth_aa_modes, ", ")); } From 728663bdc03dfe20343c45ff36f5fb080b49ffec Mon Sep 17 00:00:00 2001 From: mitaclaw <140017135+mitaclaw@users.noreply.github.com> Date: Sat, 28 Sep 2024 22:30:41 -0700 Subject: [PATCH 14/17] Modernize `std::binary_search` with ranges In VolumeVerifier.cpp, constructing a `std::string_view` of the volume's GameID is unnecessary, as `std::`(`ranges::`)`binary_search` supports heterogeneous lookup. The usage in GameFile.cpp is a perfect example. --- Source/Core/DiscIO/VolumeVerifier.cpp | 6 ++---- Source/Core/UICommon/GameFile.cpp | 3 +-- Source/Core/VideoCommon/VertexManagerBase.cpp | 3 +-- 3 files changed, 4 insertions(+), 8 deletions(-) diff --git a/Source/Core/DiscIO/VolumeVerifier.cpp b/Source/Core/DiscIO/VolumeVerifier.cpp index 5a4a9c6856..8e31eff4eb 100644 --- a/Source/Core/DiscIO/VolumeVerifier.cpp +++ b/Source/Core/DiscIO/VolumeVerifier.cpp @@ -722,8 +722,7 @@ bool VolumeVerifier::ShouldHaveChannelPartition() const }; static_assert(std::ranges::is_sorted(channel_discs)); - return std::binary_search(channel_discs.cbegin(), channel_discs.cend(), - std::string_view(m_volume.GetGameID())); + return std::ranges::binary_search(channel_discs, m_volume.GetGameID()); } bool VolumeVerifier::ShouldHaveInstallPartition() const @@ -755,8 +754,7 @@ bool VolumeVerifier::ShouldBeDualLayer() const }; static_assert(std::ranges::is_sorted(dual_layer_discs)); - return std::binary_search(dual_layer_discs.cbegin(), dual_layer_discs.cend(), - std::string_view(m_volume.GetGameID())); + return std::ranges::binary_search(dual_layer_discs, m_volume.GetGameID()); } void VolumeVerifier::CheckVolumeSize() diff --git a/Source/Core/UICommon/GameFile.cpp b/Source/Core/UICommon/GameFile.cpp index 9151aec796..5c32c511df 100644 --- a/Source/Core/UICommon/GameFile.cpp +++ b/Source/Core/UICommon/GameFile.cpp @@ -616,8 +616,7 @@ bool GameFile::CheckIfTwoDiscGame(const std::string& game_id) const static_assert(std::ranges::is_sorted(two_disc_game_id_prefixes)); std::string_view game_id_prefix(game_id.data(), GAME_ID_PREFIX_SIZE); - return std::binary_search(two_disc_game_id_prefixes.begin(), two_disc_game_id_prefixes.end(), - game_id_prefix); + return std::ranges::binary_search(two_disc_game_id_prefixes, game_id_prefix); } std::string GameFile::GetNetPlayName(const Core::TitleDatabase& title_database) const diff --git a/Source/Core/VideoCommon/VertexManagerBase.cpp b/Source/Core/VideoCommon/VertexManagerBase.cpp index 02edb56d35..8a4f7f75bd 100644 --- a/Source/Core/VideoCommon/VertexManagerBase.cpp +++ b/Source/Core/VideoCommon/VertexManagerBase.cpp @@ -954,8 +954,7 @@ void VertexManagerBase::OnDraw() // Check if this draw is scheduled to kick a command buffer. // The draw counters will always be sorted so a binary search is possible here. - if (std::binary_search(m_scheduled_command_buffer_kicks.begin(), - m_scheduled_command_buffer_kicks.end(), m_draw_counter)) + if (std::ranges::binary_search(m_scheduled_command_buffer_kicks, m_draw_counter)) { // Kick a command buffer on the background thread. g_gfx->Flush(); From 88a1a5b4f2d63b96d47a6fd31a2bab89d50d701e Mon Sep 17 00:00:00 2001 From: mitaclaw <140017135+mitaclaw@users.noreply.github.com> Date: Sat, 28 Sep 2024 22:33:13 -0700 Subject: [PATCH 15/17] Modernize `std::set_intersection` with ranges --- Source/Core/InputCommon/InputProfile.cpp | 3 +-- Source/Core/VideoBackends/OGL/OGLConfig.cpp | 8 ++++---- 2 files changed, 5 insertions(+), 6 deletions(-) diff --git a/Source/Core/InputCommon/InputProfile.cpp b/Source/Core/InputCommon/InputProfile.cpp index 0d439c48e1..0bb452ac1e 100644 --- a/Source/Core/InputCommon/InputProfile.cpp +++ b/Source/Core/InputCommon/InputProfile.cpp @@ -111,8 +111,7 @@ ProfileCycler::GetMatchingProfilesFromSetting(const std::string& setting, } std::vector result; - std::set_intersection(profiles.begin(), profiles.end(), profiles_from_setting.begin(), - profiles_from_setting.end(), std::back_inserter(result)); + std::ranges::set_intersection(profiles, profiles_from_setting, std::back_inserter(result)); return result; } diff --git a/Source/Core/VideoBackends/OGL/OGLConfig.cpp b/Source/Core/VideoBackends/OGL/OGLConfig.cpp index f53d38645b..4b1e5308a2 100644 --- a/Source/Core/VideoBackends/OGL/OGLConfig.cpp +++ b/Source/Core/VideoBackends/OGL/OGLConfig.cpp @@ -631,10 +631,10 @@ bool PopulateConfig(GLContext* m_main_gl_context) g_Config.backend_info.AAModes.clear(); g_Config.backend_info.AAModes.reserve(std::min(color_aa_modes.size(), depth_aa_modes.size())); // We only want AA modes that are supported for both the color and depth textures. Probably - // the support is the same, though. rbegin/rend are used to swap the order ahead of time. - std::set_intersection(color_aa_modes.rbegin(), color_aa_modes.rend(), depth_aa_modes.rbegin(), - depth_aa_modes.rend(), - std::back_inserter(g_Config.backend_info.AAModes)); + // the support is the same, though. views::reverse is used to swap the order ahead of time. + std::ranges::set_intersection(color_aa_modes | std::views::reverse, + depth_aa_modes | std::views::reverse, + std::back_inserter(g_Config.backend_info.AAModes)); } else { From c99a0c25e05f6ff4107f39975a20d2e66bdaa041 Mon Sep 17 00:00:00 2001 From: mitaclaw <140017135+mitaclaw@users.noreply.github.com> Date: Sun, 29 Sep 2024 11:12:37 -0700 Subject: [PATCH 16/17] Modernize `std::max_element` with ranges --- Source/Core/DolphinQt/Config/Mapping/MappingIndicator.cpp | 2 +- Source/Core/DolphinQt/ToolBar.cpp | 2 +- 2 files changed, 2 insertions(+), 2 deletions(-) diff --git a/Source/Core/DolphinQt/Config/Mapping/MappingIndicator.cpp b/Source/Core/DolphinQt/Config/Mapping/MappingIndicator.cpp index c60c732e37..9ad3db8ae0 100644 --- a/Source/Core/DolphinQt/Config/Mapping/MappingIndicator.cpp +++ b/Source/Core/DolphinQt/Config/Mapping/MappingIndicator.cpp @@ -913,7 +913,7 @@ CalibrationWidget::CalibrationWidget(ControllerEmu::ReshapableInput& input, m_informative_timer = new QTimer(this); connect(m_informative_timer, &QTimer::timeout, this, [this] { // If the user has started moving we'll assume they know what they are doing. - if (*std::max_element(m_calibration_data.begin(), m_calibration_data.end()) > 0.5) + if (*std::ranges::max_element(m_calibration_data) > 0.5) return; ModalMessageBox::information( diff --git a/Source/Core/DolphinQt/ToolBar.cpp b/Source/Core/DolphinQt/ToolBar.cpp index 9649af6b00..9c8350f9f8 100644 --- a/Source/Core/DolphinQt/ToolBar.cpp +++ b/Source/Core/DolphinQt/ToolBar.cpp @@ -146,7 +146,7 @@ void ToolBar::MakeActions() std::ranges::transform(items, std::back_inserter(widths), [](QWidget* item) { return item->sizeHint().width(); }); - const int min_width = *std::max_element(widths.begin(), widths.end()) * 0.85; + const int min_width = *std::ranges::max_element(widths) * 0.85; for (QWidget* widget : items) widget->setMinimumWidth(min_width); } From e572081ac322253d65bf767a88887fedd4e97c2e Mon Sep 17 00:00:00 2001 From: mitaclaw <140017135+mitaclaw@users.noreply.github.com> Date: Sun, 29 Sep 2024 11:12:44 -0700 Subject: [PATCH 17/17] Modernize `std::min_element` with ranges --- Source/Core/DolphinQt/Debugger/AssemblerWidget.cpp | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/Source/Core/DolphinQt/Debugger/AssemblerWidget.cpp b/Source/Core/DolphinQt/Debugger/AssemblerWidget.cpp index 23fffefa64..958e731c0d 100644 --- a/Source/Core/DolphinQt/Debugger/AssemblerWidget.cpp +++ b/Source/Core/DolphinQt/Debugger/AssemblerWidget.cpp @@ -846,7 +846,7 @@ void AssemblerWidget::CloseTab(int index, AsmEditor* editor) int AssemblerWidget::AllocateTabNum() { - auto min_it = std::min_element(m_free_editor_nums.begin(), m_free_editor_nums.end()); + auto min_it = std::ranges::min_element(m_free_editor_nums); if (min_it == m_free_editor_nums.end()) { return m_unnamed_editor_count++;