gri3-wm/i3bar/include/outputs.h

79 lines
1.9 KiB
C
Raw Permalink Normal View History

2010-08-07 18:05:16 +02:00
/*
* vim:ts=4:sw=4:expandtab
2010-08-07 18:05:16 +02:00
*
* i3bar - an xcb-based status- and ws-bar for i3
* © 2010 Axel Wagner and contributors (see also: LICENSE)
2010-08-07 18:05:16 +02:00
*
2015-03-23 20:56:49 +01:00
* outputs.c: Maintaining the outputs list
2010-08-07 18:05:16 +02:00
*
*/
#pragma once
2010-07-22 01:15:18 +02:00
#include <config.h>
2010-07-22 01:15:18 +02:00
#include <xcb/xcb.h>
#include <cairo/cairo-xcb.h>
2010-07-22 01:15:18 +02:00
2010-07-30 03:11:54 +02:00
#include "common.h"
typedef struct i3_output i3_output;
2010-07-22 01:15:18 +02:00
2010-07-30 03:11:54 +02:00
SLIST_HEAD(outputs_head, i3_output);
extern struct outputs_head* outputs;
2010-07-22 01:15:18 +02:00
2010-08-07 02:10:05 +02:00
/*
2015-03-23 20:56:49 +01:00
* Start parsing the received JSON string
2010-08-07 02:10:05 +02:00
*
*/
2011-08-12 18:43:09 +02:00
void parse_outputs_json(char* json);
2010-08-07 02:10:05 +02:00
/*
2015-03-23 20:56:49 +01:00
* Initiate the outputs list
2010-08-07 02:10:05 +02:00
*
*/
void init_outputs(void);
2010-08-07 02:10:05 +02:00
2017-09-26 13:50:26 +02:00
/*
* free() all outputs data structures.
*
*/
void free_outputs(void);
2010-08-07 02:10:05 +02:00
/*
* Returns the output with the given name
*
*/
2011-08-12 18:43:09 +02:00
i3_output* get_output_by_name(char* name);
2010-07-22 01:15:18 +02:00
/*
* Returns true if the output has the currently focused workspace
*
*/
bool output_has_focus(i3_output* output);
2010-07-30 03:11:54 +02:00
struct i3_output {
char* name; /* Name of the output */
bool active; /* If the output is active */
bool primary; /* If it is the primary output */
bool visible; /* If the bar is visible on this output */
int ws; /* The number of the currently visible ws */
2015-03-23 20:56:49 +01:00
rect rect; /* The rect (relative to the root window) */
/* Off-screen buffer for preliminary rendering of the bar. */
surface_t buffer;
/* Off-screen buffer for pre-rendering the statusline, separated to make clipping easier. */
surface_t statusline_buffer;
/* How much of statusline_buffer's horizontal space was used on last statusline render. */
int statusline_width;
/* Whether statusline block short texts where used on last statusline render. */
bool statusline_short_text;
/* The actual window on which we draw. */
surface_t bar;
struct ws_head* workspaces; /* The workspaces on this output */
struct tc_head* trayclients; /* The tray clients on this output */
2010-07-30 03:11:54 +02:00
SLIST_ENTRY(i3_output)
slist; /* Pointer for the SLIST-Macro */
2010-07-22 01:15:18 +02:00
};