2011-10-25 21:19:38 +01:00
|
|
|
|
/*
|
|
|
|
|
* vim:ts=4:sw=4:expandtab
|
|
|
|
|
*
|
|
|
|
|
* i3 - an improved dynamic tiling window manager
|
2015-04-03 20:17:56 -04:00
|
|
|
|
* © 2009 Michael Stapelberg and contributors (see also: LICENSE)
|
2011-10-25 21:19:38 +01:00
|
|
|
|
*
|
|
|
|
|
* load_layout.c: Restore (parts of) the layout, for example after an inplace
|
|
|
|
|
* restart.
|
|
|
|
|
*
|
|
|
|
|
*/
|
2013-12-29 06:11:50 +04:00
|
|
|
|
#pragma once
|
2010-03-27 15:25:51 +01:00
|
|
|
|
|
2014-07-15 10:15:04 +02:00
|
|
|
|
typedef enum {
|
|
|
|
|
// We could not determine the content of the JSON file. This typically
|
|
|
|
|
// means it’s unreadable or contains garbage.
|
|
|
|
|
JSON_CONTENT_UNKNOWN = 0,
|
|
|
|
|
|
|
|
|
|
// The JSON file contains a “normal” container, i.e. a container to be
|
|
|
|
|
// appended to an existing workspace (or split container!).
|
|
|
|
|
JSON_CONTENT_CON = 1,
|
|
|
|
|
|
|
|
|
|
// The JSON file contains a workspace container, which needs to be appended
|
|
|
|
|
// to the output (next to the other workspaces) with special care to avoid
|
|
|
|
|
// naming conflicts and ensuring that the workspace _has_ a name.
|
|
|
|
|
JSON_CONTENT_WORKSPACE = 2,
|
|
|
|
|
} json_content_t;
|
|
|
|
|
|
|
|
|
|
/* Parses the given JSON file until it encounters the first “type” property to
|
|
|
|
|
* determine whether the file contains workspaces or regular containers, which
|
|
|
|
|
* is important to know when deciding where (and how) to append the contents.
|
|
|
|
|
* */
|
|
|
|
|
json_content_t json_determine_content(const char *filename);
|
|
|
|
|
|
2014-04-18 20:30:27 +02:00
|
|
|
|
void tree_append_json(Con *con, const char *filename, char **errormsg);
|