29 DLOG(
"Initializing criteria, current_match = %p, state = %d\n",
current_match, _state);
43 CFGFUN(criteria_add,
const char *ctype,
const char *cvalue) {
52 return (strcasecmp(str,
"1") == 0 ||
53 strcasecmp(str,
"yes") == 0 ||
54 strcasecmp(str,
"true") == 0 ||
55 strcasecmp(str,
"on") == 0 ||
56 strcasecmp(str,
"enable") == 0 ||
57 strcasecmp(str,
"active") == 0);
70 if (strstr(str,
"Mod1") != NULL)
71 result |= XCB_KEY_BUT_MASK_MOD_1;
72 if (strstr(str,
"Mod2") != NULL)
73 result |= XCB_KEY_BUT_MASK_MOD_2;
74 if (strstr(str,
"Mod3") != NULL)
75 result |= XCB_KEY_BUT_MASK_MOD_3;
76 if (strstr(str,
"Mod4") != NULL)
77 result |= XCB_KEY_BUT_MASK_MOD_4;
78 if (strstr(str,
"Mod5") != NULL)
79 result |= XCB_KEY_BUT_MASK_MOD_5;
80 if (strstr(str,
"Control") != NULL ||
81 strstr(str,
"Ctrl") != NULL)
82 result |= XCB_KEY_BUT_MASK_CONTROL;
83 if (strstr(str,
"Shift") != NULL)
84 result |= XCB_KEY_BUT_MASK_SHIFT;
86 if (strstr(str,
"Group1") != NULL)
88 if (strstr(str,
"Group2") != NULL ||
89 strstr(str,
"Mode_switch") != NULL)
91 if (strstr(str,
"Group3") != NULL)
93 if (strstr(str,
"Group4") != NULL)
109 CFGFUN(binding,
const char *bindtype,
const char *modifiers,
const char *key,
const char *release,
const char *border,
const char *whole_window,
const char *exclude_titlebar,
const char *command) {
120 CFGFUN(mode_binding,
const char *bindtype,
const char *modifiers,
const char *key,
const char *release,
const char *border,
const char *whole_window,
const char *exclude_titlebar,
const char *command) {
132 if (strcmp(mode->
name, modename) == 0) {
133 ELOG(
"The binding mode with name \"%s\" is defined at least twice.\n", modename);
137 DLOG(
"\t now in mode %s\n", modename);
143 CFGFUN(exec,
const char *exectype,
const char *no_startup_id,
const char *command) {
147 if (strcmp(exectype,
"exec") == 0) {
156 ELOG(
"Match is empty, ignoring this for_window statement\n");
159 DLOG(
"\t should execute command %s for the criteria mentioned above\n",
command);
161 assignment->
type = A_COMMAND;
177 CFGFUN(floating_modifier,
const char *modifiers) {
181 CFGFUN(default_orientation,
const char *orientation) {
182 if (strcmp(orientation,
"horizontal") == 0)
184 else if (strcmp(orientation,
"vertical") == 0)
190 CFGFUN(workspace_layout,
const char *layout) {
191 if (strcmp(layout,
"default") == 0)
193 else if (strcmp(layout,
"stacking") == 0 ||
194 strcmp(layout,
"stacked") == 0)
200 CFGFUN(default_border,
const char *windowtype,
const char *border,
const long width) {
204 if (strcmp(border,
"1pixel") == 0) {
207 }
else if (strcmp(border,
"none") == 0) {
210 }
else if (strcmp(border,
"pixel") == 0) {
212 border_width =
width;
215 border_width =
width;
218 if ((strcmp(windowtype,
"default_border") == 0) ||
219 (strcmp(windowtype,
"new_window") == 0)) {
220 DLOG(
"default tiled border style = %d and border width = %d (%d physical px)\n",
221 border_style, border_width,
logical_px(border_width));
225 DLOG(
"default floating border style = %d and border width = %d (%d physical px)\n",
226 border_style, border_width,
logical_px(border_width));
232 CFGFUN(hide_edge_borders,
const char *borders) {
233 if (strcmp(borders,
"smart") == 0)
235 else if (strcmp(borders,
"vertical") == 0)
237 else if (strcmp(borders,
"horizontal") == 0)
239 else if (strcmp(borders,
"both") == 0)
241 else if (strcmp(borders,
"none") == 0)
249 CFGFUN(focus_follows_mouse,
const char *value) {
253 CFGFUN(mouse_warping,
const char *value) {
254 if (strcmp(value,
"none") == 0)
256 else if (strcmp(value,
"output") == 0)
264 CFGFUN(disable_randr15,
const char *value) {
268 CFGFUN(focus_wrapping,
const char *value) {
269 if (strcmp(value,
"force") == 0) {
278 CFGFUN(force_focus_wrapping,
const char *value) {
300 CFGFUN(force_display_urgency_hint,
const long duration_ms) {
304 CFGFUN(focus_on_window_activation,
const char *mode) {
305 if (strcmp(mode,
"smart") == 0)
307 else if (strcmp(mode,
"urgent") == 0)
309 else if (strcmp(mode,
"focus") == 0)
311 else if (strcmp(mode,
"none") == 0)
314 ELOG(
"Unknown focus_on_window_activation mode \"%s\", ignoring it.\n", mode);
321 CFGFUN(title_align,
const char *alignment) {
322 if (strcmp(alignment,
"left") == 0) {
324 }
else if (strcmp(alignment,
"center") == 0) {
326 }
else if (strcmp(alignment,
"right") == 0) {
339 CFGFUN(workspace,
const char *workspace,
const char *output) {
350 if (strcasecmp(assignment->
name, workspace) == 0) {
351 ELOG(
"You have a duplicate workspace assignment for workspace \"%s\"\n",
360 DLOG(
"Both workspace and current_workspace are NULL, assuming we had an error before\n");
366 DLOG(
"Assigning workspace \"%s\" to output \"%s\"\n", workspace,
output);
379 CFGFUN(restart_state,
const char *path) {
384 CFGFUN(popup_during_fullscreen,
const char *value) {
385 if (strcmp(value,
"ignore") == 0) {
387 }
else if (strcmp(value,
"leave_fullscreen") == 0) {
394 CFGFUN(color_single,
const char *colorclass,
const char *color) {
399 CFGFUN(color,
const char *colorclass,
const char *border,
const char *background,
const char *text,
const char *indicator,
const char *child_border) {
400 #define APPLY_COLORS(classname) \ 402 if (strcmp(colorclass, "client." #classname) == 0) { \ 403 config.client.classname.border = draw_util_hex_to_color(border); \ 404 config.client.classname.background = draw_util_hex_to_color(background); \ 405 config.client.classname.text = draw_util_hex_to_color(text); \ 406 if (indicator != NULL) { \ 407 config.client.classname.indicator = draw_util_hex_to_color(indicator); \ 409 if (child_border != NULL) { \ 410 config.client.classname.child_border = draw_util_hex_to_color(child_border); \ 412 config.client.classname.child_border = config.client.classname.background; \ 428 ELOG(
"Match is empty, ignoring this assignment\n");
433 ELOG(
"Assignments using window mode (floating/tiling) is not supported\n");
437 DLOG(
"New assignment, using above criteria, to output \"%s\".\n",
output);
440 assignment->
type = A_TO_OUTPUT;
445 CFGFUN(assign,
const char *workspace,
bool is_number) {
447 ELOG(
"Match is empty, ignoring this assignment\n");
452 ELOG(
"Assignments using window mode (floating/tiling) is not supported\n");
457 ELOG(
"Could not parse initial part of \"%s\" as a number.\n", workspace);
461 DLOG(
"New assignment, using above criteria, to workspace \"%s\".\n", workspace);
464 assignment->
type = is_number ? A_TO_WORKSPACE_NUMBER : A_TO_WORKSPACE;
471 ELOG(
"Match is empty, ignoring this assignment\n");
475 DLOG(
"New assignment, using above criteria, to ignore focus on manage.\n");
478 assignment->
type = A_NO_FOCUS;
482 CFGFUN(ipc_kill_timeout,
const long timeout_ms) {
497 CFGFUN(bar_separator_symbol,
const char *separator) {
503 current_bar->
mode = (strcmp(mode,
"dock") == 0 ? M_DOCK : (strcmp(mode,
"hide") == 0 ? M_HIDE : M_INVISIBLE));
506 CFGFUN(bar_hidden_state,
const char *hidden_state) {
525 CFGFUN(bar_modifier,
const char *modifiers) {
530 if (strncasecmp(button,
"button", strlen(
"button")) != 0) {
531 ELOG(
"Bindings for a bar can only be mouse bindings, not \"%s\", ignoring.\n", button);
535 int input_code = atoi(button + strlen(
"button"));
536 if (input_code < 1) {
537 ELOG(
"Button \"%s\" does not seem to be in format 'buttonX'.\n", button);
540 const bool release_bool = release != NULL;
545 ELOG(
"command for button %s was already specified, ignoring.\n", button);
551 new_binding->
release = release_bool;
558 ELOG(
"'wheel_up_cmd' is deprecated. Please us 'bindsym button4 %s' instead.\n",
command);
563 ELOG(
"'wheel_down_cmd' is deprecated. Please us 'bindsym button5 %s' instead.\n",
command);
571 CFGFUN(bar_position,
const char *position) {
575 CFGFUN(bar_i3bar_command,
const char *i3bar_command) {
580 CFGFUN(bar_color,
const char *colorclass,
const char *border,
const char *background,
const char *text) {
581 #define APPLY_COLORS(classname) \ 583 if (strcmp(colorclass, #classname) == 0) { \ 584 if (text != NULL) { \ 586 current_bar->colors.classname##_border = sstrdup(border); \ 587 current_bar->colors.classname##_bg = sstrdup(background); \ 588 current_bar->colors.classname##_text = sstrdup(text); \ 591 current_bar->colors.classname##_bg = sstrdup(background); \ 592 current_bar->colors.classname##_text = sstrdup(border); \ 606 CFGFUN(bar_socket_path,
const char *socket_path) {
611 CFGFUN(bar_tray_output,
const char *output) {
617 CFGFUN(bar_tray_padding,
const long padding_px) {
621 CFGFUN(bar_color_single,
const char *colorclass,
const char *color) {
622 if (strcmp(colorclass,
"background") == 0)
624 else if (strcmp(colorclass,
"separator") == 0)
626 else if (strcmp(colorclass,
"statusline") == 0)
628 else if (strcmp(colorclass,
"focused_background") == 0)
630 else if (strcmp(colorclass,
"focused_separator") == 0)
636 CFGFUN(bar_status_command,
const char *command) {
641 CFGFUN(bar_binding_mode_indicator,
const char *value) {
645 CFGFUN(bar_workspace_buttons,
const char *value) {
649 CFGFUN(bar_strip_workspace_numbers,
const char *value) {
653 CFGFUN(bar_strip_workspace_name,
const char *value) {
666 DLOG(
"\t new bar configuration finished, saving.\n");
struct Barconfig::bar_colors colors
static bool eval_boolstr(const char *str)
char * i3bar_command
Command that should be run to execute i3bar, give a full path if i3bar is not in your $PATH...
char * separator_symbol
A custom separator to use instead of a vertical line.
struct Config::config_client client
Match match
the criteria to check if a window matches
struct outputs_head outputs
Defines a mouse command to be executed instead of the default behavior when clicking on the non-statu...
#define SLIST_FOREACH(var, head, field)
void * srealloc(void *ptr, size_t size)
Safe-wrapper around realloc which exits if realloc returns NULL (meaning that there is no more memory...
int logical_px(const int logical)
Convert a logical amount of pixels (e.g.
bool strip_workspace_name
Strip workspace name? Configuration option is 'strip_workspace_name yes'.
int input_code
The button to be used (e.g., 1 for "button1").
char ** outputs
Outputs on which this bar should show up on.
struct barconfig_head barconfigs
char * id
Automatically generated ID for this bar config.
bool hide_binding_mode_indicator
Hide mode button? Configuration option is 'binding_mode_indicator no' but we invert the bool for the ...
bool workspace_auto_back_and_forth
Automatic workspace back and forth switching.
bool hide_workspace_buttons
Hide workspace buttons? Configuration option is 'workspace_buttons no' but we invert the bool to get ...
void * smalloc(size_t size)
Safe-wrapper around malloc which exits if malloc returns NULL (meaning that there is no more memory a...
bool release
If true, the command will be executed after the button is released.
void * scalloc(size_t num, size_t size)
Safe-wrapper around calloc which exits if malloc returns NULL (meaning that there is no more memory a...
char * restart_state_path
void match_free(Match *match)
Frees the given match.
uint32_t modifier
Bar modifier (to show bar when in hide mode).
bool strip_workspace_numbers
Strip workspace numbers? Configuration option is 'strip_workspace_numbers yes'.
uint32_t floating_modifier
The modifier which needs to be pressed in combination with your mouse buttons to do things with float...
const char * DEFAULT_BINDING_MODE
The name of the default mode.
static void bar_configure_binding(const char *button, const char *release, const char *command)
#define APPLY_COLORS(classname)
struct bindings_head * bindings
struct autostarts_always_head autostarts_always
char * status_command
Command that should be run to get a statusline, for example 'i3status'.
int num_outputs
Number of outputs in the outputs array.
struct assignments_head assignments
float workspace_urgency_timer
By default, urgency is cleared immediately when switching to another workspace leads to focusing the ...
char * fake_outputs
Overwrites output detection (for testing), see src/fake_outputs.c.
CFGFUN(criteria_init, int _state)
void match_parse_property(Match *match, const char *ctype, const char *cvalue)
Interprets a ctype=cvalue pair and adds it to the given match specification.
enum Barconfig::@10 hidden_state
enum Barconfig::@11 position
Bar position (bottom by default).
bool disable_focus_follows_mouse
By default, focus follows mouse.
union Assignment::@19 dest
destination workspace/command/output, depending on the type
static int criteria_next_state
bool force_xinerama
By default, use the RandR API for multi-monitor setups.
focus_wrapping_t focus_wrapping
When focus wrapping is enabled (the default), attempting to move focus past the edge of the screen (i...
int sasprintf(char **strp, const char *fmt,...)
Safe-wrapper around asprintf which exits if it returns -1 (meaning that there is no more memory avail...
int32_t floating_maximum_width
Maximum and minimum dimensions of a floating window.
int32_t floating_minimum_width
long ws_name_to_number(const char *name)
Parses the workspace name as a number.
bool match_is_empty(Match *match)
Check if a match is empty.
int default_floating_border_width
Holds a command specified by either an:
bool disable_randr15
Don’t use RandR 1.5 for querying outputs.
static char * font_pattern
void workspace_back_and_forth(void)
Focuses the previously focused workspace.
Stores which workspace (by name or number) goes to which output.
char * sstrdup(const char *str)
Safe-wrapper around strdup which exits if malloc returns NULL (meaning that there is no more memory a...
enum Config::@8 popup_during_fullscreen
What should happen when a new popup is opened during fullscreen mode.
static char * current_mode
enum Assignment::@18 type
type of this assignment:
char * font
Font specification for all text rendered on the bar.
char * command
The command which is to be executed for this button.
border_style_t default_floating_border
The default border style for new floating windows.
An Assignment makes specific windows go to a specific workspace/output or run a command for that wind...
void ipc_set_kill_timeout(ev_tstamp new)
Set the maximum duration that we allow for a connection with an unwriteable socket.
char * focused_statusline
static bool current_mode_pango_markup
bool verbose
Enable verbose mode? Useful for debugging purposes.
int32_t floating_minimum_height
color_t draw_util_hex_to_color(const char *color)
Parses the given color in hex format to an internal color representation.
struct autostarts_head autostarts
int32_t floating_maximum_height
i3_event_state_mask_t event_state_from_str(const char *str)
A utility function to convert a string containing the group and modifiers to the corresponding bit ma...
The configuration file can contain multiple sets of bindings.
enum Match::@16 window_mode
bool show_marks
Specifies whether or not marks should be displayed in the window decoration.
i3Font load_font(const char *pattern, const bool fallback)
Loads a font for usage, also getting its height.
int default_orientation
Default orientation for new containers.
enum Barconfig::@9 mode
Bar display mode (hide unless modifier is pressed or show in dock mode or always hide in invisible mo...
warping_t mouse_warping
By default, when switching focus to a window on a different output (e.g.
static Match current_match
border_style_t default_border
The default border style for new windows.
struct ws_assignments_head ws_assignments
uint32_t i3_event_state_mask_t
The lower 16 bits contain a xcb_key_but_mask_t, the higher 16 bits contain an i3_xkb_group_mask_t.
hide_edge_borders_mode_t hide_edge_borders
Remove borders if they are adjacent to the screen edge.
void match_copy(Match *dest, Match *src)
Copies the data of a match from src to dest.
bool no_startup_id
no_startup_id flag for start_application().
char * focused_background
void match_init(Match *match)
Initializes the Match data structure.
char * command
Command, like in command mode.
enum Config::@6 focus_on_window_activation
Behavior when a window sends a NET_ACTIVE_WINDOW message.
void set_font(i3Font *font)
Defines the font to be used for the forthcoming calls.
Binding * configure_binding(const char *bindtype, const char *modifiers, const char *input_code, const char *release, const char *border, const char *whole_window, const char *exclude_titlebar, const char *command, const char *modename, bool pango_markup)
Adds a binding from config parameters given as strings and returns a pointer to the binding structure...
Holds the status bar configuration (i3bar).
enum Config::@7 title_align
Title alignment options.
#define TAILQ_INSERT_TAIL(head, elm, field)
static char * current_workspace
#define TAILQ_FOREACH(var, head, field)
static Barconfig * current_bar
char * socket_path
Path to the i3 IPC socket.