mirror of
				https://github.com/OpenMW/openmw.git
				synced 2025-10-25 00:56:37 +00:00 
			
		
		
		
	
		
			
				
	
	
		
			84 lines
		
	
	
	
		
			1.8 KiB
		
	
	
	
		
			C++
		
	
	
	
	
	
			
		
		
	
	
			84 lines
		
	
	
	
		
			1.8 KiB
		
	
	
	
		
			C++
		
	
	
	
	
	
| #ifndef FILE_FINDER_LESS_H
 | |
| #define FILE_FINDER_LESS_H
 | |
| 
 | |
| #include <libs/platform/strings.h>
 | |
| #include <string>
 | |
| 
 | |
| namespace FileFinder{
 | |
| 
 | |
| // Used for maps of file paths. Compares file paths, but ignores case
 | |
| // AND treats \ and / as the same character.
 | |
| struct path_less
 | |
| {
 | |
|   int compareChar(char a, char b) const
 | |
|   {
 | |
|     if(a>b) return 1;
 | |
|     else if(a<b) return -1;
 | |
|     return 0;
 | |
|   }
 | |
| 
 | |
|   int comparePathChar(char a, char b) const
 | |
|   {
 | |
|     if(a >= 'a' && a <= 'z') a += 'A'-'a';
 | |
|     else if(a == '\\') a = '/';
 | |
|     if(b >= 'a' && b <= 'z') b += 'A'-'a';
 | |
|     else if(b == '\\') b = '/';
 | |
|     return compareChar(a,b);
 | |
|   }
 | |
| 
 | |
|   int compareString(const char *a, const char *b) const
 | |
|   {
 | |
|     while(*a && *b)
 | |
|       {
 | |
|         int i = comparePathChar(*a,*b);
 | |
|         if(i != 0) return i;
 | |
|         a++; b++;
 | |
|       }
 | |
|     // At this point, one or both of the chars is a null terminator.
 | |
|     // Normal char comparison will get the correct final result here.
 | |
|     return compareChar(*a,*b);
 | |
|   }
 | |
| 
 | |
|   bool operator() (const std::string& a, const std::string& b) const
 | |
|   {
 | |
|     return compareString(a.c_str(), b.c_str()) < 0;
 | |
|   }
 | |
| };
 | |
| 
 | |
| struct path_slash
 | |
| {
 | |
|   int compareChar(char a, char b) const
 | |
|   {
 | |
|     if(a>b) return 1;
 | |
|     else if(a<b) return -1;
 | |
|     return 0;
 | |
|   }
 | |
| 
 | |
|   int comparePathChar(char a, char b) const
 | |
|   {
 | |
|    if(a == '\\') a = '/';
 | |
|    if(b == '\\') b = '/';
 | |
|     return compareChar(a,b);
 | |
|   }
 | |
| 
 | |
|   int compareString(const char *a, const char *b) const
 | |
|   {
 | |
|     while(*a && *b)
 | |
|       {
 | |
|         int i = comparePathChar(*a,*b);
 | |
|         if(i != 0) return i;
 | |
|         a++; b++;
 | |
|       }
 | |
|     // At this point, one or both of the chars is a null terminator.
 | |
|     // Normal char comparison will get the correct final result here.
 | |
|     return compareChar(*a,*b);
 | |
|   }
 | |
| 
 | |
|   bool operator() (const std::string& a, const std::string& b) const
 | |
|   {
 | |
|     return compareString(a.c_str(), b.c_str()) < 0;
 | |
|   }
 | |
| };
 | |
|  
 | |
| }
 | |
| #endif
 |