gint height;
RrPixel32 *data;
};
-
+
/*! Possible window types */
typedef enum
{
window placement. In theory, where this window exists.
*/
StrutPartial strut;
-
+
/*! The logical size of the window
The "logical" size of the window is refers to the user's perception of
the size of the window, and is the value that should be displayed to the
A value of 0 means this is ignored.
*/
gfloat max_ratio;
-
+
/*! The minimum size of the client window
If the min is > the max, then the window is not resizable
*/
/*! The client's specified colormap */
Colormap colormap;
-
+
/*! Where to place the decorated window in relation to the undecorated
window */
gint gravity;
/*! True if the client supports the delete_window protocol */
gboolean delete_window;
-
+
/*! Was the window's position requested by the application or the user?
if by the application, we force it completely onscreen, if by the user
we only force it if it tries to go completely offscreen, if neither, we
/*! Was the window's size requested by the application or the user?
If by the application we don't let it go outside the available area */
guint sized;
-
+
/*! Can the window receive input focus? */
gboolean can_focus;
/*! Notify the window when it receives focus? */
/*! Where the window should iconify to/from */
Rect icon_geometry;
-
- /*! The time when the client last received user interaction */
- guint32 user_time;
- /*! A separate window for the client to update it's user_time on */
- Window user_time_window;
};
extern GList *client_list;
-extern GHashTable *client_user_time_window_map;
void client_startup(gboolean reconfig);
void client_shutdown(gboolean reconfig);
/*! dir is either North, South, East or West. It can't be, for example,
Northwest */
+void client_find_edge_directional(ObClient *self, ObDirection dir,
+ gint my_head, gint my_tail,
+ gint my_edge_start, gint my_edge_size,
+ gint *dest, gboolean *near_edge);
void client_find_move_directional(ObClient *self, ObDirection dir,
gint *x, gint *y);
+void client_find_resize_directional(ObClient *self, ObDirection side,
+ gboolean grow,
+ gint *x, gint *y, gint *w, gint *h);
/*! Fullscreen's or unfullscreen's the client window
@param fs true if the window should be made fullscreen; false if it should
void client_update_strut(ObClient *self);
/*! Updates the window's icons */
void client_update_icons(ObClient *self);
-/*! Updates the window's user time */
-void client_update_user_time(ObClient *self);
-/*! Updates the window's user time window */
-void client_update_user_time_window(ObClient *self);
/*! Updates the window's icon geometry (where to iconify to/from) */
void client_update_icon_geometry(ObClient *self);
const ObClientIcon *client_icon(ObClient *self, gint w, gint h);
-ObClientIcon *client_thumbnail(ObClient *self, gint w, gint h);
-
/*! Return TRUE if the client is transient for some other window. Return
FALSE if it's not transient or there is no window for it to be
transient for */
gboolean client_has_group_siblings(ObClient *self);
-void clienticon_free(ObClientIcon *ci);
-
#endif