diff options
| author | Drew DeVault <[email protected]> | 2018-08-18 10:29:46 -0400 | 
|---|---|---|
| committer | GitHub <[email protected]> | 2018-08-18 10:29:46 -0400 | 
| commit | 744724b3cb28c2ee9d265dcbf78b1cbf2b2e3fef (patch) | |
| tree | 7a5ebeae1d5e15f047f09698978fa84f61756faa /sway/tree/root.c | |
| parent | d4a32800d5eb938a769d7802b23f4a0f43cadaef (diff) | |
| parent | d6cd79c342495738fc23fbfbf19a01e73cdc42dc (diff) | |
Merge pull request #2473 from RyanDwyer/iterators-per-type
Implement iterators per container type
Diffstat (limited to 'sway/tree/root.c')
| -rw-r--r-- | sway/tree/root.c | 78 | 
1 files changed, 78 insertions, 0 deletions
| diff --git a/sway/tree/root.c b/sway/tree/root.c index fc908cc1..8d8f42dc 100644 --- a/sway/tree/root.c +++ b/sway/tree/root.c @@ -256,3 +256,81 @@ void root_record_workspace_pid(pid_t pid) {  			&pw->output_destroy);  	wl_list_insert(&pid_workspaces, &pw->link);  } + +void root_for_each_workspace(void (*f)(struct sway_container *con, void *data), +		void *data) { +	for (int i = 0; i < root_container.children->length; ++i) { +		struct sway_container *output = root_container.children->items[i]; +		output_for_each_workspace(output, f, data); +	} +} + +void root_for_each_container(void (*f)(struct sway_container *con, void *data), +		void *data) { +	for (int i = 0; i < root_container.children->length; ++i) { +		struct sway_container *output = root_container.children->items[i]; +		output_for_each_container(output, f, data); +	} + +	// Scratchpad +	for (int i = 0; i < root_container.sway_root->scratchpad->length; ++i) { +		struct sway_container *container = +			root_container.sway_root->scratchpad->items[i]; +		// If the container has a parent then it's visible on a workspace +		// and will have been iterated in the previous for loop. So we only +		// iterate the hidden scratchpad containers here. +		if (!container->parent) { +			f(container, data); +			container_for_each_child(container, f, data); +		} +	} +} + +struct sway_container *root_find_output( +		bool (*test)(struct sway_container *con, void *data), void *data) { +	for (int i = 0; i < root_container.children->length; ++i) { +		struct sway_container *output = root_container.children->items[i]; +		if (test(output, data)) { +			return output; +		} +	} +	return NULL; +} + +struct sway_container *root_find_workspace( +		bool (*test)(struct sway_container *con, void *data), void *data) { +	struct sway_container *result = NULL; +	for (int i = 0; i < root_container.children->length; ++i) { +		struct sway_container *output = root_container.children->items[i]; +		if ((result = output_find_workspace(output, test, data))) { +			return result; +		} +	} +	return NULL; +} + +struct sway_container *root_find_container( +		bool (*test)(struct sway_container *con, void *data), void *data) { +	struct sway_container *result = NULL; +	for (int i = 0; i < root_container.children->length; ++i) { +		struct sway_container *output = root_container.children->items[i]; +		if ((result = output_find_container(output, test, data))) { +			return result; +		} +	} + +	// Scratchpad +	for (int i = 0; i < root_container.sway_root->scratchpad->length; ++i) { +		struct sway_container *container = +			root_container.sway_root->scratchpad->items[i]; +		if (!container->parent) { +			if (test(container, data)) { +				return container; +			} +			if ((result = container_find_child(container, test, data))) { +				return result; +			} +		} +	} +	return NULL; +} | 
