+ print "Recreated lookup index."
+
+
+def command_setup(*args):
+ parser = get_parser(verbose=False)
+ options, _ = parser.parse_args(list(args))
+
+ options.directory = None
+
+ session = get_session(options)
+ print_csv_directory(options)
+ pokedex.db.load.load(session, directory=None, drop_tables=True,
+ verbose=options.verbose)
+
+ lookup = get_lookup(options, session=session, recreate=True)
+
+ print "Recreated lookup index."
+
+
+def command_status(*args):
+ parser = get_parser(verbose=True)
+ options, _ = parser.parse_args(list(args))
+ options.verbose = True
+ options.directory = None
+
+ session = get_session(options)
+ print_csv_directory(options)
+ lookup = get_lookup(options, recreate=False)
+
+
+### User-facing commands
+
+def command_lookup(*args):
+ parser = get_parser(verbose=False)
+ options, words = parser.parse_args(list(args))
+
+ name = u' '.join(words)
+
+ session = get_session(options)
+ lookup = get_lookup(options, session=session, recreate=False)
+
+ results = lookup.lookup(name)
+ if not results:
+ print "No matches."
+ elif results[0].exact:
+ print "Matched:"
+ else:
+ print "Fuzzy-matched:"
+
+ for result in results:
+ if hasattr(result.object, 'full_name'):
+ name = result.object.full_name
+ else:
+ name = result.object.name
+
+ print "%s: %s" % (result.object.__tablename__, name),
+ if result.language:
+ print "(%s in %s)" % (result.name, result.language)
+ else:
+ print
+
+
+def command_help():
+ print u"""pokedex -- a command-line Pokédex interface
+usage: pokedex {command} [options...]
+Run `pokedex setup` first, or nothing will work!
+See http://bugs.veekun.com/projects/pokedex/wiki/CLI for more documentation.
+
+Commands:
+ help Displays this message.
+ lookup [thing] Look up something in the Pokédex.
+
+System commands:
+ load Load Pokédex data into a database from CSV files.
+ dump Dump Pokédex data from a database into CSV files.
+ reindex Rebuilds the lookup index from the database.
+ setup Combines load and reindex.
+ status No effect, but prints which engine, index, and csv
+ directory would be used for other commands.
+
+Global options:
+ -e|--engine=URI By default, all commands try to use a SQLite database
+ in the pokedex install directory. Use this option (or
+ a POKEDEX_DB_ENGINE environment variable) to specify an
+ alternate database.
+ -i|--index=DIR By default, all commands try to put the lookup index in
+ the pokedex install directory. Use this option (or a
+ POKEDEX_INDEX_DIR environment variable) to specify an
+ alternate loction.
+ -q|--quiet Don't print system output. This is the default for
+ non-system commands and setup.
+ -v|--verbose Print system output. This is the default for system
+ commands, except setup.
+
+System options:
+ -d|--directory=DIR By default, load and dump will use the CSV files in the
+ pokedex install directory. Use this option to specify
+ a different directory.
+ -D|--drop-tables With load, drop all tables before loading data.
+
+ Additionally, load and dump accept a list of table names (possibly with
+ wildcards) and/or csv fileames as an argument list.
+""".encode(sys.getdefaultencoding(), 'replace')