2009-02-06 11:49:45 -05:00
|
|
|
/*
|
|
|
|
* This file defines all data structures used by i3
|
|
|
|
*
|
|
|
|
*/
|
2009-02-06 20:43:28 -05:00
|
|
|
#include "queue.h"
|
2009-02-06 11:49:45 -05:00
|
|
|
|
2009-02-06 12:23:37 -05:00
|
|
|
/*
|
|
|
|
* Defines a position in the table
|
|
|
|
*
|
|
|
|
*/
|
|
|
|
typedef struct Cell {
|
|
|
|
int row;
|
|
|
|
int column;
|
|
|
|
} Cell;
|
|
|
|
|
|
|
|
/*
|
|
|
|
* We need to save the height of a font because it is required for each drawing of
|
|
|
|
* text but relatively hard to get. As soon as a new font needs to be loaded, a
|
|
|
|
* Font-entry will be filled for later use.
|
|
|
|
*
|
|
|
|
*/
|
2009-02-06 11:49:45 -05:00
|
|
|
typedef struct Font {
|
|
|
|
char *name;
|
|
|
|
int height;
|
|
|
|
} Font;
|
2009-02-06 12:23:37 -05:00
|
|
|
|
|
|
|
/*
|
|
|
|
* A client is X11-speak for a window.
|
|
|
|
*
|
|
|
|
*/
|
|
|
|
typedef struct Client {
|
|
|
|
/* TODO: this is NOT final */
|
|
|
|
Cell old_position; /* if you set a client to floating and set it back to managed,
|
|
|
|
it does remember its old position and *tries* to get back there */
|
2009-02-06 19:38:51 -05:00
|
|
|
|
|
|
|
|
|
|
|
/* XCB contexts */
|
|
|
|
xcb_gcontext_t titlegc;
|
|
|
|
xcb_window_t window;
|
2009-02-06 20:43:28 -05:00
|
|
|
xcb_window_t child;
|
|
|
|
|
|
|
|
/* The following entry provides the necessary list pointers to use Client with LIST_* macros */
|
|
|
|
LIST_ENTRY(Client) clients;
|
2009-02-06 12:23:37 -05:00
|
|
|
} Client;
|