ALIGN_RIGHT
} blockalign_t;
+/* This data structure describes the way a status block should be rendered. These
+ * variables are updated each time the statusline is re-rendered. */
+struct status_block_render_desc {
+ uint32_t width;
+ uint32_t x_offset;
+ uint32_t x_append;
+};
+
/* This data structure represents one JSON dictionary, multiple of these make
* up one status line. */
struct status_block {
i3String *short_text;
char *color;
+ char *background;
+ char *border;
/* min_width can be specified either as a numeric value (in pixels) or as a
* string. For strings, we set min_width to the measured text width of
/* The amount of pixels necessary to render a separater after the block. */
uint32_t sep_block_width;
- /* The amount of pixels necessary to render this block. These variables are
- * only temporarily used in refresh_statusline(). */
- uint32_t width;
- uint32_t x_offset;
- uint32_t x_append;
+ /* Continuously-updated information on how to render this status block. */
+ struct status_block_render_desc full_render;
+ struct status_block_render_desc short_render;
/* Optional */
char *name;
#include "config.h"
#include "libi3.h"
#include "parse_json_header.h"
-#include "cairo_util.h"
+#include "draw_util.h"