summaryrefslogtreecommitdiff
path: root/src/libstddjb/bitarray_firstset.c
blob: de3d27ea628c6a376694c338819e5c7f00017724 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
/* ISC license. */

#include <skalibs/bitarray.h>

unsigned int bitarray_firstset (register unsigned char const *s, unsigned int max)
{
  unsigned int n = bitarray_div8(max) ;
  register unsigned int i = 0 ;
  for (; i < n ; i++) if (s[i]) break ;
  if (i == n) return max ;
  i <<= 3 ;
  while ((i < max) && !bitarray_peek(s, i)) i++ ;
  return i ;
}