annotate src/sysselect.h @ 53333:c23cf5520cd9

(Qarrow, Qhand, Qtext, Qpointer): New variables for pointer types. (Qrelative_width, Qalign_to): Remove unused variables. (Vvoid_text_area_pointer): Replace Vshow_text_cursor_in_void. (QCmap, QCpointer, Qrect, Qcircle, Qpoly): New variables for image maps. (x_y_to_hpos_vpos): Return glyph relative coordinates through new dx and dy args. Remove buffer_only_p arg (always 0). Simplify code accordingly. (get_glyph_string_clip_rect): Draw cursor using glyph's rather than row's ascent and height, to get sensible height on tall rows. (build_desired_tool_bar_string): Remove Qimage extern. (get_tool_bar_item): Fix call to x_y_to_hpos_vpos. (produce_image_glyph): Adjust it.ascent to minimum row ascent if image glyph is alone on the last line. (append_glyph, append_composite_glyph, produce_image_glyph) (append_stretch_glyph): Set glyph's ascent and descent. (on_hot_spot_p): New function to check if position is inside an rectangular, circular, or polygon-shaped image hot-spot, (find_hot_spot): New function to search for image hot-spot. (Flookup_image_map): New defun to search for image hot-spot. (define_frame_cursor1): New aux function to determine frame pointer. (note_mode_line_or_margin_highlight, note_mouse_highlight): Handle `pointer' text property and :pointer image property to control frame pointer shape. Detect image hot-spots for pointer and help_echo properties. Use define_frame_cursor1. (note_mouse_highlight): Use Vvoid_text_area_pointer. (syms_of_xdisp): Defsubr new defun. Intern and staticpro new variables. DEFVAR_LISP Vvoid_text_area_pointer instead of Vshow_text_cursor_in_void.
author Kim F. Storm <storm@cua.dk>
date Sun, 28 Dec 2003 00:12:27 +0000
parents 695cf19ef79e
children 5b7105f0624e 375f2633d815
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
10526
62d5058cf94a Initial revision
Karl Heuer <kwzh@gnu.org>
parents:
diff changeset
1 /* sysselect.h - System-dependent definitions for the select function.
62d5058cf94a Initial revision
Karl Heuer <kwzh@gnu.org>
parents:
diff changeset
2 Copyright (C) 1995 Free Software Foundation, Inc.
62d5058cf94a Initial revision
Karl Heuer <kwzh@gnu.org>
parents:
diff changeset
3
62d5058cf94a Initial revision
Karl Heuer <kwzh@gnu.org>
parents:
diff changeset
4 This file is part of GNU Emacs.
62d5058cf94a Initial revision
Karl Heuer <kwzh@gnu.org>
parents:
diff changeset
5
62d5058cf94a Initial revision
Karl Heuer <kwzh@gnu.org>
parents:
diff changeset
6 GNU Emacs is free software; you can redistribute it and/or modify
62d5058cf94a Initial revision
Karl Heuer <kwzh@gnu.org>
parents:
diff changeset
7 it under the terms of the GNU General Public License as published by
62d5058cf94a Initial revision
Karl Heuer <kwzh@gnu.org>
parents:
diff changeset
8 the Free Software Foundation; either version 2, or (at your option)
62d5058cf94a Initial revision
Karl Heuer <kwzh@gnu.org>
parents:
diff changeset
9 any later version.
62d5058cf94a Initial revision
Karl Heuer <kwzh@gnu.org>
parents:
diff changeset
10
62d5058cf94a Initial revision
Karl Heuer <kwzh@gnu.org>
parents:
diff changeset
11 GNU Emacs is distributed in the hope that it will be useful,
62d5058cf94a Initial revision
Karl Heuer <kwzh@gnu.org>
parents:
diff changeset
12 but WITHOUT ANY WARRANTY; without even the implied warranty of
62d5058cf94a Initial revision
Karl Heuer <kwzh@gnu.org>
parents:
diff changeset
13 MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
62d5058cf94a Initial revision
Karl Heuer <kwzh@gnu.org>
parents:
diff changeset
14 GNU General Public License for more details.
62d5058cf94a Initial revision
Karl Heuer <kwzh@gnu.org>
parents:
diff changeset
15
62d5058cf94a Initial revision
Karl Heuer <kwzh@gnu.org>
parents:
diff changeset
16 You should have received a copy of the GNU General Public License
62d5058cf94a Initial revision
Karl Heuer <kwzh@gnu.org>
parents:
diff changeset
17 along with GNU Emacs; see the file COPYING. If not, write to
14186
ee40177f6c68 Update FSF's address in the preamble.
Erik Naggum <erik@naggum.no>
parents: 10526
diff changeset
18 the Free Software Foundation, Inc., 59 Temple Place - Suite 330,
ee40177f6c68 Update FSF's address in the preamble.
Erik Naggum <erik@naggum.no>
parents: 10526
diff changeset
19 Boston, MA 02111-1307, USA. */
10526
62d5058cf94a Initial revision
Karl Heuer <kwzh@gnu.org>
parents:
diff changeset
20
62d5058cf94a Initial revision
Karl Heuer <kwzh@gnu.org>
parents:
diff changeset
21 #ifdef HAVE_SYS_SELECT
62d5058cf94a Initial revision
Karl Heuer <kwzh@gnu.org>
parents:
diff changeset
22 #include <sys/select.h>
62d5058cf94a Initial revision
Karl Heuer <kwzh@gnu.org>
parents:
diff changeset
23 #endif
62d5058cf94a Initial revision
Karl Heuer <kwzh@gnu.org>
parents:
diff changeset
24
62d5058cf94a Initial revision
Karl Heuer <kwzh@gnu.org>
parents:
diff changeset
25 #ifdef FD_SET
62d5058cf94a Initial revision
Karl Heuer <kwzh@gnu.org>
parents:
diff changeset
26 #ifdef FD_SETSIZE
62d5058cf94a Initial revision
Karl Heuer <kwzh@gnu.org>
parents:
diff changeset
27 #define MAXDESC FD_SETSIZE
62d5058cf94a Initial revision
Karl Heuer <kwzh@gnu.org>
parents:
diff changeset
28 #else
62d5058cf94a Initial revision
Karl Heuer <kwzh@gnu.org>
parents:
diff changeset
29 #define MAXDESC 64
62d5058cf94a Initial revision
Karl Heuer <kwzh@gnu.org>
parents:
diff changeset
30 #endif
62d5058cf94a Initial revision
Karl Heuer <kwzh@gnu.org>
parents:
diff changeset
31 #define SELECT_TYPE fd_set
62d5058cf94a Initial revision
Karl Heuer <kwzh@gnu.org>
parents:
diff changeset
32 #else /* no FD_SET */
62d5058cf94a Initial revision
Karl Heuer <kwzh@gnu.org>
parents:
diff changeset
33 #define MAXDESC 32
62d5058cf94a Initial revision
Karl Heuer <kwzh@gnu.org>
parents:
diff changeset
34 #define SELECT_TYPE int
62d5058cf94a Initial revision
Karl Heuer <kwzh@gnu.org>
parents:
diff changeset
35
62d5058cf94a Initial revision
Karl Heuer <kwzh@gnu.org>
parents:
diff changeset
36 /* Define the macros to access a single-int bitmap of descriptors. */
62d5058cf94a Initial revision
Karl Heuer <kwzh@gnu.org>
parents:
diff changeset
37 #define FD_SET(n, p) (*(p) |= (1 << (n)))
62d5058cf94a Initial revision
Karl Heuer <kwzh@gnu.org>
parents:
diff changeset
38 #define FD_CLR(n, p) (*(p) &= ~(1 << (n)))
62d5058cf94a Initial revision
Karl Heuer <kwzh@gnu.org>
parents:
diff changeset
39 #define FD_ISSET(n, p) (*(p) & (1 << (n)))
62d5058cf94a Initial revision
Karl Heuer <kwzh@gnu.org>
parents:
diff changeset
40 #define FD_ZERO(p) (*(p) = 0)
62d5058cf94a Initial revision
Karl Heuer <kwzh@gnu.org>
parents:
diff changeset
41 #endif /* no FD_SET */
62d5058cf94a Initial revision
Karl Heuer <kwzh@gnu.org>
parents:
diff changeset
42
62d5058cf94a Initial revision
Karl Heuer <kwzh@gnu.org>
parents:
diff changeset
43 #if !defined (HAVE_SELECT) || defined (BROKEN_SELECT_NON_X)
62d5058cf94a Initial revision
Karl Heuer <kwzh@gnu.org>
parents:
diff changeset
44 #define select sys_select
62d5058cf94a Initial revision
Karl Heuer <kwzh@gnu.org>
parents:
diff changeset
45 #endif
52401
695cf19ef79e Add arch taglines
Miles Bader <miles@gnu.org>
parents: 14186
diff changeset
46
695cf19ef79e Add arch taglines
Miles Bader <miles@gnu.org>
parents: 14186
diff changeset
47 /* arch-tag: 36d05500-8cf6-4847-8e78-6721f18c06ef
695cf19ef79e Add arch taglines
Miles Bader <miles@gnu.org>
parents: 14186
diff changeset
48 (do not change this comment) */