|
|
@ -314,9 +314,24 @@ struct focus_inactive_data {
|
|
|
|
static void focus_inactive_children_iterator(struct sway_node *node,
|
|
|
|
static void focus_inactive_children_iterator(struct sway_node *node,
|
|
|
|
void *_data) {
|
|
|
|
void *_data) {
|
|
|
|
struct focus_inactive_data *data = _data;
|
|
|
|
struct focus_inactive_data *data = _data;
|
|
|
|
if (node_get_parent(node) == data->node) {
|
|
|
|
json_object *focus = data->object;
|
|
|
|
json_object_array_add(data->object, json_object_new_int(node->id));
|
|
|
|
if (data->node == &root->node) {
|
|
|
|
|
|
|
|
struct sway_output *output = node_get_output(node);
|
|
|
|
|
|
|
|
if (output == NULL) {
|
|
|
|
|
|
|
|
return;
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
size_t id = output->node.id;
|
|
|
|
|
|
|
|
int len = json_object_array_length(focus);
|
|
|
|
|
|
|
|
for (int i = 0; i < len; ++i) {
|
|
|
|
|
|
|
|
if ((size_t) json_object_get_int(json_object_array_get_idx(focus, i)) == id) {
|
|
|
|
|
|
|
|
return;
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
node = &output->node;
|
|
|
|
|
|
|
|
} else if (node_get_parent(node) != data->node) {
|
|
|
|
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
json_object_array_add(focus, json_object_new_int(node->id));
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
json_object *ipc_json_describe_node(struct sway_node *node) {
|
|
|
|
json_object *ipc_json_describe_node(struct sway_node *node) {
|
|
|
|