Function nom::bits::bits[][src]

pub fn bits<I, O, E1: ParseError<(I, usize)> + ErrorConvert<E2>, E2: ParseError<I>, P>(
    parser: P
) -> impl FnMut(I) -> IResult<I, O, E2> where
    I: Slice<RangeFrom<usize>>,
    P: FnMut((I, usize)) -> IResult<(I, usize), O, E1>, 

Converts a byte-level input to a bit-level input, for consumption by a parser that uses bits.

Afterwards, the input is converted back to a byte-level parser, with any remaining bits thrown away.

Example

use nom::bits::bits;
use nom::bits::complete::take;
use nom::error::Error;

fn take_4_bits(input: &[u8]) -> IResult<&[u8], u64> {
  bits(take::<_, _, _, Error<_>>(4usize))(input)
}

let input = vec![0xAB, 0xCD, 0xEF, 0x12];
let sl    = &input[..];

assert_eq!(take_4_bits( sl ), Ok( (&sl[1..], 0xA) ));