X-Git-Url: https://git.dogcows.com/gitweb?a=blobdiff_plain;f=openbox%2Fevent.h;h=ba5a03ea15cfdee8f52fa6f66b4b3113dfd17177;hb=d78ae0546dae17eda6084a1bd33e63637ba802e5;hp=b8f567a8d9c41978636d10cf2969db1957ba6029;hpb=78a8680cd7379cc0d75af810dabe62c7a6c4a8b2;p=chaz%2Fopenbox diff --git a/openbox/event.h b/openbox/event.h index b8f567a8..ba5a03ea 100644 --- a/openbox/event.h +++ b/openbox/event.h @@ -1,28 +1,71 @@ +/* -*- indent-tabs-mode: nil; tab-width: 4; c-basic-offset: 4; -*- + + event.h for the Openbox window manager + Copyright (c) 2003-2007 Dana Jansens + + This program is free software; you can redistribute it and/or modify + it under the terms of the GNU General Public License as published by + the Free Software Foundation; either version 2 of the License, or + (at your option) any later version. + + This program is distributed in the hope that it will be useful, + but WITHOUT ANY WARRANTY; without even the implied warranty of + MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the + GNU General Public License for more details. + + See the COPYING file for a copy of the GNU General Public License. +*/ + #ifndef __events_h #define __events_h #include +#include + +struct _ObClient; + +/*! The amount of time before a window appears that is checked for user input + to determine if the user is working in another window */ +#define OB_EVENT_USER_TIME_DELAY (500) /* 0.5 seconds */ /*! Time at which the last event with a timestamp occured. */ -extern Time event_lasttime; +extern Time event_curtime; +/*! The last user-interaction time, as given by the clients */ +extern Time event_last_user_time; + +void event_startup(gboolean reconfig); +void event_shutdown(gboolean reconfig); + +/*! Make as if the mouse just entered the client, use only when using focus + follows mouse */ +void event_enter_client(struct _ObClient *client); + +/*! Make mouse focus not move at all from the stuff that happens between these + two function calls. */ +gulong event_start_ignore_all_enters(void); +void event_end_ignore_all_enters(gulong start); + +/*! End *all* active and passive grabs on the keyboard + This is called in situations where if there is a grab going on, then + we need to cancel it. If we move focus during the grab, applications + will get NotifyWhileGrabbed events and ignore them! -/*! The value of the mask for the NumLock modifier */ -extern unsigned int NumLockMask; -/*! The value of the mask for the ScrollLock modifier */ -extern unsigned int ScrollLockMask; + Actions should not rely on being able to move focus during an + interactive grab. */ +void event_cancel_all_key_grabs(void); -void event_startup(); -void event_shutdown(); +/* Halts any focus delay in progress, use this when the user is selecting a + window for focus */ +void event_halt_focus_delay(void); -typedef struct event_fd_handler { - int fd; - void *data; - void (*handler)(int fd, void *data); -} event_fd_handler; +/*! Compare t1 and t2, taking into account wraparound. True if t1 + comes at the same time or later than t2. */ +gboolean event_time_after(Time t1, Time t2); -void event_add_fd_handler(event_fd_handler *handler); -void event_remove_fd(int n); +Time event_get_server_time(void); -void event_loop(); +/*! Given a possible target client, returns what the target client really + should be for actions */ +struct _ObClient* event_target_client(struct _ObClient *client); #endif