breakout downloadmode
This commit is contained in:
parent
35bb1edfc3
commit
2419592f22
84
src/main.rs
84
src/main.rs
@ -64,7 +64,7 @@ async fn main() {
|
|||||||
}
|
}
|
||||||
|
|
||||||
let user_wish = readline
|
let user_wish = readline
|
||||||
.input("Which one do you wish to stream? [ q/s/r/d ]: ")
|
.input("Which one do you wish to stream? [ q/f/s/r/d ]: ")
|
||||||
.to_lowercase();
|
.to_lowercase();
|
||||||
let user_wish = user_wish.trim();
|
let user_wish = user_wish.trim();
|
||||||
|
|
||||||
@ -84,38 +84,18 @@ async fn main() {
|
|||||||
refresh(&parser).await;
|
refresh(&parser).await;
|
||||||
continue;
|
continue;
|
||||||
}
|
}
|
||||||
// Downloadmode
|
"f" => {
|
||||||
"d" => {
|
mpv_fs = !mpv_fs;
|
||||||
let selection = readline
|
println!(
|
||||||
.input("Download all or select in comma separated [a | 1,2,3,4]: ")
|
"Toggled mpv to {}launch in fullscreen",
|
||||||
.to_lowercase();
|
if mpv_fs { "" } else { "not " }
|
||||||
let selection = selection.trim();
|
);
|
||||||
|
|
||||||
let to_download = loop {
|
|
||||||
break if selection == "a" {
|
|
||||||
println!("Downloading all");
|
|
||||||
search_result.as_ref().unwrap().clone()
|
|
||||||
} else {
|
|
||||||
let selections = selection
|
|
||||||
.split(",")
|
|
||||||
.map(|x| x.trim().parse::<usize>())
|
|
||||||
.collect::<Vec<Result<usize, ParseIntError>>>();
|
|
||||||
|
|
||||||
for selection in selections.iter() {
|
|
||||||
if selection.is_err() {
|
|
||||||
println!("Not a valid number or the option {}", "a".bold());
|
|
||||||
continue;
|
continue;
|
||||||
}
|
}
|
||||||
}
|
// Downloadmode
|
||||||
let selections = selections.into_iter().map(|x| x.unwrap() - 1);
|
"d" => {
|
||||||
let mut final_selections = Vec::new();
|
let to_download =
|
||||||
for selection in selections {
|
ask_which_to_download(&mut readline, search_result.as_ref().unwrap().clone());
|
||||||
final_selections.push((search_result.as_ref().unwrap())[selection]);
|
|
||||||
}
|
|
||||||
|
|
||||||
Rc::new(final_selections)
|
|
||||||
};
|
|
||||||
};
|
|
||||||
download_m3u8(to_download).await;
|
download_m3u8(to_download).await;
|
||||||
}
|
}
|
||||||
_ => {}
|
_ => {}
|
||||||
@ -133,6 +113,48 @@ async fn main() {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
fn ask_which_to_download<'a>(
|
||||||
|
readline: &mut Readline,
|
||||||
|
search_result: Rc<Vec<&'a M3u8>>,
|
||||||
|
) -> Rc<Vec<&'a M3u8>> {
|
||||||
|
let selections = loop {
|
||||||
|
// Ask for userinput
|
||||||
|
let selection = readline
|
||||||
|
.input("Download all or select in comma separated [a | 1,2,3,4]: ")
|
||||||
|
.to_lowercase();
|
||||||
|
let selection = selection.trim();
|
||||||
|
|
||||||
|
// Download all
|
||||||
|
if selection == "a" {
|
||||||
|
println!("Downloading all");
|
||||||
|
return search_result.clone();
|
||||||
|
}
|
||||||
|
|
||||||
|
// Convert to numbers
|
||||||
|
let selections = selection
|
||||||
|
.split(",")
|
||||||
|
.map(|x| x.trim().parse::<usize>())
|
||||||
|
.collect::<Vec<Result<usize, ParseIntError>>>();
|
||||||
|
|
||||||
|
// Ask again if any number wasn't a valid number
|
||||||
|
let wrong_input = selections.iter().any(|x| x.is_err());
|
||||||
|
if wrong_input {
|
||||||
|
println!("Invalid input. Has to be either {}, a number or a sequence of numbers separated by commas","a".bold());
|
||||||
|
continue;
|
||||||
|
}
|
||||||
|
|
||||||
|
break selections;
|
||||||
|
};
|
||||||
|
|
||||||
|
Rc::new(
|
||||||
|
selections
|
||||||
|
.into_iter()
|
||||||
|
.map(|x| x.unwrap() - 1) // Since all numbers are valid, remap them
|
||||||
|
.map(|x| search_result[x]) // We don't want the numbers, but the &M3u8 in those positions
|
||||||
|
.collect(),
|
||||||
|
)
|
||||||
|
}
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* I know that this is also frowned upon, but it is perfectly safe right here,
|
* I know that this is also frowned upon, but it is perfectly safe right here,
|
||||||
* even though the borrowchecker complains
|
* even though the borrowchecker complains
|
||||||
|
Loading…
x
Reference in New Issue
Block a user