X-Git-Url: https://njoseph.me/gitweb/nimcoon.git/blobdiff_plain/52ecc638d90fa3f2ee52a538f3950b4253de7a28..121e06b2f5cb4a48cd9190d4a6b88ca756512d6d:/clitube.nim diff --git a/clitube.nim b/clitube.nim index 1c30b92..b15d5a9 100644 --- a/clitube.nim +++ b/clitube.nim @@ -1,18 +1,22 @@ -import htmlparser -import httpClient -import parseopt -import osproc -import sequtils, sugar -import strformat -import std/[terminal] -import strtabs -import strutils -import uri -import xmltree +import + htmlparser, + httpClient, + parseopt, + osproc, + sequtils, + sugar, + strformat, + std/[terminal], + strtabs, + strutils, + uri, + xmltree import preferences -type SearchResult = tuple[title: string, url: string] +type + SearchResult = tuple[title: string, url: string] + CommandLineOptions = tuple[searchQuery: string, musicOnly: bool, feelingLucky: bool] proc selectMediaPlayer(): string = let availablePlayers = filterIt(supportedPlayers, execProcess("which " & it).len != 0) @@ -22,6 +26,25 @@ proc selectMediaPlayer(): string = else: return availablePlayers[0] +proc parseOptions(): CommandLineOptions = + var + searchQuery = "" + musicOnly = false + feelingLucky = false + + for kind, key, value in getopt(): + case kind + of cmdArgument: + searchQuery = key + of cmdShortOption, cmdLongOption: + case key + of "m", "music": musicOnly = true + of "l", "lucky": feelingLucky = true + of cmdEnd: + discard + + return (searchQuery, musicOnly, feelingLucky) + proc getYoutubePage(searchQuery: string): string = let queryParam = encodeUrl(searchQuery) let client = newHttpClient() @@ -38,50 +61,39 @@ proc presentVideoOptions(searchResults: seq[SearchResult]) = for index, (title, url) in searchResults: styledEcho $index, ". ", styleBright, fgMagenta, title, "\n", resetStyle, fgCyan, url, "\n" -let player = selectMediaPlayer() - -var searchQuery = "" -var musicOnly = false -var feelingLucky = false - -for kind, key, value in getopt(): - case kind - of cmdArgument: - searchQuery = key - of cmdShortOption, cmdLongOption: - case key - of "m", "music": musicOnly = true - of "l", "lucky": feelingLucky = true - of cmdEnd: - discard +proc directPlay(searchQuery: string, player: string) = + styledEcho "\n", fgGreen, "Playing ", styleBright, fgMagenta, searchQuery + if "watch?" in searchQuery or "videos/watch" in searchQuery : + discard execProcess(&"{player} {searchQuery}") + quit(0) + elif searchQuery.startswith("magnet:"): + discard execProcess(&"peerflix \"{searchQuery}\" --{player}") + quit(0) +proc main() = + let + player = selectMediaPlayer() + (searchQuery, musicOnly, feelingLucky) = parseOptions() -if "?watch" in searchQuery or "videos/watch" in searchQuery : - discard execProcess(&"{player} {searchQuery}") - quit(0) + directPlay(searchQuery, player) + let searchResults = extractTitlesAndUrls(getYoutubePage(searchQuery)) -if searchQuery.startswith("magnet:"): - discard execProcess(&"peerflix \"{searchQuery}\" --{player}") - quit(0) + let number = + if feelingLucky: 0 + else: + presentVideoOptions(searchResults) + stdout.styledWrite(fgYellow, "Choose video number: ") + parseInt(readLine(stdin)) + styledEcho "\n", fgGreen, "Playing ", styleBright, fgMagenta, searchResults[number].title -let searchResults = extractTitlesAndUrls(getYoutubePage(searchQuery)) - -let number = - if feelingLucky: - 0 - else: - presentVideoOptions(searchResults) - stdout.styledWrite(fgYellow, "Choose video number: ") - parseInt(readLine(stdin)) - -styledEcho "\n", fgGreen, "Playing ", styleBright, fgMagenta, searchResults[number].title + var command = @[player, searchResults[number].url] -var command = @[player, searchResults[number].url] + if musicOnly: + command.add("--no-video") -if musicOnly: - command.add("--no-video") + # Play the video using the preferred/available media player + discard execProcess(command.join(" ")) -# Play the video using the preferred/available media player -discard execProcess(command.join(" ")) +main()