Use gettimeofday() and struct timevals instead of time()

Initially I thought using the second precision time() function is good enough,
but to make t/113-urgent.t considerably faster (>2s vs. 0.08s), we put in a
little more effort and use gettimeofday. Otherwise, this test blocks the whole
testsuite from completing much faster on modern machines :).
This commit is contained in:
Michael Stapelberg
2012-02-21 13:38:49 +01:00
parent 1ab3621656
commit ab9ba6fcf9
4 changed files with 19 additions and 17 deletions

View File

@ -17,6 +17,7 @@
#include <xcb/xcb_atom.h> #include <xcb/xcb_atom.h>
#include <stdbool.h> #include <stdbool.h>
#include <pcre.h> #include <pcre.h>
#include <sys/time.h>
#include "queue.h" #include "queue.h"
@ -305,7 +306,7 @@ struct Window {
bool needs_take_focus; bool needs_take_focus;
/** When this window was marked urgent. 0 means not urgent */ /** When this window was marked urgent. 0 means not urgent */
time_t urgent; struct timeval urgent;
/** Whether this window accepts focus. We store this inverted so that the /** Whether this window accepts focus. We store this inverted so that the
* default will be 'accepts focus'. */ * default will be 'accepts focus'. */

View File

@ -11,6 +11,7 @@
#include "all.h" #include "all.h"
#include <time.h> #include <time.h>
#include <sys/time.h>
#include <xcb/randr.h> #include <xcb/randr.h>
#include <X11/XKBlib.h> #include <X11/XKBlib.h>
#define SN_API_NOT_YET_FROZEN 1 #define SN_API_NOT_YET_FROZEN 1
@ -844,7 +845,8 @@ static bool handle_hints(void *data, xcb_connection_t *conn, uint8_t state, xcb_
if (!con->urgent && focused == con) { if (!con->urgent && focused == con) {
DLOG("Ignoring urgency flag for current client\n"); DLOG("Ignoring urgency flag for current client\n");
con->window->urgent = 0; con->window->urgent.tv_sec = 0;
con->window->urgent.tv_usec = 0;
goto end; goto end;
} }
@ -853,9 +855,10 @@ static bool handle_hints(void *data, xcb_connection_t *conn, uint8_t state, xcb_
//CLIENT_LOG(con); //CLIENT_LOG(con);
if (con->window) { if (con->window) {
if (con->urgent) { if (con->urgent) {
con->window->urgent = time(NULL); gettimeofday(&con->window->urgent, NULL);
} else { } else {
con->window->urgent = 0; con->window->urgent.tv_sec = 0;
con->window->urgent.tv_usec = 0;
} }
} }
LOG("Urgency flag changed to %d\n", con->urgent); LOG("Urgency flag changed to %d\n", con->urgent);

View File

@ -13,6 +13,12 @@
*/ */
#include "all.h" #include "all.h"
/* From sys/time.h, not sure if its available on all systems. */
# define _i3_timercmp(a, b, CMP) \
(((a).tv_sec == (b).tv_sec) ? \
((a).tv_usec CMP (b).tv_usec) : \
((a).tv_sec CMP (b).tv_sec))
/* /*
* Initializes the Match data structure. This function is necessary because the * Initializes the Match data structure. This function is necessary because the
* members representing boolean values (like dock) need to be initialized with * members representing boolean values (like dock) need to be initialized with
@ -125,13 +131,13 @@ bool match_matches_window(Match *match, i3Window *window) {
Con *con = NULL; Con *con = NULL;
if (match->urgent == U_LATEST) { if (match->urgent == U_LATEST) {
/* if the window isn't urgent, no sense in searching */ /* if the window isn't urgent, no sense in searching */
if (window->urgent == 0) { if (window->urgent.tv_sec == 0) {
return false; return false;
} }
/* if we find a window that is newer than this one, bail */ /* if we find a window that is newer than this one, bail */
TAILQ_FOREACH(con, &all_cons, all_cons) { TAILQ_FOREACH(con, &all_cons, all_cons) {
if ((con->window != NULL) && if ((con->window != NULL) &&
(con->window->urgent > window->urgent)) { _i3_timercmp(con->window->urgent, window->urgent, >)) {
return false; return false;
} }
} }
@ -140,14 +146,14 @@ bool match_matches_window(Match *match, i3Window *window) {
if (match->urgent == U_OLDEST) { if (match->urgent == U_OLDEST) {
/* if the window isn't urgent, no sense in searching */ /* if the window isn't urgent, no sense in searching */
if (window->urgent == 0) { if (window->urgent.tv_sec == 0) {
return false; return false;
} }
/* if we find a window that is older than this one (and not 0), bail */ /* if we find a window that is older than this one (and not 0), bail */
TAILQ_FOREACH(con, &all_cons, all_cons) { TAILQ_FOREACH(con, &all_cons, all_cons) {
if ((con->window != NULL) && if ((con->window != NULL) &&
(con->window->urgent != 0) && (con->window->urgent.tv_sec != 0) &&
(con->window->urgent < window->urgent)) { _i3_timercmp(con->window->urgent, window->urgent, <)) {
return false; return false;
} }
} }

View File

@ -95,10 +95,6 @@ is($x->input_focus, $different_window->id, 'new window focused again');
$top->add_hint('urgency'); $top->add_hint('urgency');
sync_with_i3; sync_with_i3;
# Unfortunately, we cannot get rid of this delay. We need it because i3 stores
# the time of an urgency hint with second precision.
sleep 1;
$bottom->add_hint('urgency'); $bottom->add_hint('urgency');
sync_with_i3; sync_with_i3;
@ -123,10 +119,6 @@ is($x->input_focus, $different_window->id, 'new window focused again');
$top->add_hint('urgency'); $top->add_hint('urgency');
sync_with_i3; sync_with_i3;
# Unfortunately, we cannot get rid of this delay. We need it because i3 stores
# the time of an urgency hint with second precision.
sleep 1;
$bottom->add_hint('urgency'); $bottom->add_hint('urgency');
sync_with_i3; sync_with_i3;