Move the presentation part of the 'look' command out to the new scripting system. You can now make different scripted objects appear vastly different by overriding basicobject's return_appearance (or any of its submethods). Also fixed word wrapping, and we are now wrapping descriptions to 78 characters by default. We'll see how gracefully it handles this, and we might eventually apply it to all output.

This commit is contained in:
Greg Taylor 2007-07-17 14:39:10 +00:00
parent fa4cc4cab3
commit fadf3933af
4 changed files with 57 additions and 49 deletions

View file

@ -93,6 +93,7 @@ class Object(models.Model):
zone = models.ForeignKey('self', related_name="obj_zone", blank=True, null=True) zone = models.ForeignKey('self', related_name="obj_zone", blank=True, null=True)
home = models.ForeignKey('self', related_name="obj_home", blank=True, null=True) home = models.ForeignKey('self', related_name="obj_home", blank=True, null=True)
type = models.SmallIntegerField(choices=defines_global.OBJECT_TYPES) type = models.SmallIntegerField(choices=defines_global.OBJECT_TYPES)
# TODO: Move description to an attribute.s
description = models.TextField(blank=True, null=True) description = models.TextField(blank=True, null=True)
location = models.ForeignKey('self', related_name="obj_location", blank=True, null=True) location = models.ForeignKey('self', related_name="obj_location", blank=True, null=True)
flags = models.TextField(blank=True, null=True) flags = models.TextField(blank=True, null=True)
@ -301,22 +302,24 @@ class Object(models.Model):
self.description = new_desc self.description = new_desc
self.save() self.save()
def get_description(self, no_parsing=False, wrap_width=False): def get_description(self, no_parsing=False, wrap_text=True):
""" """
Returns an object's ANSI'd description. Returns an object's ANSI'd description.
""" """
try: try:
# Evaluate ANSI and stuff?
if no_parsing: if no_parsing:
retval = self.description retval = self.description
else: else:
retval = ansi.parse_ansi(self.description) retval = ansi.parse_ansi(self.description)
if wrap_width: # Default to a 78 character wrap.
# TODO: Broken for some reason? Returning None. if wrap_text:
return functions_general.word_wrap(retval, width=wrap_width) return functions_general.word_wrap(retval)
else: else:
return retval return retval
except: except:
# No description attribute present, return empty string.
return "" return ""
def get_flags(self): def get_flags(self):

View file

@ -112,37 +112,11 @@ def cmd_look(cdat):
if not target_obj: if not target_obj:
return return
retval = "%s\r\n%s" % ( # SCRIPT: Get the item's appearance from the scriptlink.
target_obj.get_name(), session.msg(target_obj.get_scriptlink().return_appearance({
target_obj.get_description(), "target_obj": target_obj,
) "pobject": pobject
session.msg(retval) }))
con_players = []
con_things = []
con_exits = []
for obj in target_obj.get_contents():
if obj.is_player():
if obj != pobject and obj.is_connected_plr():
con_players.append(obj)
elif obj.is_exit():
con_exits.append(obj)
else:
con_things.append(obj)
if con_players:
session.msg("%sPlayers:%s" % (ansi.ansi["hilite"], ansi.ansi["normal"],))
for player in con_players:
session.msg('%s' %(player.get_name(),))
if con_things:
session.msg("%sContents:%s" % (ansi.ansi["hilite"], ansi.ansi["normal"],))
for thing in con_things:
session.msg('%s' %(thing.get_name(),))
if con_exits:
session.msg("%sExits:%s" % (ansi.ansi["hilite"], ansi.ansi["normal"],))
for exit in con_exits:
session.msg('%s' %(exit.get_name(),))
# SCRIPT: Call the object's script's a_desc() method. # SCRIPT: Call the object's script's a_desc() method.
target_obj.get_scriptlink().a_desc(pobject) target_obj.get_scriptlink().a_desc(pobject)

View file

@ -1,3 +1,4 @@
import textwrap
from twisted.python import log from twisted.python import log
import session_mgr import session_mgr
@ -132,17 +133,9 @@ def announce_all(message, with_ann_prefix=True):
def word_wrap(text, width=78): def word_wrap(text, width=78):
""" """
A word-wrap function that preserves existing line breaks Wrap text to a certain number of characters.
and most spaces in the text. Expects that existing line
breaks are posix newlines (\n). text: (str) The text to wrap.
width: (int) The number of characters to wrap to.
Function originally by Mike Brown
""" """
return reduce(lambda line, word, width=width: '%s%s%s' % return '\r\n'.join(textwrap.wrap(text, width))
(line,
' \n'[(len(line)-line.rfind('\n')-1
+ len(word.split('\n',1)[0]
) >= width)],
word),
text.split(' ')
)

View file

@ -3,6 +3,8 @@ This will be the base object type/interface that all scripts are derived from by
default. It will have the necessary outline for developers to sub-class and override. default. It will have the necessary outline for developers to sub-class and override.
""" """
import ansi
class BasicObject: class BasicObject:
def __init__(self, source_obj): def __init__(self, source_obj):
""" """
@ -22,6 +24,42 @@ class BasicObject:
#print "SCRIPT TEST: %s looked at %s." % (actor, self.source_obj) #print "SCRIPT TEST: %s looked at %s." % (actor, self.source_obj)
pass pass
def return_appearance(self, values):
target_obj = values["target_obj"]
pobject = values["pobject"]
retval = "\r\n%s\r\n%s" % (
target_obj.get_name(),
target_obj.get_description(),
)
con_players = []
con_things = []
con_exits = []
for obj in target_obj.get_contents():
if obj.is_player():
if obj != pobject and obj.is_connected_plr():
con_players.append(obj)
elif obj.is_exit():
con_exits.append(obj)
else:
con_things.append(obj)
if con_players:
retval += "\n\r%sPlayers:%s" % (ansi.ansi["hilite"], ansi.ansi["normal"],)
for player in con_players:
retval +='\n\r%s' %(player.get_name(),)
if con_things:
retval += "\n\r%sContents:%s" % (ansi.ansi["hilite"], ansi.ansi["normal"],)
for thing in con_things:
retval += '\n\r%s' %(thing.get_name(),)
if con_exits:
retval += "\n\r%sExits:%s" % (ansi.ansi["hilite"], ansi.ansi["normal"],)
for exit in con_exits:
retval += '\n\r%s' %(exit.get_name(),)
return retval
def a_get(self, actor): def a_get(self, actor):
""" """
Perform this action when someone uses the GET command on the object. Perform this action when someone uses the GET command on the object.