Fix download command
Also implement proper usage on error or -h
This commit is contained in:
parent
b77ae6c9a8
commit
4b67699a39
1 changed files with 21 additions and 5 deletions
|
@ -538,9 +538,14 @@ def mirror(toc, downloaddb, one=False):
|
||||||
|
|
||||||
def download_episode(toc, downloaddb, episode):
|
def download_episode(toc, downloaddb, episode):
|
||||||
items = toc.getItems()
|
items = toc.getItems()
|
||||||
|
options = {}
|
||||||
for item in items:
|
for item in items:
|
||||||
if item.title == episode or item.name == episode or item.episode == episode:
|
if item.title == episode or item.name == episode or item.episode == episode:
|
||||||
download_one(item, downloaddb)
|
for i in (item.title, item.episode, item.name):
|
||||||
|
if IncludeShow.includes.has_key(i):
|
||||||
|
options = IncludeShow.includes[i]
|
||||||
|
download_one(item, downloaddb, options)
|
||||||
|
return
|
||||||
|
|
||||||
|
|
||||||
def printtoc(toc, downloaddb):
|
def printtoc(toc, downloaddb):
|
||||||
|
@ -561,6 +566,12 @@ def printtoc(toc, downloaddb):
|
||||||
print "*** {} shows listed".format(len(items))
|
print "*** {} shows listed".format(len(items))
|
||||||
|
|
||||||
|
|
||||||
|
def usage():
|
||||||
|
print >>sys.stderr, 'usage: tivomirror -dvuT [-c config] cmd'
|
||||||
|
print >>sys.stderr, ' cmd is one of download, list, mirror, mirrorone'
|
||||||
|
sys.exit(64)
|
||||||
|
|
||||||
|
|
||||||
def main():
|
def main():
|
||||||
global config, logger
|
global config, logger
|
||||||
curdir = os.getcwd()
|
curdir = os.getcwd()
|
||||||
|
@ -576,8 +587,8 @@ def main():
|
||||||
conffile = None
|
conffile = None
|
||||||
|
|
||||||
try:
|
try:
|
||||||
options, remainder = getopt.getopt(sys.argv[1:], 'c:dvuT',
|
options, remainder = getopt.getopt(sys.argv[1:], 'c:dhvuT?',
|
||||||
['config', 'ignoreepisodetitle', 'debug', 'verbose', 'update'])
|
['config', 'ignoreepisodetitle', 'debug', 'verbose', 'update', help])
|
||||||
|
|
||||||
for opt, arg in options:
|
for opt, arg in options:
|
||||||
if opt in ('-c', '--config'):
|
if opt in ('-c', '--config'):
|
||||||
|
@ -591,6 +602,8 @@ def main():
|
||||||
updateToc = True
|
updateToc = True
|
||||||
if opt in ('-T', '--ignoreepisodetitle'):
|
if opt in ('-T', '--ignoreepisodetitle'):
|
||||||
config.ignoreepisodetitle = True
|
config.ignoreepisodetitle = True
|
||||||
|
if opt in ('-h', '-?', '--help'):
|
||||||
|
usage()
|
||||||
|
|
||||||
config = Config(conffile)
|
config = Config(conffile)
|
||||||
|
|
||||||
|
@ -614,9 +627,12 @@ def main():
|
||||||
else:
|
else:
|
||||||
logger.error("invalid command {}".format(cmd))
|
logger.error("invalid command {}".format(cmd))
|
||||||
print >>sys.stderr, "invalid command {}".format(cmd)
|
print >>sys.stderr, "invalid command {}".format(cmd)
|
||||||
sys.exit(64)
|
usage()
|
||||||
|
|
||||||
downloaddb.close()
|
downloaddb.close()
|
||||||
|
except getopt.GetoptError as e:
|
||||||
|
print >>sys.stderr, 'Error parsing options: {}'.format(e)
|
||||||
|
usage()
|
||||||
except Exception:
|
except Exception:
|
||||||
logger.exception("")
|
logger.exception("")
|
||||||
logger.info("*** Completed")
|
logger.info("*** Completed")
|
||||||
|
|
Loading…
Reference in a new issue