mirror of
				https://github.com/labwc/labwc.git
				synced 2025-11-03 09:01:51 -05:00 
			
		
		
		
	node.c: add helpers for returning structs from node data
Support returning the following structs: - view from LAB_NODE_DESC_VIEW or LAB_NODE_DESC_XDG_POPUP - lab_layer_surface form LAB_NODE_DESC_LAYER_SURFACE - lab_layer_popup from LAB_NODE_DESC_LAYER_POPUP
This commit is contained in:
		
							parent
							
								
									30298228e3
								
							
						
					
					
						commit
						b4cbc20e8c
					
				
					 3 changed files with 66 additions and 13 deletions
				
			
		| 
						 | 
				
			
			@ -3,12 +3,16 @@
 | 
			
		|||
#define __LABWC_NODE_DESCRIPTOR_H
 | 
			
		||||
#include <wlr/types/wlr_scene.h>
 | 
			
		||||
 | 
			
		||||
struct view;
 | 
			
		||||
struct lab_layer_surface;
 | 
			
		||||
struct lab_layer_popup;
 | 
			
		||||
 | 
			
		||||
enum node_descriptor_type {
 | 
			
		||||
	LAB_NODE_DESC_NODE = 0,
 | 
			
		||||
	LAB_NODE_DESC_VIEW,		/* *data --> struct view */
 | 
			
		||||
	LAB_NODE_DESC_XDG_POPUP,	/* *data --> struct view */
 | 
			
		||||
	LAB_NODE_DESC_LAYER_SURFACE,	/* *data --> struct lab_layer_surface */
 | 
			
		||||
	LAB_NODE_DESC_LAYER_POPUP,	/* *data --> struct lab_layer_popup */
 | 
			
		||||
	LAB_NODE_DESC_VIEW,
 | 
			
		||||
	LAB_NODE_DESC_XDG_POPUP,
 | 
			
		||||
	LAB_NODE_DESC_LAYER_SURFACE,
 | 
			
		||||
	LAB_NODE_DESC_LAYER_POPUP,
 | 
			
		||||
};
 | 
			
		||||
 | 
			
		||||
struct node_descriptor {
 | 
			
		||||
| 
						 | 
				
			
			@ -17,7 +21,37 @@ struct node_descriptor {
 | 
			
		|||
	struct wl_listener destroy;
 | 
			
		||||
};
 | 
			
		||||
 | 
			
		||||
void node_descriptor_create(struct wlr_scene_node *node,
 | 
			
		||||
/**
 | 
			
		||||
 * node_descriptor_create - create node descriptor for wlr_scene_node user_data
 | 
			
		||||
 * @scene_node: wlr_scene_node to attached node_descriptor to
 | 
			
		||||
 * @type: node descriptor type
 | 
			
		||||
 * @data: struct to point to as follows:
 | 
			
		||||
 *   - LAB_NODE_DESC_VIEW		struct view
 | 
			
		||||
 *   - LAB_NODE_DESC_XDG_POPUP		struct view
 | 
			
		||||
 *   - LAB_NODE_DESC_LAYER_SURFACE	struct lab_layer_surface
 | 
			
		||||
 *   - LAB_NODE_DESC_LAYER_POPUP	struct lab_layer_popup
 | 
			
		||||
 */
 | 
			
		||||
void node_descriptor_create(struct wlr_scene_node *scene_node,
 | 
			
		||||
	enum node_descriptor_type type, void *data);
 | 
			
		||||
 | 
			
		||||
/**
 | 
			
		||||
 * node_view_from_node - return view struct from node
 | 
			
		||||
 * @node_descriptor: node_descriptor from which to return data
 | 
			
		||||
 */
 | 
			
		||||
struct view *node_view_from_node(struct node_descriptor *node_descriptor);
 | 
			
		||||
 | 
			
		||||
/**
 | 
			
		||||
 * node_lab_surface_from_node - return lab_layer_surface struct from node
 | 
			
		||||
 * @node_descriptor: node_descriptor from which to return data
 | 
			
		||||
 */
 | 
			
		||||
struct lab_layer_surface *node_layer_surface_from_node(
 | 
			
		||||
	struct node_descriptor *node_descriptor);
 | 
			
		||||
 | 
			
		||||
/**
 | 
			
		||||
 * node_layer_popup_from_node - return lab_layer_popup struct from node
 | 
			
		||||
 * @node_descriptor: node_descriptor from which to return data
 | 
			
		||||
 */
 | 
			
		||||
struct lab_layer_popup *node_layer_popup_from_node(
 | 
			
		||||
	struct node_descriptor *node_descriptor);
 | 
			
		||||
 | 
			
		||||
#endif /* __LABWC_NODE_DESCRIPTOR_H */
 | 
			
		||||
| 
						 | 
				
			
			
 | 
			
		|||
| 
						 | 
				
			
			@ -1,5 +1,4 @@
 | 
			
		|||
// SPDX-License-Identifier: GPL-2.0-only
 | 
			
		||||
#include <assert.h>
 | 
			
		||||
#include <wlr/types/wlr_layer_shell_v1.h>
 | 
			
		||||
#include <wlr/types/wlr_scene.h>
 | 
			
		||||
#include "buffer.h"
 | 
			
		||||
| 
						 | 
				
			
			@ -113,10 +112,7 @@ get_special(struct server *server, struct wlr_scene_node *node,
 | 
			
		|||
		return "server->view_tree";
 | 
			
		||||
	}
 | 
			
		||||
	if (node->parent == &server->view_tree->node) {
 | 
			
		||||
		struct node_descriptor *desc = node->data;
 | 
			
		||||
		assert(desc->type == LAB_NODE_DESC_VIEW
 | 
			
		||||
			|| desc->type == LAB_NODE_DESC_XDG_POPUP);
 | 
			
		||||
		*last_view = desc->data;
 | 
			
		||||
		*last_view = node_view_from_node(node->data);
 | 
			
		||||
	}
 | 
			
		||||
	const char *view_part = get_view_part(*last_view, node);
 | 
			
		||||
	if (view_part) {
 | 
			
		||||
| 
						 | 
				
			
			
 | 
			
		|||
							
								
								
									
										29
									
								
								src/node.c
									
										
									
									
									
								
							
							
						
						
									
										29
									
								
								src/node.c
									
										
									
									
									
								
							| 
						 | 
				
			
			@ -1,4 +1,5 @@
 | 
			
		|||
// SPDX-License-Identifier: GPL-2.0-only
 | 
			
		||||
#include <assert.h>
 | 
			
		||||
#include <stdlib.h>
 | 
			
		||||
#include "node.h"
 | 
			
		||||
 | 
			
		||||
| 
						 | 
				
			
			@ -21,7 +22,7 @@ destroy_notify(struct wl_listener *listener, void *data)
 | 
			
		|||
}
 | 
			
		||||
 | 
			
		||||
void
 | 
			
		||||
node_descriptor_create(struct wlr_scene_node *node,
 | 
			
		||||
node_descriptor_create(struct wlr_scene_node *scene_node,
 | 
			
		||||
		enum node_descriptor_type type, void *data)
 | 
			
		||||
{
 | 
			
		||||
	struct node_descriptor *node_descriptor =
 | 
			
		||||
| 
						 | 
				
			
			@ -32,6 +33,28 @@ node_descriptor_create(struct wlr_scene_node *node,
 | 
			
		|||
	node_descriptor->type = type;
 | 
			
		||||
	node_descriptor->data = data;
 | 
			
		||||
	node_descriptor->destroy.notify = destroy_notify;
 | 
			
		||||
	wl_signal_add(&node->events.destroy, &node_descriptor->destroy);
 | 
			
		||||
	node->data = node_descriptor;
 | 
			
		||||
	wl_signal_add(&scene_node->events.destroy, &node_descriptor->destroy);
 | 
			
		||||
	scene_node->data = node_descriptor;
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
struct view *
 | 
			
		||||
node_view_from_node(struct node_descriptor *node_descriptor)
 | 
			
		||||
{
 | 
			
		||||
	assert(node_descriptor->type == LAB_NODE_DESC_VIEW
 | 
			
		||||
		|| node_descriptor->type == LAB_NODE_DESC_XDG_POPUP);
 | 
			
		||||
	return (struct view *)node_descriptor->data;
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
struct lab_layer_surface *
 | 
			
		||||
node_layer_surface_from_node(struct node_descriptor *node_descriptor)
 | 
			
		||||
{
 | 
			
		||||
	assert(node_descriptor->type == LAB_NODE_DESC_LAYER_SURFACE);
 | 
			
		||||
	return (struct lab_layer_surface *)node_descriptor->data;
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
struct lab_layer_popup *
 | 
			
		||||
node_layer_popup_from_node(struct node_descriptor *node_descriptor)
 | 
			
		||||
{
 | 
			
		||||
	assert(node_descriptor->type == LAB_NODE_DESC_LAYER_POPUP);
 | 
			
		||||
	return (struct lab_layer_popup *)node_descriptor->data;
 | 
			
		||||
}
 | 
			
		||||
| 
						 | 
				
			
			
 | 
			
		|||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue