forked from github/server
102 lines
2 KiB
C
102 lines
2 KiB
C
|
/* vi: set ts=2:
|
||
|
+-------------------+ Christian Schlittchen <corwin@amber.kn-bremen.de>
|
||
|
| | Enno Rehling <enno@eressea.de>
|
||
|
| Eressea PBEM host | Katja Zedel <katze@felidae.kn-bremen.de>
|
||
|
| (c) 1998 - 2003 | Henning Peters <faroul@beyond.kn-bremen.de>
|
||
|
| | 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 <platform.h>
|
||
|
#include "player.h"
|
||
|
|
||
|
#include <util/goodies.h>
|
||
|
#include <util/rng.h>
|
||
|
|
||
|
#include <string.h>
|
||
|
#include <limits.h>
|
||
|
|
||
|
#define PMAXHASH 1021
|
||
|
|
||
|
typedef struct player_hash {
|
||
|
struct player * entries;
|
||
|
} player_hash;
|
||
|
|
||
|
static player_hash * players[PMAXHASH];
|
||
|
|
||
|
player *
|
||
|
make_player(const struct faction * f)
|
||
|
{
|
||
|
player * p = calloc(sizeof(player), 1);
|
||
|
unsigned int hash;
|
||
|
|
||
|
for (p->id = rng_int();;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;
|
||
|
p->faction = f;
|
||
|
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);
|
||
|
if (p->name) free(p->name);
|
||
|
free(p);
|
||
|
}
|
||
|
}
|