import
htmlparser,
httpClient,
- logging,
parseopt,
osproc,
sequtils,
uri,
xmltree
-import preferences
+import config
type
SearchResult = tuple[title: string, url: string]
CommandLineOptions = tuple[searchQuery: string, musicOnly: bool, feelingLucky: bool, fullScreen: bool]
-let logger = newConsoleLogger()
-setLogFilter(lvlInfo)
-
proc selectMediaPlayer(): string =
let availablePlayers = filterIt(supportedPlayers, execProcess("which " & it).len != 0)
if len(availablePlayers) == 0:
for index, (title, url) in searchResults:
styledEcho $index, ". ", styleBright, fgMagenta, title, "\n", resetStyle, fgCyan, url, "\n"
-proc play(command: string) =
- logger.log(lvlDebug, &"Executing: ${command}")
- discard execProcess(command)
+proc play(player: string, args: openArray[string]) =
+ discard execProcess(player, args=args, options={poStdErrToStdOut, poUsePath, poEchoCmd})
quit(0)
proc directPlay(searchQuery: string, player: string) =
- if "watch?" in searchQuery or "videos/watch" in searchQuery :
- play(&"{player} {searchQuery}")
+ if "watch?" in searchQuery or "videos/watch" in searchQuery:
+ play(player, args=[searchQuery])
elif searchQuery.startswith("magnet:"):
- play(&"peerflix \"{searchQuery}\" --{player}")
+ play("peerflix", args=[searchQuery, &"--{player}"])
proc main() =
let
styledEcho "\n", fgGreen, "Playing ", styleBright, fgMagenta, searchResults[number].title
- var command = @[player, searchResults[number].url]
+ var args = @[searchResults[number].url]
if musicOnly:
- command.add("--no-video")
+ args.add("--no-video")
if fullScreen:
- if player == "cvlc":
- command.add("--fullscreen")
- if player == "mpv":
- command.add("--fs")
+ args.add("--fullscreen")
# Play the video using the preferred/available media player
- play(command.join(" "))
+ play(player, args)
main()