From 67eebd17a0c4fc3ce322b6265d216197d9ad3ecd Mon Sep 17 00:00:00 2001 From: Rogier 'DocWilco' Mulhuijzen Date: Wed, 12 Feb 2020 14:38:15 -0800 Subject: [PATCH] Done is now Ok, map works a little different --- src/lib.rs | 18 +++++++++--------- src/playlist.rs | 2 +- 2 files changed, 10 insertions(+), 10 deletions(-) diff --git a/src/lib.rs b/src/lib.rs index 1e68a0c..f2149aa 100644 --- a/src/lib.rs +++ b/src/lib.rs @@ -88,7 +88,6 @@ //! //! ``` -#[macro_use] extern crate nom; pub mod playlist; @@ -129,8 +128,9 @@ use playlist::*; /// } pub fn parse_playlist(input: &[u8]) -> IResult<&[u8], Playlist> { match is_master_playlist(input) { - true => parse_master_playlist(input).map(Playlist::MasterPlaylist), - false => parse_media_playlist(input).map(Playlist::MediaPlaylist), + // XXX: get rid of the local `map` to be able to `use` this + true => nom::combinator::map(parse_master_playlist, Playlist::MasterPlaylist)(input), + false => nom::combinator::map(parse_media_playlist, Playlist::MediaPlaylist)(input), } } @@ -157,35 +157,35 @@ pub fn parse_playlist(input: &[u8]) -> IResult<&[u8], Playlist> { pub fn parse_playlist_res(input: &[u8]) -> Result> { let parse_result = parse_playlist(input); match parse_result { - IResult::Done(_, playlist) => Ok(playlist), + IResult::Ok((_, playlist)) => Ok(playlist), _ => Err(parse_result), } } /// Parse input as a master playlist pub fn parse_master_playlist(input: &[u8]) -> IResult<&[u8], MasterPlaylist> { - parse_master_playlist_tags(input).map(MasterPlaylist::from_tags) + nom::combinator::map(parse_master_playlist_tags, MasterPlaylist::from_tags)(input) } /// Parse input as a master playlist pub fn parse_master_playlist_res(input: &[u8]) -> Result> { let parse_result = parse_master_playlist(input); match parse_result { - IResult::Done(_, playlist) => Ok(playlist), + IResult::Ok((_, playlist)) => Ok(playlist), _ => Err(parse_result), } } /// Parse input as a media playlist pub fn parse_media_playlist(input: &[u8]) -> IResult<&[u8], MediaPlaylist> { - parse_media_playlist_tags(input).map(MediaPlaylist::from_tags) + nom::combinator::map(parse_media_playlist_tags, MediaPlaylist::from_tags)(input) } /// Parse input as a media playlist pub fn parse_media_playlist_res(input: &[u8]) -> Result> { let parse_result = parse_media_playlist(input); match parse_result { - IResult::Done(_, playlist) => Ok(playlist), + IResult::Ok((_, playlist)) => Ok(playlist), _ => Err(parse_result), } } @@ -210,7 +210,7 @@ pub fn contains_master_tag(input: &[u8]) -> Option<(bool, String)> { while is_master_opt == None { match is_master_playlist_tag_line(current_input) { - IResult::Done(rest, result) => { + IResult::Ok((rest, result)) => { current_input = rest; is_master_opt = result; // result can be None (no media or master tag found) } diff --git a/src/playlist.rs b/src/playlist.rs index 13417ab..e87ad50 100644 --- a/src/playlist.rs +++ b/src/playlist.rs @@ -732,7 +732,7 @@ impl From for ByteRange { impl<'a> From<&'a str> for ByteRange { fn from(s: &'a str) -> Self { match byte_range_val(s.as_bytes()) { - IResult::Done(_, br) => br, + IResult::Ok((_, br)) => br, _ => panic!("Should not happen"), } }