2015-01-30 20:37:14 +01:00
|
|
|
/*
|
|
|
|
+-------------------+
|
2010-08-08 10:06:34 +02:00
|
|
|
| | Christian Schlittchen <corwin@amber.kn-bremen.de>
|
|
|
|
| Eressea PBEM host | Enno Rehling <enno@eressea.de>
|
|
|
|
| (c) 1998 - 2004 | Katja Zedel <katze@felidae.kn-bremen.de>
|
|
|
|
| |
|
2015-01-30 20:37:14 +01:00
|
|
|
+-------------------+
|
2010-08-08 10:06:34 +02:00
|
|
|
|
|
|
|
This program may not be used, modified or distributed
|
|
|
|
without prior permission by the authors of Eressea.
|
2015-01-30 20:37:14 +01:00
|
|
|
*/
|
2010-08-08 10:06:34 +02:00
|
|
|
|
|
|
|
#ifndef KRNL_ORDER_H
|
|
|
|
#define KRNL_ORDER_H
|
2016-11-25 20:15:11 +01:00
|
|
|
|
|
|
|
#include "keyword.h"
|
|
|
|
#include <stddef.h>
|
2017-01-10 18:05:48 +01:00
|
|
|
#include <stdbool.h>
|
2016-11-25 20:15:11 +01:00
|
|
|
|
2010-08-08 10:06:34 +02:00
|
|
|
#ifdef __cplusplus
|
|
|
|
extern "C" {
|
|
|
|
#endif
|
|
|
|
|
2015-01-30 20:37:14 +01:00
|
|
|
/* 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.
|
|
|
|
*/
|
2010-08-08 10:06:34 +02:00
|
|
|
|
2017-09-30 19:22:24 +02:00
|
|
|
#define CMD_QUIET 0x010000
|
|
|
|
#define CMD_PERSIST 0x020000
|
|
|
|
#define CMD_DEFAULT 0x040000
|
|
|
|
|
2015-01-30 20:37:14 +01:00
|
|
|
typedef struct order {
|
|
|
|
struct order *next;
|
|
|
|
/* do not access this data: */
|
2017-10-08 12:39:41 +02:00
|
|
|
int id;
|
2017-09-30 19:22:24 +02:00
|
|
|
int command;
|
2015-01-30 20:37:14 +01:00
|
|
|
} order;
|
2010-08-08 10:06:34 +02:00
|
|
|
|
2015-01-30 20:37:14 +01:00
|
|
|
/* constructor */
|
2017-09-25 22:04:16 +02:00
|
|
|
order *create_order(keyword_t kwd, const struct locale *lang,
|
2015-01-30 20:37:14 +01:00
|
|
|
const char *params, ...);
|
2017-09-25 22:04:16 +02:00
|
|
|
order *parse_order(const char *s, const struct locale *lang);
|
|
|
|
void replace_order(order ** dst, order * orig, const order * src);
|
2010-08-08 10:06:34 +02:00
|
|
|
|
2015-01-30 20:37:14 +01:00
|
|
|
/* reference counted copies of orders: */
|
2017-09-25 22:04:16 +02:00
|
|
|
order *copy_order(const order * ord);
|
|
|
|
void free_order(order * ord);
|
|
|
|
void free_orders(order ** olist);
|
2010-08-08 10:06:34 +02:00
|
|
|
|
2017-09-25 22:04:16 +02:00
|
|
|
void push_order(struct order **olist, struct order *ord);
|
2011-02-22 07:00:03 +01:00
|
|
|
|
2015-01-30 20:37:14 +01:00
|
|
|
/* access functions for orders */
|
|
|
|
keyword_t getkeyword(const order * ord);
|
|
|
|
void set_order(order ** destp, order * src);
|
|
|
|
char* get_command(const order *ord, char *buffer, size_t size);
|
|
|
|
bool is_persistent(const order * ord);
|
2017-09-30 19:44:39 +02:00
|
|
|
bool is_silent(const order * ord);
|
2015-01-30 20:37:14 +01:00
|
|
|
bool is_exclusive(const order * ord);
|
2015-08-04 22:47:55 +02:00
|
|
|
bool is_repeated(keyword_t kwd);
|
|
|
|
bool is_long(keyword_t kwd);
|
2010-08-08 10:06:34 +02:00
|
|
|
|
2015-01-30 20:37:14 +01:00
|
|
|
char *write_order(const order * ord, char *buffer, size_t size);
|
|
|
|
keyword_t init_order(const struct order *ord);
|
2010-08-08 10:06:34 +02:00
|
|
|
|
2015-10-13 23:25:44 +02:00
|
|
|
void close_orders(void);
|
|
|
|
|
2010-08-08 10:06:34 +02:00
|
|
|
#ifdef __cplusplus
|
|
|
|
}
|
|
|
|
#endif
|
|
|
|
#endif
|