X-Git-Url: http://dolda2000.com/gitweb/?p=automanga.git;a=blobdiff_plain;f=automanga;h=a3e7af4ba5ac1b9b912cff26ef434c558d0db4c3;hp=0381786b830ef00871330c2ed29326d8165641cd;hb=acdde6cabb481343d32450ac88873cf0ee063c9a;hpb=7f4e185b4436452be259b15b172c52e309770085 diff --git a/automanga b/automanga index 0381786..a3e7af4 100755 --- a/automanga +++ b/automanga @@ -8,26 +8,40 @@ gobject.threads_init() gtk.gdk.threads_init() def usage(out): - out.write("usage: automanga [-h] [-p PROFILE] [-l LIBRARY] [DIR-OR-ID]\n") - out.write(" automanga [-h] -s LIBRARY NAME\n") + out.write("usage: automanga [-h] [-p PROFILE] {DIRECTORY|-l LIBRARY ID|-a ALIAS}\n") + out.write(" automanga -a ALIAS=LIBRARY:ID\n") + out.write(" automanga -t {DIRECTORY|-l LIBRARY ID|-a ALIAS} [-]TAG...\n") + out.write(" automanga -{s|S} LIBRARY NAME\n") + out.write(" automanga -L TAG\n") libname = None -search = False +search = None profile = "" -opts, args = getopt.getopt(sys.argv[1:], "hl:sp:") +alias = None +settags = False +listtag = None +opts, args = getopt.getopt(sys.argv[1:], "hl:sSp:a:tL:") for o, a in opts: if o == "-h": usage(sys.stdout) sys.exit(0) elif o == "-l": libname = a + elif o == "-a": + alias = a elif o == "-s": - search = True + search = "name" + elif o == "-S": + search = "match" elif o == "-p": if a == "": profile = None else: profile = a + elif o == "-t": + settags = True + elif o == "-L": + listtag = a if profile == "": try: profile = manga.profile.profile.last() @@ -36,44 +50,120 @@ if profile == "": elif profile is not None: profile = manga.profile.profile.byname(profile) -if search: - if len(args) < 2: - usage(sys.stderr) - sys.exit(1) - try: - lib = manga.lib.findlib(args[0]) - except ImportError: - sys.stderr.write("automanga: no such library: %s\n" % args[0]) - sys.exit(1) - for manga in lib.byname(args[1]): - sys.stdout.write("\"%s\": %s\n" % (manga.name, manga.id)) - sys.exit(0) +def main(): + global libname -if libname is not None: - if len(args) < 1: - usage(sys.stderr) - sys.exit(1) - try: - lib = manga.lib.findlib(libname) - except ImportError: - sys.stderr.write("automanga: no such library: %s\n" % libname) - sys.exit(1) - try: - mng = lib.byid(args[0]) - except KeyError: - sys.stderr.write("automanga: no such manga: %s\n" % args[0]) - sys.exit(1) -else: - libname = "local" - if len(args) > 0: - mng = manga.local.manga(args[0]) + if search: + if len(args) < 2: + usage(sys.stderr) + sys.exit(1) + try: + lib = manga.lib.findlib(args[0]) + except ImportError: + sys.stderr.write("automanga: no such library: %s\n" % args[0]) + sys.exit(1) + try: + if search == "name": + results = lib.byname(args[1]) + elif search == "match": + results = lib.search(args[1]) + if hasattr(results, "__length_hint__"): + sys.stderr.write("%i results:\n" % results.__length_hint__()) + except NotImplementedError: + sys.stderr.write("automanga: %s does not support searching\n" % args[0]) + sys.exit(1) + for mng in results: + sys.stdout.write("\"%s\": %s\n" % (mng.name, mng.id)) + return + + if listtag is not None: + if profile is not None: + for mprof in profile.bytag(listtag): + try: + mng = mprof.open() + sys.stdout.write("%s %s: \"%s\"\n" % (mprof.libnm, mprof.id, mng.name)) + except KeyError: + sys.stdout.write("%s %s: no longer exists\n" % (mprof.libnm, mprof.id)) + return + + if alias and (alias.find('=') > 0): + tgt, nm = alias.split('=', 1) + if not ':' in nm: + usage(sys.stderr) + sys.exit(1) + libname, mid = nm.split(':', 1) + try: + lib = manga.lib.findlib(libname) + except ImportError: + sys.stderr.write("automanga: no such library: %s\n" % libname) + sys.exit(1) + try: + mng = lib.byid(mid) + except KeyError as e: + sys.stderr.write("automanga: no such manga: %s\n" % str(e)) + sys.exit(1) + profile.setalias(tgt, libname, mng.id) + return + + if alias: + try: + libname, mid = profile.getalias(alias) + except KeyError: + sys.stderr("automanga: no such alias: %s\n" % alias) + sys.exit(1) + try: + lib = manga.lib.findlib(libname) + except ImportError: + sys.stderr.write("automanga: no such library: %s\n" % libname) + sys.exit(1) + try: + mng = lib.byid(mid) + except KeyError: + sys.stderr.write("automanga: manga no longer found: %s\n" % mid) + sys.exit(1) + elif libname is not None: + if len(args) < 1: + usage(sys.stderr) + sys.exit(1) + try: + lib = manga.lib.findlib(libname) + except ImportError: + sys.stderr.write("automanga: no such library: %s\n" % libname) + sys.exit(1) + try: + mng = lib.byid(args.pop(0)) + except KeyError as e: + sys.stderr.write("automanga: no such manga: %s\n" % str(e)) + sys.exit(1) else: - mng = manga.local.manga(".") + libname = "local" + try: + if len(args) > 0: + mdir = args.pop(0) + else: + mdir = "." + mng = manga.local.manga(mdir) + except TypeError: + sys.stderr.write("automanga: not a valid manga directory: %s\n" % mdir) + sys.exit(1) + + mprof = None if profile is None else profile.getmanga(libname, mng.id, True) + if profile is not None: + profile.setlast() + + if settags: + if mprof is not None: + ntags = [tag for tag in args if tag[:1] != "-"] + rtags = [tag[1:] for tag in args if tag[:1] == "-"] + if ntags: mprof.tags.add(*ntags) + if rtags: mprof.tags.remove(*rtags) + return -mprof = None if profile is None else profile.getmanga(libname, mng.id, True) -if profile is not None: - profile.setlast() + reader = manga.reader.reader(mng, mprof) + reader.show() + gtk.main() -reader = manga.reader.reader(mng, mprof) -reader.show() -gtk.main() +try: + main() +except KeyboardInterrupt: + pass