2 * vim:ts=4:sw=4:expandtab
4 * i3bar - an xcb-based status- and ws-bar for i3
5 * © 2010 Axel Wagner and contributors (see also: LICENSE)
7 * outputs.c: Maintaining the outputs list
15 #include <cairo/cairo-xcb.h>
19 typedef struct i3_output i3_output;
21 SLIST_HEAD(outputs_head, i3_output);
22 struct outputs_head* outputs;
25 * Start parsing the received JSON string
28 void parse_outputs_json(char* json);
31 * Initiate the outputs list
34 void init_outputs(void);
37 * free() all outputs data structures.
40 void free_outputs(void);
43 * Returns the output with the given name
46 i3_output* get_output_by_name(char* name);
49 * Returns true if the output has the currently focused workspace
52 bool output_has_focus(i3_output* output);
55 char* name; /* Name of the output */
56 bool active; /* If the output is active */
57 bool primary; /* If it is the primary output */
58 bool visible; /* If the bar is visible on this output */
59 int ws; /* The number of the currently visible ws */
60 rect rect; /* The rect (relative to the root window) */
62 /* Off-screen buffer for preliminary rendering of the bar. */
64 /* Off-screen buffer for pre-rendering the statusline, separated to make clipping easier. */
65 surface_t statusline_buffer;
66 /* How much of statusline_buffer's horizontal space was used on last statusline render. */
68 /* Whether statusline block short texts where used on last statusline render. */
69 bool statusline_short_text;
70 /* The actual window on which we draw. */
73 struct ws_head* workspaces; /* The workspaces on this output */
74 struct tc_head* trayclients; /* The tray clients on this output */
76 SLIST_ENTRY(i3_output)
77 slist; /* Pointer for the SLIST-Macro */