diff --git a/kiwmi/desktop/.output.c.kak.pRsrnt b/kiwmi/desktop/.output.c.kak.pRsrnt deleted file mode 100644 index 4017256..0000000 --- a/kiwmi/desktop/.output.c.kak.pRsrnt +++ /dev/null @@ -1,277 +0,0 @@ -wow such kakoune/* Copyright (c), Niclas Meyer - * - * This Source Code Form is subject to the terms of the Mozilla Public - * License, v. 2.0. If a copy of the MPL was not distributed with this file, - * You can obtain one at https://mozilla.org/MPL/2.0/. - */ - -#include "desktop/output.h" - -#include - -#include -#include -#include -#include -#include -#include -#include -#include -#include -#include - -#include "desktop/desktop.h" -#include "desktop/layer_shell.h" -#include "desktop/view.h" -#include "input/cursor.h" -#include "input/input.h" -#include "server.h" - -static void -render_layer_surface(struct wlr_surface *surface, int x, int y, void *data) -{ - struct kiwmi_render_data *rdata = data; - struct wlr_output *output = rdata->output; - struct wlr_box *geom = rdata->data; - - struct wlr_texture *texture = wlr_surface_get_texture(surface); - if (!texture) { - return; - } - - int ox = rdata->output_lx + x + geom->x; - int oy = rdata->output_ly + y + geom->y; - - struct wlr_box box = { - .x = ox * output->scale, - .y = oy * output->scale, - .width = surface->current.width * output->scale, - .height = surface->current.height * output->scale, - }; - - float matrix[9]; - enum wl_output_transform transform = - wlr_output_transform_invert(surface->current.transform); - wlr_matrix_project_box( - matrix, &box, transform, 0, output->transform_matrix); - - wlr_render_texture_with_matrix(rdata->renderer, texture, matrix, 1); - - wlr_surface_send_frame_done(surface, rdata->when); -} - -static void -render_layer(struct wl_list *layer, struct kiwmi_render_data *rdata) -{ - struct kiwmi_layer *surface; - wl_list_for_each (surface, layer, link) { - rdata->data = &surface->geom; - - wlr_layer_surface_v1_for_each_surface( - surface->layer_surface, render_layer_surface, rdata); - } -} - -static void -render_surface(struct wlr_surface *surface, int sx, int sy, void *data) -{ - struct kiwmi_render_data *rdata = data; - struct kiwmi_view *view = rdata->data; - struct wlr_output *output = rdata->output; - - struct wlr_texture *texture = wlr_surface_get_texture(surface); - if (!texture) { - return; - } - - int ox = rdata->output_lx + sx + view->x - view->geom.x; - int oy = rdata->output_ly + sy + view->y - view->geom.y; - - struct wlr_box box = { - .x = ox * output->scale, - .y = oy * output->scale, - .width = surface->current.width * output->scale, - .height = surface->current.height * output->scale, - }; - - float matrix[9]; - enum wl_output_transform transform = - wlr_output_transform_invert(surface->current.transform); - wlr_matrix_project_box( - matrix, &box, transform, 0, output->transform_matrix); - - wlr_render_texture_with_matrix(rdata->renderer, texture, matrix, 1); - - wlr_surface_send_frame_done(surface, rdata->when); -} - -static void -output_frame_notify(struct wl_listener *listener, void *data) -{ - struct kiwmi_output *output = wl_container_of(listener, output, frame); - struct wlr_output *wlr_output = data; - struct kiwmi_desktop *desktop = output->desktop; - struct wlr_output_layout *output_layout = desktop->output_layout; - struct wlr_renderer *renderer = - wlr_backend_get_renderer(wlr_output->backend); - - struct timespec now; - clock_gettime(CLOCK_MONOTONIC, &now); - - if (!wlr_output_attach_render(wlr_output, NULL)) { - wlr_log(WLR_ERROR, "Failed to attach renderer to output"); - return; - } - - int width; - int height; - wlr_output_effective_resolution(wlr_output, &width, &height); - - wlr_renderer_begin(renderer, width, height); - wlr_renderer_clear(renderer, (float[]){0.0f, 1.0f, 0.0f, 1.0f}); - - double output_lx; - double output_ly; - wlr_output_layout_output_coords( - output_layout, wlr_output, &output_lx, &output_ly); - - struct kiwmi_render_data rdata = { - .output = output->wlr_output, - .output_lx = output_lx, - .output_ly = output_ly, - .renderer = renderer, - .when = &now, - }; - - render_layer(&output->layers[ZWLR_LAYER_SHELL_V1_LAYER_BACKGROUND], &rdata); - render_layer(&output->layers[ZWLR_LAYER_SHELL_V1_LAYER_BOTTOM], &rdata); - - struct kiwmi_view *view; - wl_list_for_each_reverse (view, &desktop->views, link) { - if (view->hidden || !view->mapped) { - continue; - } - - rdata.data = view; - - wl_signal_emit(&view->events.pre_render, &rdata); - view_for_each_surface(view, render_surface, &rdata); - wl_signal_emit(&view->events.post_render, &rdata); - } - - render_layer(&output->layers[ZWLR_LAYER_SHELL_V1_LAYER_TOP], &rdata); - render_layer(&output->layers[ZWLR_LAYER_SHELL_V1_LAYER_OVERLAY], &rdata); - - wlr_output_render_software_cursors(wlr_output, NULL); - wlr_renderer_end(renderer); - - wlr_output_commit(wlr_output); -} - -static void -output_destroy_notify(struct wl_listener *listener, void *UNUSED(data)) -{ - struct kiwmi_output *output = wl_container_of(listener, output, destroy); - - wlr_output_layout_remove( - output->desktop->output_layout, output->wlr_output); - - wl_signal_emit(&output->events.destroy, output); - - wl_list_remove(&output->link); - wl_list_remove(&output->frame.link); - wl_list_remove(&output->destroy.link); - - free(output); -} - -static void -output_mode_notify(struct wl_listener *listener, void *UNUSED(data)) -{ - struct kiwmi_output *output = wl_container_of(listener, output, mode); - - arrange_layers(output); - - wl_signal_emit(&output->events.resize, output); -} - -static void -output_transform_notify(struct wl_listener *listener, void *UNUSED(data)) -{ - struct kiwmi_output *output = wl_container_of(listener, output, transform); - - arrange_layers(output); - - wl_signal_emit(&output->events.resize, output); -} - -static struct kiwmi_output * -output_create(struct wlr_output *wlr_output, struct kiwmi_desktop *desktop) -{ - struct kiwmi_output *output = calloc(1, sizeof(*output)); - if (!output) { - return NULL; - } - - output->wlr_output = wlr_output; - output->desktop = desktop; - - output->frame.notify = output_frame_notify; - wl_signal_add(&wlr_output->events.frame, &output->frame); - - output->destroy.notify = output_destroy_notify; - wl_signal_add(&wlr_output->events.destroy, &output->destroy); - - output->mode.notify = output_mode_notify; - wl_signal_add(&wlr_output->events.mode, &output->mode); - - output->transform.notify = output_transform_notify; - wl_signal_add(&wlr_output->events.transform, &output->transform); - - return output; -} - -void -new_output_notify(struct wl_listener *listener, void *data) -{ - struct kiwmi_desktop *desktop = - wl_container_of(listener, desktop, new_output); - struct kiwmi_server *server = wl_container_of(desktop, server, desktop); - struct wlr_output *wlr_output = data; - - wlr_log(WLR_DEBUG, "New output %p: %s", wlr_output, wlr_output->name); - - if (!wl_list_empty(&wlr_output->modes)) { - struct wlr_output_mode *mode = - wl_container_of(wlr_output->modes.prev, mode, link); - wlr_output_set_mode(wlr_output, mode); - } - - struct kiwmi_output *output = output_create(wlr_output, desktop); - if (!output) { - wlr_log(WLR_ERROR, "Failed to create output"); - return; - } - - wlr_output->data = output; - - struct kiwmi_cursor *cursor = server->input.cursor; - - wlr_xcursor_manager_load(cursor->xcursor_manager, wlr_output->scale); - - wl_list_insert(&desktop->outputs, &output->link); - - wlr_output_layout_add_auto(desktop->output_layout, wlr_output); - - wlr_output_create_global(wlr_output); - - size_t len_outputs = sizeof(output->layers) / sizeof(output->layers[0]); - for (size_t i = 0; i < len_outputs; ++i) { - wl_list_init(&output->layers[i]); - } - - wl_signal_init(&output->events.destroy); - wl_signal_init(&output->events.resize); - - wl_signal_emit(&desktop->events.new_output, output); -}