nightmare3_fluffos_v2/
nightmare3_fluffos_v2/bin/
nightmare3_fluffos_v2/fluffos-2.9-ds2.08/
nightmare3_fluffos_v2/fluffos-2.9-ds2.08/ChangeLog.old/
nightmare3_fluffos_v2/fluffos-2.9-ds2.08/Win32/
nightmare3_fluffos_v2/fluffos-2.9-ds2.08/compat/
nightmare3_fluffos_v2/fluffos-2.9-ds2.08/compat/simuls/
nightmare3_fluffos_v2/fluffos-2.9-ds2.08/include/
nightmare3_fluffos_v2/fluffos-2.9-ds2.08/testsuite/
nightmare3_fluffos_v2/fluffos-2.9-ds2.08/testsuite/clone/
nightmare3_fluffos_v2/fluffos-2.9-ds2.08/testsuite/command/
nightmare3_fluffos_v2/fluffos-2.9-ds2.08/testsuite/data/
nightmare3_fluffos_v2/fluffos-2.9-ds2.08/testsuite/etc/
nightmare3_fluffos_v2/fluffos-2.9-ds2.08/testsuite/include/
nightmare3_fluffos_v2/fluffos-2.9-ds2.08/testsuite/inherit/
nightmare3_fluffos_v2/fluffos-2.9-ds2.08/testsuite/inherit/master/
nightmare3_fluffos_v2/fluffos-2.9-ds2.08/testsuite/log/
nightmare3_fluffos_v2/fluffos-2.9-ds2.08/testsuite/single/
nightmare3_fluffos_v2/fluffos-2.9-ds2.08/testsuite/single/tests/compiler/
nightmare3_fluffos_v2/fluffos-2.9-ds2.08/testsuite/single/tests/efuns/
nightmare3_fluffos_v2/fluffos-2.9-ds2.08/testsuite/single/tests/operators/
nightmare3_fluffos_v2/fluffos-2.9-ds2.08/testsuite/u/
nightmare3_fluffos_v2/fluffos-2.9-ds2.08/tmp/
nightmare3_fluffos_v2/fluffos-2.9-ds2.08/windows/
nightmare3_fluffos_v2/lib/cmds/ambassador/
nightmare3_fluffos_v2/lib/cmds/database/
nightmare3_fluffos_v2/lib/cmds/hm/
nightmare3_fluffos_v2/lib/cmds/soul/
nightmare3_fluffos_v2/lib/daemon/cfg/
nightmare3_fluffos_v2/lib/daemon/cfg/mon_races/
nightmare3_fluffos_v2/lib/daemon/cfg/races/
nightmare3_fluffos_v2/lib/daemon/include/
nightmare3_fluffos_v2/lib/daemon/save/
nightmare3_fluffos_v2/lib/daemon/services/
nightmare3_fluffos_v2/lib/daemon/soul/
nightmare3_fluffos_v2/lib/doc/
nightmare3_fluffos_v2/lib/doc/TestPlans/
nightmare3_fluffos_v2/lib/doc/approval/
nightmare3_fluffos_v2/lib/doc/approval/QC/
nightmare3_fluffos_v2/lib/doc/approval/balance/
nightmare3_fluffos_v2/lib/doc/build/
nightmare3_fluffos_v2/lib/doc/build/armours/
nightmare3_fluffos_v2/lib/doc/build/economy/
nightmare3_fluffos_v2/lib/doc/build/etc/
nightmare3_fluffos_v2/lib/doc/build/monster/
nightmare3_fluffos_v2/lib/doc/build/room/
nightmare3_fluffos_v2/lib/doc/build/virtual/
nightmare3_fluffos_v2/lib/doc/build/weapon/
nightmare3_fluffos_v2/lib/doc/classes/
nightmare3_fluffos_v2/lib/doc/efun/
nightmare3_fluffos_v2/lib/doc/etc/
nightmare3_fluffos_v2/lib/doc/help/creator/
nightmare3_fluffos_v2/lib/doc/help/hm/
nightmare3_fluffos_v2/lib/doc/law/
nightmare3_fluffos_v2/lib/doc/lpc/basic/
nightmare3_fluffos_v2/lib/doc/lpc/data_types/
nightmare3_fluffos_v2/lib/doc/lpc/etc/
nightmare3_fluffos_v2/lib/doc/lpc/intermediate/
nightmare3_fluffos_v2/lib/doc/lpc/types/
nightmare3_fluffos_v2/lib/doc/mudlib/
nightmare3_fluffos_v2/lib/doc/mudlib/features/
nightmare3_fluffos_v2/lib/domains/Examples/etc/
nightmare3_fluffos_v2/lib/domains/Examples/room/
nightmare3_fluffos_v2/lib/domains/Examples/virtual/
nightmare3_fluffos_v2/lib/domains/Examples/virtual/exaA/
nightmare3_fluffos_v2/lib/domains/Examples/virtual/exaB/
nightmare3_fluffos_v2/lib/domains/Examples/weapon/
nightmare3_fluffos_v2/lib/domains/Praxis/
nightmare3_fluffos_v2/lib/domains/Praxis/adm/
nightmare3_fluffos_v2/lib/domains/Praxis/attic/
nightmare3_fluffos_v2/lib/domains/Praxis/cemetary/
nightmare3_fluffos_v2/lib/domains/Praxis/cemetary/mon/
nightmare3_fluffos_v2/lib/domains/Praxis/data/
nightmare3_fluffos_v2/lib/domains/Praxis/death/
nightmare3_fluffos_v2/lib/domains/Praxis/mountains/
nightmare3_fluffos_v2/lib/domains/Praxis/obj/armour/
nightmare3_fluffos_v2/lib/domains/Praxis/obj/magic/
nightmare3_fluffos_v2/lib/domains/Praxis/obj/weapon/
nightmare3_fluffos_v2/lib/domains/Praxis/orc_valley/
nightmare3_fluffos_v2/lib/domains/Praxis/quests/
nightmare3_fluffos_v2/lib/domains/Praxis/standardOld/
nightmare3_fluffos_v2/lib/include/
nightmare3_fluffos_v2/lib/log/
nightmare3_fluffos_v2/lib/log/errors/
nightmare3_fluffos_v2/lib/log/reports/
nightmare3_fluffos_v2/lib/log/watch/
nightmare3_fluffos_v2/lib/news/
nightmare3_fluffos_v2/lib/secure/cfg/
nightmare3_fluffos_v2/lib/secure/cmds/ambassador/
nightmare3_fluffos_v2/lib/secure/cmds/mortal/
nightmare3_fluffos_v2/lib/secure/save/users/d/
nightmare3_fluffos_v2/lib/secure/std/
nightmare3_fluffos_v2/lib/std/hm/
nightmare3_fluffos_v2/lib/std/living/
nightmare3_fluffos_v2/lib/std/room/
nightmare3_fluffos_v2/lib/std/user/
nightmare3_fluffos_v2/lib/std/virtual/
nightmare3_fluffos_v2/lib/www/
nightmare3_fluffos_v2/lib/www/errors/
nightmare3_fluffos_v2/lib/www/gateways/
nightmare3_fluffos_v2/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;
    
#ifdef __MINGW__
    write("This command is not available in Windows.");
    return 1;
#endif
    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;
#ifndef __MINGW__
    r = rusage();
    time = r["usertime"];
    for (i = 0; i < 10000; i++)
    {
    }
    r = rusage();
    write ("time taken: "+(r["usertime"] - time) + "\n");
#endif
}

void yy()
{
}

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

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

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

void test5 ()
{
    int i, time;
    mapping r;
    string *s;
    
#ifndef __MINGW__
    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");
#endif
}

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;
}