Added an at_obj_receive hook to basic player/object script parents. This allows

e.g. room parents to react when a player enters them.
This commit is contained in:
Griatch 2009-10-25 15:25:15 +00:00
parent d06ac3e239
commit eb6f82fea0
5 changed files with 22 additions and 11 deletions

View file

@ -476,17 +476,8 @@ def cmd_find(command):
dbref_limits=(lowlim, highlim))
if not results:
return
source_object.emit_to("Name match: %s" % results)
source_object.emit_to("Found a unique name match: %s" % results)
## if len(results) > 0:
## source_object.emit_to("Name matches for: %s" % (searchstring,))
## s = ""
## for result in results:
## s += " %s\n\r" % (result.get_name(fullname=True),)
## s += "%d matches returned." % (len(results),)
## source_object.emit_to(s)
## else:
## source_object.emit_to("No name matches found for: %s" % (searchstring,))
GLOBAL_CMD_TABLE.add_command("@find", cmd_find,
priv_tuple=("objects.info",), help_category="Building",
auto_help_override=False)

View file

@ -169,9 +169,15 @@ class ObjectManager(models.Manager):
"""
Searches through all objects returning those which has a certain script parent.
"""
o_query = self.filter(script_parent__exact=script_parent)
o_query = self.filter(script_parent__exact=script_parent)
return o_query.exclude(type__in=[defines_global.OTYPE_GARBAGE,
defines_global.OTYPE_GOING])
def local_object_script_parent_search(self, script_parent, location):
o_query = self.filter(script_parent__exact=script_parent).filter(location__iexact=location)
return o_query.exclude(type__in=[defines_global.OTYPE_GARBAGE,
defines_global.OTYPE_GOING])
def list_search_object_namestr(self, searchlist, ostring, dbref_only=False,
limit_types=False, match_type="fuzzy",

View file

@ -1002,6 +1002,9 @@ class Object(models.Model):
# Execute eventual extra commands on this object after moving it
self.scriptlink.at_after_move()
# Perform eventual extra commands on the receiving location
target.scriptlink.at_obj_receive(self)
if force_look and self.is_player():
self.execute_cmd('look')

View file

@ -125,6 +125,12 @@ class EvenniaBasicObject(object):
#print "SCRIPT TEST: %s dropped %s." % (pobject, self.scripted_obj)
pass
def at_obj_receive(self, object=None):
"""
Called whenever an object is added to the contents of this object.
"""
pass
def return_appearance(self, pobject=None):
"""
Returns a string representation of an object's appearance when LOOKed at.

View file

@ -99,6 +99,11 @@ class EvenniaBasicPlayer(object):
"""
pass
def at_obj_receive(self, object=None):
"""
Called whenever an object is added to the inventory of the player.
"""
pass
def at_disconnect(self):
"""