forked from github/server
that stupid warning triggers too often for anyone to pay attention to it
This commit is contained in:
parent
802228db41
commit
7c2b1e3445
1 changed files with 46 additions and 46 deletions
|
@ -1,7 +1,7 @@
|
|||
/* vi: set ts=2:
|
||||
*
|
||||
*
|
||||
* Eressea PB(E)M host Copyright (C) 1998-2003
|
||||
*
|
||||
* Eressea PB(E)M host Copyright (C) 1998-2003
|
||||
* Christian Schlittchen (corwin@amber.kn-bremen.de)
|
||||
* Katja Zedel (katze@felidae.kn-bremen.de)
|
||||
* Henning Peters (faroul@beyond.kn-bremen.de)
|
||||
|
@ -27,81 +27,81 @@
|
|||
**/
|
||||
|
||||
typedef struct timeout_data {
|
||||
trigger * triggers;
|
||||
int timer;
|
||||
variant trigger_data;
|
||||
trigger * triggers;
|
||||
int timer;
|
||||
variant trigger_data;
|
||||
} timeout_data;
|
||||
|
||||
static void
|
||||
timeout_init(trigger * t)
|
||||
{
|
||||
t->data.v = calloc(sizeof(timeout_data), 1);
|
||||
t->data.v = calloc(sizeof(timeout_data), 1);
|
||||
}
|
||||
|
||||
static void
|
||||
timeout_free(trigger * t)
|
||||
{
|
||||
timeout_data * td = (timeout_data*)t->data.v;
|
||||
free_triggers(td->triggers);
|
||||
free(t->data.v);
|
||||
timeout_data * td = (timeout_data*)t->data.v;
|
||||
free_triggers(td->triggers);
|
||||
free(t->data.v);
|
||||
}
|
||||
|
||||
static int
|
||||
timeout_handle(trigger * t, void * data)
|
||||
{
|
||||
/* call an event handler on timeout.
|
||||
* data.v -> ( variant event, int timer )
|
||||
*/
|
||||
timeout_data * td = (timeout_data*)t->data.v;
|
||||
if (--td->timer==0) {
|
||||
handle_triggers(&td->triggers, NULL);
|
||||
return -1;
|
||||
}
|
||||
unused(data);
|
||||
return 0;
|
||||
/* call an event handler on timeout.
|
||||
* data.v -> ( variant event, int timer )
|
||||
*/
|
||||
timeout_data * td = (timeout_data*)t->data.v;
|
||||
if (--td->timer==0) {
|
||||
handle_triggers(&td->triggers, NULL);
|
||||
return -1;
|
||||
}
|
||||
unused(data);
|
||||
return 0;
|
||||
}
|
||||
|
||||
static void
|
||||
timeout_write(const trigger * t, FILE * F)
|
||||
{
|
||||
timeout_data * td = (timeout_data*)t->data.v;
|
||||
fprintf(F, "%d ", td->timer);
|
||||
write_triggers(F, td->triggers);
|
||||
timeout_data * td = (timeout_data*)t->data.v;
|
||||
fprintf(F, "%d ", td->timer);
|
||||
write_triggers(F, td->triggers);
|
||||
}
|
||||
|
||||
static int
|
||||
timeout_read(trigger * t, FILE * F)
|
||||
{
|
||||
timeout_data * td = (timeout_data*)t->data.v;
|
||||
fscanf(F, "%d", &td->timer);
|
||||
read_triggers(F, &td->triggers);
|
||||
if (td->timer>10) {
|
||||
trigger * tr = td->triggers;
|
||||
log_warning(("there is a timeout lasting for another %d turns\n", td->timer));
|
||||
while (tr) {
|
||||
log_warning((" timeout triggers: %s\n", tr->type->name));
|
||||
tr = tr->next;
|
||||
}
|
||||
}
|
||||
if (td->triggers!=NULL && td->timer>0) return AT_READ_OK;
|
||||
return AT_READ_FAIL;
|
||||
timeout_data * td = (timeout_data*)t->data.v;
|
||||
fscanf(F, "%d", &td->timer);
|
||||
read_triggers(F, &td->triggers);
|
||||
if (td->timer>20) {
|
||||
trigger * tr = td->triggers;
|
||||
log_warning(("there is a timeout lasting for another %d turns\n", td->timer));
|
||||
while (tr) {
|
||||
log_warning((" timeout triggers: %s\n", tr->type->name));
|
||||
tr = tr->next;
|
||||
}
|
||||
}
|
||||
if (td->triggers!=NULL && td->timer>0) return AT_READ_OK;
|
||||
return AT_READ_FAIL;
|
||||
}
|
||||
|
||||
trigger_type tt_timeout = {
|
||||
"timeout",
|
||||
timeout_init,
|
||||
timeout_free,
|
||||
timeout_handle,
|
||||
timeout_write,
|
||||
timeout_read
|
||||
"timeout",
|
||||
timeout_init,
|
||||
timeout_free,
|
||||
timeout_handle,
|
||||
timeout_write,
|
||||
timeout_read
|
||||
};
|
||||
|
||||
trigger *
|
||||
trigger_timeout(int time, trigger * callbacks)
|
||||
{
|
||||
trigger * t = t_new(&tt_timeout);
|
||||
timeout_data * td = (timeout_data*)t->data.v;
|
||||
td->triggers = callbacks;
|
||||
td->timer = time;
|
||||
return t;
|
||||
trigger * t = t_new(&tt_timeout);
|
||||
timeout_data * td = (timeout_data*)t->data.v;
|
||||
td->triggers = callbacks;
|
||||
td->timer = time;
|
||||
return t;
|
||||
}
|
||||
|
|
Loading…
Reference in a new issue