foundationI_fluffos_v1/
foundationI_fluffos_v1/bin/
foundationI_fluffos_v1/fluffos-2.9-ds2.12/
foundationI_fluffos_v1/fluffos-2.9-ds2.12/ChangeLog.old/
foundationI_fluffos_v1/fluffos-2.9-ds2.12/Win32/
foundationI_fluffos_v1/fluffos-2.9-ds2.12/compat/
foundationI_fluffos_v1/fluffos-2.9-ds2.12/compat/simuls/
foundationI_fluffos_v1/fluffos-2.9-ds2.12/include/
foundationI_fluffos_v1/fluffos-2.9-ds2.12/testsuite/
foundationI_fluffos_v1/fluffos-2.9-ds2.12/testsuite/clone/
foundationI_fluffos_v1/fluffos-2.9-ds2.12/testsuite/command/
foundationI_fluffos_v1/fluffos-2.9-ds2.12/testsuite/data/
foundationI_fluffos_v1/fluffos-2.9-ds2.12/testsuite/etc/
foundationI_fluffos_v1/fluffos-2.9-ds2.12/testsuite/include/
foundationI_fluffos_v1/fluffos-2.9-ds2.12/testsuite/inherit/
foundationI_fluffos_v1/fluffos-2.9-ds2.12/testsuite/inherit/master/
foundationI_fluffos_v1/fluffos-2.9-ds2.12/testsuite/log/
foundationI_fluffos_v1/fluffos-2.9-ds2.12/testsuite/single/
foundationI_fluffos_v1/fluffos-2.9-ds2.12/testsuite/single/tests/compiler/
foundationI_fluffos_v1/fluffos-2.9-ds2.12/testsuite/single/tests/efuns/
foundationI_fluffos_v1/fluffos-2.9-ds2.12/testsuite/single/tests/operators/
foundationI_fluffos_v1/fluffos-2.9-ds2.12/testsuite/u/
foundationI_fluffos_v1/fluffos-2.9-ds2.12/tmp/
foundationI_fluffos_v1/fluffos-2.9-ds2.12/windows/
foundationI_fluffos_v1/lib/
foundationI_fluffos_v1/lib/cmds/ambassador/
foundationI_fluffos_v1/lib/cmds/database/
foundationI_fluffos_v1/lib/cmds/soul/
foundationI_fluffos_v1/lib/daemon/include/
foundationI_fluffos_v1/lib/daemon/save/
foundationI_fluffos_v1/lib/daemon/services/
foundationI_fluffos_v1/lib/daemon/soul/
foundationI_fluffos_v1/lib/doc/build/
foundationI_fluffos_v1/lib/doc/build/room/
foundationI_fluffos_v1/lib/doc/build/virtual/
foundationI_fluffos_v1/lib/doc/driver/
foundationI_fluffos_v1/lib/doc/efun/
foundationI_fluffos_v1/lib/doc/etc/
foundationI_fluffos_v1/lib/doc/help/creator/
foundationI_fluffos_v1/lib/doc/help/hm/
foundationI_fluffos_v1/lib/doc/help/user/
foundationI_fluffos_v1/lib/doc/lpc/basic/
foundationI_fluffos_v1/lib/doc/lpc/data_types/
foundationI_fluffos_v1/lib/doc/lpc/etc/
foundationI_fluffos_v1/lib/doc/lpc/intermediate/
foundationI_fluffos_v1/lib/doc/lpc/types/
foundationI_fluffos_v1/lib/doc/mudlib/
foundationI_fluffos_v1/lib/doc/mudlib/features/
foundationI_fluffos_v1/lib/domains/Examples/etc/
foundationI_fluffos_v1/lib/domains/Examples/room/
foundationI_fluffos_v1/lib/domains/Examples/virtual/
foundationI_fluffos_v1/lib/domains/Examples/virtual/exaA/
foundationI_fluffos_v1/lib/domains/Examples/virtual/exaB/
foundationI_fluffos_v1/lib/domains/Examples/weapon/
foundationI_fluffos_v1/lib/domains/Standard/
foundationI_fluffos_v1/lib/domains/Standard/pools/
foundationI_fluffos_v1/lib/domains/Standard/std/
foundationI_fluffos_v1/lib/domains/Standard/xtra/
foundationI_fluffos_v1/lib/include/
foundationI_fluffos_v1/lib/news/
foundationI_fluffos_v1/lib/secure/cfg/
foundationI_fluffos_v1/lib/secure/cmds/adm/
foundationI_fluffos_v1/lib/secure/cmds/ambassador/
foundationI_fluffos_v1/lib/secure/cmds/mortal/
foundationI_fluffos_v1/lib/secure/etc/
foundationI_fluffos_v1/lib/secure/etc/approval/
foundationI_fluffos_v1/lib/secure/etc/elections/
foundationI_fluffos_v1/lib/secure/etc/mudlib/
foundationI_fluffos_v1/lib/secure/etc/quests/
foundationI_fluffos_v1/lib/secure/save/daemon/
foundationI_fluffos_v1/lib/secure/save/postal/d/descartes/
foundationI_fluffos_v1/lib/secure/save/users/d/
foundationI_fluffos_v1/lib/secure/std/
foundationI_fluffos_v1/lib/std/obj/
foundationI_fluffos_v1/lib/std/room/
foundationI_fluffos_v1/lib/std/user/
foundationI_fluffos_v1/lib/std/virtual/
foundationI_fluffos_v1/old/
foundationI_fluffos_v1/win32/
/*
 * bench.c [cmd]
 * description: the benchmarks as posted by Karl
 * Help added by Pallando 93-02-13
 */

#include <std.h>

inherit DAEMON;


int cmd_bench (string arg)
{
    string test;
    
    if (!arg) {
       notify_fail ("usage: bench {1-5 or all}\n");
       return 0;
    }
    test = "test";     
    switch (arg)
    {
        case "1":
	   write ("Empty loop benchmark\n");
	   call_other(this_object(),test + arg);
	   break;
        case "2":
	   write ("Function call benchmark\n");
	   call_other(this_object(),test + arg);
	   break;
        case "3":
	   write ("call_other benchmark\n");
	   call_other(this_object(),test + arg);
	   break;
        case "4":
	   write ("String addition benchmark\n");
	   call_other(this_object(),test + arg);
	   break;
        case "5":
	   write ("array addition benchmark\n");
	   call_other(this_object(),test + arg);
	   break;
	case "all":
	   write ("doing all benchmarks\n");
	   cmd_bench("1");
	   cmd_bench("2");
	   cmd_bench("3");
	   cmd_bench("4");
	   cmd_bench("5");
	   break;
	default:
   write( "You must specify a number between 1 and 5.\n" );
	   break;
   }
   return 1;
}
 
void test1 ()
{
    int i, time;
    mapping r;
    r = rusage();
    time = r["usertime"];
    for (i = 0; i < 10000; i++)
    {
    }
    r = rusage();
    write ("time taken: "+(r["usertime"] - time) + "\n");
}

void yy()
{
}

void test2 ()
{
    int i, time;
    mapping r;
    r = rusage();
    time = r["usertime"];
    for (i = 0; i < 10000; i++)
    {
	yy();
    }
    r = rusage();
    write ("time taken: "+(r["usertime"] - time) + "\n");
}

void test3 ()
{
    int i, time;
    mapping r;
    r = rusage();
    time = r["usertime"];
    for (i = 0; i < 10000; i++)
    {
	this_object()->yy();
    }
    r = rusage();
    write ("time taken: "+(r["usertime"] - time) + "\n");
}

void test4 ()
{
    int i, time;
    mapping r;
    string s;
    r = rusage();
    time = r["usertime"];
    for (i = 0; i < 10000; i++)
    {
	s = "xxxxxx";
	s += s;
    }
    r = rusage();
    write ("time taken: "+(r["usertime"] - time) + "\n");
}

void test5 ()
{
    int i, time;
    mapping r;
    string *s;
    
    r = rusage();
    time = r["usertime"];
    for (i = 0; i < 10000; i++)
    {
	s = allocate(10);
	s += s;
    }
    r = rusage();
    write ("time taken: "+(r["usertime"] - time) + "\n");
}

int help()
{
  write( ""+
"Syntax: bench <arg>\n"+
"Effect: <arg> may be 1-5 or \"all\"\n"+
"        Calculates Karl's Standard Mud Driver Benchmarks.\n"+
"1 - Empty loop\n"+
"2 - Function call\n"+
"3 - call_other\n"+
"4 - String addition\n"+
"5 - Array addition\n"+
  "" );
  return 1;
}