]> njoseph.me Git - nimcoon.git/blobdiff - clitube.nim
Get rid of all global state mutation
[nimcoon.git] / clitube.nim
index 3714c13612433ed295690aec1a41063ecfde2110..b15d5a9a47756692adf75feb416a4e5efee5c019 100644 (file)
@@ -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,36 +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
+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)
 
-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
+proc main() =
+  let
+    player = selectMediaPlayer()
+    (searchQuery, musicOnly, feelingLucky) = parseOptions()
 
-let noVideo = if musicOnly: "--no-video" else: ""
+  directPlay(searchQuery, player)
 
-if "https://www.youtube.com" in searchQuery:
-  discard execProcess(&"{player} {searchQuery}")
-  quit(0)
+  let searchResults = extractTitlesAndUrls(getYoutubePage(searchQuery))
 
+  let number =
+    if feelingLucky: 0
+    else:
+      presentVideoOptions(searchResults)
+      stdout.styledWrite(fgYellow, "Choose video number: ")
+      parseInt(readLine(stdin))
 
-let searchResults = extractTitlesAndUrls(getYoutubePage(searchQuery))
+  styledEcho "\n", fgGreen, "Playing ", styleBright, fgMagenta, searchResults[number].title
 
-presentVideoOptions(searchResults)
+  var command = @[player, searchResults[number].url]
 
-stdout.styledWrite(fgYellow, "Choose video number: ")
-let number = parseInt(readLine(stdin))
+  if musicOnly:
+    command.add("--no-video")
 
-styledEcho "\n", fgGreen, "Playing ", styleBright, fgMagenta, searchResults[number].title
+  # Play the video using the preferred/available media player
+  discard execProcess(command.join(" "))
 
-# Play the video using the preferred/available media player
-discard execProcess(&"{player} {noVideo} {searchResults[number].url}")
+main()