summaryrefslogtreecommitdiff
path: root/checklink/Bitstring_utils.ml
blob: 2253b63f8f097aa41b512c1ba8051dc884117291 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
(** Note that a bitstring is a triple (string * int * int), where the string
    contains the contents (the last char is filled up with zeros if necessary),
    the firts int gives the first bit to consider, and the second int gives the
    bit length of the considered bitstring.
*)
type bitstring = Bitstring.bitstring

(** Checks whether a given number of bits of a bitstring are zeroed. The
    bitstring may be longer.
    @param size number of bits to check
*)
let rec is_zeros (bs: bitstring) (size: int): bool =
  size = 0 ||
  if size >= 64
  then (
    bitmatch bs with
    | { 0L : 64 : int ; rest : -1 : bitstring } ->
        is_zeros rest (size - 64)
    | { _ } -> false
  )
  else (
    bitmatch bs with
    | { 0L : size : int } -> true
    | { _ } -> false
  )