struct shell_surface *pshsurf,
int x, int y, uint32_t flags);
int (*move)(struct shell_surface *shsurf, struct weston_seat *ws);
+ int (*resize)(struct shell_surface *shsurf,
+ struct weston_seat *ws, uint32_t edges);
+
};
struct weston_border {
};
static int
-weston_surface_resize(struct shell_surface *shsurf,
- struct weston_seat *ws, uint32_t edges)
+surface_resize(struct shell_surface *shsurf,
+ struct weston_seat *ws, uint32_t edges)
{
struct weston_resize_grab *resize;
ws->seat.pointer->focus != &shsurf->surface->surface)
return;
- if (weston_surface_resize(shsurf, ws, edges) < 0)
+ if (surface_resize(shsurf, ws, edges) < 0)
wl_resource_post_no_memory(resource);
}
else
edges |= WL_SHELL_SURFACE_RESIZE_BOTTOM;
- weston_surface_resize(shsurf, (struct weston_seat *) seat, edges);
+ surface_resize(shsurf, (struct weston_seat *) seat, edges);
}
static void
ec->shell_interface.set_toplevel = set_toplevel;
ec->shell_interface.set_transient = set_transient;
ec->shell_interface.move = surface_move;
+ ec->shell_interface.resize = surface_resize;
wl_list_init(&shell->backgrounds);
wl_list_init(&shell->panels);
struct weston_wm_window *window;
enum theme_location location;
struct theme *t = wm->theme;
+ int width, height;
fprintf(stderr, "XCB_BUTTON_%s (detail %d)\n",
button->response_type == XCB_BUTTON_PRESS ?
"PRESS" : "RELEASE", button->detail);
window = hash_table_lookup(wm->window_hash, button->event);
+ weston_wm_window_get_frame_size(window, &width, &height);
+
if (button->response_type == XCB_BUTTON_PRESS &&
button->detail == 1) {
location = theme_get_location(t,
button->event_x,
button->event_y,
- window->width,
- window->height);
+ width, height);
switch (location) {
case THEME_LOCATION_TITLEBAR:
shell_interface->move(window->shsurf,
wm->server->compositor->seat);
break;
+ case THEME_LOCATION_RESIZING_TOP:
+ case THEME_LOCATION_RESIZING_BOTTOM:
+ case THEME_LOCATION_RESIZING_LEFT:
+ case THEME_LOCATION_RESIZING_RIGHT:
+ case THEME_LOCATION_RESIZING_TOP_LEFT:
+ case THEME_LOCATION_RESIZING_TOP_RIGHT:
+ case THEME_LOCATION_RESIZING_BOTTOM_LEFT:
+ case THEME_LOCATION_RESIZING_BOTTOM_RIGHT:
+ shell_interface->resize(window->shsurf,
+ wm->server->compositor->seat,
+ location);
+ break;
default:
break;
}