X-Git-Url: https://git.sur5r.net/?a=blobdiff_plain;f=include%2Fcommands.h;h=6d1046d4b74cece97c59ee2ee36e475dbb13eeda;hb=05fb9096362e788f032de6eccea2d7fea03317ab;hp=a28b799f9f6342f4ee7dd87666ed90dcd41e36c5;hpb=3229f7677f1cdb78bfb5fb269c09f6e825378bad;p=i3%2Fi3 diff --git a/include/commands.h b/include/commands.h index a28b799f..6d1046d4 100644 --- a/include/commands.h +++ b/include/commands.h @@ -2,60 +2,306 @@ * vim:ts=4:sw=4:expandtab * * i3 - an improved dynamic tiling window manager - * © 2009-2012 Michael Stapelberg and contributors (see also: LICENSE) + * © 2009 Michael Stapelberg and contributors (see also: LICENSE) * * commands.c: all command functions (see commands_parser.c) * */ -#ifndef _COMMANDS_H -#define _COMMANDS_H +#pragma once + +#include "commands_parser.h" + +/** The beginning of the prototype for every cmd_ function. */ +#define I3_CMD Match *current_match, struct CommandResultIR *cmd_output + +/** + * Initializes the specified 'Match' data structure and the initial state of + * commands.c for matching target windows of a command. + * + */ +void cmd_criteria_init(I3_CMD); + +/** + * A match specification just finished (the closing square bracket was found), + * so we filter the list of owindows. + * + */ +void cmd_criteria_match_windows(I3_CMD); + +/** + * Interprets a ctype=cvalue pair and adds it to the current match + * specification. + * + */ +void cmd_criteria_add(I3_CMD, char *ctype, char *cvalue); + +/** + * Implementation of 'move [window|container] [to] workspace + * next|prev|next_on_output|prev_on_output'. + * + */ +void cmd_move_con_to_workspace(I3_CMD, char *which); + +/** + * Implementation of 'move [window|container] [to] workspace back_and_forth'. + * + */ +void cmd_move_con_to_workspace_back_and_forth(I3_CMD); + +/** + * Implementation of 'move [window|container] [to] workspace '. + * + */ +void cmd_move_con_to_workspace_name(I3_CMD, char *name); + +/** + * Implementation of 'move [window|container] [to] workspace number '. + * + */ +void cmd_move_con_to_workspace_number(I3_CMD, char *which); + +/** + * Implementation of 'resize grow|shrink [ px] [or ppt]'. + * + */ +void cmd_resize(I3_CMD, char *way, char *direction, char *resize_px, char *resize_ppt); + +/** + * Implementation of 'border normal|pixel []', 'border none|1pixel|toggle'. + * + */ +void cmd_border(I3_CMD, char *border_style_str, char *border_width); + +/** + * Implementation of 'nop '. + * + */ +void cmd_nop(I3_CMD, char *comment); + +/** + * Implementation of 'append_layout '. + * + */ +void cmd_append_layout(I3_CMD, char *path); + +/** + * Implementation of 'workspace next|prev|next_on_output|prev_on_output'. + * + */ +void cmd_workspace(I3_CMD, char *which); + +/** + * Implementation of 'workspace number ' + * + */ +void cmd_workspace_number(I3_CMD, char *which); + +/** + * Implementation of 'workspace back_and_forth'. + * + */ +void cmd_workspace_back_and_forth(I3_CMD); + +/** + * Implementation of 'workspace ' + * + */ +void cmd_workspace_name(I3_CMD, char *name); + +/** + * Implementation of 'mark [--toggle] ' + * + */ +void cmd_mark(I3_CMD, char *mark, char *toggle); + +/** + * Implementation of 'unmark [mark]' + * + */ +void cmd_unmark(I3_CMD, char *mark); + +/** + * Implementation of 'mode '. + * + */ +void cmd_mode(I3_CMD, char *mode); + +/** + * Implementation of 'move [window|container] [to] output '. + * + */ +void cmd_move_con_to_output(I3_CMD, char *name); + +/** + * Implementation of 'move [window|container] [to] mark '. + * + */ +void cmd_move_con_to_mark(I3_CMD, char *mark); + +/** + * Implementation of 'floating enable|disable|toggle' + * + */ +void cmd_floating(I3_CMD, char *floating_mode); + +/** + * Implementation of 'move workspace to [output] '. + * + */ +void cmd_move_workspace_to_output(I3_CMD, char *name); + +/** + * Implementation of 'split v|h|vertical|horizontal'. + * + */ +void cmd_split(I3_CMD, char *direction); + +/** + * Implementation of 'kill [window|client]'. + * + */ +void cmd_kill(I3_CMD, char *kill_mode_str); + +/** + * Implementation of 'exec [--no-startup-id] '. + * + */ +void cmd_exec(I3_CMD, char *nosn, char *command); + +/** + * Implementation of 'focus left|right|up|down'. + * + */ +void cmd_focus_direction(I3_CMD, char *direction); + +/** + * Implementation of 'focus tiling|floating|mode_toggle'. + * + */ +void cmd_focus_window_mode(I3_CMD, char *window_mode); + +/** + * Implementation of 'focus parent|child'. + * + */ +void cmd_focus_level(I3_CMD, char *level); + +/** + * Implementation of 'focus'. + * + */ +void cmd_focus(I3_CMD); + +/** + * Implementation of 'fullscreen [enable|disable|toggle] [global]'. + * + */ +void cmd_fullscreen(I3_CMD, char *action, char *fullscreen_mode); + +/** + * Implementation of 'move [ [px]]'. + * + */ +void cmd_move_direction(I3_CMD, char *direction, char *move_px); + +/** + * Implementation of 'layout default|stacked|stacking|tabbed|splitv|splith'. + * + */ +void cmd_layout(I3_CMD, char *layout_str); + +/** + * Implementation of 'layout toggle [all|split]'. + * + */ +void cmd_layout_toggle(I3_CMD, char *toggle_mode); + +/** + * Implementation of 'exit'. + * + */ +void cmd_exit(I3_CMD); + +/** + * Implementation of 'reload'. + * + */ +void cmd_reload(I3_CMD); + +/** + * Implementation of 'restart'. + * + */ +void cmd_restart(I3_CMD); + +/** + * Implementation of 'open'. + * + */ +void cmd_open(I3_CMD); + +/** + * Implementation of 'focus output '. + * + */ +void cmd_focus_output(I3_CMD, char *name); + +/** + * Implementation of 'move [window|container] [to] [absolute] position [px] [px] + * + */ +void cmd_move_window_to_position(I3_CMD, char *method, char *x, char *y); + +/** + * Implementation of 'move [window|container] [to] [absolute] position center + * + */ +void cmd_move_window_to_center(I3_CMD, char *method); + +/** + * Implementation of 'move [window|container] [to] position mouse' + * + */ +void cmd_move_window_to_mouse(I3_CMD); + +/** + * Implementation of 'move scratchpad'. + * + */ +void cmd_move_scratchpad(I3_CMD); + +/** + * Implementation of 'scratchpad show'. + * + */ +void cmd_scratchpad_show(I3_CMD); + +/** + * Implementation of 'title_format ' + * + */ +void cmd_title_format(I3_CMD, char *format); + +/** + * Implementation of 'rename workspace to ' + * + */ +void cmd_rename_workspace(I3_CMD, char *old_name, char *new_name); + +/** + * Implementation of 'bar (hidden_state hide|show|toggle)|(mode dock|hide|invisible|toggle) []' + * + */ +void cmd_bar(I3_CMD, char *bar_type, char *bar_value, char *bar_id); /* - * Helper data structure for an operation window (window on which the operation - * will be performed). Used to build the TAILQ owindows. - * - */ -typedef struct owindow { - Con *con; - TAILQ_ENTRY(owindow) owindows; -} owindow; - -typedef TAILQ_HEAD(owindows_head, owindow) owindows_head; - -char *cmd_criteria_init(Match *current_match); -char *cmd_criteria_match_windows(Match *current_match); -char *cmd_criteria_add(Match *current_match, char *ctype, char *cvalue); - -char *cmd_move_con_to_workspace(Match *current_match, char *which); -char *cmd_move_con_to_workspace_name(Match *current_match, char *name); -char *cmd_resize(Match *current_match, char *way, char *direction, char *resize_px, char *resize_ppt); -char *cmd_border(Match *current_match, char *border_style_str); -char *cmd_nop(Match *current_match, char *comment); -char *cmd_append_layout(Match *current_match, char *path); -char *cmd_workspace(Match *current_match, char *which); -char *cmd_workspace_back_and_forth(Match *current_match); -char *cmd_workspace_name(Match *current_match, char *name); -char *cmd_mark(Match *current_match, char *mark); -char *cmd_mode(Match *current_match, char *mode); -char *cmd_move_con_to_output(Match *current_match, char *name); -char *cmd_floating(Match *current_match, char *floating_mode); -char *cmd_move_workspace_to_output(Match *current_match, char *name); -char *cmd_split(Match *current_match, char *direction); -char *cmd_kill(Match *current_match, char *kill_mode); -char *cmd_exec(Match *current_match, char *nosn, char *command); -char *cmd_focus_direction(Match *current_match, char *direction); -char *cmd_focus_window_mode(Match *current_match, char *window_mode); -char *cmd_focus_level(Match *current_match, char *level); -char *cmd_focus(Match *current_match); -char *cmd_fullscreen(Match *current_match, char *fullscreen_mode); -char *cmd_move_direction(Match *current_match, char *direction, char *px); -char *cmd_layout(Match *current_match, char *layout); -char *cmd_exit(Match *current_match); -char *cmd_reload(Match *current_match); -char *cmd_restart(Match *current_match); -char *cmd_open(Match *current_match); -char *cmd_focus_output(Match *current_match, char *name); -char *cmd_move_scratchpad(Match *current_match); -char *cmd_scratchpad_show(Match *current_match); - -#endif + * Implementation of 'shmlog |toggle|on|off' + * + */ +void cmd_shmlog(I3_CMD, char *argument); + +/* + * Implementation of 'debuglog toggle|on|off' + * + */ +void cmd_debuglog(I3_CMD, char *argument);