forked from github/server
smallify order
This commit is contained in:
parent
86e99a560c
commit
54fdda85cd
6 changed files with 33 additions and 39 deletions
|
@ -83,7 +83,7 @@ struct message *msg_feedback(const struct unit *u, struct order *ord,
|
||||||
variant var;
|
variant var;
|
||||||
memset(args, 0, sizeof(args));
|
memset(args, 0, sizeof(args));
|
||||||
|
|
||||||
if (ord && ord->_noerror) {
|
if (ord && (ord->command & CMD_QUIET)) {
|
||||||
return NULL;
|
return NULL;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -79,8 +79,8 @@ static void test_noerror(CuTest *tc) {
|
||||||
lang = test_create_locale();
|
lang = test_create_locale();
|
||||||
u = test_create_unit(test_create_faction(NULL), test_create_region(0, 0, NULL));
|
u = test_create_unit(test_create_faction(NULL), test_create_region(0, 0, NULL));
|
||||||
u->thisorder = parse_order("!@move", lang);
|
u->thisorder = parse_order("!@move", lang);
|
||||||
CuAssertTrue(tc, u->thisorder->_persistent);
|
CuAssertIntEquals(tc, K_MOVE | CMD_QUIET | CMD_PERSIST, u->thisorder->command);
|
||||||
CuAssertTrue(tc, u->thisorder->_noerror);
|
CuAssertTrue(tc, is_persistent(u->thisorder));
|
||||||
CuAssertPtrEquals(tc, NULL, msg_error(u, u->thisorder, 100));
|
CuAssertPtrEquals(tc, NULL, msg_error(u, u->thisorder, 100));
|
||||||
CuAssertPtrEquals(tc, NULL, msg_feedback(u, u->thisorder, "error_unit_not_found", NULL));
|
CuAssertPtrEquals(tc, NULL, msg_feedback(u, u->thisorder, "error_unit_not_found", NULL));
|
||||||
test_cleanup();
|
test_cleanup();
|
||||||
|
|
|
@ -94,7 +94,7 @@ char* get_command(const order *ord, char *sbuffer, size_t size) {
|
||||||
keyword_t kwd = ORD_KEYWORD(ord);
|
keyword_t kwd = ORD_KEYWORD(ord);
|
||||||
int bytes;
|
int bytes;
|
||||||
|
|
||||||
if (ord->_noerror) {
|
if (ord->command & CMD_QUIET) {
|
||||||
if (size > 0) {
|
if (size > 0) {
|
||||||
*bufp++ = '!';
|
*bufp++ = '!';
|
||||||
--size;
|
--size;
|
||||||
|
@ -103,7 +103,7 @@ char* get_command(const order *ord, char *sbuffer, size_t size) {
|
||||||
WARN_STATIC_BUFFER();
|
WARN_STATIC_BUFFER();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
if (ord->_persistent) {
|
if (ord->command & CMD_PERSIST) {
|
||||||
if (size > 0) {
|
if (size > 0) {
|
||||||
*bufp++ = '@';
|
*bufp++ = '@';
|
||||||
--size;
|
--size;
|
||||||
|
@ -162,8 +162,7 @@ order *copy_order(const order * src)
|
||||||
if (src != NULL) {
|
if (src != NULL) {
|
||||||
order *ord = (order *)malloc(sizeof(order));
|
order *ord = (order *)malloc(sizeof(order));
|
||||||
ord->next = NULL;
|
ord->next = NULL;
|
||||||
ord->_persistent = src->_persistent;
|
ord->command = src->command;
|
||||||
ord->_noerror = src->_noerror;
|
|
||||||
ord->data = src->data;
|
ord->data = src->data;
|
||||||
++ord->data->_refcount;
|
++ord->data->_refcount;
|
||||||
return ord;
|
return ord;
|
||||||
|
@ -316,8 +315,9 @@ static order *create_order_i(order *ord, keyword_t kwd, const char *sptr, bool p
|
||||||
}
|
}
|
||||||
locale_array[lindex]->lang = lang;
|
locale_array[lindex]->lang = lang;
|
||||||
|
|
||||||
ord->_persistent = persistent;
|
ord->command = (int)kwd;
|
||||||
ord->_noerror = noerror;
|
if (persistent) ord->command |= CMD_PERSIST;
|
||||||
|
if (noerror) ord->command |= CMD_QUIET;
|
||||||
ord->next = NULL;
|
ord->next = NULL;
|
||||||
|
|
||||||
while (isspace(*(unsigned char *)sptr)) ++sptr;
|
while (isspace(*(unsigned char *)sptr)) ++sptr;
|
||||||
|
@ -560,7 +560,7 @@ bool is_persistent(const order * ord)
|
||||||
case K_KOMMENTAR:
|
case K_KOMMENTAR:
|
||||||
return true;
|
return true;
|
||||||
default:
|
default:
|
||||||
return ord->_persistent || is_repeated(kwd);
|
return (ord->command & CMD_PERSIST) || is_repeated(kwd);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -32,12 +32,15 @@ extern "C" {
|
||||||
|
|
||||||
struct order_data;
|
struct order_data;
|
||||||
|
|
||||||
|
#define CMD_QUIET 0x010000
|
||||||
|
#define CMD_PERSIST 0x020000
|
||||||
|
#define CMD_DEFAULT 0x040000
|
||||||
|
|
||||||
typedef struct order {
|
typedef struct order {
|
||||||
struct order *next;
|
struct order *next;
|
||||||
/* do not access this data: */
|
/* do not access this data: */
|
||||||
struct order_data *data;
|
struct order_data *data;
|
||||||
bool _persistent;
|
int command;
|
||||||
bool _noerror;
|
|
||||||
} order;
|
} order;
|
||||||
|
|
||||||
/* constructor */
|
/* constructor */
|
||||||
|
|
|
@ -38,8 +38,7 @@ static void test_parse_order(CuTest *tc) {
|
||||||
|
|
||||||
ord = parse_order("MOVE NORTH", lang);
|
ord = parse_order("MOVE NORTH", lang);
|
||||||
CuAssertPtrNotNull(tc, ord);
|
CuAssertPtrNotNull(tc, ord);
|
||||||
CuAssertTrue(tc, !ord->_noerror);
|
CuAssertIntEquals(tc, K_MOVE, ord->command);
|
||||||
CuAssertTrue(tc, !ord->_persistent);
|
|
||||||
CuAssertIntEquals(tc, K_MOVE, getkeyword(ord));
|
CuAssertIntEquals(tc, K_MOVE, getkeyword(ord));
|
||||||
CuAssertStrEquals(tc, "move NORTH", get_command(ord, cmd, sizeof(cmd)));
|
CuAssertStrEquals(tc, "move NORTH", get_command(ord, cmd, sizeof(cmd)));
|
||||||
|
|
||||||
|
@ -51,40 +50,35 @@ static void test_parse_order(CuTest *tc) {
|
||||||
CuAssertPtrNotNull(tc, ord);
|
CuAssertPtrNotNull(tc, ord);
|
||||||
CuAssertPtrNotNull(tc, ord->data);
|
CuAssertPtrNotNull(tc, ord->data);
|
||||||
CuAssertIntEquals(tc, K_MOVE, getkeyword(ord));
|
CuAssertIntEquals(tc, K_MOVE, getkeyword(ord));
|
||||||
CuAssertTrue(tc, ord->_noerror);
|
CuAssertIntEquals(tc, K_MOVE | CMD_QUIET, ord->command);
|
||||||
CuAssertTrue(tc, !ord->_persistent);
|
|
||||||
free_order(ord);
|
free_order(ord);
|
||||||
|
|
||||||
ord = parse_order("@MOVE NORTH", lang);
|
ord = parse_order("@MOVE NORTH", lang);
|
||||||
CuAssertPtrNotNull(tc, ord);
|
CuAssertPtrNotNull(tc, ord);
|
||||||
CuAssertPtrNotNull(tc, ord->data);
|
CuAssertPtrNotNull(tc, ord->data);
|
||||||
CuAssertIntEquals(tc, K_MOVE, getkeyword(ord));
|
CuAssertIntEquals(tc, K_MOVE, getkeyword(ord));
|
||||||
CuAssertTrue(tc, !ord->_noerror);
|
CuAssertIntEquals(tc, K_MOVE | CMD_PERSIST, ord->command);
|
||||||
CuAssertTrue(tc, ord->_persistent);
|
|
||||||
free_order(ord);
|
|
||||||
|
|
||||||
ord = parse_order("@!MOVE NORTH", lang);
|
|
||||||
CuAssertPtrNotNull(tc, ord);
|
|
||||||
CuAssertPtrNotNull(tc, ord->data);
|
|
||||||
CuAssertIntEquals(tc, K_MOVE, getkeyword(ord));
|
|
||||||
CuAssertTrue(tc, ord->_noerror);
|
|
||||||
CuAssertTrue(tc, ord->_persistent);
|
|
||||||
free_order(ord);
|
free_order(ord);
|
||||||
|
|
||||||
ord = parse_order("!@MOVE NORTH", lang);
|
ord = parse_order("!@MOVE NORTH", lang);
|
||||||
CuAssertPtrNotNull(tc, ord);
|
CuAssertPtrNotNull(tc, ord);
|
||||||
CuAssertPtrNotNull(tc, ord->data);
|
CuAssertPtrNotNull(tc, ord->data);
|
||||||
CuAssertIntEquals(tc, K_MOVE, getkeyword(ord));
|
CuAssertIntEquals(tc, K_MOVE, getkeyword(ord));
|
||||||
CuAssertTrue(tc, ord->_noerror);
|
CuAssertIntEquals(tc, K_MOVE | CMD_PERSIST | CMD_QUIET, ord->command);
|
||||||
CuAssertTrue(tc, ord->_persistent);
|
free_order(ord);
|
||||||
|
|
||||||
|
ord = parse_order("@!MOVE NORTH", lang);
|
||||||
|
CuAssertPtrNotNull(tc, ord);
|
||||||
|
CuAssertPtrNotNull(tc, ord->data);
|
||||||
|
CuAssertIntEquals(tc, K_MOVE, getkeyword(ord));
|
||||||
|
CuAssertIntEquals(tc, K_MOVE | CMD_PERSIST | CMD_QUIET, ord->command);
|
||||||
free_order(ord);
|
free_order(ord);
|
||||||
|
|
||||||
ord = parse_order(" !@MOVE NORTH", lang);
|
ord = parse_order(" !@MOVE NORTH", lang);
|
||||||
CuAssertPtrNotNull(tc, ord);
|
CuAssertPtrNotNull(tc, ord);
|
||||||
CuAssertPtrNotNull(tc, ord->data);
|
CuAssertPtrNotNull(tc, ord->data);
|
||||||
CuAssertIntEquals(tc, K_MOVE, getkeyword(ord));
|
CuAssertIntEquals(tc, K_MOVE, getkeyword(ord));
|
||||||
CuAssertTrue(tc, ord->_noerror);
|
CuAssertIntEquals(tc, K_MOVE | CMD_PERSIST | CMD_QUIET, ord->command);
|
||||||
CuAssertTrue(tc, ord->_persistent);
|
|
||||||
free_order(ord);
|
free_order(ord);
|
||||||
|
|
||||||
test_cleanup();
|
test_cleanup();
|
||||||
|
@ -220,11 +214,11 @@ static void test_get_command(CuTest *tc) {
|
||||||
lang = test_create_locale();
|
lang = test_create_locale();
|
||||||
ord = create_order(K_MAKE, lang, "iron");
|
ord = create_order(K_MAKE, lang, "iron");
|
||||||
CuAssertStrEquals(tc, "make iron", get_command(ord, buf, sizeof(buf)));
|
CuAssertStrEquals(tc, "make iron", get_command(ord, buf, sizeof(buf)));
|
||||||
ord->_noerror = true;
|
ord->command |= CMD_QUIET;
|
||||||
CuAssertStrEquals(tc, "!make iron", get_command(ord, buf, sizeof(buf)));
|
CuAssertStrEquals(tc, "!make iron", get_command(ord, buf, sizeof(buf)));
|
||||||
ord->_persistent = true;
|
ord->command |= CMD_PERSIST;
|
||||||
CuAssertStrEquals(tc, "!@make iron", get_command(ord, buf, sizeof(buf)));
|
CuAssertStrEquals(tc, "!@make iron", get_command(ord, buf, sizeof(buf)));
|
||||||
ord->_noerror = false;
|
ord->command = K_MAKE | CMD_PERSIST;
|
||||||
CuAssertStrEquals(tc, "@make iron", get_command(ord, buf, sizeof(buf)));
|
CuAssertStrEquals(tc, "@make iron", get_command(ord, buf, sizeof(buf)));
|
||||||
free_order(ord);
|
free_order(ord);
|
||||||
test_cleanup();
|
test_cleanup();
|
||||||
|
|
|
@ -463,24 +463,21 @@ static void test_read_order(CuTest *tc) {
|
||||||
|
|
||||||
ord = read_order("MOVE NORTH", lang);
|
ord = read_order("MOVE NORTH", lang);
|
||||||
CuAssertPtrNotNull(tc, ord);
|
CuAssertPtrNotNull(tc, ord);
|
||||||
CuAssertTrue(tc, !ord->_noerror);
|
CuAssertIntEquals(tc, K_MOVE, ord->command);
|
||||||
CuAssertTrue(tc, !ord->_persistent);
|
|
||||||
CuAssertIntEquals(tc, K_MOVE, getkeyword(ord));
|
CuAssertIntEquals(tc, K_MOVE, getkeyword(ord));
|
||||||
CuAssertStrEquals(tc, "move NORTH", get_command(ord, cmd, sizeof(cmd)));
|
CuAssertStrEquals(tc, "move NORTH", get_command(ord, cmd, sizeof(cmd)));
|
||||||
free_order(ord);
|
free_order(ord);
|
||||||
|
|
||||||
ord = read_order("MAKE TEMP foo", lang);
|
ord = read_order("MAKE TEMP foo", lang);
|
||||||
CuAssertPtrNotNull(tc, ord);
|
CuAssertPtrNotNull(tc, ord);
|
||||||
CuAssertTrue(tc, !ord->_noerror);
|
CuAssertIntEquals(tc, K_MAKETEMP, ord->command);
|
||||||
CuAssertTrue(tc, !ord->_persistent);
|
|
||||||
CuAssertIntEquals(tc, K_MAKETEMP, getkeyword(ord));
|
CuAssertIntEquals(tc, K_MAKETEMP, getkeyword(ord));
|
||||||
CuAssertStrEquals(tc, "maketemp foo", get_command(ord, cmd, sizeof(cmd)));
|
CuAssertStrEquals(tc, "maketemp foo", get_command(ord, cmd, sizeof(cmd)));
|
||||||
free_order(ord);
|
free_order(ord);
|
||||||
|
|
||||||
ord = read_order("MAKETEMP foo", lang);
|
ord = read_order("MAKETEMP foo", lang);
|
||||||
CuAssertPtrNotNull(tc, ord);
|
CuAssertPtrNotNull(tc, ord);
|
||||||
CuAssertTrue(tc, !ord->_noerror);
|
CuAssertIntEquals(tc, K_MAKETEMP, ord->command);
|
||||||
CuAssertTrue(tc, !ord->_persistent);
|
|
||||||
CuAssertIntEquals(tc, K_MAKETEMP, getkeyword(ord));
|
CuAssertIntEquals(tc, K_MAKETEMP, getkeyword(ord));
|
||||||
CuAssertStrEquals(tc, "maketemp foo", get_command(ord, cmd, sizeof(cmd)));
|
CuAssertStrEquals(tc, "maketemp foo", get_command(ord, cmd, sizeof(cmd)));
|
||||||
free_order(ord);
|
free_order(ord);
|
||||||
|
|
Loading…
Reference in a new issue