2012-10-08 18:28:32 +04:00
|
|
|
/*
|
|
|
|
* vim:ts=4:sw=4:expandtab
|
|
|
|
*
|
|
|
|
* i3 - an improved dynamic tiling window manager
|
2015-04-04 03:17:56 +03:00
|
|
|
* © 2009 Michael Stapelberg and contributors (see also: LICENSE)
|
2012-10-08 18:28:32 +04:00
|
|
|
*
|
|
|
|
* config_parser.h: config parser-related definitions
|
|
|
|
*
|
|
|
|
*/
|
2013-12-29 06:11:50 +04:00
|
|
|
#pragma once
|
2012-10-08 18:28:32 +04:00
|
|
|
|
2016-10-11 10:13:35 +03:00
|
|
|
#include <config.h>
|
|
|
|
|
2012-10-08 18:28:32 +04:00
|
|
|
#include <yajl/yajl_gen.h>
|
|
|
|
|
2016-05-08 13:55:27 +03:00
|
|
|
SLIST_HEAD(variables_head, Variable);
|
2012-12-24 19:53:20 +04:00
|
|
|
extern pid_t config_error_nagbar_pid;
|
|
|
|
|
2018-04-21 13:02:14 +03:00
|
|
|
/**
|
2014-05-18 08:44:19 +04:00
|
|
|
* An intermediate reprsentation of the result of a parse_config call.
|
|
|
|
* Currently unused, but the JSON output will be useful in the future when we
|
|
|
|
* implement a config parsing IPC command.
|
2012-10-08 18:28:32 +04:00
|
|
|
*
|
|
|
|
*/
|
2014-05-18 08:44:19 +04:00
|
|
|
struct ConfigResultIR {
|
2012-10-08 18:28:32 +04:00
|
|
|
/* 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;
|
|
|
|
};
|
|
|
|
|
2014-05-18 08:44:19 +04:00
|
|
|
struct ConfigResultIR *parse_config(const char *input, struct context *context);
|
2012-10-08 18:28:32 +04:00
|
|
|
|
2015-09-25 17:20:28 +03:00
|
|
|
/**
|
|
|
|
* launch nagbar to indicate errors in the configuration file.
|
|
|
|
*/
|
|
|
|
void start_config_error_nagbar(const char *configpath, bool has_errors);
|
|
|
|
|
2012-12-24 18:57:02 +04:00
|
|
|
/**
|
|
|
|
* Parses the given file by first replacing the variables, then calling
|
2014-08-02 09:01:15 +04:00
|
|
|
* parse_config and launching i3-nagbar if use_nagbar is true.
|
|
|
|
*
|
|
|
|
* The return value is a boolean indicating whether there were errors during
|
|
|
|
* parsing.
|
2012-12-24 18:57:02 +04:00
|
|
|
*
|
|
|
|
*/
|
2014-08-02 09:01:15 +04:00
|
|
|
bool parse_file(const char *f, bool use_nagbar);
|