X-Git-Url: https://njoseph.me/gitweb/nimcoon.git/blobdiff_plain/03a70308b52756e52aeeb883abd012bb06779b33..4827df7ac6cc2b6cbc55894f95509c2c6a26c095:/clitube.nim diff --git a/clitube.nim b/clitube.nim index 0c21a94..3714c13 100644 --- a/clitube.nim +++ b/clitube.nim @@ -1,6 +1,6 @@ import htmlparser import httpClient -import os +import parseopt import osproc import sequtils, sugar import strformat @@ -38,14 +38,29 @@ proc presentVideoOptions(searchResults: seq[SearchResult]) = for index, (title, url) in searchResults: styledEcho $index, ". ", styleBright, fgMagenta, title, "\n", resetStyle, fgCyan, url, "\n" -let input = paramStr(1) let player = selectMediaPlayer() -if "https://www.youtube.com" in input: - discard execProcess(&"{player} {input}") +var searchQuery = "" +var musicOnly = false + +for kind, key, value in getopt(): + case kind + of cmdArgument: + searchQuery = key + of cmdShortOption, cmdLongOption: + case key + of "m", "music": musicOnly = true + of cmdEnd: + discard + +let noVideo = if musicOnly: "--no-video" else: "" + +if "https://www.youtube.com" in searchQuery: + discard execProcess(&"{player} {searchQuery}") quit(0) -let searchResults = extractTitlesAndUrls(getYoutubePage(input)) + +let searchResults = extractTitlesAndUrls(getYoutubePage(searchQuery)) presentVideoOptions(searchResults) @@ -55,4 +70,4 @@ let number = parseInt(readLine(stdin)) styledEcho "\n", fgGreen, "Playing ", styleBright, fgMagenta, searchResults[number].title # Play the video using the preferred/available media player -discard execProcess(&"{player} {searchResults[number].url}") +discard execProcess(&"{player} {noVideo} {searchResults[number].url}")