1
 2
 3
 4
 5
 6
 7
 8
 9
10
11
12
13
14
use bitops::*;

pub fn fls<T: Bitops>(x: T) -> u8 {
    (msb(x) + 1) as u8
}

pub fn msb<T: Bitops>(x: T) -> i8 {
    let bits = bit_length::<T>() as i8;
    if x != T::zero() {
        (bits -1i8 - (x.leading_zeros() as i8))
    } else {
        -1i8
    }
}