From f1eb5fe1371c768cf47db0efee7ec0254af57e2d Mon Sep 17 00:00:00 2001 From: Eevee <git@veekun.com> Date: Mon, 11 Jun 2012 23:03:24 -0700 Subject: [PATCH] Update for current pokedex as of 2012-06-12 thanks Zhorken <3 --- plugins/Pokedex/plugin.py | 32 +++++++++++++++++++++----------- 1 file changed, 21 insertions(+), 11 deletions(-) diff --git a/plugins/Pokedex/plugin.py b/plugins/Pokedex/plugin.py index e57d517..a19b677 100644 --- a/plugins/Pokedex/plugin.py +++ b/plugins/Pokedex/plugin.py @@ -130,9 +130,11 @@ class Pokedex(callbacks.Plugin): result = results[0] obj = result.object - # Deal with Pokémon form matches + # Deal with Pokémon shenanigans if isinstance(obj, tables.PokemonForm): - obj = obj.unique_pokemon or obj.form_base_pokemon + obj = obj.pokemon + elif isinstance(obj, tables.PokemonSpecies): + obj = obj.default_pokemon if isinstance(obj, tables.Pokemon): reply_template = \ @@ -140,17 +142,17 @@ class Pokedex(callbacks.Plugin): """{stats}. """ \ """http://veekun.com/dex/pokemon/{link_name}""" - if not obj.is_base_form: + if not obj.is_default: # 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.form_name.lower().encode('utf8')), + name=urllib.quote(obj.species.name.lower().encode('utf8')), + form=urllib.quote(obj.default_form.form_identifier.lower().encode('utf8')), ) else: - link_name = urllib.quote(obj.name.lower().encode('utf8')) + link_name = urllib.quote(obj.species.name.lower().encode('utf8')) # a/b/c/d/e/f sucks. Put stats in a more readable format. # Also, color-code them by good-osity. @@ -172,8 +174,8 @@ class Pokedex(callbacks.Plugin): stats = """{0} HP, {1}/{2} phys, {3}/{4} spec, {5} speed; {total} total""" \ .format(*colored_stats, total=colored_stat_total) self._reply(irc, reply_template.format( - id=obj.normal_form.id, - name=obj.full_name or obj.name, + id=obj.species.id, + name=obj.name, type='/'.join(_.name for _ in obj.types), abilities=' or '.join(_.name for _ in obj.abilities), stats=stats, @@ -194,7 +196,7 @@ class Pokedex(callbacks.Plugin): power=obj.power, accuracy=obj.accuracy, pp=obj.pp, - effect=unicode(obj.short_effect.as_text), + effect=unicode(obj.short_effect.as_text()), link_name=urllib.quote(obj.name.lower().encode('utf8')), ) ) @@ -254,10 +256,18 @@ class Pokedex(callbacks.Plugin): elif isinstance(obj, tables.Item): reply_template = \ - u"""{name}, an item. """ \ + u"""{name}, an item. {effect} """ \ """http://veekun.com/dex/items/{link_pocket}/{link_name}""" + + effect = obj.short_effect + if effect is None: + effect = 'No short effect, sorry. :(' + else: + effect = unicode(effect.as_text()) + self._reply(irc, reply_template.format( name=obj.name, + effect=effect, link_pocket=urllib.quote(obj.pocket.name.lower().encode('utf8')), link_name=urllib.quote(obj.name.lower().encode('utf8')), ) @@ -269,7 +279,7 @@ class Pokedex(callbacks.Plugin): """http://veekun.com/dex/abilities/{link_name}""" self._reply(irc, reply_template.format( name=obj.name, - effect=obj.short_effect.as_text, + effect=obj.short_effect.as_text(), link_name=urllib.quote(obj.name.lower().encode('utf8')), ) ) -- 2.7.4