mirror of
https://github.com/dolphin-emu/dolphin.git
synced 2025-01-24 06:51:17 +01:00
Modernize std::lower_bound
/upper_bound
with ranges and projections
This commit is contained in:
parent
1c668350a0
commit
41c04ded93
@ -220,9 +220,7 @@ WindowsMemoryRegion* MemArena::EnsureSplitRegionForMapping(void* start_address,
|
|||||||
}
|
}
|
||||||
|
|
||||||
// find closest region that is <= the given address by using upper bound and decrementing
|
// find closest region that is <= the given address by using upper bound and decrementing
|
||||||
auto it = std::upper_bound(
|
auto it = std::ranges::upper_bound(regions, address, {}, &WindowsMemoryRegion::m_start);
|
||||||
regions.begin(), regions.end(), address,
|
|
||||||
[](u8* addr, const WindowsMemoryRegion& region) { return addr < region.m_start; });
|
|
||||||
if (it == regions.begin())
|
if (it == regions.begin())
|
||||||
{
|
{
|
||||||
// this should never happen, implies that the given address is before the start of the
|
// this should never happen, implies that the given address is before the start of the
|
||||||
@ -363,9 +361,7 @@ bool MemArena::JoinRegionsAfterUnmap(void* start_address, size_t size)
|
|||||||
}
|
}
|
||||||
|
|
||||||
// there should be a mapping that matches the request exactly, find it
|
// there should be a mapping that matches the request exactly, find it
|
||||||
auto it = std::lower_bound(
|
auto it = std::ranges::lower_bound(regions, address, {}, &WindowsMemoryRegion::m_start);
|
||||||
regions.begin(), regions.end(), address,
|
|
||||||
[](const WindowsMemoryRegion& region, u8* addr) { return region.m_start < addr; });
|
|
||||||
if (it == regions.end() || it->m_start != address || it->m_size != size)
|
if (it == regions.end() || it->m_start != address || it->m_size != size)
|
||||||
{
|
{
|
||||||
// didn't find it, we were given bogus input
|
// didn't find it, we were given bogus input
|
||||||
|
Loading…
x
Reference in New Issue
Block a user