2001-01-25 10:37:55 +01:00
|
|
|
|
/* vi: set ts=2:
|
|
|
|
|
*
|
2001-04-14 13:39:14 +02:00
|
|
|
|
*
|
2001-01-25 10:37:55 +01:00
|
|
|
|
* Eressea PB(E)M host Copyright (C) 1998-2000
|
|
|
|
|
* Christian Schlittchen (corwin@amber.kn-bremen.de)
|
|
|
|
|
* Katja Zedel (katze@felidae.kn-bremen.de)
|
|
|
|
|
* Henning Peters (faroul@beyond.kn-bremen.de)
|
|
|
|
|
* Enno Rehling (enno@eressea-pbem.de)
|
|
|
|
|
* Ingo Wilken (Ingo.Wilken@informatik.uni-oldenburg.de)
|
|
|
|
|
*
|
|
|
|
|
* based on:
|
|
|
|
|
*
|
|
|
|
|
* Atlantis v1.0 13 September 1993 Copyright 1993 by Russell Wallace
|
|
|
|
|
* Atlantis v1.7 Copyright 1996 by Alex Schr<EFBFBD>der
|
|
|
|
|
*
|
|
|
|
|
* This program may not be used, modified or distributed without
|
|
|
|
|
* prior permission by the authors of Eressea.
|
|
|
|
|
* This program may not be sold or used commercially without prior written
|
|
|
|
|
* permission from the authors.
|
|
|
|
|
*/
|
|
|
|
|
|
|
|
|
|
#include <config.h>
|
|
|
|
|
#include "eressea.h"
|
|
|
|
|
#include "plane.h"
|
|
|
|
|
|
|
|
|
|
/* kernel includes */
|
|
|
|
|
#include "region.h"
|
|
|
|
|
#include "faction.h"
|
|
|
|
|
|
2001-02-17 15:47:43 +01:00
|
|
|
|
/* util includes */
|
|
|
|
|
#include <resolve.h>
|
|
|
|
|
|
2001-01-25 10:37:55 +01:00
|
|
|
|
/* libc includes */
|
|
|
|
|
#include <string.h>
|
|
|
|
|
#include <stdlib.h>
|
|
|
|
|
|
|
|
|
|
plane *
|
|
|
|
|
getplane(const region *r)
|
|
|
|
|
{
|
|
|
|
|
if(r)
|
|
|
|
|
return r->planep;
|
|
|
|
|
|
|
|
|
|
return NULL;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
plane *
|
|
|
|
|
getplanebyid(int id)
|
|
|
|
|
{
|
|
|
|
|
plane *p;
|
|
|
|
|
|
|
|
|
|
for (p=planes; p; p=p->next)
|
|
|
|
|
if (p->id == id)
|
|
|
|
|
return p;
|
|
|
|
|
return NULL;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
plane *
|
|
|
|
|
getplanebyname(const char * name)
|
|
|
|
|
{
|
|
|
|
|
plane *p;
|
|
|
|
|
|
|
|
|
|
for (p=planes; p; p=p->next)
|
|
|
|
|
if (!strcasecmp(p->name, name))
|
|
|
|
|
return p;
|
|
|
|
|
return NULL;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
plane *
|
|
|
|
|
findplane(int x, int y)
|
|
|
|
|
{
|
|
|
|
|
plane *pl;
|
|
|
|
|
|
|
|
|
|
for(pl=planes;pl;pl=pl->next) {
|
|
|
|
|
if(x >= pl->minx && x <= pl->maxx
|
|
|
|
|
&& y >= pl->miny && y <= pl->maxy) {
|
|
|
|
|
return pl;
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
return NULL;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
int
|
|
|
|
|
getplaneid(region *r)
|
|
|
|
|
|
|
|
|
|
{
|
|
|
|
|
if(r) {
|
|
|
|
|
plane * pl = getplane(r);
|
|
|
|
|
if (pl) return pl->id;
|
|
|
|
|
|
|
|
|
|
for(pl=planes;pl;pl=pl->next) {
|
|
|
|
|
if(r->x >= pl->minx && r->x <= pl->maxx
|
|
|
|
|
&& r->y >= pl->miny && r->y <= pl->maxy) {
|
|
|
|
|
return pl->id;
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
return 0;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
int
|
|
|
|
|
ursprung_x(const faction *f, const plane *pl)
|
|
|
|
|
{
|
|
|
|
|
ursprung *ur;
|
|
|
|
|
int id = 0;
|
|
|
|
|
|
|
|
|
|
if(!f)
|
|
|
|
|
return 0;
|
|
|
|
|
|
|
|
|
|
if(pl)
|
|
|
|
|
id = pl->id;
|
|
|
|
|
|
|
|
|
|
for(ur = f->ursprung; ur; ur = ur->next) {
|
|
|
|
|
if(ur->id == id)
|
|
|
|
|
return ur->x;
|
|
|
|
|
}
|
|
|
|
|
return 0;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
int
|
|
|
|
|
ursprung_y(const faction *f, const plane *pl)
|
|
|
|
|
{
|
|
|
|
|
ursprung *ur;
|
|
|
|
|
int id = 0;
|
|
|
|
|
|
|
|
|
|
if(!f)
|
|
|
|
|
return 0;
|
|
|
|
|
|
|
|
|
|
if(pl)
|
|
|
|
|
id = pl->id;
|
|
|
|
|
|
|
|
|
|
for(ur = f->ursprung; ur; ur = ur->next) {
|
|
|
|
|
if(ur->id == id)
|
|
|
|
|
return ur->y;
|
|
|
|
|
}
|
|
|
|
|
return 0;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
int
|
2001-04-22 10:21:07 +02:00
|
|
|
|
plane_center_x(const plane *pl)
|
2001-01-25 10:37:55 +01:00
|
|
|
|
{
|
|
|
|
|
if(pl == NULL)
|
|
|
|
|
return 0;
|
|
|
|
|
|
|
|
|
|
return(pl->minx + pl->maxx)/2;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
int
|
2001-04-22 10:21:07 +02:00
|
|
|
|
plane_center_y(const plane *pl)
|
2001-01-25 10:37:55 +01:00
|
|
|
|
{
|
|
|
|
|
if(pl == NULL)
|
|
|
|
|
return 0;
|
|
|
|
|
|
|
|
|
|
return(pl->miny + pl->maxy)/2;
|
|
|
|
|
}
|
|
|
|
|
|
2001-04-01 08:58:45 +02:00
|
|
|
|
int
|
|
|
|
|
region_x(const region *r, const faction *f)
|
2001-01-25 10:37:55 +01:00
|
|
|
|
{
|
|
|
|
|
plane *pl;
|
|
|
|
|
|
|
|
|
|
pl = getplane(r);
|
|
|
|
|
return r->x - ursprung_x(f, pl) - plane_center_x(pl);
|
|
|
|
|
}
|
|
|
|
|
|
2001-04-01 08:58:45 +02:00
|
|
|
|
int
|
|
|
|
|
region_y(const region *r, const faction *f)
|
2001-01-25 10:37:55 +01:00
|
|
|
|
{
|
|
|
|
|
plane *pl;
|
|
|
|
|
|
|
|
|
|
pl = getplane(r);
|
|
|
|
|
return r->y - ursprung_y(f, pl) - plane_center_y(pl);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
void
|
|
|
|
|
set_ursprung(faction *f, int id, int x, int y)
|
|
|
|
|
{
|
|
|
|
|
ursprung *ur;
|
|
|
|
|
|
|
|
|
|
for(ur=f->ursprung;ur;ur=ur->next) {
|
|
|
|
|
if(ur->id == id) {
|
|
|
|
|
ur->x += x;
|
|
|
|
|
ur->y += y;
|
|
|
|
|
return;
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
ur = calloc(1, sizeof(ursprung));
|
|
|
|
|
ur->id = id;
|
|
|
|
|
ur->x = x;
|
|
|
|
|
ur->y = y;
|
|
|
|
|
|
|
|
|
|
addlist(&f->ursprung, ur);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
plane *
|
|
|
|
|
create_new_plane(int id, const char *name, int minx, int maxx, int miny, int maxy, int flags)
|
|
|
|
|
{
|
|
|
|
|
plane *pl = getplanebyid(id);
|
|
|
|
|
|
|
|
|
|
if (pl) return pl;
|
|
|
|
|
pl = calloc(1, sizeof(plane));
|
|
|
|
|
|
|
|
|
|
pl->next = NULL;
|
|
|
|
|
pl->id = id;
|
|
|
|
|
pl->name = strdup(name);
|
|
|
|
|
pl->minx = minx;
|
|
|
|
|
pl->maxx = maxx;
|
|
|
|
|
pl->miny = miny;
|
|
|
|
|
pl->maxy = maxy;
|
|
|
|
|
pl->flags = flags;
|
|
|
|
|
|
|
|
|
|
addlist(&planes, pl);
|
|
|
|
|
return pl;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
/* Umrechnung Relative-Absolute-Koordinaten */
|
|
|
|
|
int
|
2001-04-01 08:58:45 +02:00
|
|
|
|
rel_to_abs(const struct plane *pl, const struct faction * f, int rel, unsigned char index)
|
2001-01-25 10:37:55 +01:00
|
|
|
|
{
|
|
|
|
|
assert(index == 0 || index == 1);
|
|
|
|
|
|
|
|
|
|
if(index == 0)
|
2001-04-22 20:14:07 +02:00
|
|
|
|
return (rel + ursprung_x(f,pl) + plane_center_x(pl));
|
2001-01-25 10:37:55 +01:00
|
|
|
|
|
2001-04-22 20:14:07 +02:00
|
|
|
|
return (rel + ursprung_y(f,pl) + plane_center_y(pl));
|
2001-01-25 10:37:55 +01:00
|
|
|
|
}
|
2001-02-17 15:47:43 +01:00
|
|
|
|
|
|
|
|
|
|
|
|
|
|
void *
|
|
|
|
|
resolve_plane(void * id)
|
|
|
|
|
{
|
|
|
|
|
return getplanebyid((int)id);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
void
|
|
|
|
|
write_plane_reference(const plane * u, FILE * F)
|
|
|
|
|
{
|
|
|
|
|
fprintf(F, "%d ", u?(u->id):0);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
void
|
2001-04-22 20:14:07 +02:00
|
|
|
|
read_plane_reference(plane ** pp, FILE * F)
|
2001-02-17 15:47:43 +01:00
|
|
|
|
{
|
|
|
|
|
int i;
|
|
|
|
|
fscanf(F, "%d", &i);
|
2001-04-22 20:14:07 +02:00
|
|
|
|
if (i==0) *pp = NULL;
|
2001-02-17 15:47:43 +01:00
|
|
|
|
{
|
2001-04-22 20:14:07 +02:00
|
|
|
|
*pp = getplanebyid(i);
|
|
|
|
|
if (*pp==NULL) ur_add((void*)i, (void**)pp, resolve_plane);
|
2001-02-17 15:47:43 +01:00
|
|
|
|
}
|
|
|
|
|
}
|