From: Michael Stapelberg Date: Sun, 15 Dec 2013 20:29:05 +0000 (+0100) Subject: ipc: dump window properties when not restarting inplace X-Git-Tag: 4.8~182 X-Git-Url: https://git.sur5r.net/?a=commitdiff_plain;h=c964c010f050ae82bb15679333d010afd520d5dd;p=i3%2Fi3 ipc: dump window properties when not restarting inplace --- diff --git a/src/ipc.c b/src/ipc.c index b5d17ba4..ab12dcb0 100644 --- a/src/ipc.c +++ b/src/ipc.c @@ -306,6 +306,32 @@ void dump_node(yajl_gen gen, struct Con *con, bool inplace_restart) { y(integer, con->window->id); else y(null); + if (con->window && !inplace_restart) { + /* Window properties are useless to preserve when restarting because + * they will be queried again anyway. However, for i3-save-tree(1), + * they are very useful and save i3-save-tree dealing with X11. */ + ystr("window_properties"); + y(map_open); + +#define DUMP_PROPERTY(key, prop_name) do { \ + if (con->window->prop_name != NULL) { \ + ystr(key); \ + ystr(con->window->prop_name); \ + } \ +} while (0) + + DUMP_PROPERTY("class", class_class); + DUMP_PROPERTY("instance", class_instance); + DUMP_PROPERTY("window_role", role); + + if (con->window->name != NULL) { + ystr("title"); + ystr(i3string_as_utf8(con->window->name)); + } + + y(map_close); + } + ystr("nodes"); y(array_open); Con *node;