2004-06-23 00:00:36 +02:00
|
|
|
/* vi: set ts=2:
|
|
|
|
+-------------------+
|
|
|
|
| | 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
|
|
|
#include <config.h>
|
|
|
|
#include "eressea.h"
|
|
|
|
#include "order.h"
|
2007-06-20 02:34:02 +02:00
|
|
|
|
2005-05-22 14:26:19 +02:00
|
|
|
#include "skill.h"
|
2003-11-10 00:36:11 +01:00
|
|
|
|
2007-06-26 11:32:28 +02:00
|
|
|
#include <util/base36.h>
|
2005-06-17 20:12:58 +02:00
|
|
|
#include <util/bsdstring.h>
|
2007-06-20 02:34:02 +02:00
|
|
|
#include <util/language.h>
|
2007-06-22 00:31:28 +02:00
|
|
|
#include <util/parser.h>
|
2005-06-17 20:12:58 +02:00
|
|
|
|
2003-11-10 00:36:11 +01:00
|
|
|
/* libc includes */
|
|
|
|
#include <assert.h>
|
|
|
|
#include <ctype.h>
|
2007-08-10 09:03:23 +02:00
|
|
|
#include <stdarg.h>
|
2003-11-10 00:36:11 +01:00
|
|
|
#include <stdlib.h>
|
|
|
|
#include <string.h>
|
|
|
|
|
2005-05-11 22:24:51 +02:00
|
|
|
# define ORD_KEYWORD(ord) (ord)->data->_keyword
|
|
|
|
# define ORD_LOCALE(ord) locale_array[(ord)->data->_lindex]->lang
|
|
|
|
# define ORD_STRING(ord) (ord)->data->_str
|
|
|
|
|
2005-05-09 22:01:28 +02:00
|
|
|
|
2005-05-09 21:57:44 +02:00
|
|
|
typedef struct locale_data {
|
|
|
|
struct order_data * short_orders[MAXKEYWORDS];
|
2005-05-11 18:12:42 +02:00
|
|
|
struct order_data * study_orders[MAXSKILLS];
|
2005-05-09 21:57:44 +02:00
|
|
|
const struct locale * lang;
|
|
|
|
} locale_data;
|
|
|
|
|
|
|
|
static struct locale_data * locale_array[16];
|
2004-06-26 22:51:19 +02:00
|
|
|
static int nlocales = 0;
|
|
|
|
|
2005-05-09 21:57:44 +02:00
|
|
|
typedef struct order_data {
|
2007-08-10 09:03:23 +02:00
|
|
|
char * _str;
|
2005-05-29 03:11:52 +02:00
|
|
|
int _refcount : 20;
|
|
|
|
int _lindex : 4;
|
2005-05-09 23:18:51 +02:00
|
|
|
keyword_t _keyword;
|
2005-05-09 21:57:44 +02:00
|
|
|
} order_data;
|
|
|
|
|
|
|
|
static void
|
|
|
|
release_data(order_data * data)
|
|
|
|
{
|
|
|
|
if (data) {
|
|
|
|
if (--data->_refcount == 0) {
|
|
|
|
if (data->_str) free(data->_str);
|
|
|
|
free(data);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2005-04-30 19:07:46 +02:00
|
|
|
void
|
2005-05-22 14:26:19 +02:00
|
|
|
replace_order(order ** dlist, order * orig, const order * src)
|
2005-04-30 19:07:46 +02:00
|
|
|
{
|
2005-05-22 14:26:19 +02:00
|
|
|
while (*dlist!=NULL) {
|
|
|
|
order * dst = *dlist;
|
|
|
|
if (dst->data==orig->data) {
|
|
|
|
order * cpy = copy_order(src);
|
|
|
|
*dlist = cpy;
|
|
|
|
cpy->next = dst->next;
|
|
|
|
dst->next = 0;
|
|
|
|
free_order(dst);
|
|
|
|
}
|
|
|
|
dlist = &(*dlist)->next;
|
|
|
|
}
|
2005-04-30 19:07:46 +02:00
|
|
|
}
|
|
|
|
|
2003-11-10 00:36:11 +01:00
|
|
|
keyword_t
|
2004-06-21 18:45:27 +02:00
|
|
|
get_keyword(const order * ord)
|
2003-11-10 00:36:11 +01:00
|
|
|
{
|
2004-06-21 18:45:27 +02:00
|
|
|
if (ord==NULL) {
|
|
|
|
return NOKEYWORD;
|
|
|
|
}
|
2005-05-22 14:26:19 +02:00
|
|
|
return ORD_KEYWORD(ord);
|
2003-11-10 00:36:11 +01:00
|
|
|
}
|
|
|
|
|
2007-07-17 17:33:48 +02:00
|
|
|
static char *
|
|
|
|
get_command(const order * ord, char * sbuffer, size_t bufsize)
|
2003-11-10 00:36:11 +01:00
|
|
|
{
|
2007-07-17 17:33:48 +02:00
|
|
|
char * str = sbuffer;
|
2007-08-10 09:03:23 +02:00
|
|
|
const char * text = ORD_STRING(ord);
|
2005-05-11 22:24:51 +02:00
|
|
|
keyword_t kwd = ORD_KEYWORD(ord);
|
2004-06-26 22:51:19 +02:00
|
|
|
|
2005-05-11 22:24:51 +02:00
|
|
|
if (ord->_persistent) *str++ = '@';
|
|
|
|
if (kwd!=NOKEYWORD) {
|
|
|
|
const struct locale * lang = ORD_LOCALE(ord);
|
2006-01-25 00:19:09 +01:00
|
|
|
size_t size = bufsize-(str-sbuffer);
|
2005-06-17 20:12:58 +02:00
|
|
|
if (text) --size;
|
2007-07-17 17:33:48 +02:00
|
|
|
str += strlcpy(str, (const char*)LOC(lang, keywords[kwd]), size);
|
2005-05-11 22:24:51 +02:00
|
|
|
if (text) {
|
2004-06-26 22:51:19 +02:00
|
|
|
*str++ = ' ';
|
|
|
|
}
|
|
|
|
}
|
2005-06-17 20:12:58 +02:00
|
|
|
if (text) {
|
2007-07-17 17:33:48 +02:00
|
|
|
str += strlcpy(str, (const char *)text, bufsize-(str-sbuffer));
|
2005-06-17 20:12:58 +02:00
|
|
|
}
|
2006-01-25 00:19:09 +01:00
|
|
|
return sbuffer;
|
|
|
|
}
|
|
|
|
|
2007-08-10 09:03:23 +02:00
|
|
|
char *
|
2006-01-25 00:19:09 +01:00
|
|
|
getcommand(const order * ord)
|
|
|
|
{
|
2007-07-17 17:33:48 +02:00
|
|
|
char sbuffer[DISPLAYSIZE*2];
|
2007-08-10 09:03:23 +02:00
|
|
|
return strdup(get_command(ord, sbuffer, sizeof(sbuffer)));
|
2003-11-10 00:36:11 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
void
|
|
|
|
free_order(order * ord)
|
|
|
|
{
|
2005-05-09 21:57:44 +02:00
|
|
|
if (ord!=NULL) {
|
2005-05-10 00:30:43 +02:00
|
|
|
assert(ord->next==0);
|
2005-05-11 22:24:51 +02:00
|
|
|
|
2005-05-09 21:57:44 +02:00
|
|
|
release_data(ord->data);
|
2005-04-30 19:16:17 +02:00
|
|
|
free(ord);
|
|
|
|
}
|
2003-11-10 00:36:11 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
order *
|
2005-05-22 14:26:19 +02:00
|
|
|
copy_order(const order * src)
|
2003-11-10 00:36:11 +01:00
|
|
|
{
|
2005-05-09 21:57:44 +02:00
|
|
|
if (src!=NULL) {
|
|
|
|
order * ord = (order*)malloc(sizeof(order));
|
|
|
|
ord->next = NULL;
|
|
|
|
ord->_persistent = src->_persistent;
|
|
|
|
ord->data = src->data;
|
|
|
|
++ord->data->_refcount;
|
|
|
|
return ord;
|
|
|
|
}
|
|
|
|
return NULL;
|
2003-11-10 00:36:11 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
void
|
|
|
|
set_order(struct order ** destp, struct order * src)
|
|
|
|
{
|
2004-06-21 18:45:27 +02:00
|
|
|
if (*destp==src) return;
|
|
|
|
free_order(*destp);
|
2005-05-10 00:30:43 +02:00
|
|
|
*destp = src;
|
2003-11-10 00:36:11 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
void
|
|
|
|
free_orders(order ** olist)
|
|
|
|
{
|
|
|
|
while (*olist) {
|
|
|
|
order * ord = *olist;
|
|
|
|
*olist = ord->next;
|
2004-06-27 14:19:58 +02:00
|
|
|
ord->next = NULL;
|
2003-11-10 00:36:11 +01:00
|
|
|
free_order(ord);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2005-05-11 18:12:42 +02:00
|
|
|
static order_data *
|
2007-08-10 09:03:23 +02:00
|
|
|
create_data(keyword_t kwd, const char * sptr, int lindex)
|
2005-05-11 18:12:42 +02:00
|
|
|
{
|
2007-08-10 09:03:23 +02:00
|
|
|
const char * s = sptr;
|
2005-05-11 18:12:42 +02:00
|
|
|
order_data * data;
|
|
|
|
const struct locale * lang = locale_array[lindex]->lang;
|
2005-05-22 14:26:19 +02:00
|
|
|
|
2007-06-26 11:32:28 +02:00
|
|
|
if (kwd!=NOKEYWORD) s = (*sptr)?sptr:NULL;
|
|
|
|
|
2005-05-22 14:26:19 +02:00
|
|
|
/* learning, only one order_data per skill required */
|
2005-05-11 18:12:42 +02:00
|
|
|
if (kwd==K_STUDY) {
|
|
|
|
skill_t sk = findskill(parse_token(&sptr), lang);
|
2005-05-22 23:02:42 +02:00
|
|
|
switch (sk) {
|
|
|
|
case NOSKILL: /* fehler */
|
|
|
|
break;
|
2005-05-29 10:53:31 +02:00
|
|
|
case SK_MAGIC: /* kann parameter haben */
|
|
|
|
if (*sptr != 0) break;
|
2005-05-22 23:02:42 +02:00
|
|
|
default: /* nur skill als Parameter, keine extras */
|
|
|
|
data = locale_array[lindex]->study_orders[sk];
|
|
|
|
if (data==NULL) {
|
2007-08-10 09:03:23 +02:00
|
|
|
const char * skname = skillname(sk, lang);
|
2005-05-22 23:02:42 +02:00
|
|
|
data = (order_data*)malloc(sizeof(order_data));
|
|
|
|
locale_array[lindex]->study_orders[sk] = data;
|
|
|
|
data->_keyword = kwd;
|
|
|
|
data->_lindex = lindex;
|
2007-08-10 09:03:23 +02:00
|
|
|
if (strchr(skname, ' ')!=NULL) {
|
|
|
|
size_t len = strlen(skname);
|
|
|
|
data->_str = malloc(len+3);
|
2007-06-26 11:32:28 +02:00
|
|
|
data->_str[0]='\"';
|
|
|
|
memcpy(data->_str+1, skname, len);
|
|
|
|
data->_str[len+1]='\"';
|
|
|
|
data->_str[len+2]='\0';
|
2005-06-17 10:50:59 +02:00
|
|
|
} else {
|
2007-08-10 09:03:23 +02:00
|
|
|
data->_str = strdup(skname);
|
2005-06-17 10:50:59 +02:00
|
|
|
}
|
2005-05-22 23:02:42 +02:00
|
|
|
data->_refcount = 1;
|
|
|
|
}
|
|
|
|
++data->_refcount;
|
|
|
|
return data;
|
2005-05-11 18:12:42 +02:00
|
|
|
}
|
|
|
|
}
|
2005-05-22 14:26:19 +02:00
|
|
|
|
|
|
|
/* orders with no parameter, only one order_data per order required */
|
2005-05-29 10:53:31 +02:00
|
|
|
else if (kwd!=NOKEYWORD && *sptr == 0) {
|
2005-05-11 18:12:42 +02:00
|
|
|
data = locale_array[lindex]->short_orders[kwd];
|
|
|
|
if (data == NULL) {
|
|
|
|
data = (order_data*)malloc(sizeof(order_data));
|
|
|
|
locale_array[lindex]->short_orders[kwd] = data;
|
|
|
|
data->_keyword = kwd;
|
|
|
|
data->_lindex = lindex;
|
2005-05-22 14:26:19 +02:00
|
|
|
data->_str = NULL;
|
2005-05-11 18:12:42 +02:00
|
|
|
data->_refcount = 1;
|
|
|
|
}
|
|
|
|
++data->_refcount;
|
|
|
|
return data;
|
|
|
|
}
|
|
|
|
data = (order_data*)malloc(sizeof(order_data));
|
|
|
|
data->_keyword = kwd;
|
|
|
|
data->_lindex = lindex;
|
2007-08-10 09:03:23 +02:00
|
|
|
data->_str = s?strdup(s):NULL;
|
2005-05-11 18:12:42 +02:00
|
|
|
data->_refcount = 1;
|
|
|
|
return data;
|
|
|
|
}
|
|
|
|
|
2007-06-26 11:32:28 +02:00
|
|
|
static order *
|
2007-08-10 09:03:23 +02:00
|
|
|
create_order_i(keyword_t kwd, const char * sptr, int persistent, const struct locale * lang)
|
2003-11-10 00:36:11 +01:00
|
|
|
{
|
2007-06-26 11:32:28 +02:00
|
|
|
order * ord = NULL;
|
|
|
|
int lindex;
|
2005-04-23 11:47:03 +02:00
|
|
|
|
2007-06-26 11:32:28 +02:00
|
|
|
/* if this is just nonsense, then we skip it. */
|
|
|
|
if (lomem) {
|
|
|
|
switch (kwd) {
|
2005-04-23 11:47:03 +02:00
|
|
|
case K_KOMMENTAR:
|
|
|
|
case NOKEYWORD:
|
|
|
|
return NULL;
|
2005-07-25 23:14:52 +02:00
|
|
|
case K_LIEFERE:
|
|
|
|
kwd = K_GIVE;
|
|
|
|
persistent = 1;
|
|
|
|
break;
|
2005-04-23 11:47:03 +02:00
|
|
|
default:
|
|
|
|
break;
|
|
|
|
}
|
2007-06-26 11:32:28 +02:00
|
|
|
}
|
2005-04-23 11:47:03 +02:00
|
|
|
|
2007-06-26 11:32:28 +02:00
|
|
|
for (lindex=0;lindex!=nlocales;++lindex) {
|
|
|
|
if (locale_array[lindex]->lang==lang) break;
|
|
|
|
}
|
|
|
|
if (lindex==nlocales) {
|
|
|
|
locale_array[nlocales] = (locale_data*)calloc(1, sizeof(locale_data));
|
|
|
|
locale_array[nlocales]->lang = lang;
|
|
|
|
++nlocales;
|
|
|
|
}
|
|
|
|
|
|
|
|
ord = (order*)malloc(sizeof(order));
|
|
|
|
ord->_persistent = persistent;
|
|
|
|
ord->next = NULL;
|
|
|
|
|
|
|
|
ord->data = create_data(kwd, sptr, lindex);
|
|
|
|
|
|
|
|
return ord;
|
|
|
|
}
|
|
|
|
|
|
|
|
order *
|
|
|
|
create_order(keyword_t kwd, const struct locale * lang, const char * params, ...)
|
|
|
|
{
|
|
|
|
va_list marker;
|
|
|
|
char zBuffer[DISPLAYSIZE];
|
|
|
|
char * sptr = zBuffer;
|
|
|
|
|
|
|
|
va_start(marker, params);
|
2007-08-10 09:03:23 +02:00
|
|
|
while (*params) {
|
2007-06-26 11:32:28 +02:00
|
|
|
switch (*params) {
|
|
|
|
case '%':
|
|
|
|
/* ignore these, they are syntactical sugar */
|
|
|
|
break;
|
2007-06-26 23:17:10 +02:00
|
|
|
case '"':
|
|
|
|
case '\'':
|
2007-06-26 23:50:07 +02:00
|
|
|
case ' ':
|
2007-06-26 23:17:10 +02:00
|
|
|
*sptr++ = *params;
|
|
|
|
break;
|
2007-06-26 11:32:28 +02:00
|
|
|
case 's':
|
|
|
|
sptr += strlcpy(sptr, va_arg(marker, const char *), sizeof(zBuffer)-(sptr-zBuffer));
|
|
|
|
break;
|
|
|
|
case 'd':
|
|
|
|
sptr += strlcpy(sptr, itoa10(va_arg(marker, int)), sizeof(zBuffer)-(sptr-zBuffer));
|
|
|
|
break;
|
|
|
|
case 'i':
|
|
|
|
sptr += strlcpy(sptr, itoa36(va_arg(marker, int)), sizeof(zBuffer)-(sptr-zBuffer));
|
|
|
|
break;
|
2007-06-26 23:50:07 +02:00
|
|
|
default:
|
|
|
|
assert(!"unknown format-character in create_order");
|
2005-05-09 21:57:44 +02:00
|
|
|
}
|
2007-08-10 09:03:23 +02:00
|
|
|
++params;
|
2007-06-26 11:32:28 +02:00
|
|
|
}
|
|
|
|
va_end(marker);
|
2005-05-09 21:57:44 +02:00
|
|
|
|
2007-08-10 09:03:23 +02:00
|
|
|
return create_order_i(kwd, zBuffer, 0, lang);
|
2007-06-26 11:32:28 +02:00
|
|
|
}
|
2004-06-26 22:51:19 +02:00
|
|
|
|
2007-06-26 11:32:28 +02:00
|
|
|
order *
|
2007-08-10 09:03:23 +02:00
|
|
|
parse_order(const char * s, const struct locale * lang)
|
2007-06-26 11:32:28 +02:00
|
|
|
{
|
|
|
|
while (*s && !isalnum(*(unsigned char*)s) && !ispunct(*(unsigned char*)s)) ++s;
|
|
|
|
if (*s!=0) {
|
|
|
|
keyword_t kwd;
|
2007-08-10 09:03:23 +02:00
|
|
|
const char * sptr;
|
2007-06-26 11:32:28 +02:00
|
|
|
int persistent = 0;
|
2005-05-11 18:12:42 +02:00
|
|
|
|
2007-06-26 11:32:28 +02:00
|
|
|
while (*s=='@') {
|
|
|
|
persistent = 1;
|
|
|
|
++s;
|
|
|
|
}
|
|
|
|
sptr = s;
|
|
|
|
kwd = findkeyword(parse_token(&sptr), lang);
|
|
|
|
if (kwd!=NOKEYWORD) {
|
|
|
|
while (isspace(*(unsigned char*)sptr)) ++sptr;
|
|
|
|
s = sptr;
|
|
|
|
}
|
|
|
|
return create_order_i(kwd, s, persistent, lang);
|
2004-06-21 18:45:27 +02:00
|
|
|
}
|
2007-06-26 11:32:28 +02:00
|
|
|
return NULL;
|
2003-11-10 00:36:11 +01:00
|
|
|
}
|
|
|
|
|
2005-05-01 13:32:24 +02:00
|
|
|
boolean
|
|
|
|
is_repeated(const order * ord)
|
|
|
|
{
|
2005-05-11 22:24:51 +02:00
|
|
|
keyword_t kwd = ORD_KEYWORD(ord);
|
|
|
|
const struct locale * lang = ORD_LOCALE(ord);
|
2005-05-01 13:32:24 +02:00
|
|
|
param_t param;
|
|
|
|
|
2005-05-11 22:24:51 +02:00
|
|
|
switch (kwd) {
|
2005-05-01 13:32:24 +02:00
|
|
|
case K_CAST:
|
|
|
|
case K_BUY:
|
|
|
|
case K_SELL:
|
|
|
|
case K_ROUTE:
|
|
|
|
case K_DRIVE:
|
|
|
|
case K_WORK:
|
|
|
|
case K_BESIEGE:
|
|
|
|
case K_ENTERTAIN:
|
|
|
|
case K_TAX:
|
|
|
|
case K_RESEARCH:
|
|
|
|
case K_SPY:
|
|
|
|
case K_STEAL:
|
|
|
|
case K_SABOTAGE:
|
|
|
|
case K_STUDY:
|
|
|
|
case K_TEACH:
|
2005-05-11 22:24:51 +02:00
|
|
|
case K_BREED:
|
2005-05-01 13:32:24 +02:00
|
|
|
case K_PIRACY:
|
|
|
|
return true;
|
|
|
|
|
2005-05-11 22:24:51 +02:00
|
|
|
case K_PLANT:
|
2005-05-01 13:32:24 +02:00
|
|
|
return true;
|
|
|
|
|
|
|
|
case K_FOLLOW:
|
|
|
|
/* FOLLOW is only a long order if we are following a ship. */
|
|
|
|
parser_pushstate();
|
|
|
|
init_tokens(ord);
|
|
|
|
skip_token();
|
|
|
|
param = getparam(lang);
|
|
|
|
parser_popstate();
|
|
|
|
|
|
|
|
if (param == P_SHIP) return true;
|
|
|
|
break;
|
|
|
|
|
|
|
|
case K_MAKE:
|
|
|
|
/* Falls wir MACHE TEMP haben, ignorieren wir es. Alle anderen
|
|
|
|
* Arten von MACHE zaehlen aber als neue defaults und werden
|
|
|
|
* behandelt wie die anderen (deswegen kein break nach case
|
|
|
|
* K_MAKE) - und in thisorder (der aktuelle 30-Tage Befehl)
|
|
|
|
* abgespeichert). */
|
|
|
|
parser_pushstate();
|
|
|
|
init_tokens(ord); /* initialize token-parser */
|
|
|
|
skip_token();
|
|
|
|
param = getparam(lang);
|
|
|
|
parser_popstate();
|
|
|
|
|
|
|
|
if (param != P_TEMP) return true;
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
return false;
|
|
|
|
}
|
|
|
|
|
2003-11-10 00:36:11 +01:00
|
|
|
boolean
|
2005-04-30 19:07:46 +02:00
|
|
|
is_exclusive(const order * ord)
|
2003-11-10 00:36:11 +01:00
|
|
|
{
|
2005-05-11 22:24:51 +02:00
|
|
|
keyword_t kwd = ORD_KEYWORD(ord);
|
|
|
|
const struct locale * lang = ORD_LOCALE(ord);
|
2005-04-30 19:07:46 +02:00
|
|
|
param_t param;
|
|
|
|
|
2005-05-11 22:24:51 +02:00
|
|
|
switch (kwd) {
|
2005-04-30 19:07:46 +02:00
|
|
|
case K_MOVE:
|
|
|
|
case K_WEREWOLF:
|
|
|
|
/* these should not become persistent */
|
|
|
|
case K_ROUTE:
|
|
|
|
case K_DRIVE:
|
|
|
|
case K_WORK:
|
|
|
|
case K_BESIEGE:
|
|
|
|
case K_ENTERTAIN:
|
|
|
|
case K_TAX:
|
|
|
|
case K_RESEARCH:
|
|
|
|
case K_SPY:
|
|
|
|
case K_STEAL:
|
|
|
|
case K_SABOTAGE:
|
|
|
|
case K_STUDY:
|
|
|
|
case K_TEACH:
|
2005-05-11 22:24:51 +02:00
|
|
|
case K_BREED:
|
2005-04-30 19:07:46 +02:00
|
|
|
case K_PIRACY:
|
|
|
|
return true;
|
|
|
|
|
2005-05-11 22:24:51 +02:00
|
|
|
case K_PLANT:
|
2005-04-30 19:07:46 +02:00
|
|
|
return true;
|
|
|
|
|
|
|
|
case K_FOLLOW:
|
|
|
|
/* FOLLOW is only a long order if we are following a ship. */
|
|
|
|
parser_pushstate();
|
|
|
|
init_tokens(ord);
|
|
|
|
skip_token();
|
|
|
|
param = getparam(lang);
|
|
|
|
parser_popstate();
|
|
|
|
|
|
|
|
if (param == P_SHIP) return true;
|
|
|
|
break;
|
|
|
|
|
|
|
|
case K_MAKE:
|
|
|
|
/* Falls wir MACHE TEMP haben, ignorieren wir es. Alle anderen
|
|
|
|
* Arten von MACHE zaehlen aber als neue defaults und werden
|
|
|
|
* behandelt wie die anderen (deswegen kein break nach case
|
|
|
|
* K_MAKE) - und in thisorder (der aktuelle 30-Tage Befehl)
|
|
|
|
* abgespeichert). */
|
|
|
|
parser_pushstate();
|
|
|
|
init_tokens(ord); /* initialize token-parser */
|
|
|
|
skip_token();
|
|
|
|
param = getparam(lang);
|
|
|
|
parser_popstate();
|
|
|
|
|
|
|
|
if (param != P_TEMP) return true;
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
return false;
|
|
|
|
}
|
|
|
|
|
|
|
|
boolean
|
|
|
|
is_persistent(const order * ord)
|
|
|
|
{
|
2005-05-11 22:24:51 +02:00
|
|
|
keyword_t kwd = ORD_KEYWORD(ord);
|
2005-04-30 19:07:46 +02:00
|
|
|
boolean persist = ord->_persistent!=0;
|
2005-05-11 22:24:51 +02:00
|
|
|
switch (kwd) {
|
2005-04-30 19:07:46 +02:00
|
|
|
case K_MOVE:
|
|
|
|
case K_WEREWOLF:
|
2004-06-26 22:51:19 +02:00
|
|
|
case NOKEYWORD:
|
2005-04-30 19:07:46 +02:00
|
|
|
/* lang, aber niemals persistent! */
|
2004-06-26 22:51:19 +02:00
|
|
|
return false;
|
2005-04-30 19:07:46 +02:00
|
|
|
|
2004-06-26 22:51:19 +02:00
|
|
|
case K_KOMMENTAR:
|
|
|
|
case K_LIEFERE:
|
|
|
|
return true;
|
2003-11-10 00:36:11 +01:00
|
|
|
}
|
2005-04-30 19:07:46 +02:00
|
|
|
|
2005-05-01 13:32:24 +02:00
|
|
|
return persist || is_repeated(ord);
|
2003-11-10 00:36:11 +01:00
|
|
|
}
|
|
|
|
|
2007-07-17 17:33:48 +02:00
|
|
|
char *
|
|
|
|
write_order(const order * ord, const struct locale * lang, char * buffer, size_t size)
|
2003-11-10 00:36:11 +01:00
|
|
|
{
|
2005-05-11 22:38:19 +02:00
|
|
|
if (ord==0) {
|
2004-06-23 00:00:36 +02:00
|
|
|
buffer[0]=0;
|
|
|
|
} else {
|
2005-05-11 22:38:19 +02:00
|
|
|
keyword_t kwd = ORD_KEYWORD(ord);
|
|
|
|
if (kwd==NOKEYWORD) {
|
2007-08-10 09:03:23 +02:00
|
|
|
const char * text = ORD_STRING(ord);
|
2007-07-17 17:33:48 +02:00
|
|
|
strlcpy(buffer, (const char *)text, size);
|
2005-05-11 22:38:19 +02:00
|
|
|
} else {
|
2006-01-25 00:19:09 +01:00
|
|
|
get_command(ord, buffer, size);
|
2005-05-11 22:38:19 +02:00
|
|
|
}
|
2004-06-23 00:00:36 +02:00
|
|
|
}
|
|
|
|
return buffer;
|
2003-11-10 00:36:11 +01:00
|
|
|
}
|