mirror of
				https://github.com/glfw/glfw.git
				synced 2025-10-31 12:42:26 +00:00 
			
		
		
		
	Add _glfw_ffs returning 1-based index of lsb set to one
This commit is contained in:
		
							parent
							
								
									8031534c38
								
							
						
					
					
						commit
						519ee68876
					
				
							
								
								
									
										35
									
								
								src/init.c
									
									
									
									
									
								
							
							
						
						
									
										35
									
								
								src/init.c
									
									
									
									
									
								
							| @ -266,6 +266,41 @@ float _glfw_fmaxf(float a, float b) | |||||||
|         return b; |         return b; | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
|  | int _glfw_ffs(int i) | ||||||
|  | { | ||||||
|  | #if defined(__GNUC__) || defined(__clang__) | ||||||
|  |     return __builtin_ffs(i); | ||||||
|  | #elif defined(_MSC_VER) | ||||||
|  |     unsigned long n, u = i; | ||||||
|  |     return _BitScanForward(&n, u) ? n + 1 : 0; | ||||||
|  | #else | ||||||
|  |     // https://en.wikipedia.org/wiki/Find_first_set#CTZ
 | ||||||
|  |     unsigned int u = i; | ||||||
|  |     int n = 1; | ||||||
|  |     if (!u) return 0; | ||||||
|  |     if (!(u & 0x0000FFFF)) { | ||||||
|  |         n += 16; | ||||||
|  |         u >>= 16; | ||||||
|  |     } | ||||||
|  |     if (!(u & 0x000000FF)) { | ||||||
|  |         n += 8; | ||||||
|  |         u >>= 8; | ||||||
|  |     } | ||||||
|  |     if (!(u & 0x0000000F)) { | ||||||
|  |         n += 4; | ||||||
|  |         u >>= 4; | ||||||
|  |     } | ||||||
|  |     if (!(u & 0x00000003)) { | ||||||
|  |         n += 2; | ||||||
|  |         u >>= 2; | ||||||
|  |     } | ||||||
|  |     if (!(u & 0x00000001)) { | ||||||
|  |         n += 1; | ||||||
|  |     } | ||||||
|  |     return n; | ||||||
|  | #endif | ||||||
|  | } | ||||||
|  | 
 | ||||||
| void* _glfw_calloc(size_t count, size_t size) | void* _glfw_calloc(size_t count, size_t size) | ||||||
| { | { | ||||||
|     if (count && size) |     if (count && size) | ||||||
|  | |||||||
| @ -1015,6 +1015,7 @@ int _glfw_min(int a, int b); | |||||||
| int _glfw_max(int a, int b); | int _glfw_max(int a, int b); | ||||||
| float _glfw_fminf(float a, float b); | float _glfw_fminf(float a, float b); | ||||||
| float _glfw_fmaxf(float a, float b); | float _glfw_fmaxf(float a, float b); | ||||||
|  | int _glfw_ffs(int i); | ||||||
| 
 | 
 | ||||||
| void* _glfw_calloc(size_t count, size_t size); | void* _glfw_calloc(size_t count, size_t size); | ||||||
| void* _glfw_realloc(void* pointer, size_t size); | void* _glfw_realloc(void* pointer, size_t size); | ||||||
|  | |||||||
		Loading…
	
		Reference in New Issue
	
	Block a user