mirror of
https://github.com/rutgersc/m3u8-rs.git
synced 2024-12-31 18:28:40 +00:00
Done is now Ok, map works a little different
This commit is contained in:
parent
ca07767eb4
commit
67eebd17a0
2 changed files with 10 additions and 10 deletions
18
src/lib.rs
18
src/lib.rs
|
@ -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)
|
||||||
}
|
}
|
||||||
|
|
|
@ -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"),
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in a new issue