X-Git-Url: https://git.realraum.at/?a=blobdiff_plain;f=door_daemon%2Fcommand_queue.c;h=8e6ca2c7246b7ad35701e8ad7b5bebe2c0a947db;hb=2ae179f8740bf2183dc9141c67b141473188b46b;hp=638c08b6913c4a356d5dfc76c9ab6f29fc13b243;hpb=8fe111b5262925abdaf1614627ecfd128e112b11;p=svn42.git diff --git a/door_daemon/command_queue.c b/door_daemon/command_queue.c index 638c08b..8e6ca2c 100644 --- a/door_daemon/command_queue.c +++ b/door_daemon/command_queue.c @@ -57,6 +57,8 @@ int cmd_push(cmd_t** first, int fd, cmd_id_t cmd, const char* param) else new_cmd->param = NULL; new_cmd->sent = 0; + new_cmd->tv_start.tv_sec = 0; + new_cmd->tv_start.tv_usec = 0; new_cmd->next = NULL; if(!(*first)) { @@ -69,6 +71,25 @@ int cmd_push(cmd_t** first, int fd, cmd_id_t cmd, const char* param) return 0; } +void cmd_sent(cmd_t* cmd) +{ + if(!cmd) + return; + + cmd->sent = 1; + gettimeofday(&cmd->tv_start, NULL); +} + +int cmd_has_expired(cmd_t cmd) +{ + struct timeval now; + timerclear(&now); + gettimeofday(&now, NULL); + cmd.tv_start.tv_sec++; + + return timercmp(&cmd.tv_start, &now, <); +} + void cmd_pop(cmd_t** first) { if(!first || !(*first))