ldmud-3.2.9/doc/
ldmud-3.2.9/doc/efun/
ldmud-3.2.9/mud/
ldmud-3.2.9/mud/heaven7/
ldmud-3.2.9/mud/heaven7/lib/
ldmud-3.2.9/mud/lp-245/
ldmud-3.2.9/mud/lp-245/banish/
ldmud-3.2.9/mud/lp-245/doc/
ldmud-3.2.9/mud/lp-245/doc/examples/
ldmud-3.2.9/mud/lp-245/doc/sefun/
ldmud-3.2.9/mud/lp-245/log/
ldmud-3.2.9/mud/lp-245/obj/Go/
ldmud-3.2.9/mud/lp-245/players/lars/
ldmud-3.2.9/mud/lp-245/room/death/
ldmud-3.2.9/mud/lp-245/room/maze1/
ldmud-3.2.9/mud/lp-245/room/sub/
ldmud-3.2.9/mud/lp-245/secure/
ldmud-3.2.9/mud/morgengrauen/
ldmud-3.2.9/mud/morgengrauen/lib/
ldmud-3.2.9/mud/sticklib/
ldmud-3.2.9/mud/sticklib/src/
ldmud-3.2.9/mudlib/uni-crasher/
ldmud-3.2.9/pkg/
ldmud-3.2.9/pkg/debugger/
ldmud-3.2.9/pkg/diff/
ldmud-3.2.9/pkg/misc/
ldmud-3.2.9/src/autoconf/
ldmud-3.2.9/src/bugs/
ldmud-3.2.9/src/bugs/MudCompress/
ldmud-3.2.9/src/bugs/b-020916-files/
ldmud-3.2.9/src/bugs/doomdark/
ldmud-3.2.9/src/bugs/ferrycode/ferry/
ldmud-3.2.9/src/bugs/ferrycode/obj/
ldmud-3.2.9/src/bugs/psql/
ldmud-3.2.9/src/done/
ldmud-3.2.9/src/done/order_alist/
ldmud-3.2.9/src/done/order_alist/obj/
ldmud-3.2.9/src/done/order_alist/room/
ldmud-3.2.9/src/gcc/
ldmud-3.2.9/src/gcc/2.7.0/
ldmud-3.2.9/src/gcc/2.7.1/
ldmud-3.2.9/src/hosts/
ldmud-3.2.9/src/hosts/GnuWin32/
ldmud-3.2.9/src/hosts/amiga/NetIncl/
ldmud-3.2.9/src/hosts/amiga/NetIncl/netinet/
ldmud-3.2.9/src/hosts/amiga/NetIncl/sys/
ldmud-3.2.9/src/hosts/i386/
ldmud-3.2.9/src/hosts/msdos/byacc/
ldmud-3.2.9/src/hosts/msdos/doc/
ldmud-3.2.9/src/hosts/os2/
ldmud-3.2.9/src/hosts/win32/
ldmud-3.2.9/src/util/
ldmud-3.2.9/src/util/erq/
ldmud-3.2.9/src/util/indent/hosts/next/
ldmud-3.2.9/src/util/xerq/
ldmud-3.2.9/src/util/xerq/lpc/
ldmud-3.2.9/src/util/xerq/lpc/www/
Subject: "*":: vs virtually inherited functions
From: Lars
Date: Wed, 17 Feb 1999 21:56:37 +0100 (MET)
Type: Bug
State: Done - corrected in 3.2.8-dev.151.
See also: p-990217.

If function 'f' is inherited in object o virtually several times, using
parallel parent lines, a "*"::f in o may call f repeatedly. This may
be C++ like, but imo consitutes a bug.

Sunblood writes on this topic in p-990217:

Eine Sache war mich nicht 100% klar, und zwar in dem "*":: fall (in
insert_inherited()). Da steht weiter unter ein continue, das ich recht
unlogisch fand, selbst bei dem alten verhalten. Lies dir bitte den kommentar
durch und schau, ob ich recht hab oder nicht.

diff -rc ldmud-dev-37/prolang.y ldmud-dev/prolang.y
*** 6036,6044 ****
--- 6050,6080 ----
                    !(prog2->variable_names[numvar2-1].flags & TYPE_MOD_VIRTUAL) )
                  {
                      /* Inherited from a virtually inherited program */
+ #if 0
                      /* The call for the virtually program itself should
                       * be sufficent. */
+             /* wieso???? ich hab wirklich keine ahnung wozu das gut sein soll
+              *
+              * wenn man verhindern will, dass mehrfach virtuell inheritete
+              * funktionen mehrfach aufgerufen werden, sollte man
+              * das selbst in lpc machen (is ja auch in c++ so)
+              *
+              * ausserdem: wenn ein programm mehrmals virtuell
+              * inherited wird, gibt es hier 2 alternativen: entweder man
+              * macht meinen neuen obigen test, was zur folge hat, dass
+              * die funktion in der klasse ueberhaupt nicht aufgerufen wird,
+              * oder man macht ihn nicht und ruft somit die funktion in
+              * allen zusaetzlichen inherits auf (also potentiell
+              * mehrfach) UND hat den bug a la ::f(), d.h. eigentlich
+              * ueberladene funktionen werden auch aufgerufen
+              *
+              * wenn ich mich jedoch irren sollte, nimm es wieder rein
+              */
                      continue;
+ #else
+                     do --ip; while (ip->prog != prog2);
+                     i -= ip2->function_index_offset;
+ #endif
                  }
              }
              add_f_byte(F_CALL_EXPLICIT_INHERITED);