Changes from MudOS 0.8.14 to MudOS 0.9.14. [Changes since the MudOS 0.9.0 release are marked with an 'o' instead of an '*'] o added a new data type named 'function'. Be sure to change the names of any variables you may have named 'function'. This data type is a variant on the idea of function pointers. It may be used to store an (object, function) pair in a single variable. The constructor for function variables is as follows: function f; f = (: obj, func :); where obj and func may be anything allowed by call_other(obj, func). To call the function func in object obj via function variable f, type: (*f)(arg0, arg1, ...); You may use the new functionp() efun to detect if a variable is of type function. o the driver now compiles under the xlc compiler on the RS/6000 (xlc is IBM's fastest of AIX 3.2 C compilers). o added Mappings and Interactives fields to the stats output by mud_status(). o added a new efun set_eval_limit (#define SET_EVAL_LIMIT on options.h) that allows an object to change the max eval cost limit. Be sure to add appropriate mudlib level security before enabling this efun (read the ChangeLog 0.9.13.4). o added Cynosure's livings() efun that returns an array of all objects that have called enable_commands() (and haven't yet called disable_commands()). o changed the behavior of nullp() and undefinedp() slightly (see 0.9.13.2 ChangeLog). o The catch() efun may no longer be used to trap max eval_cost exceeded errors (and thus hang the driver). o System V Release 4 support (added M.B. Bundy's patches) o added capability to configure the default 'What?' message via the runtime config file. o dramatically improved global apply_low (call_other) cache hit rates. Many muds that used to have hit rates near 40% are reporting 93% and above. [This improvement results from fixing a bug we found in the LPmud 3.1.2 cache code. See ChangeLog for more details.] o 0.9.14 mappings use about 50% less memory overhead per mapping (compared to 0.9.0). o improved performance. MudOS 0.9.14 is much faster than MudOS 0.9.0 at executing many of the more commonly used eoperators. o created an efuns.h file that should be #include'd from any file that wants to define new efunctions (see efunctions.c for example). o added strcmp() efun (just like C's strcmp) that is convenient for use in the compare functions used by sort_array(). sort_array() has been recoded to use a robust version of qsort so that ill-behaved compare functions won't crash the driver. o added efuns clonedp() (detects if an object was created via clone_object), functionp() (detects if a variable is of type 'function'). o added a new eoperator F_CALL_EXTRA that allows for 512 efuns+eopers instead of the previous limit of 256 (easily extended to allow more). This replaces and enhances the F_CALL_EFUN that we had added to the previous release. * Literally hundreds of bug fixes (read the ChangeLog file in the source directory for complete descriptions of these if you're interested) * MudOS now runs on more architectures. Here's what we know that it runs on: o System V Release 4 systems (Dell SVR4 v2.2 [386/486] in particular) o Ridge (RISC/os) * Sequent (maybe other SYS VR3 systems or those using POSIX-style signals) * HP 9000 (HP-UX 7.0 && 8.x) * NeXT (NeXTStep 2.1 and 3.0) * DECstations and VAXen (Ultrix 3.1, 4.1, 4.2) * IBM RS/6000 (AIX 3.2) * SUN sparcs (SunOS) * (internal change) totally rewrote and replaced communication code in the driver (comm.c) to be more efficient. * added socket efunctions for inter-object and inter-mud communication (see separate socket efun tutorial and man pages for more a detailed explanation) * int socket_create(int, string, string|void); * int socket_bind(int, int); * int socket_listen(int, string); * int socket_accept(int, string, string); * int socket_connect(int, string, string, string); * int socket_write(int, mixed, string|void); * int socket_close(int); * int socket_release(int, object, string); * int socket_acquire(int, string, string, string); * string socket_error(int); * string socket_address(int); * void dump_socket_status(void); * void dump_file_descriptors(); * added MUD mode to the LPC socket efunctions. MUD mode allows LPC data structures such as arrays, mappings, integers, and strings (all except for objects) to be sent atomically via sockets. * added DATAGRAM (UDP) mode to the LPC socket efunctions. * (internal change) rearchitected interpret.c to use a function lookup table rather than one large switch statement. New efunctions should be added to efunctions.c instead of interpret.c. This enhancement makes it easier to integrate your own efuns into the driver and it allows interpret.c to compile on machines that previously had problems with it. * added call to master.c::valid_override(string filename, string function) for each attempt to override a simulated efunction via the efun::func_name() method. 'filename' is the path to the file which is attempting to call efun::func_name(). 'function' is the name of the efun that is to be overridden. If valid_override returns 0, then the current compilation will fail (note: valid_override is only called at compile time and _not_ runtime). valid_override allows valid_destruct, valid_exec, etc. to be dispensed with since the same functionality can be obtained by wrapping the efun in question with a simul_efun of the same name (and including valid_* style checking in the simul_efun). Gist of the idea taken from Amylaar's done file. * added the option of configuring the driver so that resets (the calling of reset() in LPC objects) happen in a lazy fashion (by defining LAZY_RESETS in options.h). This option allows resets to happen in an incrementally (rather than all in one pass) and it prevents resets from occuring unless the object to be reset is touched (via an apply_low or move_object) after the usual required reset delay has occurred. The benefits of this option are that performance is smoother (no reset lags) and memory is conserved (since those object which are touched once and never again won't have reset called in them and hence won't reload any objects in reset()). * changed various efunctions to honor the hidden object flags so that the set_hide() efunction now offers true driver-supported invisibility of objects. * new internal implementation of mappings (associative arrays) which is faster and more robust. * new efuns for mappings: * keys() - this used to be named indices() * values() - the inverse of keys() * each() - traverse a mapping * split config.h into options.h and port.h. This simplifies the task of configuring the driver to run on a particular machine. In most cases, it will be sufficient to configure options.h (options.h contains configuration options pertaining to preference rather than portability). * fixed make_func.y so that it correctly processes func_spec.c on the HP and Sequent. * added a NO_ANSI option to options.h that allows escape codes included in user commands to be replaced with spaces. * added a MAX_SAVE_SVALUE_DEPTH macro to options.h which solves the problem of calling save_object on an object containing a data structure with a circular (recursive) reference. Admittedly, this isn't a true fix since the object in question (having the circular reference) cannot be saved; however, this is better than allowing the driver to hang. (Yes I know that Amylaar solved this by saving the circular reference in a recoverable fashion. I didn't consider it an important enough problem to spend the time necessary to adopt his solution). * added a new efunction replace_string() (see the replace_string man page) * added a clonep() efunction that determines if an object was created via the clone_object() efunction. * added a localtime() efunction (see the localtime(3) man page) * added an uptime() efunction that returns the number of seconds since the driver has been running. * removed the mudwho code from the driver (including clilib.c). We have implemented the mudwho protocol (same as that implemented in clilib.c) in LPC using the new MudOS socket efunctions (DATAGRAM mode). See the README in the included mini-mudlib for more details. * changed inherit_list() and deep_inherit_list() not to return the filename which is passed to them. * added a configuration option that causes this_player() to return 0 inside callbacks made by call_out(). * heartbeat interval can be now be specified in units of microseconds on those machines with the ualarm() system call. * size of the call_other cache table is configurable (via the APPLY_CACHE_BITS define in options.h).* (internal change) totally rewrote and replaced communication code in the driver (comm.c) to be more efficient. * made the ed() efunction (internal editor) optional. * input_to can now take extra arguments so that you can pass one or more extra arguments to the function input_to calls (notice that this feature makes it possible to avoid using global variables which makes it easier for a single object to be designed to beshared by many players [e.g. daemon-style objects]). For example: void get_name(string name, object new_player) { write("\nWhat is your email address: "); input_to("get_email", 0, new_player, name); } void get_email(string email, object new_player, string name) { new_player->set_email(email); new_player->set_name(name); } * implemented variable arguments to call_out just like the additions made to input_to described above. * You can now compare mappings for equality using the == operator. * the message() efun now works. For more info read the accompanying doc on this important new efun! * several new required functions to be implemented in the mudlib master.c: * valid_socket - security to monitor or limit usage of the new socket efuns * valid_domain - a check for domain_stats to make sure that it only keeps stats on domains that you care about * valid_hide - for the set_hide() efun so that who can be "hidden" is controlled by master.c * slow_shutdown - when the driver is running out of memory and wants a nice shutdown it calls this * several new additions to the runtime configuration file: * inherit chain size : the maximum inheritance depth allowed. This is mainly to prevent infinite inheritance loops * maximum mapping size : similar to maximum array size * address server ip : machine name where an addr_server is running * address server port : port number that the addr_server is listening on * max users : this used to be max players (doesn't matter anyway, since this is still unused by the driver here) * maximum efun sockets : control the number of efun sockets open at once * maximum string length: controls the maximum allowed string size * wizlist() changed to domain_stats(), this is to make statistic taking more consistant with the new domain model versus the wizard model previous to LPmud 3.0. See also: author_stats() * valid clone - this isn't enabled by default, but with some changes to options.h, clone_object will fail if an object doesn't have read permission on the file being cloned. (note: this is pretty useless since inheritance doesn't have a similar check) * old "parser magic functions" were changed into efuns: * malloc_status() - was the 'malloc' command * dumpallobj() - was the command of the same name * mud_status() - was 'status' (use mud_status(1) to get 'status tables' * some new debugging efuns were added or changed: * rusage() now returns a mapping of the values returned by the getrusage() system call. * debugmalloc() - if the driver is compiled with malloc debugging enabled this prints out more detailed malloc information * set_malloc_mask() - control the level of info being debugged with debugmalloc * set_debug_level() - more control on debugging levels (see debug.h in the src directory) * opcprof() - dump a file detailing efun usage (usage frequencies) * cache_stats() - display call_other function table cache hit rate information * removed the old hname process and replaced it with a new autonomous (not forked from driver) addr_server program that can be shared by several different drivers at once. * removed the cindent() efun * removed the describe() efun * removed two unused variables from the runtime config system * global include file * max commands per heartbeat * removed everything to do with the "priveleged object" concept * set_priv() * privp() * removed everything to do with "global verbs", "global preverbs" and "preverbs" * all objects now call create when first loaded, even if loaded via inheritance (create called in the original objects, not what's being inherited) * crash in master.c is now called with three args (type of crash, command_giver, current_object) * if the driver crashes it tries to dump its core file in /cores if that dir exists and core dumping is enabled * removed the global define LPCA and replaced it with MUDOS (LPC objects can do #ifdef MUDOS) * added AUTO_SETEUID option. if defined, all objects do the equivalent of seteuid(getuid(this_object())); when created. * added AUTO_TRUST_BACKBONE define so that you could disable the automatic trusting of backbone uid objects if you want. * added Pinkfish's modifications to parse command package so that it actually works now. :-) * added an optional integer argument to the shutdown() efun. when an argument is specified, the driver exits with that exit code. * removed smalloc from the driver completely (memory alignment violations and other problems made it not worth dealing with). * added BSD malloc as an option (seems to work well for those machines having slow system mallocs like the HP). * added the concepts of "null" and "undefined" to variables and added two efuns to make use of these concepts * nullp() - returns true for unitiliazed variables and destructed objects * undefinedp() - returns true for (1) call_others to non-existant methods, (2) access to map keys that aren't in the map, and (3) arguments in the formal parameter list of a function for which values were not passed. * there's a DROP_CORE option in options.h which allows you to specify if you want the driver to try to dump core if it has crashed * replaced sort_array() with a faster version. Also changed it so that it expects the callback function to return -1, 0, or 1 in a fashion similar to how strcmp() does it. * added an option to define the default error message users receive. If it is not defined, then all users get wizard level error messages. This is useful since players are the ones that most often experience these errors and this lets players report them in a more coherent fashion (maybe?). * Reworked the domain stuff (added uid.c and uid.h) by separating the concept of uids and euids from that of domains and authors. The wizlist (domain list) code is no longer based on uids but rather on domains. Two new functions are required in master.c: string domain_file(string domain); and string author_file(string author); In addition, valid_author(string author) should be added to master if you wish set_author(string author) to be functional. Note: domain_file and author_file are similar to creator_file (which returns information for uids). domain_file lets the gamedriver know which domain a given object should be in an author_file lets the gamedriver know the author of the file.