2014-01-27 22:45:01 -05:00
|
|
|
/*
|
|
|
|
* vim:ts=4:sw=4:expandtab
|
|
|
|
*
|
|
|
|
* i3 - an improved dynamic tiling window manager
|
|
|
|
* © 2009-2014 Michael Stapelberg and contributors (see also: LICENSE)
|
|
|
|
*
|
|
|
|
* bindings.h: Functions for configuring, finding, and running bindings.
|
|
|
|
*
|
|
|
|
*/
|
|
|
|
#pragma once
|
|
|
|
|
2014-05-31 11:00:02 -04:00
|
|
|
extern pid_t command_error_nagbar_pid;
|
|
|
|
|
2014-01-27 22:45:01 -05:00
|
|
|
/**
|
|
|
|
* The name of the default mode.
|
|
|
|
*
|
|
|
|
*/
|
|
|
|
const char *DEFAULT_BINDING_MODE;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Adds a binding from config parameters given as strings and returns a
|
|
|
|
* pointer to the binding structure. Returns NULL if the input code could not
|
|
|
|
* be parsed.
|
|
|
|
*
|
|
|
|
*/
|
|
|
|
Binding *configure_binding(const char *bindtype, const char *modifiers, const char *input_code,
|
2014-06-19 11:20:32 +02:00
|
|
|
const char *release, const char *command, const char *mode);
|
2014-02-14 18:38:01 -05:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Grab the bound keys (tell X to send us keypress events for those keycodes)
|
|
|
|
*
|
|
|
|
*/
|
|
|
|
void grab_all_keys(xcb_connection_t *conn, bool bind_mode_switch);
|
2014-02-21 19:10:21 -05:00
|
|
|
|
|
|
|
/**
|
2014-05-02 10:22:40 -04:00
|
|
|
* Returns a pointer to the Binding that matches the given xcb event or NULL if
|
|
|
|
* no such binding exists.
|
2014-02-21 19:10:21 -05:00
|
|
|
*
|
|
|
|
*/
|
2014-05-02 10:22:40 -04:00
|
|
|
Binding *get_binding_from_xcb_event(xcb_generic_event_t *event);
|
2014-03-13 08:02:07 -04:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Translates keysymbols to keycodes for all bindings which use keysyms.
|
|
|
|
*
|
|
|
|
*/
|
|
|
|
void translate_keysyms(void);
|
2014-04-14 14:52:56 -04:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Switches the key bindings to the given mode, if the mode exists
|
|
|
|
*
|
|
|
|
*/
|
|
|
|
void switch_mode(const char *new_mode);
|
2014-04-22 21:41:28 -04:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Checks for duplicate key bindings (the same keycode or keysym is configured
|
|
|
|
* more than once). If a duplicate binding is found, a message is printed to
|
|
|
|
* stderr and the has_errors variable is set to true, which will start
|
|
|
|
* i3-nagbar.
|
|
|
|
*
|
|
|
|
*/
|
|
|
|
void check_for_duplicate_bindings(struct context *context);
|
2014-05-31 11:00:02 -04:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Runs the given binding and handles parse errors. Returns a CommandResult for
|
|
|
|
* running the binding's command. Caller should render tree if
|
|
|
|
* needs_tree_render is true. Free with command_result_free().
|
|
|
|
*
|
|
|
|
*/
|
|
|
|
CommandResult *run_binding(Binding *bind);
|