server/src/kernel/player.c

104 lines
2.1 KiB
C
Raw Normal View History

2010-08-08 10:06:34 +02:00
/* 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 <stdlib.h>
2010-08-08 10:06:34 +02:00
#include <string.h>
#include <limits.h>
#define PMAXHASH 1021
typedef struct player_hash {
2011-03-07 08:02:35 +01:00
struct player *entries;
2010-08-08 10:06:34 +02:00
} player_hash;
2011-03-07 08:02:35 +01:00
static player_hash *players[PMAXHASH];
2010-08-08 10:06:34 +02:00
2011-03-07 08:02:35 +01:00
player *make_player(const struct faction *f)
2010-08-08 10:06:34 +02:00
{
2011-03-07 08:02:35 +01:00
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;
2010-08-08 10:06:34 +02:00
}
2011-03-07 08:02:35 +01:00
player *next_player(player * p)
2010-08-08 10:06:34 +02:00
{
2011-03-07 08:02:35 +01:00
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;
}
2010-08-08 10:06:34 +02:00
}
2011-03-07 08:02:35 +01:00
player *get_player(unsigned int id)
2010-08-08 10:06:34 +02:00
{
2011-03-07 08:02:35 +01:00
unsigned int hash = id % PMAXHASH;
struct player *p = players[hash]->entries;
while (p && p->id != id)
p = p->nexthash;
return p;
2010-08-08 10:06:34 +02:00
}
2011-03-07 08:02:35 +01:00
player *get_players(void)
2010-08-08 10:06:34 +02:00
{
2011-03-07 08:02:35 +01:00
struct player *p = NULL;
unsigned int hash = 0;
2010-08-08 10:06:34 +02:00
2011-03-07 08:02:35 +01:00
while (p != NULL && hash != PMAXHASH) {
p = players[hash++]->entries;
}
return p;
2010-08-08 10:06:34 +02:00
}
2011-03-07 08:02:35 +01:00
void players_done(void)
2010-08-08 10:06:34 +02:00
{
2011-03-07 08:02:35 +01:00
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);
}
2010-08-08 10:06:34 +02:00
}