1
0
mirror of https://github.com/vikstrous/pirate-get synced 2025-01-25 12:24:20 +01:00

Merge remote-tracking branch 'fredefox/master'

Conflicts:
	pirate-get.py
This commit is contained in:
Viktor Stanchev 2014-02-15 15:12:59 -05:00
commit 1261090d68

View File

@ -1,4 +1,6 @@
#!/usr/bin/env python
from __future__ import print_function
import __builtin__
import webbrowser
import urllib
import urllib2
@ -51,14 +53,7 @@ def main():
parser.add_argument('--local', dest='database', help="An xml file containing the Pirate Bay database")
parser.add_argument('-p', dest='pages', help="The number of pages to fetch (doesn't work with --local)", default=1)
parser.add_argument('-0', dest='first', action='store_true', help="choose the top result", default=False)
def local(args):
xml_str = ''
with open(args.database, 'r') as f:
xml_str += f.read()
htmlparser = MyHTMLParser(args.q)
htmlparser.feed(xml_str)
return htmlparser.results
parser.add_argument('--color', dest='color', action='store_true', help="use colored output", default=False)
#todo: redo this with html parser instead of regex
def remote(args, mirror):
@ -98,13 +93,51 @@ def main():
res_l.append(curr)
curr = ['', 0, 0]
except KeyboardInterrupt :
print "\nCancelled."
print("\nCancelled.")
exit()
# return the sizes in a spearate list
return res_l, sizes, uploaded
args = parser.parse_args()
def make_print():
if(args.color):
import colorama
colorama.init()
color_dict = {"default": "",
"header": colorama.Back.WHITE + colorama.Fore.BLACK,
"zebra_0": "",
"zebra_1": colorama.Style.DIM,
"WARN": colorama.Fore.YELLOW,
"ERROR": colorama.Fore.RED}
def n_print(*args, **kwargs):
"""Print with colors"""
try:
c = color_dict[kwargs.pop("color")]
args = (c + str(args[0]),) + args[1:] + (colorama.Style.RESET_ALL,)
except KeyError as e:
pass
except IndexError as e:
pass
return __builtin__.print(*args, **kwargs)
else:
def n_print(*args, **kwargs):
if("color" in kwargs):
kwargs.pop('color')
return __builtin__.print(*args, **kwargs)
return n_print
print=make_print()
def local(args):
xml_str = ''
with open(args.database, 'r') as f:
xml_str += f.read()
htmlparser = MyHTMLParser(args.q)
htmlparser.feed(xml_str)
return htmlparser.results
if args.database:
mags = local(args)
else:
@ -117,40 +150,52 @@ def main():
res = f.read()
mirrors += res.split("\n")[3:]
except:
print "Could not fetch additional mirrors"
print("Could not fetch additional mirrors", color="WARN")
for mirror in mirrors:
try:
print("Trying " + mirror)
mags, sizes, uploaded = remote(args, mirror)
break
except Exception, e:
print("Could not contact " + mirror)
print("Could not contact " + mirror, color="WARN")
if mags and len(mags) > 0:
# enhanced print output with column titles
print "\n%-5s %-6s %-6s %-5s %-11s %-11s %s" % ( "LINK", "SEED", "LEECH", "RATIO", "SIZE", "UPLOAD", "NAME")
for m in range(len(mags)):
magnet = mags[m]
print("%5s %6s %6s %-5s %-11s %-11s %s" \
% ( "LINK", "SEED", "LEECH", "RATIO", "SIZE", "UPLOAD", "NAME"),
color="header")
cur_color = "zebra_0"
for i in range(len(mags)):
magnet = mags[i]
no_seeders = int(magnet[1])
no_leechers = int(magnet[2])
name = re.search("dn=([^\&]*)", magnet[0])
# compute the S/L ratio (Higher is better)
try:
ratio = float(magnet[1])/float(magnet[2])
ratio = no_seeders/no_leechers
except ZeroDivisionError:
ratio = 0
ratio = -1
# Alternate between colors
cur_color = "zebra_0" if (cur_color == "zebra_1") else "zebra_1"
torrent_name = urllib.unquote(name.group(1).encode('ascii')) \
.decode('utf-8').replace("+", " ")
# enhanced print output with justified columns
print "%-5s %-6s %-6s %5.1f %-11s %-11s %s" % (m, magnet[1], magnet[2], ratio ,sizes[m], uploaded[m],urllib.unquote(name.group(1).encode('ascii')).decode('utf-8').replace("+", " ") )
print ("%5d %6d %6d %5.1f %-11s %-11s %s" % (
i, no_seeders, no_leechers, ratio ,sizes[i],
uploaded[i], torrent_name), color=cur_color)
if args.first:
print "Choosing first result";
print("Choosing first result");
choice = 0
else:
try:
l = raw_input("Select a link: ")
except KeyboardInterrupt :
print "\nCancelled."
print("\nCancelled.")
exit()
try:
@ -161,17 +206,17 @@ def main():
if not choice == None:
url = mags[choice][0]
print
print "url:"
print url
print("url:")
print(url)
if args.transmission:
os.system("""transmission-remote --add "%s" """ % (url))
os.system("transmission-remote -l")
else:
webbrowser.open(url)
else:
print "Cancelled."
print("Cancelled.")
else:
print "no results"
print("no results")
if __name__ == "__main__":
main()