server/src/common/kernel/region.h

243 lines
7.4 KiB
C
Raw Normal View History

2001-01-25 10:37:55 +01:00
/* vi: set ts=2:
*
*
* Eressea PB(E)M host Copyright (C) 1998-2003
2001-01-25 10:37:55 +01:00
* 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)
*
* This program may not be used, modified or distributed without
* prior permission by the authors of Eressea.
*/
#ifndef H_KRNL_REGION
#define H_KRNL_REGION
#ifdef __cplusplus
extern "C" {
#endif
2001-01-25 10:37:55 +01:00
#include "language.h"
#include <assert.h>
/* FAST_CONNECT: regions are directly connected to neighbours, saves doing
a hash-access each time a neighbour is needed */
#define FAST_CONNECT
2001-01-25 10:37:55 +01:00
#define RF_CHAOTIC (1<<0)
#define RF_MALLORN (1<<1)
#define RF_BLOCKED (1<<2)
2001-01-25 10:37:55 +01:00
#define RF_BLOCK_NORTHWEST (1<<3)
#define RF_BLOCK_NORTHEAST (1<<4)
#define RF_BLOCK_EAST (1<<5)
#define RF_BLOCK_SOUTHEAST (1<<6)
#define RF_BLOCK_SOUTHWEST (1<<7)
#define RF_BLOCK_WEST (1<<8)
2001-01-25 10:37:55 +01:00
#define RF_ENCOUNTER (1<<9)
#define RF_MIGRATION (1<<10)
#define RF_UNUSED_1 (1<<11)
#define RF_ORCIFIED (1<<12)
#define RF_CURSED (1<<13)
#define RF_COMBATDEBUG (1<<14)
#define RF_DH (1<<18)
2001-01-25 10:37:55 +01:00
/* flags that speed up attribute access: */
#define RF_TRAVELUNIT (1<<19)
2001-01-25 10:37:55 +01:00
#define RF_ALL 0xFFFFFF
#define RF_SAVEMASK (RF_CHAOTIC|RF_MALLORN|RF_BLOCKED|RF_BLOCK_NORTHWEST|RF_BLOCK_NORTHEAST|RF_BLOCK_EAST|RF_BLOCK_SOUTHEAST|RF_BLOCK_SOUTHWEST|RF_BLOCK_WEST|RF_ENCOUNTER|RF_ORCIFIED)
struct message;
struct message_list;
struct rawmaterial;
struct donation;
2001-01-25 10:37:55 +01:00
typedef struct land_region {
char *name;
/* TODO: demand kann nach Konvertierung entfernt werden. */
struct demand {
struct demand * next;
const struct luxury_type * type;
int value;
} * demands;
const struct item_type * herbtype;
short herbs;
int trees[3]; /* 0 -> Samen, 1 -> Spr<70><72>linge, 2 -> B<>ume */
int horses;
int peasants;
int newpeasants;
int money;
struct item * items; /* items that can be claimed */
2001-01-25 10:37:55 +01:00
} land_region;
2005-06-11 10:09:55 +02:00
typedef struct donation {
struct donation *next;
struct faction *f1, *f2;
int amount;
} donation;
2001-01-25 10:37:55 +01:00
typedef struct region {
struct region *next;
struct land_region *land;
struct unit *units;
struct ship *ships;
struct building *buildings;
unsigned int index;
/* an ascending number, to improve the speed of determining the interval in
which a faction has its units. See the implementations of firstregion
and lastregion */
short x, y;
struct plane *planep;
char *display;
unsigned int flags;
unsigned short age;
struct message_list *msgs;
struct individual_message {
struct individual_message * next;
const struct faction * viewer;
struct message_list *msgs;
} * individual_messages;
struct attrib *attribs;
struct region *nexthash;
struct donation * donations;
const struct terrain_type * terrain;
struct rawmaterial * resources;
#ifdef REGIONOWNERS
struct faction * owner;
#endif
#ifdef FAST_CONNECT
struct region * connect[MAXDIRECTIONS];
#endif
2001-01-25 10:37:55 +01:00
} region;
typedef struct region_list {
struct region_list * next;
struct region * data;
} region_list;
extern struct message_list * r_getmessages(const struct region * r, const struct faction * viewer);
extern struct message * r_addmessage(struct region * r, const struct faction * viewer, struct message * msg);
typedef struct spec_direction {
short x, y;
2004-04-09 03:33:19 +02:00
int duration;
boolean active;
char *desc;
char *keyword;
2001-01-25 10:37:55 +01:00
} spec_direction;
typedef struct {
direction_t dir;
2001-01-25 10:37:55 +01:00
} moveblock;
#define reg_hashkey(r) (r->index)
#define coor_hashkey(x, y) (abs(x + 0x100 * y))
2001-01-25 10:37:55 +01:00
int distance(const struct region*, const struct region*);
int koor_distance(int ax, int ay, int bx, int by) ;
extern direction_t reldirection(const struct region * from, const struct region * to);
extern struct region * findregion(short x, short y);
2001-01-25 10:37:55 +01:00
extern attrib_type at_direction;
extern attrib_type at_moveblock;
/* new: */
extern attrib_type at_peasantluck;
extern attrib_type at_horseluck;
extern attrib_type at_chaoscount;
extern attrib_type at_woodcount;
extern attrib_type at_deathcount;
extern attrib_type at_travelunit;
extern attrib_type at_laen;
2001-01-25 10:37:55 +01:00
void initrhash(void);
void rhash(struct region * r);
void runhash(struct region * r);
void free_regionlist(region_list *rl);
void add_regionlist(region_list **rl, struct region *r);
extern struct spec_direction * special_direction(const region * from, const region * to);
extern struct attrib *create_special_direction(struct region *r, struct region *rt,
int duration, const char *desc,
const char *keyword);
2001-01-25 10:37:55 +01:00
int deathcount(const struct region * r);
int chaoscount(const struct region * r);
void deathcounts(struct region * r, int delta);
void chaoscounts(struct region * r, int delta);
void setluxuries(struct region * r, const struct luxury_type * sale);
2005-11-26 01:09:29 +01:00
extern int get_maxluxuries(void);
2005-06-12 11:48:19 +02:00
short rroad(const struct region * r, direction_t d);
void rsetroad(struct region * r, direction_t d, short value);
2001-01-25 10:37:55 +01:00
int is_coastregion(struct region *r);
int rtrees(const struct region * r, int ageclass);
int rsettrees(const struct region *r, int ageclass, int value);
2001-01-25 10:37:55 +01:00
int rpeasants(const struct region * r);
void rsetpeasants(struct region * r, int value);
int rmoney(const struct region * r);
void rsetmoney(struct region * r, int value);
int rhorses(const struct region * r);
void rsethorses(const struct region * r, int value);
2001-01-25 10:37:55 +01:00
#define rbuildings(r) ((r)->buildings)
extern int rlaen(const struct region * r);
extern void rsetlaen(struct region * r, int value);
2001-01-25 10:37:55 +01:00
#define rherbtype(r) ((r)->land?(r)->land->herbtype:0)
#define rsetherbtype(r, value) ((r)->land?((r)->land->herbtype=(value)):(value),0)
#define rherbs(r) ((r)->land?(r)->land->herbs:0)
#define rsetherbs(r, value) ((r)->land?((r)->land->herbs=(short)(value)):(value),0)
extern boolean r_isforest(const struct region * r);
#define rterrain(r) (oldterrain((r)->terrain))
#define rsetterrain(r, t) ((r)->terrain = newterrain(t))
2001-01-25 10:37:55 +01:00
extern const char * rname(const struct region * r, const struct locale * lang);
2001-01-25 10:37:55 +01:00
#define rsetname(r, str) (set_string(&(r)->land->name, str))
#define rplane(r) getplane(r)
extern void r_setdemand(struct region * r, const struct luxury_type * ltype, int value);
extern int r_demand(const struct region * r, const struct luxury_type * ltype);
extern const char * regionname(const struct region * r, const struct faction * f);
extern void * resolve_region(variant data);
extern struct region * new_region(short x, short y);
2001-01-25 10:37:55 +01:00
extern void terraform(struct region * r, terrain_t terrain);
extern void terraform_region(struct region * r, const struct terrain_type * terrain);
2001-01-25 10:37:55 +01:00
extern const short delta_x[MAXDIRECTIONS];
extern const short delta_y[MAXDIRECTIONS];
extern direction_t dir_invert(direction_t dir);
2001-01-25 10:37:55 +01:00
extern int production(const struct region *r);
extern int read_region_reference(struct region ** r, FILE * F);
2001-01-25 10:37:55 +01:00
extern void write_region_reference(const struct region * r, FILE * F);
void region_setowner(struct region * r, struct faction * owner);
extern struct faction * region_owner(const struct region * r);
extern struct region * r_connect(const struct region *, direction_t dir);
#ifdef FAST_CONNECT
# define rconnect(r, dir) ((r)->connect[dir]?(r)->connect[dir]:r_connect(r, dir))
#else
# define rconnect(r, dir) r_connect(r, dir)
#endif
#ifdef __cplusplus
}
#endif
2001-01-25 10:37:55 +01:00
#endif /* _REGION_H */