X-Git-Url: https://mudpy.org/gitweb?p=mudpy.git;a=blobdiff_plain;f=lib%2Fmudpy%2Fmisc.py;fp=lib%2Fmudpy%2Fmisc.py;h=ead6f54f52b5ede7796a4cb66272219ec436fe8b;hp=8e747dd819ffb300e602fa1989329798b53f84ca;hb=d9bc0e9251378f4b6eab0bd5537e0e9b0261a7bf;hpb=bc1722f6f7aa9ccc4aeb28bc091b0bffe7f66433 diff --git a/lib/mudpy/misc.py b/lib/mudpy/misc.py index 8e747dd..ead6f54 100644 --- a/lib/mudpy/misc.py +++ b/lib/mudpy/misc.py @@ -414,9 +414,13 @@ class Universe: # make a list of inactive avatars inactive_avatars = [] for account in self.categories["account"].values(): - inactive_avatars += [ - (self.contents[x]) for x in account.getlist("avatars") - ] + for avatar in account.get("avatars"): + try: + inactive_avatars.append(self.contents[avatar]) + except KeyError: + pending_loglines.append(( + "Missing avatar \"%s\", possible data corruption" % + avatar, 6)) for user in self.userlist: if user.avatar in inactive_avatars: inactive_avatars.remove(user.avatar) @@ -973,11 +977,14 @@ class User: def list_avatar_names(self): """List names of assigned avatars.""" - return [ - universe.contents[avatar].get( - "name" - ) for avatar in self.account.getlist("avatars") - ] + avatars = [] + for avatar in self.account.get("avatars"): + try: + avatars.append(universe.contents[avatar].get("name")) + except KeyError: + log("Missing avatar \"%s\", possible data corruption." % + avatar, 6) + return avatars def broadcast(message, add_prompt=True):