Change the names of parser result structs

Change the name of structs CommandResult and ConfigResult to
CommandResultIR and ConfigResultIR to show they are an intermediate
representation used during parsing.
This commit is contained in:
Tony Crisci 2014-05-18 00:44:19 -04:00 committed by Michael Stapelberg
parent dda9a7f6e0
commit 45fa4b7d23
11 changed files with 24 additions and 27 deletions

View File

@ -131,7 +131,7 @@ close($enumfh);
# Third step: Generate the call function. # Third step: Generate the call function.
open(my $callfh, '>', "GENERATED_${prefix}_call.h"); open(my $callfh, '>', "GENERATED_${prefix}_call.h");
my $resultname = uc(substr($prefix, 0, 1)) . substr($prefix, 1) . 'Result'; my $resultname = uc(substr($prefix, 0, 1)) . substr($prefix, 1) . 'ResultIR';
say $callfh "static void GENERATED_call(const int call_identifier, struct $resultname *result) {"; say $callfh "static void GENERATED_call(const int call_identifier, struct $resultname *result) {";
say $callfh ' switch (call_identifier) {'; say $callfh ' switch (call_identifier) {';
my $call_id = 0; my $call_id = 0;

View File

@ -12,7 +12,7 @@
#include "commands_parser.h" #include "commands_parser.h"
/** The beginning of the prototype for every cmd_ function. */ /** The beginning of the prototype for every cmd_ function. */
#define I3_CMD Match *current_match, struct CommandResult *cmd_output #define I3_CMD Match *current_match, struct CommandResultIR *cmd_output
/** /**
* Initializes the specified 'Match' data structure and the initial state of * Initializes the specified 'Match' data structure and the initial state of

View File

@ -12,15 +12,11 @@
#include <yajl/yajl_gen.h> #include <yajl/yajl_gen.h>
/* /*
* Holds the result of a call to any command. When calling * Holds an intermediate represenation of the result of a call to any command.
* parse_command("floating enable, border none"), the parser will internally * When calling parse_command("floating enable, border none"), the parser will
* use a struct CommandResult when calling cmd_floating and cmd_border. * internally use this struct 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 { struct CommandResultIR {
/* The JSON generator to append a reply to. */ /* The JSON generator to append a reply to. */
yajl_gen json_gen; yajl_gen json_gen;
@ -33,4 +29,4 @@ struct CommandResult {
bool needs_tree_render; bool needs_tree_render;
}; };
struct CommandResult *parse_command(const char *input); struct CommandResultIR *parse_command(const char *input);

View File

@ -18,7 +18,7 @@
uint32_t modifiers_from_str(const char *str); uint32_t modifiers_from_str(const char *str);
/** The beginning of the prototype for every cfg_ function. */ /** The beginning of the prototype for every cfg_ function. */
#define I3_CFG Match *current_match, struct ConfigResult *result #define I3_CFG Match *current_match, struct ConfigResultIR *result
/* Defines a configuration function, that is, anything that can be called by /* Defines a configuration function, that is, anything that can be called by
* using 'call cfg_foo()' in parser-specs/.*.spec. Useful so that we dont need * using 'call cfg_foo()' in parser-specs/.*.spec. Useful so that we dont need

View File

@ -14,11 +14,12 @@
extern pid_t config_error_nagbar_pid; extern pid_t config_error_nagbar_pid;
/* /*
* The result of a parse_config call. Currently unused, but the JSON output * An intermediate reprsentation of the result of a parse_config call.
* will be useful in the future when we implement a config parsing IPC command. * Currently unused, but the JSON output will be useful in the future when we
* implement a config parsing IPC command.
* *
*/ */
struct ConfigResult { struct ConfigResultIR {
/* The JSON generator to append a reply to. */ /* The JSON generator to append a reply to. */
yajl_gen json_gen; yajl_gen json_gen;
@ -28,7 +29,7 @@ struct ConfigResult {
int next_state; int next_state;
}; };
struct ConfigResult *parse_config(const char *input, struct context *context); struct ConfigResultIR *parse_config(const char *input, struct context *context);
/** /**
* Parses the given file by first replacing the variables, then calling * Parses the given file by first replacing the variables, then calling

View File

@ -45,7 +45,7 @@ void run_assignments(i3Window *window) {
DLOG("execute command %s\n", current->dest.command); DLOG("execute command %s\n", current->dest.command);
char *full_command; char *full_command;
sasprintf(&full_command, "[id=\"%d\"] %s", window->id, current->dest.command); sasprintf(&full_command, "[id=\"%d\"] %s", window->id, current->dest.command);
struct CommandResult *command_output = parse_command(full_command); struct CommandResultIR *command_output = parse_command(full_command);
free(full_command); free(full_command);
if (command_output->needs_tree_render) if (command_output->needs_tree_render)

View File

@ -95,7 +95,7 @@ static Output *get_output_of_con(Con *con) {
* and return true, signaling that no further workspace switching should occur in the calling function. * and return true, signaling that no further workspace switching should occur in the calling function.
* *
*/ */
static bool maybe_back_and_forth(struct CommandResult *cmd_output, char *name) { static bool maybe_back_and_forth(struct CommandResultIR *cmd_output, char *name) {
Con *ws = con_get_workspace(focused); Con *ws = con_get_workspace(focused);
/* If we switched to a different workspace, do nothing */ /* If we switched to a different workspace, do nothing */

View File

@ -179,8 +179,8 @@ static cmdp_state state;
#ifndef TEST_PARSER #ifndef TEST_PARSER
static Match current_match; static Match current_match;
#endif #endif
static struct CommandResult subcommand_output; static struct CommandResultIR subcommand_output;
static struct CommandResult command_output; static struct CommandResultIR command_output;
#include "GENERATED_command_call.h" #include "GENERATED_command_call.h"
@ -205,7 +205,7 @@ static void next_state(const cmdp_token *token) {
} }
} }
struct CommandResult *parse_command(const char *input) { struct CommandResultIR *parse_command(const char *input) {
DLOG("COMMAND: *%s*\n", input); DLOG("COMMAND: *%s*\n", input);
state = INITIAL; state = INITIAL;

View File

@ -232,8 +232,8 @@ static void clear_criteria(void *unused_criteria) {
static cmdp_state state; static cmdp_state state;
static Match current_match; static Match current_match;
static struct ConfigResult subcommand_output; static struct ConfigResultIR subcommand_output;
static struct ConfigResult command_output; static struct ConfigResultIR command_output;
/* A list which contains the states that lead to the current state, e.g. /* A list which contains the states that lead to the current state, e.g.
* INITIAL, WORKSPACE_LAYOUT. * INITIAL, WORKSPACE_LAYOUT.
@ -304,7 +304,7 @@ static char *single_line(const char *start) {
return result; return result;
} }
struct ConfigResult *parse_config(const char *input, struct context *context) { struct ConfigResultIR *parse_config(const char *input, struct context *context) {
/* Dump the entire config file into the debug log. We cannot just use /* Dump the entire config file into the debug log. We cannot just use
* DLOG("%s", input); because one log message must not exceed 4 KiB. */ * DLOG("%s", input); because one log message must not exceed 4 KiB. */
const char *dumpwalk = input; const char *dumpwalk = input;
@ -1000,7 +1000,7 @@ void parse_file(const char *f) {
context = scalloc(sizeof(struct context)); context = scalloc(sizeof(struct context));
context->filename = f; context->filename = f;
struct ConfigResult *config_output = parse_config(new, context); struct ConfigResultIR *config_output = parse_config(new, context);
yajl_gen_free(config_output->json_gen); yajl_gen_free(config_output->json_gen);
check_for_duplicate_bindings(context); check_for_duplicate_bindings(context);

View File

@ -117,7 +117,7 @@ IPC_HANDLER(command) {
char *command = scalloc(message_size + 1); char *command = scalloc(message_size + 1);
strncpy(command, (const char*)message, message_size); strncpy(command, (const char*)message, message_size);
LOG("IPC: received: *%s*\n", command); LOG("IPC: received: *%s*\n", command);
struct CommandResult *command_output = parse_command((const char*)command); struct CommandResultIR *command_output = parse_command((const char*)command);
free(command); free(command);
if (command_output->needs_tree_render) if (command_output->needs_tree_render)

View File

@ -73,7 +73,7 @@ void handle_key_press(xcb_key_press_event_t *event) {
return; return;
char *command_copy = sstrdup(bind->command); char *command_copy = sstrdup(bind->command);
struct CommandResult *command_output = parse_command(command_copy); struct CommandResultIR *command_output = parse_command(command_copy);
free(command_copy); free(command_copy);
if (command_output->needs_tree_render) if (command_output->needs_tree_render)