Done is now Ok, map works a little different

This commit is contained in:
Rogier 'DocWilco' Mulhuijzen 2020-02-12 14:38:15 -08:00
parent ca07767eb4
commit 67eebd17a0
2 changed files with 10 additions and 10 deletions

View file

@ -88,7 +88,6 @@
//! //!
//! ``` //! ```
#[macro_use]
extern crate nom; extern crate nom;
pub mod playlist; pub mod playlist;
@ -129,8 +128,9 @@ use playlist::*;
/// } /// }
pub fn parse_playlist(input: &[u8]) -> IResult<&[u8], Playlist> { pub fn parse_playlist(input: &[u8]) -> IResult<&[u8], Playlist> {
match is_master_playlist(input) { match is_master_playlist(input) {
true => parse_master_playlist(input).map(Playlist::MasterPlaylist), // XXX: get rid of the local `map` to be able to `use` this
false => parse_media_playlist(input).map(Playlist::MediaPlaylist), 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<Playlist, IResult<&[u8], Playlist>> { pub fn parse_playlist_res(input: &[u8]) -> Result<Playlist, IResult<&[u8], Playlist>> {
let parse_result = parse_playlist(input); let parse_result = parse_playlist(input);
match parse_result { match parse_result {
IResult::Done(_, playlist) => Ok(playlist), IResult::Ok((_, playlist)) => Ok(playlist),
_ => Err(parse_result), _ => Err(parse_result),
} }
} }
/// Parse input as a master playlist /// Parse input as a master playlist
pub fn parse_master_playlist(input: &[u8]) -> IResult<&[u8], MasterPlaylist> { 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 /// Parse input as a master playlist
pub fn parse_master_playlist_res(input: &[u8]) -> Result<MasterPlaylist, IResult<&[u8], MasterPlaylist>> { pub fn parse_master_playlist_res(input: &[u8]) -> Result<MasterPlaylist, IResult<&[u8], MasterPlaylist>> {
let parse_result = parse_master_playlist(input); let parse_result = parse_master_playlist(input);
match parse_result { match parse_result {
IResult::Done(_, playlist) => Ok(playlist), IResult::Ok((_, playlist)) => Ok(playlist),
_ => Err(parse_result), _ => Err(parse_result),
} }
} }
/// Parse input as a media playlist /// Parse input as a media playlist
pub fn parse_media_playlist(input: &[u8]) -> IResult<&[u8], MediaPlaylist> { 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 /// Parse input as a media playlist
pub fn parse_media_playlist_res(input: &[u8]) -> Result<MediaPlaylist, IResult<&[u8], MediaPlaylist>> { pub fn parse_media_playlist_res(input: &[u8]) -> Result<MediaPlaylist, IResult<&[u8], MediaPlaylist>> {
let parse_result = parse_media_playlist(input); let parse_result = parse_media_playlist(input);
match parse_result { match parse_result {
IResult::Done(_, playlist) => Ok(playlist), IResult::Ok((_, playlist)) => Ok(playlist),
_ => Err(parse_result), _ => Err(parse_result),
} }
} }
@ -210,7 +210,7 @@ pub fn contains_master_tag(input: &[u8]) -> Option<(bool, String)> {
while is_master_opt == None { while is_master_opt == None {
match is_master_playlist_tag_line(current_input) { match is_master_playlist_tag_line(current_input) {
IResult::Done(rest, result) => { IResult::Ok((rest, result)) => {
current_input = rest; current_input = rest;
is_master_opt = result; // result can be None (no media or master tag found) is_master_opt = result; // result can be None (no media or master tag found)
} }

View file

@ -732,7 +732,7 @@ impl From<String> for ByteRange {
impl<'a> From<&'a str> for ByteRange { impl<'a> From<&'a str> for ByteRange {
fn from(s: &'a str) -> Self { fn from(s: &'a str) -> Self {
match byte_range_val(s.as_bytes()) { match byte_range_val(s.as_bytes()) {
IResult::Done(_, br) => br, IResult::Ok((_, br)) => br,
_ => panic!("Should not happen"), _ => panic!("Should not happen"),
} }
} }