void combine_updates_for_frame (struct frame *f, bool inhibit_id_p);
void tty_raise_lower_frame (struct frame *f, bool raise);
int max_child_z_order (struct frame *parent);
-void frame_pos_abs (struct frame *f, int *x, int *y);
+void root_xy (struct frame *f, int x, int y, int *rx, int *ry);
bool is_frame_ancestor (struct frame *f1, struct frame *f2);
INLINE_HEADER_END
return true;
}
-/* Return the absolute position of frame F in *X and *Y. */
+/* Translate (X, Y) relative to frame F to absolute coordinates
+ in (*X, *Y). */
void
-frame_pos_abs (struct frame *f, int *x, int *y)
+root_xy (struct frame *f, int x, int y, int *rx, int *ry)
{
- *x = *y = 0;
+ *rx = x;
+ *ry = y;
for (; f; f = FRAME_PARENT_FRAME (f))
{
- *x += f->left_pos;
- *y += f->top_pos;
+ *rx += f->left_pos;
+ *ry += f->top_pos;
}
}
frame_rect_abs (struct frame *f)
{
int x, y;
- frame_pos_abs (f, &x, &y);
+ root_xy (f, 0, 0, &x, &y);
return (struct rect) { x, y, f->total_cols, f->total_lines };
}
wx += max (0, w->left_margin_cols);
- int fx, fy;
- frame_pos_abs (f, &fx, &fy);
- *x = fx + wx;
- *y = fy + wy;
+ root_xy (f, wx, wy, x, y);
return true;
}
struct frame *sf = SELECTED_FRAME ();
if (f == sf || is_frame_ancestor (sf, f))
{
- int fx, fy;
- frame_pos_abs (f, &fx, &fy);
- *x = fx + XFIXNUM (XCAR (XCDR (mouse)));
- *y = fy + XFIXNUM (XCDR (XCDR (mouse)));
+ int mx = XFIXNUM (XCAR (XCDR (mouse)));
+ int my = XFIXNUM (XCDR (XCDR (mouse)));
+ root_xy (f, mx, my, x, y);
}
}