X-Git-Url: http://git.veekun.com/zzz-dywypi.git/blobdiff_plain/1c23fdf085d6869227aaac6953efede185ec1cda..9f52f0376ea3d5d0b2a79adaf73abbb33730471f:/plugins/Pokedex/plugin.py diff --git a/plugins/Pokedex/plugin.py b/plugins/Pokedex/plugin.py index 8fdf0da..fd728e2 100644 --- a/plugins/Pokedex/plugin.py +++ b/plugins/Pokedex/plugin.py @@ -40,6 +40,8 @@ import pokedex.db import pokedex.db.tables as tables import pokedex.lookup +import urllib + class Pokedex(callbacks.Plugin): """Add the help for "@plugin help Pokedex" here This should describe *how* to use this plugin.""" @@ -89,11 +91,19 @@ class Pokedex(callbacks.Plugin): result_strings = [] for result in results: - result_string = result.name + result_string = result.object.name + + # Prepend, e.g., pokemon: if necessary if use_prefixes: # Table classes know their singular names prefix = result.object.__singlename__ result_string = prefix + ':' + result_string + + # Identify foreign language names + if result.language: + result_string += u""" ({0}: {1})""".format( + result.iso3166, result.name) + result_strings.append(result_string) self._reply(irc, u"{0}: {1}?".format(reply, '; '.join(result_strings))) @@ -101,35 +111,123 @@ class Pokedex(callbacks.Plugin): # If we got here, there's an exact match; hurrah! result = results[0] - if isinstance(result.object, tables.Pokemon): - self._reply(irc, u"""{name}, {type}-type Pokémon.""".format( - name=result.object.name, - type='/'.join(_.name for _ in result.object.types), + obj = result.object + if isinstance(obj, tables.Pokemon): + reply_template = \ + u"""#{id} {name}, {type}-type Pokémon. Has {abilities}. """ \ + """Stats are {stats}, total {total}. """ \ + """http://veekun.com/dex/pokemon/{link_name}""" + + if obj.forme_name: + name = '{form} {name}'.format( + form=obj.forme_name.title(), + name=obj.name + ) + else: + name = obj.name + + if obj.forme_base_pokemon: + # Can't use urllib.quote() on the whole thing or it'll + # catch "?" and "=" where it shouldn't. + # XXX Also we need to pass urllib.quote() things explicitly + # encoded as utf8 or else we get a UnicodeEncodeError. + link_name = '{name}?form={form}'.format( + name=urllib.quote(obj.name.lower().encode('utf8')), + form=urllib.quote(obj.forme_name.lower().encode('utf8')), + ) + else: + link_name = urllib.quote(obj.name.lower().encode('utf8')) + + self._reply(irc, reply_template.format( + id=obj.national_id, + name=name, + type='/'.join(_.name for _ in obj.types), + abilities=' or '.join(_.name for _ in obj.abilities), + stats='/'.join(str(_.base_stat) for _ in obj.stats), + total=sum(_.base_stat for _ in obj.stats), + link_name=link_name, ) ) - elif isinstance(result.object, tables.Move): - self._reply(irc, u"""{name}, {type}-type move.""".format( - name=result.object.name, - type=result.object.type.name, + elif isinstance(obj, tables.Move): + reply_template = \ + u"""{name}, {type}-type {damage_class} move. """ \ + """{power} power; {accuracy}% accuracy; {pp} PP. """ \ + """{effect} """ \ + """http://veekun.com/dex/moves/{link_name}""" + self._reply(irc, reply_template.format( + name=obj.name, + type=obj.type.name, + damage_class=obj.damage_class.name, + power=obj.power, + accuracy=obj.accuracy, + pp=obj.pp, + effect=unicode(obj.short_effect.as_text), + link_name=urllib.quote(obj.name.lower().encode('utf8')), ) ) - elif isinstance(result.object, tables.Type): - self._reply(irc, u"""{name}, a type.""".format( - name=result.object.name, + elif isinstance(obj, tables.Type): + reply_template = u"""{name}, a type. """ + + reply_factors = { 200: u'2', 50: u'½', 0: u'0' } + + offensive_modifiers = {} + for matchup in obj.damage_efficacies: + if matchup.damage_factor != 100: + offensive_modifiers.setdefault(matchup.damage_factor, []) \ + .append(matchup.target_type.name) + if offensive_modifiers: + reply_template += u"""{offensive_modifiers}. """ + for factor in offensive_modifiers: + offensive_modifiers[factor] = u'{factor}× against {types}'.format( + factor=reply_factors[factor], + types=', '.join(sorted(offensive_modifiers[factor])) + ) + + defensive_modifiers = {} + for matchup in obj.target_efficacies: + if matchup.damage_factor != 100: + defensive_modifiers.setdefault(matchup.damage_factor, []) \ + .append(matchup.damage_type.name) + if defensive_modifiers: + reply_template += u"""{defensive_modifiers}. """ + for factor in defensive_modifiers: + defensive_modifiers[factor] = u'{factor}× from {types}'.format( + factor=reply_factors[factor], + types=', '.join(sorted(defensive_modifiers[factor])) + ) + + reply_template += u"""http://veekun.com/dex/types/{link_name}""" + + self._reply(irc, reply_template.format( + name=obj.name.capitalize(), + offensive_modifiers='; '.join(offensive_modifiers[_] + for _ in sorted(offensive_modifiers)), + defensive_modifiers='; '.join(defensive_modifiers[_] + for _ in sorted(defensive_modifiers)), + link_name=urllib.quote(obj.name.lower().encode('utf8')), ) ) - elif isinstance(result.object, tables.Item): - self._reply(irc, u"""{name}, an item.""".format( - name=result.object.name, + elif isinstance(obj, tables.Item): + reply_template = \ + u"""{name}, an item. """ \ + """http://veekun.com/dex/items/{link_name}""" + self._reply(irc, reply_template.format( + name=obj.name, + link_name=urllib.quote(obj.name.lower().encode('utf8')), ) ) - elif isinstance(result.object, tables.Ability): - self._reply(irc, u"""{name}, an ability.""".format( - name=result.object.name, + elif isinstance(obj, tables.Ability): + reply_template = \ + u"""{name}, an ability. {effect} """ \ + """http://veekun.com/dex/abilities/{link_name}""" + self._reply(irc, reply_template.format( + name=obj.name, + effect=obj.effect, + link_name=urllib.quote(obj.name.lower().encode('utf8')), ) )