mirror of
				https://github.com/swaywm/sway.git
				synced 2025-11-03 09:01:43 -05:00 
			
		
		
		
	IPC fixes
This commit is contained in:
		
							parent
							
								
									49379dd0fc
								
							
						
					
					
						commit
						b28e6d2369
					
				
					 2 changed files with 55 additions and 22 deletions
				
			
		| 
						 | 
					@ -66,19 +66,42 @@ static const char *ipc_json_get_output_transform(enum wl_output_transform transf
 | 
				
			||||||
 | 
					
 | 
				
			||||||
static void ipc_json_describe_output(struct sway_container *container, json_object *object) {
 | 
					static void ipc_json_describe_output(struct sway_container *container, json_object *object) {
 | 
				
			||||||
	struct wlr_output *wlr_output = container->sway_output->wlr_output;
 | 
						struct wlr_output *wlr_output = container->sway_output->wlr_output;
 | 
				
			||||||
	json_object_object_add(object, "type", json_object_new_string("output"));
 | 
						json_object_object_add(object, "type",
 | 
				
			||||||
	json_object_object_add(object, "active", json_object_new_boolean(true));
 | 
								json_object_new_string("output"));
 | 
				
			||||||
	json_object_object_add(object, "primary", json_object_new_boolean(false));
 | 
						json_object_object_add(object, "active",
 | 
				
			||||||
	json_object_object_add(object, "layout", json_object_new_string("output"));
 | 
								json_object_new_boolean(true));
 | 
				
			||||||
	json_object_object_add(object, "make", json_object_new_string(wlr_output->make));
 | 
						json_object_object_add(object, "primary",
 | 
				
			||||||
	json_object_object_add(object, "model", json_object_new_string(wlr_output->model));
 | 
								json_object_new_boolean(false));
 | 
				
			||||||
	json_object_object_add(object, "serial", json_object_new_string(wlr_output->serial));
 | 
						json_object_object_add(object, "layout",
 | 
				
			||||||
	json_object_object_add(object, "scale", json_object_new_double(wlr_output->scale));
 | 
								json_object_new_string("output"));
 | 
				
			||||||
	json_object_object_add(object, "refresh", json_object_new_int(wlr_output->refresh));
 | 
						json_object_object_add(object, "make",
 | 
				
			||||||
 | 
								json_object_new_string(wlr_output->make));
 | 
				
			||||||
 | 
						json_object_object_add(object, "model",
 | 
				
			||||||
 | 
								json_object_new_string(wlr_output->model));
 | 
				
			||||||
 | 
						json_object_object_add(object, "serial",
 | 
				
			||||||
 | 
								json_object_new_string(wlr_output->serial));
 | 
				
			||||||
 | 
						json_object_object_add(object, "scale",
 | 
				
			||||||
 | 
								json_object_new_double(wlr_output->scale));
 | 
				
			||||||
 | 
						json_object_object_add(object, "refresh",
 | 
				
			||||||
 | 
								json_object_new_int(wlr_output->refresh));
 | 
				
			||||||
	json_object_object_add(object, "transform",
 | 
						json_object_object_add(object, "transform",
 | 
				
			||||||
		json_object_new_string(ipc_json_get_output_transform(wlr_output->transform)));
 | 
							json_object_new_string(
 | 
				
			||||||
	// TODO WLR need to set "current_workspace" to the currently focused
 | 
								ipc_json_get_output_transform(wlr_output->transform)));
 | 
				
			||||||
	// workspace in a way that makes sense with multiseat
 | 
					
 | 
				
			||||||
 | 
						struct sway_seat *seat = sway_input_manager_get_default_seat(input_manager);
 | 
				
			||||||
 | 
						const char *ws = NULL;
 | 
				
			||||||
 | 
						if (seat) {
 | 
				
			||||||
 | 
							struct sway_container *focus =
 | 
				
			||||||
 | 
								sway_seat_get_focus_inactive(seat, container);
 | 
				
			||||||
 | 
							if (focus && focus->type != C_WORKSPACE) {
 | 
				
			||||||
 | 
								focus = container_parent(focus, C_WORKSPACE);
 | 
				
			||||||
 | 
							}
 | 
				
			||||||
 | 
							if (focus) {
 | 
				
			||||||
 | 
								ws = focus->name;
 | 
				
			||||||
 | 
							}
 | 
				
			||||||
 | 
						}
 | 
				
			||||||
 | 
						json_object_object_add(object, "current_workspace",
 | 
				
			||||||
 | 
								json_object_new_string(ws));
 | 
				
			||||||
 | 
					
 | 
				
			||||||
	json_object *modes_array = json_object_new_array();
 | 
						json_object *modes_array = json_object_new_array();
 | 
				
			||||||
	struct wlr_output_mode *mode;
 | 
						struct wlr_output_mode *mode;
 | 
				
			||||||
| 
						 | 
					@ -95,16 +118,20 @@ static void ipc_json_describe_output(struct sway_container *container, json_obje
 | 
				
			||||||
	json_object_object_add(object, "modes", modes_array);
 | 
						json_object_object_add(object, "modes", modes_array);
 | 
				
			||||||
}
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
static void ipc_json_describe_workspace(struct sway_container *workspace, json_object *object) {
 | 
					static void ipc_json_describe_workspace(struct sway_container *workspace,
 | 
				
			||||||
	int num = (isdigit(workspace->name[0])) ? atoi(workspace->name) : -1;
 | 
							json_object *object) {
 | 
				
			||||||
 | 
						int num = isdigit(workspace->name[0]) ? atoi(workspace->name) : -1;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
	json_object_object_add(object, "num", json_object_new_int(num));
 | 
						json_object_object_add(object, "num", json_object_new_int(num));
 | 
				
			||||||
	json_object_object_add(object, "output", (workspace->parent) ? json_object_new_string(workspace->parent->name) : NULL);
 | 
						json_object_object_add(object, "output", workspace->parent ?
 | 
				
			||||||
 | 
								json_object_new_string(workspace->parent->name) : NULL);
 | 
				
			||||||
	json_object_object_add(object, "type", json_object_new_string("workspace"));
 | 
						json_object_object_add(object, "type", json_object_new_string("workspace"));
 | 
				
			||||||
 | 
						json_object_object_add(object, "urgent", json_object_new_boolean(false));
 | 
				
			||||||
}
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
static void ipc_json_describe_view(struct sway_container *c, json_object *object) {
 | 
					static void ipc_json_describe_view(struct sway_container *c, json_object *object) {
 | 
				
			||||||
	json_object_object_add(object, "name", (c->name) ? json_object_new_string(c->name) : NULL);
 | 
						json_object_object_add(object, "name",
 | 
				
			||||||
 | 
								c->name ? json_object_new_string(c->name) : NULL);
 | 
				
			||||||
}
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
json_object *ipc_json_describe_container(struct sway_container *c) {
 | 
					json_object *ipc_json_describe_container(struct sway_container *c) {
 | 
				
			||||||
| 
						 | 
					@ -118,28 +145,26 @@ json_object *ipc_json_describe_container(struct sway_container *c) {
 | 
				
			||||||
	json_object *object = json_object_new_object();
 | 
						json_object *object = json_object_new_object();
 | 
				
			||||||
 | 
					
 | 
				
			||||||
	json_object_object_add(object, "id", json_object_new_int((int)c->id));
 | 
						json_object_object_add(object, "id", json_object_new_int((int)c->id));
 | 
				
			||||||
	json_object_object_add(object, "name", (c->name) ? json_object_new_string(c->name) : NULL);
 | 
						json_object_object_add(object, "name",
 | 
				
			||||||
 | 
								c->name ? json_object_new_string(c->name) : NULL);
 | 
				
			||||||
	json_object_object_add(object, "rect", ipc_json_create_rect(c));
 | 
						json_object_object_add(object, "rect", ipc_json_create_rect(c));
 | 
				
			||||||
	json_object_object_add(object, "focused", json_object_new_boolean(focused));
 | 
						json_object_object_add(object, "focused",
 | 
				
			||||||
 | 
								json_object_new_boolean(focused));
 | 
				
			||||||
 | 
					
 | 
				
			||||||
	switch (c->type) {
 | 
						switch (c->type) {
 | 
				
			||||||
	case C_ROOT:
 | 
						case C_ROOT:
 | 
				
			||||||
		ipc_json_describe_root(c, object);
 | 
							ipc_json_describe_root(c, object);
 | 
				
			||||||
		break;
 | 
							break;
 | 
				
			||||||
 | 
					 | 
				
			||||||
	case C_OUTPUT:
 | 
						case C_OUTPUT:
 | 
				
			||||||
		ipc_json_describe_output(c, object);
 | 
							ipc_json_describe_output(c, object);
 | 
				
			||||||
		break;
 | 
							break;
 | 
				
			||||||
 | 
					 | 
				
			||||||
	case C_CONTAINER:
 | 
						case C_CONTAINER:
 | 
				
			||||||
	case C_VIEW:
 | 
						case C_VIEW:
 | 
				
			||||||
		ipc_json_describe_view(c, object);
 | 
							ipc_json_describe_view(c, object);
 | 
				
			||||||
		break;
 | 
							break;
 | 
				
			||||||
 | 
					 | 
				
			||||||
	case C_WORKSPACE:
 | 
						case C_WORKSPACE:
 | 
				
			||||||
		ipc_json_describe_workspace(c, object);
 | 
							ipc_json_describe_workspace(c, object);
 | 
				
			||||||
		break;
 | 
							break;
 | 
				
			||||||
 | 
					 | 
				
			||||||
	case C_TYPES:
 | 
						case C_TYPES:
 | 
				
			||||||
	default:
 | 
						default:
 | 
				
			||||||
		break;
 | 
							break;
 | 
				
			||||||
| 
						 | 
					
 | 
				
			||||||
| 
						 | 
					@ -398,6 +398,14 @@ static void ipc_get_workspaces_callback(struct sway_container *workspace,
 | 
				
			||||||
	json_object_object_add(workspace_json, "focused",
 | 
						json_object_object_add(workspace_json, "focused",
 | 
				
			||||||
			json_object_new_boolean(focused));
 | 
								json_object_new_boolean(focused));
 | 
				
			||||||
	json_object_array_add((json_object *)data, workspace_json);
 | 
						json_object_array_add((json_object *)data, workspace_json);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
						focused_ws = sway_seat_get_focus_inactive(seat, workspace->parent);
 | 
				
			||||||
 | 
						if (focused_ws->type != C_WORKSPACE) {
 | 
				
			||||||
 | 
							focused_ws = container_parent(focused_ws, C_WORKSPACE);
 | 
				
			||||||
 | 
						}
 | 
				
			||||||
 | 
						bool visible = workspace == focused_ws;
 | 
				
			||||||
 | 
						json_object_object_add(workspace_json, "visible",
 | 
				
			||||||
 | 
								json_object_new_boolean(visible));
 | 
				
			||||||
}
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
void ipc_client_handle_command(struct ipc_client *client) {
 | 
					void ipc_client_handle_command(struct ipc_client *client) {
 | 
				
			||||||
| 
						 | 
					
 | 
				
			||||||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue