2001-04-26 19:41:06 +02:00
|
|
|
/* vi: set ts=2:
|
|
|
|
+-------------------+ Christian Schlittchen <corwin@amber.kn-bremen.de>
|
|
|
|
| | Enno Rehling <enno@eressea-pbem.de>
|
|
|
|
| Eressea PBEM host | Katja Zedel <katze@felidae.kn-bremen.de>
|
2003-07-29 11:48:03 +02:00
|
|
|
| (c) 1998 - 2003 | Henning Peters <faroul@beyond.kn-bremen.de>
|
2001-04-26 19:41:06 +02:00
|
|
|
| | Ingo Wilken <Ingo.Wilken@informatik.uni-oldenburg.de>
|
|
|
|
+-------------------+ Stefan Reich <reich@halbling.de>
|
|
|
|
|
|
|
|
This program may not be used, modified or distributed
|
|
|
|
without prior permission by the authors of Eressea.
|
|
|
|
|
|
|
|
*/
|
|
|
|
#include <config.h>
|
|
|
|
#include "player.h"
|
|
|
|
|
|
|
|
#include <goodies.h>
|
|
|
|
|
|
|
|
#include <string.h>
|
|
|
|
#include <stdlib.h>
|
|
|
|
#include <limits.h>
|
|
|
|
|
|
|
|
#define PMAXHASH 1023
|
|
|
|
|
|
|
|
typedef struct player_hash {
|
|
|
|
struct player * entries;
|
|
|
|
} player_hash;
|
|
|
|
|
|
|
|
static player_hash * players[PMAXHASH];
|
|
|
|
|
|
|
|
player *
|
2001-12-10 01:13:39 +01:00
|
|
|
make_player(const struct faction * f)
|
2001-04-26 19:41:06 +02:00
|
|
|
{
|
|
|
|
player * p = calloc(sizeof(player), 1);
|
|
|
|
unsigned int hash;
|
|
|
|
|
|
|
|
for (p->id = rand();;p->id++) {
|
|
|
|
/* if there is a hashing conflict, resolve it */
|
|
|
|
player * pi = get_player(p->id);
|
|
|
|
if (pi) p->id++;
|
|
|
|
else break;
|
|
|
|
}
|
|
|
|
hash = p->id % PMAXHASH;
|
2001-12-10 01:13:39 +01:00
|
|
|
p->faction = f;
|
2001-04-26 19:41:06 +02:00
|
|
|
p->nexthash = players[hash]->entries;
|
|
|
|
players[hash]->entries = p;
|
|
|
|
|
|
|
|
return p;
|
|
|
|
}
|
|
|
|
|
|
|
|
player *
|
|
|
|
next_player(player * p)
|
|
|
|
{
|
|
|
|
if (p->nexthash) return p->nexthash;
|
|
|
|
else {
|
|
|
|
unsigned int hash = p->id % PMAXHASH;
|
|
|
|
p = NULL;
|
|
|
|
while (++hash!=PMAXHASH) {
|
|
|
|
if (players[hash]->entries!=NULL) {
|
|
|
|
p = players[hash]->entries;
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
return p;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
player *
|
|
|
|
get_player(unsigned int id)
|
|
|
|
{
|
|
|
|
unsigned int hash = id % PMAXHASH;
|
|
|
|
struct player * p = players[hash]->entries;
|
|
|
|
|
|
|
|
while (p && p->id!=id) p = p->nexthash;
|
|
|
|
return p;
|
|
|
|
}
|
|
|
|
|
|
|
|
player *
|
|
|
|
get_players(void)
|
|
|
|
{
|
|
|
|
struct player * p = NULL;
|
|
|
|
unsigned int hash = 0;
|
|
|
|
|
|
|
|
while (p!=NULL && hash!=PMAXHASH) {
|
|
|
|
p = players[hash++]->entries;
|
|
|
|
}
|
|
|
|
return p;
|
|
|
|
}
|
|
|
|
|
|
|
|
void
|
|
|
|
players_done(void)
|
|
|
|
{
|
|
|
|
int i;
|
|
|
|
for (i=0;i!=PMAXHASH;++i) {
|
|
|
|
player * p = players[i]->entries;
|
|
|
|
players[i]->entries = p->nexthash;
|
|
|
|
free(p->name);
|
|
|
|
if (p->email) free(p->email);
|
2001-12-10 01:13:39 +01:00
|
|
|
if (p->name) free(p->name);
|
2001-04-26 19:41:06 +02:00
|
|
|
free(p);
|
|
|
|
}
|
|
|
|
}
|