Mercurial > emacs
annotate oldXMenu/Post.c @ 29004:383e4e21306a
(LEADING_CODE_8_BIT_CONTROL, CHARSET_8_BIT_CONTROL,
CHARSET_8_BIT_GRAPHIC): New macros.
(SINGLE_BYTE_CHAR_P): Make it faster by using casting.
(CHARSET_ISO_GRAPHIC_PLANE): Use XINT instead of XFASTINT.
(CHARSET_REVERSE_CHARSET): Likewise.
(CHARSET_VALID_P): Handle new charsets; eight-bit-control and
eight-bit-graphic.
(BYTES_BY_CHAR_HEAD, WIDTH_BY_CHAR_HEAD): Optimize for ASCII.
(CHAR_CHARSET, MAKE_CHAR, SPLIT_CHAR, CHAR_BYTES): Likewise.
(PARSE_MULTIBYTE_SEQ) [BYTE_COMBINING_DEBUG]: Abort if we
encounter an invalid multibyte sequence.
(PARSE_MULTIBYTE_SEQ) [not BYTE_COMBINING_DEBUG]: Assume multibyte
sequence is always valid.
(MAKE_NON_ASCII_CHAR, SPLIT_NON_ASCII_CHAR): These macros Deleted.
(UNIBYTE_STR_AS_MULTIBYTE_P, MULTIBYTE_STR_AS_UNIBYTE_P): New
macros.
(CHAR_STRING): For 8-bit characters, call char_to_string.
(INC_POS) [not BYTE_COMBINING_DEBUG]: Faster version. Assume
multibyte sequence is always valid.
(BUF_INC_POS) [not BYTE_COMBINING_DEBUG]: Likewise.
(parse_str_as_multibyte, str_as_multibyte, str_to_multibyte,
str_as_unibyte): Extern them.
(BCOPY_SHORT): Fix a bug.
(CHAR_LEN): This macro deleted. Callers changed to use
CHAR_BYTES.
(FETCH_STRING_CHAR_ADVANCE): Check multibyteness of STRING.
(FETCH_STRING_CHAR_ADVANCE_NO_CHECK): New macro.
(FETCH_CHAR_ADVANCE): Check multibyteness of the current buffer.
author | Kenichi Handa <handa@m17n.org> |
---|---|
date | Fri, 19 May 2000 23:54:05 +0000 |
parents | 4a9ea0d1735b |
children | 23a1cea22d13 |
rev | line source |
---|---|
25858 | 1 #include "copyright.h" |
2 | |
27456
4a9ea0d1735b
(XMenuPost): Pass null help callback to XMenuActivate.
Gerd Moellmann <gerd@gnu.org>
parents:
25858
diff
changeset
|
3 /* $Header: /gd/gnu/cvsroot/emacs/oldXMenu/Post.c,v 1.1 1999/10/03 19:35:10 fx Exp $ */ |
25858 | 4 /* Copyright Massachusetts Institute of Technology 1985 */ |
5 | |
6 /* | |
7 * XMenu: MIT Project Athena, X Window system menu package | |
8 * | |
9 * XMenuPost - Maps a given menu to the display and activates | |
10 * the menu for user selection. The user is allowed to | |
11 * specify the mouse button event mask that will be used | |
12 * to identify a selection request. When a selection | |
13 * request is received (i.e., when the specified mouse | |
14 * event occurs) the data returned will be either the | |
15 * data associated with the particular selection active | |
16 * at the time of the selection request or NULL if no | |
17 * selection was active. A menu selection is shown to | |
18 * be active by placing a highlight box around the | |
19 * selection as the mouse cursor enters its active | |
20 * region. Inactive selections will not be highlighted. | |
21 * As the mouse cursor moved from one menu pane | |
22 * to another menu pane the pane being entered is raised | |
23 * and activated and the pane being left is deactivated. | |
24 * If an error occurs NULL will be returned with the | |
25 * p_num set to POST_ERROR, s_num set to | |
26 * NO_SELECTION and _XMErrorCode set to an | |
27 * appropriate value. | |
28 * Every time the routine returns successfully the | |
29 * p_num and s_num indices will be set to indicate | |
30 * the currently active pane and/or selection. If the | |
31 * mouse was not in a selection window at the time | |
32 * s_num will be set to NO_SELECTION. | |
33 * | |
34 * Author: Tony Della Fera, DEC | |
35 * August, 1984 | |
36 * | |
37 */ | |
38 | |
39 #include "XMenuInt.h" | |
40 | |
41 char * | |
42 XMenuPost(display, menu, p_num, s_num, x_pos, y_pos, event_mask) | |
43 register Display *display; /* Previously opened display. */ | |
44 register XMenu *menu; /* Menu to post. */ | |
45 register int *p_num; /* Pane number selected. */ | |
46 register int *s_num; /* Selection number selected. */ | |
47 register int x_pos; /* X coordinate of menu position. */ | |
48 register int y_pos; /* Y coordinate of menu position. */ | |
49 int event_mask; /* Mouse button event mask. */ | |
50 { | |
51 register int stat; /* Routine call return status. */ | |
52 char *data; /* Return data. */ | |
53 | |
54 /* | |
55 * Set up initial pane and selection assumptions. | |
56 */ | |
57 | |
58 /* | |
59 * Make the procedure call. | |
60 */ | |
61 stat = XMenuActivate( | |
62 display, | |
63 menu, | |
64 p_num, s_num, | |
65 x_pos, y_pos, | |
66 event_mask, | |
27456
4a9ea0d1735b
(XMenuPost): Pass null help callback to XMenuActivate.
Gerd Moellmann <gerd@gnu.org>
parents:
25858
diff
changeset
|
67 &data, 0); |
25858 | 68 |
69 /* | |
70 * Check the return value and return accordingly. | |
71 */ | |
72 switch (stat) { | |
73 case XM_FAILURE: | |
74 *p_num = POST_ERROR; | |
75 *s_num = NO_SELECTION; | |
76 return(NULL); | |
77 case XM_NO_SELECT: | |
78 case XM_IA_SELECT: | |
79 *s_num = NO_SELECTION; | |
80 return(NULL); | |
81 case XM_SUCCESS: | |
82 default: | |
83 return(data); | |
84 } | |
85 } |