forked from github/server
also apply noerror rules to msg_feedback.
This commit is contained in:
parent
b44c5e54bf
commit
868f4e6cef
2 changed files with 41 additions and 37 deletions
|
@ -78,14 +78,15 @@ variant v)
|
||||||
struct message *msg_feedback(const struct unit *u, struct order *ord,
|
struct message *msg_feedback(const struct unit *u, struct order *ord,
|
||||||
const char *name, const char *sig, ...)
|
const char *name, const char *sig, ...)
|
||||||
{
|
{
|
||||||
va_list marker;
|
|
||||||
const message_type *mtype = mt_find(name);
|
const message_type *mtype = mt_find(name);
|
||||||
char paramname[64];
|
|
||||||
const char *ic = sig;
|
|
||||||
variant args[16];
|
variant args[16];
|
||||||
variant var;
|
variant var;
|
||||||
memset(args, 0, sizeof(args));
|
memset(args, 0, sizeof(args));
|
||||||
|
|
||||||
|
if (ord && ord->_noerror) {
|
||||||
|
return NULL;
|
||||||
|
}
|
||||||
|
|
||||||
if (!mtype) {
|
if (!mtype) {
|
||||||
log_warning("trying to create message of unknown type \"%s\"\n", name);
|
log_warning("trying to create message of unknown type \"%s\"\n", name);
|
||||||
if (!mt_find("missing_feedback")) {
|
if (!mt_find("missing_feedback")) {
|
||||||
|
@ -103,10 +104,15 @@ struct message *msg_feedback(const struct unit *u, struct order *ord,
|
||||||
var.v = (void *)ord;
|
var.v = (void *)ord;
|
||||||
arg_set(args, mtype, "command", var);
|
arg_set(args, mtype, "command", var);
|
||||||
|
|
||||||
|
if (sig) {
|
||||||
|
const char *ic = sig;
|
||||||
|
va_list marker;
|
||||||
|
|
||||||
va_start(marker, sig);
|
va_start(marker, sig);
|
||||||
while (*ic && !isalnum(*ic))
|
while (*ic && !isalnum(*ic))
|
||||||
ic++;
|
ic++;
|
||||||
while (*ic) {
|
while (*ic) {
|
||||||
|
char paramname[64];
|
||||||
char *oc = paramname;
|
char *oc = paramname;
|
||||||
int i;
|
int i;
|
||||||
|
|
||||||
|
@ -137,7 +143,7 @@ struct message *msg_feedback(const struct unit *u, struct order *ord,
|
||||||
ic++;
|
ic++;
|
||||||
}
|
}
|
||||||
va_end(marker);
|
va_end(marker);
|
||||||
|
}
|
||||||
return msg_create(mtype, args);
|
return msg_create(mtype, args);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -245,9 +251,6 @@ void addmessage(region * r, faction * f, const char *s, msg_t mtype, int level)
|
||||||
message * msg_error(const unit * u, struct order *ord, int mno) {
|
message * msg_error(const unit * u, struct order *ord, int mno) {
|
||||||
static char msgname[20];
|
static char msgname[20];
|
||||||
|
|
||||||
if (ord && ord->_noerror) {
|
|
||||||
return NULL;
|
|
||||||
}
|
|
||||||
if (fval(u->faction, FFL_NPC)) {
|
if (fval(u->faction, FFL_NPC)) {
|
||||||
return NULL;
|
return NULL;
|
||||||
}
|
}
|
||||||
|
|
|
@ -82,6 +82,7 @@ static void test_noerror(CuTest *tc) {
|
||||||
CuAssertTrue(tc, u->thisorder->_persistent);
|
CuAssertTrue(tc, u->thisorder->_persistent);
|
||||||
CuAssertTrue(tc, u->thisorder->_noerror);
|
CuAssertTrue(tc, u->thisorder->_noerror);
|
||||||
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));
|
||||||
test_cleanup();
|
test_cleanup();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
Loading…
Reference in a new issue