/* * vim:ts=4:sw=4:expandtab * * i3 - an improved dynamic tiling window manager * © 2009-2012 Michael Stapelberg and contributors (see also: LICENSE) * * commands.c: all command functions (see commands_parser.c) * */ #pragma once #include /* * Holds the result of a call to any command. When calling * parse_command("floating enable, border none"), the parser will internally * use a struct CommandResult when calling cmd_floating and cmd_border. * parse_command will also return another struct CommandResult, whose * json_output is set to a map of individual json_outputs and whose * needs_tree_trender is true if any individual needs_tree_render was true. * */ struct CommandResult { /* The JSON generator to append a reply to. */ yajl_gen json_gen; /* The next state to transition to. Passed to the function so that we can * determine the next state as a result of a function call, like * cfg_criteria_pop_state() does. */ int next_state; /* Whether the command requires calling tree_render. */ bool needs_tree_render; }; struct CommandResult *parse_command(const char *input);