78 std::vector<PtrAndBytes> free_blocks;
79 for (std::size_t freelist_idx = 0; freelist_idx < resource.
m_free_lists.size(); ++freelist_idx) {
82 while (ptr !=
nullptr) {
83 free_blocks.emplace_back(ptr, bytes);
89 if (num_available_bytes > 0) {
94 std::vector<PtrAndBytes> chunks;
101 std::sort(free_blocks.begin(), free_blocks.end());
102 std::sort(chunks.begin(), chunks.end());
104 auto chunk_it = chunks.begin();
105 auto chunk_ptr_remaining = chunk_it->ptr;
106 auto chunk_size_remaining = chunk_it->size;
107 for (
const auto& free_block : free_blocks) {
108 if (chunk_size_remaining == 0) {
109 assert(chunk_it != chunks.end());
111 assert(chunk_it != chunks.end());
112 chunk_ptr_remaining = chunk_it->ptr;
113 chunk_size_remaining = chunk_it->size;
115 assert(free_block.ptr == chunk_ptr_remaining);
116 assert(free_block.size <= chunk_size_remaining);
118 chunk_ptr_remaining += free_block.size;
119 chunk_size_remaining -= free_block.size;
122 assert(chunk_ptr_remaining == chunk_it->ptr + chunk_it->size);
124 assert(chunk_it == chunks.end());
125 assert(chunk_size_remaining == 0);