/
lib/banish/
lib/d/coronos/
lib/d/coronos/w/alena/
lib/d/coronos/w/angel/
lib/d/coronos/w/angel/caves/
lib/d/coronos/w/angel/caves/monst/
lib/d/coronos/w/angel/city/chambers/
lib/d/coronos/w/angel/city/monst/
lib/d/coronos/w/angel/city/obj/
lib/d/coronos/w/angel/city/streets/
lib/d/coronos/w/angel/farms/plains/
lib/d/coronos/w/angel/monst/
lib/d/tempus/
lib/d/tempus/w/angel/
lib/d/tempus/w/kingbill/
lib/d/tempus/w/mirak/
lib/d/tempus/w/mirak/monst/
lib/d/tempus/w/mirak/obj/
lib/d/tempus/w/relgar/planes/baat/
lib/d/tempus/w/sarak/
lib/d/tempus/w/serepion/mon/
lib/d/tempus/w/valrejn/
lib/doc/
lib/doc/domains/
lib/doc/efun/
lib/include/fn_specs/
lib/info/
lib/inherit/base/
lib/log/
lib/log/mailbox/
lib/log/main/
lib/news/
lib/obj/party/
lib/objects/componen/
lib/open/
lib/open/party/
lib/open/paste/
lib/open/spells/
lib/open/valrejn/
lib/players/
lib/players/alena/
lib/players/alena/obj/
lib/players/alena/open/
lib/players/alena/private/
lib/players/angel/
lib/players/angel/obj/
lib/players/ash/
lib/players/biggs/
lib/players/biggs/food/
lib/players/biggs/gobkeep/
lib/players/biggs/mnstr/
lib/players/biggs/town/caves/
lib/players/biggs/town/tower/
lib/players/biggs/wpns/
lib/players/calris/
lib/players/deathurg/
lib/players/deathurg/open/
lib/players/deathurg/private/thief/
lib/players/dogberry/
lib/players/dogberry/library/
lib/players/dogberry/open/
lib/players/epsilon/
lib/players/epsilon/private/
lib/players/farewell/
lib/players/hippo/
lib/players/hippo/open/
lib/players/hippo/tools/
lib/players/jimpa/
lib/players/josh/
lib/players/josh/room/
lib/players/josh/room/mage/dungeon/
lib/players/josh/room/mage/dungeon/obj/
lib/players/josh/wep/
lib/players/kingbill/
lib/players/metatron/
lib/players/miette/
lib/players/mirak/
lib/players/mirak/open/
lib/players/parsilan/
lib/players/relgar/
lib/players/relgar/private/
lib/players/sarak/
lib/players/sarak/bugs/
lib/players/sarak/feelings/
lib/players/sarak/magical/
lib/players/sarak/minotaur/island/
lib/players/sarak/open/
lib/players/sarak/private/
lib/players/serepion/
lib/players/serepion/open/
lib/players/serepion/private/
lib/players/spike/
lib/players/spike/open/
lib/players/spike/private/
lib/players/spike/seaworld/
lib/players/valrejn/
lib/players/valrejn/open/
lib/players/valrejn/private/
lib/players/virus/
lib/players/wrath/
lib/players/wrath/arm/
lib/players/wrath/mon/
lib/players/wrath/room/
lib/players/wrath/room/entry/
lib/players/wrath/room/zolgath/
lib/players/wrath/weap/
lib/players/zil/
lib/room/
lib/room/city/arena/
lib/room/city/creator/
lib/room/city/garden/monst/
lib/room/city/library/
lib/room/city/library/open/books/
lib/room/city/shop/
lib/room/death/
lib/room/death/open/
lib/room/island/
lib/room/keeps/
lib/room/registry/
lib/room/ships/crew/
lib/room/ships/open/
lib/room/ships/open/types/bounty/
lib/room/ships/open/types/nebula/
lib/room/ships/open/types/phoenix/
lib/secure/udp_cmd_/
lib/skills/
lib/skills/fighter/
lib/skills/psionici/
lib/skills/thief/
lib/usr/
lib/usr/creators/
lib/usr/no_banis/
lib/usr/players/
^#^
vampiric touch^#^
SUBTOPIC-mage^#^
     ______________________________  ______________________________
  __/                              \/                              \__
 | /|                              |:                              |:||
 ||:| Spell:  Vampiric Touch       |:  Description:                |:||
 ||:| School: Necromancy           |:                              |:||
 ||:| Cost:   12                   |:  The spell has a chance to   |:||
 ||:| Level:  12                   |:  pipe some of the victim's   |:||
 ||:| Usage:  vampiric touch who   |:  living essence into the     |:||
 ||:| Component: corpse or skeleton|:  caster.  This in effect can |:||
 ||:| Related Spells:              |:  heal the caster.            |:||
 ||:| None.                        |:                              |:||
 ||:|                              |:                              |:||
 ||:|_____________________________ |: _____________________________|:||
 ||/______________________________\|:/______________________________\||
 |_______________________________      _______________________________|
                                 '----`
^#^
ventriloquism^#^
SUBTOPIC-mage^#^
     ______________________________  ______________________________
  __/                              \/                              \__
 | /|                              |:                              |:||
 ||:| Spell:  Ventriloquism        |:  Description:                |:||
 ||:| School: Illusion             |:                              |:||
 ||:| Cost:   1                    |:  This spell causes another   |:||
 ||:| Level:  1                    |:  person to appear to speak.  |:||
 ||:| Usage: vent target message   |:  The ventriloquised victim   |:||
 ||:|                              |:  realises that they did not  |:||
 ||:| Related Spells:              |:  say it. But they do not     |:||
 ||:| Phantasm, Improved Phantasm  |:  realise who ventriloquised  |:||
 ||:|                              |:  them.                       |:||
 ||:|_____________________________ |: _____________________________|:||
 ||/______________________________\|:/______________________________\||
 |_______________________________      _______________________________|
                                 '----`

^#^
visual illusion^#^
SUBTOPIC-mage^#^
     ______________________________  ______________________________
  __/                              \/                              \__
 | /|                              |:                              |:||
 ||:| Spell:  Visual Illusion      |:  Description:                |:||
 ||:| School: Illusion             |:                              |:||
 ||:| Cost:   15                   |:  This spell weaves an        |:||
 ||:| Level:  15                   |:  illusion about an item      |:||
 ||:| Usage:  visual illusion item |:  or monster. The woven       |:||
 ||:|                              |:  illusion fools all who      |:||
 ||:| Related Spells:              |:  touch and look at the item. |:||
 ||:| Permanent Illusion           |:  It can be dispelled with a  |:||
 ||:|                              |:  dispel magic.               |:||
 ||:|_____________________________ |: _____________________________|:||
 ||/______________________________\|:/______________________________\||
 |_______________________________      _______________________________|
                                 '----`
^#^
valid_exec^#^
SUBTOPIC-efun32^#^
SYNOPSIS
	int valid_exec(string name)

DESCRIPTION
	Validate the rebinding of an IP connection by usage of efun
	exec(). The argument is the name of the _program_ attempting
	to rebind the connection. This is not the file_name() of the
	object, and has no leading slash.

	Return 0 to disallow the action, any other value to allow it.

SEE ALSO
	exec(E)
^#^
valid_query_snoop^#^
SUBTOPIC-efun32^#^
SYNOPSIS
	valid_query_snoop(object ob)

DESCRIPTION
	Should return 1 if previous_object() (the one that called the
	efun query_snoop()) is allowed to query wether ob is being
	snooped, 0 if not.

	The master object is always allowed to use query_snoop().

SEE ALSO
	valid_snoop(M), query_snoop(E), snoop(E)
^#^
valid_read^#^
SUBTOPIC-efun32^#^
SYNOPSIS
	string valid_read(string path, string uid, string func, object ob)

DESCRIPTION
	This function is called to check if the object ob with the
	user-id uid has read permissions for the file given by path
	for the operation named by func. It should return 0 if
	permission is denied, or the normalized path if permission is
	granted. You can also return 1 to indicate that the path can
	be used unchanged.

	The returned pathname must not contain ``..'', a leading /
	will be stripped by the interpreter.

	Func denotes the efun call or other operation that caused
	valid_read() to be called:
	ed_start (check if the file to be edited is readable),
	file_size,
	get_dir,
	print_file (efun cat()),
	read_bytes,
	read_file,
	restore_object,
	tail.

	Note that this function is called in compat mode as well. If
	you need to be compatible with the old 2.4.5-mudlib, redirect
	these calls to the valid_read/valid_write in the user
	object.

SEE ALSO
	valid_write(M), make_path_absolute(M)
^#^
valid_seteuid^#^
SUBTOPIC-efun32^#^
SYNOPSIS
	int valid_seteuid(object ob, string newid)

DESCRIPTION
	Should return 1 if ob is allowed to set its euid to newid.
	Objects are always allowed to set their euid to 0.

SEE ALSO
	seteuid(E), uids(C)
^#^
valid_snoop^#^
SUBTOPIC-efun32^#^
SYNOPSIS
	int valid_snoop(object me, object you)

DESCRIPTION
	Should return 1 if me is allowed to snoop you, 0 if not.

SEE ALSO
	snoop(E), query_snoop(E), valid_query_snoop(M)
^#^
valid_write^#^
SUBTOPIC-efun32^#^
SYNOPSIS
	string valid_write(string path, string uid, string func, object ob)

DESCRIPTION
	This function is called to check if the object ob with the
	user-id uid has write permissions to the file given by path
	for the operation named by func. It should return 0 if
	permission is denied, or the normalized path if permission is
	granted. You can also return 1 to indicate that the path can
	be used unchanged.

	The returned pathname must not contain ``..'', a leading /
	will be stripped by the interpreter.

	Func denotes the efun call or other operation that caused
	valid_write() to be called:
	cindent,
	do_rename (efun rename(), for the old and then for the new name),
	ed_start (whenever the builtin ed tries to write to a file),
	mkdir,
	remove_file (efun rm()),
	rmdir,
	save_object,
	write_bytes,
	write_file.

	Note that this function is called in compat mode as well. If
	you need to be compatible with the old 2.4.5-mudlib, redirect
	these calls to the valid_read/valid_write in the user
	object.

SEE ALSO
	valid_read(M), make_path_absolute(M)