mirror of
				https://github.com/OpenMW/openmw.git
				synced 2025-10-25 01:56:41 +00:00 
			
		
		
		
	Need to load the last present record from a sequence of loaded records. That means reverse should be called before unique or unique should be applied for a reversed range. Since unique keeps only the first element from a sub sequence of equal elements. Use forEachUnique with reversed range to avoid redundant container modifications.
		
			
				
	
	
		
			45 lines
		
	
	
	
		
			1.3 KiB
		
	
	
	
		
			C++
		
	
	
	
	
	
			
		
		
	
	
			45 lines
		
	
	
	
		
			1.3 KiB
		
	
	
	
		
			C++
		
	
	
	
	
	
| #ifndef OPENMW_COMPONENTS_ESMLOADER_RECORD_H
 | |
| #define OPENMW_COMPONENTS_ESMLOADER_RECORD_H
 | |
| 
 | |
| #include <components/esm3/loadcell.hpp>
 | |
| #include <components/misc/algorithm.hpp>
 | |
| 
 | |
| #include <algorithm>
 | |
| #include <utility>
 | |
| #include <vector>
 | |
| 
 | |
| namespace EsmLoader
 | |
| {
 | |
|     template <class T>
 | |
|     struct Record
 | |
|     {
 | |
|         bool mDeleted;
 | |
|         T mValue;
 | |
| 
 | |
|         template <class ... Args>
 | |
|         explicit Record(bool deleted, Args&& ... args)
 | |
|             : mDeleted(deleted)
 | |
|             , mValue(std::forward<Args>(args) ...)
 | |
|         {}
 | |
|     };
 | |
| 
 | |
|     template <class T>
 | |
|     using Records = std::vector<Record<T>>;
 | |
| 
 | |
|     template <class T, class GetKey>
 | |
|     inline std::vector<T> prepareRecords(Records<T>& records, const GetKey& getKey)
 | |
|     {
 | |
|         const auto greaterByKey = [&] (const auto& l, const auto& r) { return getKey(r) < getKey(l); };
 | |
|         const auto equalByKey = [&] (const auto& l, const auto& r) { return getKey(l) == getKey(r); };
 | |
|         std::stable_sort(records.begin(), records.end(), greaterByKey);
 | |
|         std::vector<T> result;
 | |
|         Misc::forEachUnique(records.rbegin(), records.rend(), equalByKey, [&] (const auto& v)
 | |
|         {
 | |
|             if (!v.mDeleted)
 | |
|                 result.emplace_back(std::move(v.mValue));
 | |
|         });
 | |
|         return result;
 | |
|     }
 | |
| }
 | |
| 
 | |
| #endif
 |