CLI is working

This commit is contained in:
Kepoor Hampond 2017-03-06 12:33:05 -08:00
parent 71b658f2c9
commit 1fec75673c
4 changed files with 82 additions and 11 deletions

View file

@ -7,6 +7,7 @@ import os
# Powered by: # Powered by:
from .ripper import Ripper from .ripper import Ripper
from .utils import console
def main(): def main():
parser = argparse.ArgumentParser() parser = argparse.ArgumentParser()
@ -26,6 +27,8 @@ def main():
Ripper().spotify_list("album", args.album) Ripper().spotify_list("album", args.album)
elif args.username and args.playlist: elif args.username and args.playlist:
Ripper().spotify_list("playlist", args.playlist, args.username) Ripper().spotify_list("playlist", args.playlist, args.username)
else:
console(Ripper())
if __name__ == "__main__": if __name__ == "__main__":
main() main()

View file

@ -134,10 +134,11 @@ class Ripper:
if type == "playlist": if type == "playlist":
file_prefix = str(len(tracks) + 1) + " - " file_prefix = str(len(tracks) + 1) + " - "
track = track["track"] track = track["track"]
album = self.spotify.album(track["album"]["uri"])
elif type == "album": elif type == "album":
file_prefix = str(track["track_number"]) + " - " file_prefix = str(track["track_number"]) + " - "
track = self.spotify.track(track["uri"])
album = self.spotify.album(track["album"]["uri"]) album = the_list
data = { data = {
"name": track["name"], "name": track["name"],
@ -206,6 +207,8 @@ class Ripper:
if data == {}: if data == {}:
data = self.parse_song_data(song, artist) data = self.parse_song_data(song, artist)
song = data["name"]
artist = data["artist"]
if "file_prefix" not in data: if "file_prefix" not in data:
data["file_prefix"] = "" data["file_prefix"] = ""

View file

@ -116,9 +116,15 @@ def update_download_log_line_status(track, status="downloaded"):
import os, sys, re import os, sys, re
from time import sleep from time import sleep
import pkg_resources
COLS = int(os.popen('tput cols').read().strip("\n")) COLS = int(os.popen('tput cols').read().strip("\n"))
if sys.version_info[0] == 2:
def input(string):
return raw_input(string)
def code(code1): def code(code1):
return "\x1b[%sm" % str(code1) return "\x1b[%sm" % str(code1)
@ -128,8 +134,14 @@ def no_colors(string):
def center_colors(string, cols): def center_colors(string, cols):
return no_colors(string).center(cols).replace(no_colors(string), string) return no_colors(string).center(cols).replace(no_colors(string), string)
def decode_utf8(string):
if sys.version_info[0] == 3:
return string.encode("utf8", "strict").decode()
elif sys.version_info[0] == 2:
return string.decode("utf8")
def center_unicode(string, cols): def center_unicode(string, cols):
tmp_chars = "X" * len(string.decode("utf8")) tmp_chars = "X" * len(decode_utf8(string))
chars = center_colors(tmp_chars, cols) chars = center_colors(tmp_chars, cols)
return chars.replace(tmp_chars, string) return chars.replace(tmp_chars, string)
@ -139,7 +151,7 @@ def center_lines(string, cols, end="\n"):
lines.append(center_unicode(line, cols)) lines.append(center_unicode(line, cols))
return end.join(lines) return end.join(lines)
def flush_puts(msg, time=0.03): def flush_puts(msg, time=0.01):
# For slow *burrrp* scroll text, Morty. They-They just love it, Morty. # For slow *burrrp* scroll text, Morty. They-They just love it, Morty.
# When they see this text. Just slowwwly extending across the page. Mmm, mmm. # When they see this text. Just slowwwly extending across the page. Mmm, mmm.
# You just give the time for how *buurp* slow you wa-want it, Morty. # You just give the time for how *buurp* slow you wa-want it, Morty.
@ -171,13 +183,14 @@ YELLOW = code(33)
BLUE = code(34) BLUE = code(34)
PURPLE = code(35) PURPLE = code(35)
CYAN = code(36) CYAN = code(36)
GRAY = code(37)
BRED = RED + BOLD BRED = RED + BOLD
BGREEN = GREEN + BOLD BGREEN = GREEN + BOLD
BYELLOW = YELLOW + BOLD BYELLOW = YELLOW + BOLD
BBLUE = BLUE + BOLD BBLUE = BLUE + BOLD
BPURPLE = PURPLE + BOLD BPURPLE = PURPLE + BOLD
BCYAN = CYAN + BOLD BCYAN = CYAN + BOLD
BGRAY = GRAY + BOLD
def banner(): def banner():
title = (BCYAN + center_lines("""\ title = (BCYAN + center_lines("""\
@ -196,8 +209,60 @@ def banner():
print ("") print ("")
print (title) print (title)
sleep(0.3) sleep(0.3)
flush_puts(center_colors(BYELLOW + "\ flush_puts(center_colors("{0}Ironic Redistribution System ({1}IRS{2})"\
Ironic Redistribution System (" + BRED + "IRS" + BYELLOW + ")" + END, COLS)) .format(BYELLOW, BRED, BYELLOW), COLS))
flush_puts(center_colors(BBLUE + "\
Made with 😈 by: " + BYELLOW + "Kepoor Hampond (" + BRED + \ flush_puts(center_colors("{0}Made with 😈 by: {1}Kepoor Hampond ({2}kepoorhampond{3})\r"\
"kepoorhampond" + BYELLOW + ")" + END, COLS)) .format(BBLUE, BYELLOW, BRED, BYELLOW) + END, COLS))
flush_puts(center_colors("{0}Version: {1}".format(BBLUE, BYELLOW) + pkg_resources.get_distribution("irs").version, COLS))
def menu(unicode, time=0.01):
flush_puts("Choose option from menu:", time)
flush_puts("\t[{0}song{1}] Download Song".format(BGREEN, END), time)
flush_puts("\t[{0}album{1}] Download Album".format(BGREEN, END), time)
flush_puts("\t[{0}{1}{2}] Download Playlist".format(BGREEN, unicode[-1], END), time)
flush_puts("\t[{0}help{1}] Print This Menu".format(BGREEN, END), time)
flush_puts("\t[{0}exit{1}] Exit IRS".format(BGREEN, END), time)
print ("")
def console(ripper):
banner()
print (END)
if ripper.authorized == True:
unicode = [BGREEN + "" + END, "list"]
elif ripper.authorized == False:
unicode = [BRED + "" + END]
flush_puts("[{0}] Authenticated with Spotify".format(unicode[0]))
print ("")
menu(unicode)
while True:
try:
choice = input("{0}irs{1}>{2} ".format(BBLUE, BGRAY, END))
if choice in ("exit", "e"):
raise KeyboardInterrupt
try:
if choice in ("song", "s"):
song_name = input("Song name{0}:{1} ".format(BBLUE, END))
artist_name = input("Artist name{0}:{1} ".format(BBLUE, END))
ripper.song(song_name, artist_name)
elif choice in ("album", "a"):
album_name = input("Album name{0}:{1} ".format(BBLUE, END))
ripper.spotify_list("album", album_name)
elif choice in ("list", "l") and ripper.authorized == True:
username = input("Spotify Username{0}:{1} ".format(BBLUE, END))
list_name = input("Playlist Name{0}:{1} ".format(BBLUE, END))
ripper.spotify_list("playlist", list_name, username)
elif choice in ("help", "h", "?"):
menu(unicode, 0)
except KeyboardInterrupt:
print ("")
pass
except KeyboardInterrupt:
sys.exit(0)

View file

@ -2,7 +2,7 @@ from setuptools import setup
setup( setup(
name='irs', name='irs',
version='5.0.2', version='6.0.0',
description='A music downloader that just gets metadata.', description='A music downloader that just gets metadata.',
url='https://github.com/kepoorhampond/irs', url='https://github.com/kepoorhampond/irs',
author='Kepoor Hampond', author='Kepoor Hampond',