2003-11-10 00:36:11 +01:00
|
|
|
/* vi: set ts=2:
|
2004-06-23 00:00:36 +02:00
|
|
|
+-------------------+
|
|
|
|
| | Christian Schlittchen <corwin@amber.kn-bremen.de>
|
|
|
|
| Eressea PBEM host | Enno Rehling <enno@eressea-pbem.de>
|
|
|
|
| (c) 1998 - 2004 | Katja Zedel <katze@felidae.kn-bremen.de>
|
|
|
|
| |
|
|
|
|
+-------------------+
|
|
|
|
|
|
|
|
This program may not be used, modified or distributed
|
|
|
|
without prior permission by the authors of Eressea.
|
|
|
|
*/
|
2003-11-10 00:36:11 +01:00
|
|
|
|
|
|
|
#ifndef KRNL_ORDER_H
|
|
|
|
#define KRNL_ORDER_H
|
|
|
|
#ifdef __cplusplus
|
|
|
|
extern "C" {
|
|
|
|
#endif
|
|
|
|
|
|
|
|
/* Encapsulation of an order
|
|
|
|
*
|
|
|
|
* This structure contains one order given by a unit. These used to be
|
|
|
|
* stored in string lists, but by storing them in order-structures,
|
|
|
|
* it is possible to use reference-counting on them, reduce string copies,
|
|
|
|
* and reduce overall memory usage by sharing strings between orders (not
|
|
|
|
* implemented yet) saving approx. 50% of all string-related memory.
|
|
|
|
*/
|
|
|
|
|
2005-05-22 14:26:19 +02:00
|
|
|
#define SHARE_ORDERS
|
2005-05-11 22:24:51 +02:00
|
|
|
|
|
|
|
#ifdef SHARE_ORDERS
|
2005-05-09 21:57:44 +02:00
|
|
|
struct order_data;
|
|
|
|
|
2003-11-10 00:36:11 +01:00
|
|
|
typedef struct order {
|
2004-06-21 18:45:27 +02:00
|
|
|
struct order * next;
|
|
|
|
/* do not access this data: */
|
2005-05-09 21:57:44 +02:00
|
|
|
struct order_data * data;
|
2004-06-26 22:51:19 +02:00
|
|
|
int _persistent : 1;
|
2003-11-10 00:36:11 +01:00
|
|
|
} order;
|
2005-05-11 22:24:51 +02:00
|
|
|
#else
|
|
|
|
typedef struct order_data {
|
|
|
|
char * _str;
|
|
|
|
int _lindex : 8;
|
|
|
|
keyword_t _keyword;
|
|
|
|
} order_data;
|
|
|
|
|
|
|
|
typedef struct order {
|
|
|
|
struct order * next;
|
|
|
|
/* do not access this data: */
|
|
|
|
struct order_data data;
|
|
|
|
int _persistent : 1;
|
|
|
|
} order;
|
|
|
|
#endif
|
2003-11-10 00:36:11 +01:00
|
|
|
|
|
|
|
/* constructor */
|
2005-05-22 14:26:19 +02:00
|
|
|
extern order * parse_order(const char * s, const struct locale * lang);
|
|
|
|
extern void replace_order(order ** dst, order * orig, const order * src);
|
2003-11-10 00:36:11 +01:00
|
|
|
|
|
|
|
/* reference counted copies of orders: */
|
2005-05-22 14:26:19 +02:00
|
|
|
extern order * copy_order(const order * ord);
|
|
|
|
extern void free_order(order * ord);
|
|
|
|
extern void free_orders(order ** olist);
|
2003-11-10 00:36:11 +01:00
|
|
|
|
|
|
|
/* access functions for orders */
|
2005-05-22 14:26:19 +02:00
|
|
|
extern keyword_t get_keyword(const order * ord);
|
|
|
|
extern void set_order(order ** destp, order * src);
|
|
|
|
extern char * getcommand(const order * ord);
|
|
|
|
extern boolean is_persistent(const order *ord);
|
|
|
|
extern boolean is_exclusive(const order *ord);
|
2005-05-01 13:32:24 +02:00
|
|
|
extern boolean is_repeated(const order * ord);
|
|
|
|
|
2005-05-22 14:26:19 +02:00
|
|
|
extern char * write_order(const order * ord, const struct locale * lang, char * buffer, size_t size);
|
2003-11-10 00:36:11 +01:00
|
|
|
#ifdef __cplusplus
|
|
|
|
}
|
|
|
|
#endif
|
|
|
|
#endif
|