annotate src/mactoolbox.c @ 80771:aee651d7cdc7

(Fmac_resume_apple_event): Distribute cast to pointer over conditional branches.
author YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
date Fri, 29 Aug 2008 08:18:30 +0000
parents 1f63840526a9
children
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
80446
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1 /* Functions for GUI implemented with (HI)Toolbox on the Mac OS.
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2 Copyright (C) 2000, 2001, 2002, 2003, 2004,
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3 2005, 2006, 2007, 2008 Free Software Foundation, Inc.
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5 This file is part of GNU Emacs.
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
6
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
7 GNU Emacs is free software; you can redistribute it and/or modify
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
8 it under the terms of the GNU General Public License as published by
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
9 the Free Software Foundation; either version 3, or (at your option)
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
10 any later version.
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
11
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
12 GNU Emacs is distributed in the hope that it will be useful,
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
13 but WITHOUT ANY WARRANTY; without even the implied warranty of
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
14 MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
15 GNU General Public License for more details.
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
16
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
17 You should have received a copy of the GNU General Public License
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
18 along with GNU Emacs; see the file COPYING. If not, write to
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
19 the Free Software Foundation, Inc., 51 Franklin Street, Fifth Floor,
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
20 Boston, MA 02110-1301, USA. */
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
21
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
22 #include <config.h>
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
23
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
24 #include <stdio.h>
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
25
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
26 #include "lisp.h"
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
27 #include "blockinput.h"
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
28
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
29 #include "macterm.h"
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
30
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
31 #if !TARGET_API_MAC_CARBON
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
32 #include <Quickdraw.h>
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
33 #include <ToolUtils.h>
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
34 #include <Sound.h>
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
35 #include <Events.h>
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
36 #include <Script.h>
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
37 #include <Resources.h>
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
38 #include <Fonts.h>
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
39 #include <TextUtils.h>
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
40 #include <LowMem.h>
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
41 #include <Controls.h>
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
42 #include <Windows.h>
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
43 #include <Displays.h>
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
44 #if defined (__MRC__) || (__MSL__ >= 0x6000)
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
45 #include <ControlDefinitions.h>
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
46 #endif
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
47
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
48 #if __profile__
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
49 #include <profiler.h>
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
50 #endif
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
51 #endif /* not TARGET_API_MAC_CARBON */
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
52
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
53 #include "charset.h"
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
54 #include "coding.h"
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
55 #include "frame.h"
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
56 #include "dispextern.h"
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
57 #include "fontset.h"
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
58 #include "termhooks.h"
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
59 #include "buffer.h"
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
60 #include "window.h"
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
61 #include "keyboard.h"
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
62
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
63 #include <sys/param.h>
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
64
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
65 #ifndef MAC_OSX
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
66 #include <alloca.h>
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
67 #endif
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
68
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
69
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
70 /************************************************************************
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
71 General
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
72 ************************************************************************/
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
73
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
74 /* The difference in pixels between the top left corner of the
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
75 Emacs window (including possible window manager decorations)
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
76 and FRAME_MAC_WINDOW (f). */
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
77 #define FRAME_OUTER_TO_INNER_DIFF_X(f) ((f)->x_pixels_diff)
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
78 #define FRAME_OUTER_TO_INNER_DIFF_Y(f) ((f)->y_pixels_diff)
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
79
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
80 #define mac_window_to_frame(wp) (((mac_output *) GetWRefCon (wp))->mFP)
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
81
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
82 void
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
83 mac_alert_sound_play ()
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
84 {
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
85 #if MAC_OS_X_VERSION_MAX_ALLOWED >= 1020
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
86 AlertSoundPlay ();
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
87 #else
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
88 SysBeep (1);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
89 #endif
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
90 }
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
91
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
92
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
93 /************************************************************************
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
94 Application
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
95 ************************************************************************/
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
96
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
97 extern struct frame *mac_focus_frame P_ ((struct mac_display_info *));
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
98 extern void do_keystroke P_ ((EventKind, unsigned char, UInt32, UInt32,
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
99 unsigned long, struct input_event *));
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
100 extern UInt32 mac_mapped_modifiers P_ ((UInt32, UInt32));
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
101 #if TARGET_API_MAC_CARBON
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
102 extern int mac_to_emacs_modifiers P_ ((UInt32, UInt32));
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
103 #else
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
104 extern int mac_to_emacs_modifiers P_ ((EventModifiers, EventModifiers));
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
105 #endif
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
106
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
107 #if TARGET_API_MAC_CARBON
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
108 /* Points to the variable `inev' in the function XTread_socket. It is
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
109 used for passing an input event to the function back from
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
110 Carbon/Apple event handlers. */
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
111 static struct input_event *read_socket_inev = NULL;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
112
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
113 extern const unsigned char keycode_to_xkeysym_table[];
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
114 extern EMACS_INT extra_keyboard_modifiers;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
115
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
116 extern Lisp_Object Qhi_command;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
117 #if USE_MAC_TSM
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
118 static TSMDocumentID tsm_document_id;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
119 extern Lisp_Object Qtext_input;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
120 extern Lisp_Object Qupdate_active_input_area, Qunicode_for_key_event;
80520
aaff809b3a06 (Vmac_ts_active_input_buf) [USE_MAC_TSM]: Add extern.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents: 80517
diff changeset
121 extern Lisp_Object Vmac_ts_active_input_overlay, Vmac_ts_active_input_buf;
80446
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
122 extern Lisp_Object Qbefore_string;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
123 #endif
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
124
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
125 static int mac_event_to_emacs_modifiers P_ ((EventRef));
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
126 static OSStatus install_menu_target_item_handler P_ ((void));
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
127 #ifdef MAC_OSX
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
128 static OSStatus install_service_handler P_ ((void));
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
129 #endif
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
130
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
131 extern OSStatus mac_store_event_ref_as_apple_event P_ ((AEEventClass, AEEventID,
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
132 Lisp_Object,
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
133 Lisp_Object,
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
134 EventRef, UInt32,
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
135 const EventParamName *,
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
136 const EventParamType *));
80520
aaff809b3a06 (Vmac_ts_active_input_buf) [USE_MAC_TSM]: Add extern.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents: 80517
diff changeset
137 extern int fast_find_position P_ ((struct window *, int, int *, int *,
aaff809b3a06 (Vmac_ts_active_input_buf) [USE_MAC_TSM]: Add extern.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents: 80517
diff changeset
138 int *, int *, Lisp_Object));
aaff809b3a06 (Vmac_ts_active_input_buf) [USE_MAC_TSM]: Add extern.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents: 80517
diff changeset
139 extern struct glyph *x_y_to_hpos_vpos P_ ((struct window *, int, int,
aaff809b3a06 (Vmac_ts_active_input_buf) [USE_MAC_TSM]: Add extern.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents: 80517
diff changeset
140 int *, int *, int *, int *, int *));
aaff809b3a06 (Vmac_ts_active_input_buf) [USE_MAC_TSM]: Add extern.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents: 80517
diff changeset
141 extern void mac_ax_selected_text_range P_ ((struct frame *, CFRange *));
aaff809b3a06 (Vmac_ts_active_input_buf) [USE_MAC_TSM]: Add extern.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents: 80517
diff changeset
142 #if MAC_OS_X_VERSION_MAX_ALLOWED >= 1030
aaff809b3a06 (Vmac_ts_active_input_buf) [USE_MAC_TSM]: Add extern.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents: 80517
diff changeset
143 extern unsigned int mac_ax_number_of_characters P_ ((struct frame *));
aaff809b3a06 (Vmac_ts_active_input_buf) [USE_MAC_TSM]: Add extern.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents: 80517
diff changeset
144 #endif
80446
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
145
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
146 #if USE_MAC_TSM
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
147 extern OSStatus mac_restore_keyboard_input_source P_ ((void));
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
148 extern void mac_save_keyboard_input_source P_ ((void));
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
149
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
150 static OSStatus
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
151 mac_tsm_resume ()
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
152 {
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
153 OSStatus err;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
154
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
155 err = ActivateTSMDocument (tsm_document_id);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
156 if (err == noErr)
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
157 err = mac_restore_keyboard_input_source ();
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
158
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
159 return err;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
160 }
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
161
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
162 static OSStatus
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
163 mac_tsm_suspend ()
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
164 {
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
165 OSStatus err;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
166
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
167 mac_save_keyboard_input_source ();
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
168 err = DeactivateTSMDocument (tsm_document_id);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
169
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
170 return err;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
171 }
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
172
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
173 static void
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
174 init_tsm ()
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
175 {
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
176 #ifdef MAC_OSX
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
177 static InterfaceTypeList types = {kUnicodeDocument};
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
178 #else
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
179 static InterfaceTypeList types = {kTextService};
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
180 #endif
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
181
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
182 NewTSMDocument (sizeof (types) / sizeof (types[0]), types,
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
183 &tsm_document_id, 0);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
184 }
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
185 #endif /* USE_MAC_TSM */
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
186
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
187 static pascal OSStatus
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
188 mac_handle_keyboard_event (next_handler, event, data)
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
189 EventHandlerCallRef next_handler;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
190 EventRef event;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
191 void *data;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
192 {
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
193 OSStatus err, result = eventNotHandledErr;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
194 UInt32 event_kind, key_code, modifiers;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
195 unsigned char char_code;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
196
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
197 event_kind = GetEventKind (event);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
198 switch (event_kind)
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
199 {
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
200 case kEventRawKeyDown:
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
201 case kEventRawKeyRepeat:
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
202 case kEventRawKeyUp:
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
203 /* When using Carbon Events, we need to pass raw keyboard events
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
204 to the TSM ourselves. If TSM handles it, it will pass back
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
205 noErr, otherwise it will pass back "eventNotHandledErr" and
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
206 we can process it normally. */
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
207 result = CallNextEventHandler (next_handler, event);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
208 if (result != eventNotHandledErr)
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
209 break;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
210
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
211 if (read_socket_inev == NULL)
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
212 break;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
213
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
214 #if USE_MAC_TSM
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
215 if (read_socket_inev->kind != NO_EVENT)
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
216 {
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
217 result = noErr;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
218 break;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
219 }
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
220 #endif
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
221
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
222 if (event_kind == kEventRawKeyUp)
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
223 break;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
224
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
225 err = GetEventParameter (event, kEventParamKeyMacCharCodes,
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
226 typeChar, NULL,
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
227 sizeof (char), NULL, &char_code);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
228 if (err != noErr)
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
229 break;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
230
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
231 err = GetEventParameter (event, kEventParamKeyCode,
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
232 typeUInt32, NULL,
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
233 sizeof (UInt32), NULL, &key_code);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
234 if (err != noErr)
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
235 break;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
236
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
237 err = GetEventParameter (event, kEventParamKeyModifiers,
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
238 typeUInt32, NULL,
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
239 sizeof (UInt32), NULL, &modifiers);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
240 if (err != noErr)
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
241 break;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
242
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
243 do_keystroke ((event_kind == kEventRawKeyDown ? keyDown : autoKey),
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
244 char_code, key_code, modifiers,
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
245 ((unsigned long)
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
246 (GetEventTime (event) / kEventDurationMillisecond)),
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
247 read_socket_inev);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
248 result = noErr;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
249 break;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
250
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
251 default:
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
252 abort ();
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
253 }
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
254
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
255 return result;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
256 }
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
257
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
258 static pascal OSStatus
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
259 mac_handle_command_event (next_handler, event, data)
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
260 EventHandlerCallRef next_handler;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
261 EventRef event;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
262 void *data;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
263 {
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
264 OSStatus err, result = eventNotHandledErr;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
265 HICommand command;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
266 static const EventParamName names[] =
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
267 {kEventParamDirectObject, kEventParamKeyModifiers};
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
268 static const EventParamType types[] =
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
269 {typeHICommand, typeUInt32};
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
270 int num_params = sizeof (names) / sizeof (names[0]);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
271
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
272 err = GetEventParameter (event, kEventParamDirectObject, typeHICommand,
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
273 NULL, sizeof (HICommand), NULL, &command);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
274 if (err != noErr)
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
275 return eventNotHandledErr;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
276
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
277 switch (GetEventKind (event))
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
278 {
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
279 case kEventCommandProcess:
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
280 result = CallNextEventHandler (next_handler, event);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
281 if (result != eventNotHandledErr)
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
282 break;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
283
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
284 err = GetEventParameter (event, kEventParamDirectObject,
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
285 typeHICommand, NULL,
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
286 sizeof (HICommand), NULL, &command);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
287
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
288 if (err != noErr || command.commandID == 0)
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
289 break;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
290
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
291 /* A HI command event is mapped to an Apple event whose event
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
292 class symbol is `hi-command' and event ID is its command
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
293 ID. */
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
294 err = mac_store_event_ref_as_apple_event (0, command.commandID,
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
295 Qhi_command, Qnil,
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
296 event, num_params,
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
297 names, types);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
298 if (err == noErr)
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
299 result = noErr;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
300 break;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
301
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
302 default:
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
303 abort ();
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
304 }
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
305
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
306 return result;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
307 }
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
308
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
309 static pascal OSStatus
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
310 mac_handle_mouse_event (next_handler, event, data)
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
311 EventHandlerCallRef next_handler;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
312 EventRef event;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
313 void *data;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
314 {
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
315 OSStatus err, result = eventNotHandledErr;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
316
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
317 switch (GetEventKind (event))
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
318 {
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
319 case kEventMouseWheelMoved:
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
320 {
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
321 WindowRef wp;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
322 struct frame *f;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
323 EventMouseWheelAxis axis;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
324 SInt32 delta;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
325 Point point;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
326
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
327 result = CallNextEventHandler (next_handler, event);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
328 if (result != eventNotHandledErr || read_socket_inev == NULL)
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
329 break;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
330
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
331 f = mac_focus_frame (&one_mac_display_info);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
332
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
333 err = GetEventParameter (event, kEventParamWindowRef, typeWindowRef,
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
334 NULL, sizeof (WindowRef), NULL, &wp);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
335 if (err != noErr
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
336 || wp != FRAME_MAC_WINDOW (f))
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
337 break;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
338
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
339 err = GetEventParameter (event, kEventParamMouseWheelAxis,
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
340 typeMouseWheelAxis, NULL,
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
341 sizeof (EventMouseWheelAxis), NULL, &axis);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
342 if (err != noErr || axis != kEventMouseWheelAxisY)
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
343 break;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
344
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
345 err = GetEventParameter (event, kEventParamMouseLocation,
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
346 typeQDPoint, NULL, sizeof (Point),
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
347 NULL, &point);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
348 if (err != noErr)
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
349 break;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
350
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
351 point.h -= f->left_pos + FRAME_OUTER_TO_INNER_DIFF_X (f);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
352 point.v -= f->top_pos + FRAME_OUTER_TO_INNER_DIFF_Y (f);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
353 if (point.h < 0 || point.v < 0
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
354 || EQ (window_from_coordinates (f, point.h, point.v, 0, 0, 0, 1),
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
355 f->tool_bar_window))
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
356 break;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
357
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
358 err = GetEventParameter (event, kEventParamMouseWheelDelta,
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
359 typeSInt32, NULL, sizeof (SInt32),
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
360 NULL, &delta);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
361 if (err != noErr)
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
362 break;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
363
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
364 read_socket_inev->kind = WHEEL_EVENT;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
365 read_socket_inev->code = 0;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
366 read_socket_inev->modifiers =
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
367 (mac_event_to_emacs_modifiers (event)
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
368 | ((delta < 0) ? down_modifier : up_modifier));
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
369 XSETINT (read_socket_inev->x, point.h);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
370 XSETINT (read_socket_inev->y, point.v);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
371 XSETFRAME (read_socket_inev->frame_or_window, f);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
372
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
373 result = noErr;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
374 }
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
375 break;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
376
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
377 default:
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
378 abort ();
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
379 }
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
380
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
381 return result;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
382 }
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
383
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
384 #if USE_MAC_TSM
80520
aaff809b3a06 (Vmac_ts_active_input_buf) [USE_MAC_TSM]: Add extern.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents: 80517
diff changeset
385 extern void mac_get_selected_range P_ ((struct window *, CFRange *));
aaff809b3a06 (Vmac_ts_active_input_buf) [USE_MAC_TSM]: Add extern.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents: 80517
diff changeset
386 extern int mac_store_buffer_text_to_unicode_chars P_ ((struct buffer *,
aaff809b3a06 (Vmac_ts_active_input_buf) [USE_MAC_TSM]: Add extern.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents: 80517
diff changeset
387 int, int, UniChar *));
aaff809b3a06 (Vmac_ts_active_input_buf) [USE_MAC_TSM]: Add extern.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents: 80517
diff changeset
388
80446
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
389 static pascal OSStatus
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
390 mac_handle_text_input_event (next_handler, event, data)
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
391 EventHandlerCallRef next_handler;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
392 EventRef event;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
393 void *data;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
394 {
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
395 OSStatus err, result;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
396 Lisp_Object id_key = Qnil;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
397 int num_params;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
398 const EventParamName *names;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
399 const EventParamType *types;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
400 static UInt32 seqno_uaia = 0;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
401 static const EventParamName names_uaia[] =
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
402 {kEventParamTextInputSendComponentInstance,
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
403 kEventParamTextInputSendRefCon,
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
404 kEventParamTextInputSendSLRec,
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
405 kEventParamTextInputSendFixLen,
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
406 kEventParamTextInputSendText,
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
407 kEventParamTextInputSendUpdateRng,
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
408 kEventParamTextInputSendHiliteRng,
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
409 kEventParamTextInputSendClauseRng,
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
410 kEventParamTextInputSendPinRng,
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
411 kEventParamTextInputSendTextServiceEncoding,
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
412 kEventParamTextInputSendTextServiceMacEncoding,
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
413 EVENT_PARAM_TEXT_INPUT_SEQUENCE_NUMBER};
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
414 static const EventParamType types_uaia[] =
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
415 {typeComponentInstance,
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
416 typeLongInteger,
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
417 typeIntlWritingCode,
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
418 typeLongInteger,
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
419 #ifdef MAC_OSX
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
420 typeUnicodeText,
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
421 #else
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
422 typeChar,
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
423 #endif
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
424 typeTextRangeArray,
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
425 typeTextRangeArray,
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
426 typeOffsetArray,
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
427 typeTextRange,
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
428 typeUInt32,
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
429 typeUInt32,
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
430 typeUInt32};
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
431 static const EventParamName names_ufke[] =
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
432 {kEventParamTextInputSendComponentInstance,
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
433 kEventParamTextInputSendRefCon,
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
434 kEventParamTextInputSendSLRec,
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
435 kEventParamTextInputSendText};
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
436 static const EventParamType types_ufke[] =
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
437 {typeComponentInstance,
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
438 typeLongInteger,
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
439 typeIntlWritingCode,
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
440 typeUnicodeText};
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
441
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
442 result = CallNextEventHandler (next_handler, event);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
443 if (result != eventNotHandledErr)
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
444 return result;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
445
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
446 switch (GetEventKind (event))
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
447 {
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
448 case kEventTextInputUpdateActiveInputArea:
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
449 id_key = Qupdate_active_input_area;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
450 num_params = sizeof (names_uaia) / sizeof (names_uaia[0]);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
451 names = names_uaia;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
452 types = types_uaia;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
453 SetEventParameter (event, EVENT_PARAM_TEXT_INPUT_SEQUENCE_NUMBER,
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
454 typeUInt32, sizeof (UInt32), &seqno_uaia);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
455 seqno_uaia++;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
456 result = noErr;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
457 break;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
458
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
459 case kEventTextInputUnicodeForKeyEvent:
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
460 {
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
461 EventRef kbd_event;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
462 UInt32 actual_size, modifiers, key_code;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
463
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
464 err = GetEventParameter (event, kEventParamTextInputSendKeyboardEvent,
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
465 typeEventRef, NULL, sizeof (EventRef), NULL,
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
466 &kbd_event);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
467 if (err == noErr)
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
468 err = GetEventParameter (kbd_event, kEventParamKeyModifiers,
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
469 typeUInt32, NULL,
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
470 sizeof (UInt32), NULL, &modifiers);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
471 if (err == noErr)
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
472 err = GetEventParameter (kbd_event, kEventParamKeyCode,
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
473 typeUInt32, NULL, sizeof (UInt32),
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
474 NULL, &key_code);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
475 if (err == noErr && mac_mapped_modifiers (modifiers, key_code))
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
476 /* There're mapped modifier keys. Process it in
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
477 do_keystroke. */
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
478 break;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
479 if (err == noErr)
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
480 err = GetEventParameter (kbd_event, kEventParamKeyUnicodes,
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
481 typeUnicodeText, NULL, 0, &actual_size,
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
482 NULL);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
483 if (err == noErr && actual_size == sizeof (UniChar))
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
484 {
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
485 UniChar code;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
486
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
487 err = GetEventParameter (kbd_event, kEventParamKeyUnicodes,
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
488 typeUnicodeText, NULL,
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
489 sizeof (UniChar), NULL, &code);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
490 if (err == noErr && code < 0x80)
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
491 {
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
492 /* ASCII character. Process it in do_keystroke. */
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
493 if (read_socket_inev && code >= 0x20 && code <= 0x7e
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
494 && !(key_code <= 0x7f
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
495 && keycode_to_xkeysym_table [key_code]))
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
496 {
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
497 struct frame *f = mac_focus_frame (&one_mac_display_info);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
498
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
499 read_socket_inev->kind = ASCII_KEYSTROKE_EVENT;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
500 read_socket_inev->code = code;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
501 read_socket_inev->modifiers =
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
502 mac_to_emacs_modifiers (modifiers, 0);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
503 read_socket_inev->modifiers |=
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
504 (extra_keyboard_modifiers
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
505 & (meta_modifier | alt_modifier
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
506 | hyper_modifier | super_modifier));
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
507 XSETFRAME (read_socket_inev->frame_or_window, f);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
508 }
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
509 break;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
510 }
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
511 }
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
512 if (err == noErr)
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
513 {
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
514 /* Non-ASCII keystrokes without mapped modifiers are
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
515 processed at the Lisp level. */
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
516 id_key = Qunicode_for_key_event;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
517 num_params = sizeof (names_ufke) / sizeof (names_ufke[0]);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
518 names = names_ufke;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
519 types = types_ufke;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
520 result = noErr;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
521 }
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
522 }
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
523 break;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
524
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
525 case kEventTextInputOffsetToPos:
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
526 {
80520
aaff809b3a06 (Vmac_ts_active_input_buf) [USE_MAC_TSM]: Add extern.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents: 80517
diff changeset
527 long byte_offset;
80446
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
528 struct frame *f;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
529 struct window *w;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
530 Point p;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
531
80520
aaff809b3a06 (Vmac_ts_active_input_buf) [USE_MAC_TSM]: Add extern.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents: 80517
diff changeset
532 err = GetEventParameter (event, kEventParamTextInputSendTextOffset,
aaff809b3a06 (Vmac_ts_active_input_buf) [USE_MAC_TSM]: Add extern.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents: 80517
diff changeset
533 typeLongInteger, NULL, sizeof (long), NULL,
aaff809b3a06 (Vmac_ts_active_input_buf) [USE_MAC_TSM]: Add extern.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents: 80517
diff changeset
534 &byte_offset);
aaff809b3a06 (Vmac_ts_active_input_buf) [USE_MAC_TSM]: Add extern.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents: 80517
diff changeset
535 if (err != noErr)
80446
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
536 break;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
537
80520
aaff809b3a06 (Vmac_ts_active_input_buf) [USE_MAC_TSM]: Add extern.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents: 80517
diff changeset
538 if (STRINGP (Vmac_ts_active_input_buf)
aaff809b3a06 (Vmac_ts_active_input_buf) [USE_MAC_TSM]: Add extern.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents: 80517
diff changeset
539 && SBYTES (Vmac_ts_active_input_buf) != 0)
80446
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
540 {
80520
aaff809b3a06 (Vmac_ts_active_input_buf) [USE_MAC_TSM]: Add extern.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents: 80517
diff changeset
541 if (!OVERLAYP (Vmac_ts_active_input_overlay))
aaff809b3a06 (Vmac_ts_active_input_buf) [USE_MAC_TSM]: Add extern.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents: 80517
diff changeset
542 break;
aaff809b3a06 (Vmac_ts_active_input_buf) [USE_MAC_TSM]: Add extern.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents: 80517
diff changeset
543
aaff809b3a06 (Vmac_ts_active_input_buf) [USE_MAC_TSM]: Add extern.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents: 80517
diff changeset
544 /* Strictly speaking, this is not always correct because
aaff809b3a06 (Vmac_ts_active_input_buf) [USE_MAC_TSM]: Add extern.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents: 80517
diff changeset
545 previous events may change some states about display. */
aaff809b3a06 (Vmac_ts_active_input_buf) [USE_MAC_TSM]: Add extern.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents: 80517
diff changeset
546 if (!NILP (Foverlay_get (Vmac_ts_active_input_overlay, Qbefore_string)))
aaff809b3a06 (Vmac_ts_active_input_buf) [USE_MAC_TSM]: Add extern.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents: 80517
diff changeset
547 {
aaff809b3a06 (Vmac_ts_active_input_buf) [USE_MAC_TSM]: Add extern.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents: 80517
diff changeset
548 /* Active input area is displayed around the current point. */
aaff809b3a06 (Vmac_ts_active_input_buf) [USE_MAC_TSM]: Add extern.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents: 80517
diff changeset
549 f = SELECTED_FRAME ();
aaff809b3a06 (Vmac_ts_active_input_buf) [USE_MAC_TSM]: Add extern.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents: 80517
diff changeset
550 w = XWINDOW (f->selected_window);
aaff809b3a06 (Vmac_ts_active_input_buf) [USE_MAC_TSM]: Add extern.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents: 80517
diff changeset
551 }
aaff809b3a06 (Vmac_ts_active_input_buf) [USE_MAC_TSM]: Add extern.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents: 80517
diff changeset
552 else if (WINDOWP (echo_area_window))
aaff809b3a06 (Vmac_ts_active_input_buf) [USE_MAC_TSM]: Add extern.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents: 80517
diff changeset
553 {
aaff809b3a06 (Vmac_ts_active_input_buf) [USE_MAC_TSM]: Add extern.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents: 80517
diff changeset
554 /* Active input area is displayed in the echo area. */
aaff809b3a06 (Vmac_ts_active_input_buf) [USE_MAC_TSM]: Add extern.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents: 80517
diff changeset
555 w = XWINDOW (echo_area_window);
aaff809b3a06 (Vmac_ts_active_input_buf) [USE_MAC_TSM]: Add extern.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents: 80517
diff changeset
556 f = WINDOW_XFRAME (w);
aaff809b3a06 (Vmac_ts_active_input_buf) [USE_MAC_TSM]: Add extern.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents: 80517
diff changeset
557 }
aaff809b3a06 (Vmac_ts_active_input_buf) [USE_MAC_TSM]: Add extern.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents: 80517
diff changeset
558 else
aaff809b3a06 (Vmac_ts_active_input_buf) [USE_MAC_TSM]: Add extern.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents: 80517
diff changeset
559 break;
aaff809b3a06 (Vmac_ts_active_input_buf) [USE_MAC_TSM]: Add extern.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents: 80517
diff changeset
560
aaff809b3a06 (Vmac_ts_active_input_buf) [USE_MAC_TSM]: Add extern.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents: 80517
diff changeset
561 p.h = (WINDOW_TO_FRAME_PIXEL_X (w, w->cursor.x)
aaff809b3a06 (Vmac_ts_active_input_buf) [USE_MAC_TSM]: Add extern.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents: 80517
diff changeset
562 + WINDOW_LEFT_FRINGE_WIDTH (w)
aaff809b3a06 (Vmac_ts_active_input_buf) [USE_MAC_TSM]: Add extern.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents: 80517
diff changeset
563 + f->left_pos + FRAME_OUTER_TO_INNER_DIFF_X (f));
aaff809b3a06 (Vmac_ts_active_input_buf) [USE_MAC_TSM]: Add extern.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents: 80517
diff changeset
564 p.v = (WINDOW_TO_FRAME_PIXEL_Y (w, w->cursor.y)
aaff809b3a06 (Vmac_ts_active_input_buf) [USE_MAC_TSM]: Add extern.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents: 80517
diff changeset
565 + FONT_BASE (FRAME_FONT (f))
aaff809b3a06 (Vmac_ts_active_input_buf) [USE_MAC_TSM]: Add extern.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents: 80517
diff changeset
566 + f->top_pos + FRAME_OUTER_TO_INNER_DIFF_Y (f));
80446
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
567 }
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
568 else
80520
aaff809b3a06 (Vmac_ts_active_input_buf) [USE_MAC_TSM]: Add extern.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents: 80517
diff changeset
569 {
aaff809b3a06 (Vmac_ts_active_input_buf) [USE_MAC_TSM]: Add extern.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents: 80517
diff changeset
570 #ifndef MAC_OSX
aaff809b3a06 (Vmac_ts_active_input_buf) [USE_MAC_TSM]: Add extern.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents: 80517
diff changeset
571 break;
aaff809b3a06 (Vmac_ts_active_input_buf) [USE_MAC_TSM]: Add extern.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents: 80517
diff changeset
572 #else /* MAC_OSX */
80741
1f63840526a9 (mac_handle_text_input_event):
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents: 80606
diff changeset
573 struct buffer *b;
80520
aaff809b3a06 (Vmac_ts_active_input_buf) [USE_MAC_TSM]: Add extern.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents: 80517
diff changeset
574 CFRange sel_range;
aaff809b3a06 (Vmac_ts_active_input_buf) [USE_MAC_TSM]: Add extern.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents: 80517
diff changeset
575 int charpos;
aaff809b3a06 (Vmac_ts_active_input_buf) [USE_MAC_TSM]: Add extern.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents: 80517
diff changeset
576 int hpos, vpos, x, y;
aaff809b3a06 (Vmac_ts_active_input_buf) [USE_MAC_TSM]: Add extern.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents: 80517
diff changeset
577 struct glyph_row *row;
aaff809b3a06 (Vmac_ts_active_input_buf) [USE_MAC_TSM]: Add extern.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents: 80517
diff changeset
578 struct glyph *glyph;
80606
557c72d63824 [USE_MAC_TSM] (mac_handle_text_input_event):
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents: 80520
diff changeset
579 struct face *face;
80520
aaff809b3a06 (Vmac_ts_active_input_buf) [USE_MAC_TSM]: Add extern.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents: 80517
diff changeset
580
aaff809b3a06 (Vmac_ts_active_input_buf) [USE_MAC_TSM]: Add extern.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents: 80517
diff changeset
581 f = mac_focus_frame (&one_mac_display_info);
aaff809b3a06 (Vmac_ts_active_input_buf) [USE_MAC_TSM]: Add extern.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents: 80517
diff changeset
582 w = XWINDOW (f->selected_window);
80741
1f63840526a9 (mac_handle_text_input_event):
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents: 80606
diff changeset
583 b = XBUFFER (w->buffer);
1f63840526a9 (mac_handle_text_input_event):
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents: 80606
diff changeset
584
1f63840526a9 (mac_handle_text_input_event):
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents: 80606
diff changeset
585 /* Are we in a window whose display is up to date?
1f63840526a9 (mac_handle_text_input_event):
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents: 80606
diff changeset
586 And verify the buffer's text has not changed. */
1f63840526a9 (mac_handle_text_input_event):
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents: 80606
diff changeset
587 if (!(EQ (w->window_end_valid, w->buffer)
1f63840526a9 (mac_handle_text_input_event):
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents: 80606
diff changeset
588 && XINT (w->last_modified) == BUF_MODIFF (b)
1f63840526a9 (mac_handle_text_input_event):
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents: 80606
diff changeset
589 && XINT (w->last_overlay_modified) == BUF_OVERLAY_MODIFF (b)))
1f63840526a9 (mac_handle_text_input_event):
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents: 80606
diff changeset
590 break;
1f63840526a9 (mac_handle_text_input_event):
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents: 80606
diff changeset
591
80520
aaff809b3a06 (Vmac_ts_active_input_buf) [USE_MAC_TSM]: Add extern.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents: 80517
diff changeset
592 mac_get_selected_range (w, &sel_range);
80741
1f63840526a9 (mac_handle_text_input_event):
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents: 80606
diff changeset
593 charpos = (BUF_BEGV (b) + sel_range.location
80520
aaff809b3a06 (Vmac_ts_active_input_buf) [USE_MAC_TSM]: Add extern.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents: 80517
diff changeset
594 + byte_offset / (long) sizeof (UniChar));
aaff809b3a06 (Vmac_ts_active_input_buf) [USE_MAC_TSM]: Add extern.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents: 80517
diff changeset
595
aaff809b3a06 (Vmac_ts_active_input_buf) [USE_MAC_TSM]: Add extern.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents: 80517
diff changeset
596 if (!fast_find_position (w, charpos, &hpos, &vpos, &x, &y, Qnil))
aaff809b3a06 (Vmac_ts_active_input_buf) [USE_MAC_TSM]: Add extern.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents: 80517
diff changeset
597 {
aaff809b3a06 (Vmac_ts_active_input_buf) [USE_MAC_TSM]: Add extern.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents: 80517
diff changeset
598 result = errOffsetInvalid;
aaff809b3a06 (Vmac_ts_active_input_buf) [USE_MAC_TSM]: Add extern.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents: 80517
diff changeset
599 break;
aaff809b3a06 (Vmac_ts_active_input_buf) [USE_MAC_TSM]: Add extern.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents: 80517
diff changeset
600 }
aaff809b3a06 (Vmac_ts_active_input_buf) [USE_MAC_TSM]: Add extern.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents: 80517
diff changeset
601
aaff809b3a06 (Vmac_ts_active_input_buf) [USE_MAC_TSM]: Add extern.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents: 80517
diff changeset
602 row = MATRIX_ROW (w->current_matrix, vpos);
aaff809b3a06 (Vmac_ts_active_input_buf) [USE_MAC_TSM]: Add extern.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents: 80517
diff changeset
603 glyph = row->glyphs[TEXT_AREA] + hpos;
aaff809b3a06 (Vmac_ts_active_input_buf) [USE_MAC_TSM]: Add extern.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents: 80517
diff changeset
604 if (glyph->type != CHAR_GLYPH || glyph->glyph_not_available_p)
aaff809b3a06 (Vmac_ts_active_input_buf) [USE_MAC_TSM]: Add extern.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents: 80517
diff changeset
605 break;
aaff809b3a06 (Vmac_ts_active_input_buf) [USE_MAC_TSM]: Add extern.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents: 80517
diff changeset
606
aaff809b3a06 (Vmac_ts_active_input_buf) [USE_MAC_TSM]: Add extern.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents: 80517
diff changeset
607 p.h = (WINDOW_TEXT_TO_FRAME_PIXEL_X (w, x)
aaff809b3a06 (Vmac_ts_active_input_buf) [USE_MAC_TSM]: Add extern.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents: 80517
diff changeset
608 + f->left_pos + FRAME_OUTER_TO_INNER_DIFF_X (f));
aaff809b3a06 (Vmac_ts_active_input_buf) [USE_MAC_TSM]: Add extern.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents: 80517
diff changeset
609 p.v = (WINDOW_TO_FRAME_PIXEL_Y (w, y)
aaff809b3a06 (Vmac_ts_active_input_buf) [USE_MAC_TSM]: Add extern.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents: 80517
diff changeset
610 + row->visible_height
aaff809b3a06 (Vmac_ts_active_input_buf) [USE_MAC_TSM]: Add extern.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents: 80517
diff changeset
611 + f->top_pos + FRAME_OUTER_TO_INNER_DIFF_Y (f));
aaff809b3a06 (Vmac_ts_active_input_buf) [USE_MAC_TSM]: Add extern.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents: 80517
diff changeset
612
80606
557c72d63824 [USE_MAC_TSM] (mac_handle_text_input_event):
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents: 80520
diff changeset
613 face = FACE_FROM_ID (f, glyph->face_id);
557c72d63824 [USE_MAC_TSM] (mac_handle_text_input_event):
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents: 80520
diff changeset
614 if (face && face->font)
80520
aaff809b3a06 (Vmac_ts_active_input_buf) [USE_MAC_TSM]: Add extern.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents: 80517
diff changeset
615 {
80606
557c72d63824 [USE_MAC_TSM] (mac_handle_text_input_event):
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents: 80520
diff changeset
616 XFontStruct *font = face->font;
80520
aaff809b3a06 (Vmac_ts_active_input_buf) [USE_MAC_TSM]: Add extern.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents: 80517
diff changeset
617 Fixed point_size = Long2Fix (font->mac_fontsize);
aaff809b3a06 (Vmac_ts_active_input_buf) [USE_MAC_TSM]: Add extern.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents: 80517
diff changeset
618 short height = row->visible_height;
aaff809b3a06 (Vmac_ts_active_input_buf) [USE_MAC_TSM]: Add extern.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents: 80517
diff changeset
619 short ascent = row->ascent;
aaff809b3a06 (Vmac_ts_active_input_buf) [USE_MAC_TSM]: Add extern.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents: 80517
diff changeset
620
aaff809b3a06 (Vmac_ts_active_input_buf) [USE_MAC_TSM]: Add extern.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents: 80517
diff changeset
621 SetEventParameter (event,
aaff809b3a06 (Vmac_ts_active_input_buf) [USE_MAC_TSM]: Add extern.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents: 80517
diff changeset
622 kEventParamTextInputReplyPointSize,
aaff809b3a06 (Vmac_ts_active_input_buf) [USE_MAC_TSM]: Add extern.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents: 80517
diff changeset
623 typeFixed, sizeof (Fixed), &point_size);
aaff809b3a06 (Vmac_ts_active_input_buf) [USE_MAC_TSM]: Add extern.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents: 80517
diff changeset
624 SetEventParameter (event,
aaff809b3a06 (Vmac_ts_active_input_buf) [USE_MAC_TSM]: Add extern.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents: 80517
diff changeset
625 kEventParamTextInputReplyLineHeight,
aaff809b3a06 (Vmac_ts_active_input_buf) [USE_MAC_TSM]: Add extern.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents: 80517
diff changeset
626 typeShortInteger, sizeof (short), &height);
aaff809b3a06 (Vmac_ts_active_input_buf) [USE_MAC_TSM]: Add extern.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents: 80517
diff changeset
627 SetEventParameter (event,
aaff809b3a06 (Vmac_ts_active_input_buf) [USE_MAC_TSM]: Add extern.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents: 80517
diff changeset
628 kEventParamTextInputReplyLineAscent,
aaff809b3a06 (Vmac_ts_active_input_buf) [USE_MAC_TSM]: Add extern.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents: 80517
diff changeset
629 typeShortInteger, sizeof (short), &ascent);
aaff809b3a06 (Vmac_ts_active_input_buf) [USE_MAC_TSM]: Add extern.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents: 80517
diff changeset
630 if (font->mac_fontnum != -1)
aaff809b3a06 (Vmac_ts_active_input_buf) [USE_MAC_TSM]: Add extern.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents: 80517
diff changeset
631 {
aaff809b3a06 (Vmac_ts_active_input_buf) [USE_MAC_TSM]: Add extern.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents: 80517
diff changeset
632 OSStatus err1;
aaff809b3a06 (Vmac_ts_active_input_buf) [USE_MAC_TSM]: Add extern.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents: 80517
diff changeset
633 FMFont fm_font;
aaff809b3a06 (Vmac_ts_active_input_buf) [USE_MAC_TSM]: Add extern.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents: 80517
diff changeset
634 FMFontStyle style;
aaff809b3a06 (Vmac_ts_active_input_buf) [USE_MAC_TSM]: Add extern.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents: 80517
diff changeset
635
aaff809b3a06 (Vmac_ts_active_input_buf) [USE_MAC_TSM]: Add extern.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents: 80517
diff changeset
636 err1 = FMGetFontFromFontFamilyInstance (font->mac_fontnum,
aaff809b3a06 (Vmac_ts_active_input_buf) [USE_MAC_TSM]: Add extern.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents: 80517
diff changeset
637 font->mac_fontface,
aaff809b3a06 (Vmac_ts_active_input_buf) [USE_MAC_TSM]: Add extern.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents: 80517
diff changeset
638 &fm_font, &style);
aaff809b3a06 (Vmac_ts_active_input_buf) [USE_MAC_TSM]: Add extern.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents: 80517
diff changeset
639 if (err1 == noErr)
aaff809b3a06 (Vmac_ts_active_input_buf) [USE_MAC_TSM]: Add extern.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents: 80517
diff changeset
640 SetEventParameter (event, kEventParamTextInputReplyFMFont,
aaff809b3a06 (Vmac_ts_active_input_buf) [USE_MAC_TSM]: Add extern.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents: 80517
diff changeset
641 typeUInt32, sizeof (UInt32), &fm_font);
aaff809b3a06 (Vmac_ts_active_input_buf) [USE_MAC_TSM]: Add extern.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents: 80517
diff changeset
642 else
aaff809b3a06 (Vmac_ts_active_input_buf) [USE_MAC_TSM]: Add extern.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents: 80517
diff changeset
643 {
aaff809b3a06 (Vmac_ts_active_input_buf) [USE_MAC_TSM]: Add extern.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents: 80517
diff changeset
644 long qd_font = font->mac_fontnum;
aaff809b3a06 (Vmac_ts_active_input_buf) [USE_MAC_TSM]: Add extern.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents: 80517
diff changeset
645
aaff809b3a06 (Vmac_ts_active_input_buf) [USE_MAC_TSM]: Add extern.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents: 80517
diff changeset
646 SetEventParameter (event, kEventParamTextInputReplyFont,
aaff809b3a06 (Vmac_ts_active_input_buf) [USE_MAC_TSM]: Add extern.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents: 80517
diff changeset
647 typeLongInteger, sizeof (long),
aaff809b3a06 (Vmac_ts_active_input_buf) [USE_MAC_TSM]: Add extern.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents: 80517
diff changeset
648 &qd_font);
aaff809b3a06 (Vmac_ts_active_input_buf) [USE_MAC_TSM]: Add extern.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents: 80517
diff changeset
649 }
aaff809b3a06 (Vmac_ts_active_input_buf) [USE_MAC_TSM]: Add extern.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents: 80517
diff changeset
650 }
aaff809b3a06 (Vmac_ts_active_input_buf) [USE_MAC_TSM]: Add extern.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents: 80517
diff changeset
651 else if (font->mac_style)
aaff809b3a06 (Vmac_ts_active_input_buf) [USE_MAC_TSM]: Add extern.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents: 80517
diff changeset
652 {
aaff809b3a06 (Vmac_ts_active_input_buf) [USE_MAC_TSM]: Add extern.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents: 80517
diff changeset
653 OSStatus err1;
aaff809b3a06 (Vmac_ts_active_input_buf) [USE_MAC_TSM]: Add extern.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents: 80517
diff changeset
654 ATSUFontID font_id;
aaff809b3a06 (Vmac_ts_active_input_buf) [USE_MAC_TSM]: Add extern.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents: 80517
diff changeset
655
aaff809b3a06 (Vmac_ts_active_input_buf) [USE_MAC_TSM]: Add extern.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents: 80517
diff changeset
656 err1 = ATSUGetAttribute (font->mac_style, kATSUFontTag,
aaff809b3a06 (Vmac_ts_active_input_buf) [USE_MAC_TSM]: Add extern.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents: 80517
diff changeset
657 sizeof (ATSUFontID), &font_id,
aaff809b3a06 (Vmac_ts_active_input_buf) [USE_MAC_TSM]: Add extern.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents: 80517
diff changeset
658 NULL);
aaff809b3a06 (Vmac_ts_active_input_buf) [USE_MAC_TSM]: Add extern.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents: 80517
diff changeset
659 if (err1 == noErr)
aaff809b3a06 (Vmac_ts_active_input_buf) [USE_MAC_TSM]: Add extern.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents: 80517
diff changeset
660 SetEventParameter (event, kEventParamTextInputReplyFMFont,
aaff809b3a06 (Vmac_ts_active_input_buf) [USE_MAC_TSM]: Add extern.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents: 80517
diff changeset
661 typeUInt32, sizeof (UInt32), &font_id);
aaff809b3a06 (Vmac_ts_active_input_buf) [USE_MAC_TSM]: Add extern.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents: 80517
diff changeset
662 }
aaff809b3a06 (Vmac_ts_active_input_buf) [USE_MAC_TSM]: Add extern.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents: 80517
diff changeset
663 else
aaff809b3a06 (Vmac_ts_active_input_buf) [USE_MAC_TSM]: Add extern.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents: 80517
diff changeset
664 abort ();
aaff809b3a06 (Vmac_ts_active_input_buf) [USE_MAC_TSM]: Add extern.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents: 80517
diff changeset
665 }
aaff809b3a06 (Vmac_ts_active_input_buf) [USE_MAC_TSM]: Add extern.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents: 80517
diff changeset
666 #endif /* MAC_OSX */
aaff809b3a06 (Vmac_ts_active_input_buf) [USE_MAC_TSM]: Add extern.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents: 80517
diff changeset
667 }
aaff809b3a06 (Vmac_ts_active_input_buf) [USE_MAC_TSM]: Add extern.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents: 80517
diff changeset
668
80446
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
669 err = SetEventParameter (event, kEventParamTextInputReplyPoint,
80520
aaff809b3a06 (Vmac_ts_active_input_buf) [USE_MAC_TSM]: Add extern.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents: 80517
diff changeset
670 typeQDPoint, sizeof (Point), &p);
80446
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
671 if (err == noErr)
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
672 result = noErr;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
673 }
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
674 break;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
675
80520
aaff809b3a06 (Vmac_ts_active_input_buf) [USE_MAC_TSM]: Add extern.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents: 80517
diff changeset
676 #ifdef MAC_OSX
aaff809b3a06 (Vmac_ts_active_input_buf) [USE_MAC_TSM]: Add extern.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents: 80517
diff changeset
677 case kEventTextInputPosToOffset:
aaff809b3a06 (Vmac_ts_active_input_buf) [USE_MAC_TSM]: Add extern.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents: 80517
diff changeset
678 {
aaff809b3a06 (Vmac_ts_active_input_buf) [USE_MAC_TSM]: Add extern.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents: 80517
diff changeset
679 Point point;
aaff809b3a06 (Vmac_ts_active_input_buf) [USE_MAC_TSM]: Add extern.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents: 80517
diff changeset
680 Boolean leading_edge_p = true;
aaff809b3a06 (Vmac_ts_active_input_buf) [USE_MAC_TSM]: Add extern.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents: 80517
diff changeset
681 struct frame *f;
aaff809b3a06 (Vmac_ts_active_input_buf) [USE_MAC_TSM]: Add extern.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents: 80517
diff changeset
682 int x, y;
aaff809b3a06 (Vmac_ts_active_input_buf) [USE_MAC_TSM]: Add extern.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents: 80517
diff changeset
683 Lisp_Object window;
aaff809b3a06 (Vmac_ts_active_input_buf) [USE_MAC_TSM]: Add extern.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents: 80517
diff changeset
684 enum window_part part;
aaff809b3a06 (Vmac_ts_active_input_buf) [USE_MAC_TSM]: Add extern.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents: 80517
diff changeset
685 long region_class = kTSMOutsideOfBody, byte_offset = 0;
aaff809b3a06 (Vmac_ts_active_input_buf) [USE_MAC_TSM]: Add extern.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents: 80517
diff changeset
686
aaff809b3a06 (Vmac_ts_active_input_buf) [USE_MAC_TSM]: Add extern.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents: 80517
diff changeset
687 err = GetEventParameter (event, kEventParamTextInputSendCurrentPoint,
aaff809b3a06 (Vmac_ts_active_input_buf) [USE_MAC_TSM]: Add extern.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents: 80517
diff changeset
688 typeQDPoint, NULL, sizeof (Point), NULL,
aaff809b3a06 (Vmac_ts_active_input_buf) [USE_MAC_TSM]: Add extern.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents: 80517
diff changeset
689 &point);
aaff809b3a06 (Vmac_ts_active_input_buf) [USE_MAC_TSM]: Add extern.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents: 80517
diff changeset
690 if (err != noErr)
aaff809b3a06 (Vmac_ts_active_input_buf) [USE_MAC_TSM]: Add extern.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents: 80517
diff changeset
691 break;
aaff809b3a06 (Vmac_ts_active_input_buf) [USE_MAC_TSM]: Add extern.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents: 80517
diff changeset
692
aaff809b3a06 (Vmac_ts_active_input_buf) [USE_MAC_TSM]: Add extern.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents: 80517
diff changeset
693 GetEventParameter (event, kEventParamTextInputReplyLeadingEdge,
aaff809b3a06 (Vmac_ts_active_input_buf) [USE_MAC_TSM]: Add extern.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents: 80517
diff changeset
694 typeBoolean, NULL, sizeof (Boolean), NULL,
aaff809b3a06 (Vmac_ts_active_input_buf) [USE_MAC_TSM]: Add extern.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents: 80517
diff changeset
695 &leading_edge_p);
aaff809b3a06 (Vmac_ts_active_input_buf) [USE_MAC_TSM]: Add extern.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents: 80517
diff changeset
696
aaff809b3a06 (Vmac_ts_active_input_buf) [USE_MAC_TSM]: Add extern.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents: 80517
diff changeset
697 f = mac_focus_frame (&one_mac_display_info);
aaff809b3a06 (Vmac_ts_active_input_buf) [USE_MAC_TSM]: Add extern.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents: 80517
diff changeset
698 x = point.h - (f->left_pos + FRAME_OUTER_TO_INNER_DIFF_X (f));
aaff809b3a06 (Vmac_ts_active_input_buf) [USE_MAC_TSM]: Add extern.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents: 80517
diff changeset
699 y = point.v - (f->top_pos + FRAME_OUTER_TO_INNER_DIFF_Y (f));
aaff809b3a06 (Vmac_ts_active_input_buf) [USE_MAC_TSM]: Add extern.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents: 80517
diff changeset
700 window = window_from_coordinates (f, x, y, &part, 0, 0, 1);
aaff809b3a06 (Vmac_ts_active_input_buf) [USE_MAC_TSM]: Add extern.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents: 80517
diff changeset
701 if (WINDOWP (window) && EQ (window, f->selected_window))
aaff809b3a06 (Vmac_ts_active_input_buf) [USE_MAC_TSM]: Add extern.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents: 80517
diff changeset
702 {
aaff809b3a06 (Vmac_ts_active_input_buf) [USE_MAC_TSM]: Add extern.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents: 80517
diff changeset
703 struct window *w;
aaff809b3a06 (Vmac_ts_active_input_buf) [USE_MAC_TSM]: Add extern.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents: 80517
diff changeset
704 struct buffer *b;
aaff809b3a06 (Vmac_ts_active_input_buf) [USE_MAC_TSM]: Add extern.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents: 80517
diff changeset
705
aaff809b3a06 (Vmac_ts_active_input_buf) [USE_MAC_TSM]: Add extern.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents: 80517
diff changeset
706 /* Convert to window-relative pixel coordinates. */
aaff809b3a06 (Vmac_ts_active_input_buf) [USE_MAC_TSM]: Add extern.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents: 80517
diff changeset
707 w = XWINDOW (window);
aaff809b3a06 (Vmac_ts_active_input_buf) [USE_MAC_TSM]: Add extern.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents: 80517
diff changeset
708 frame_to_window_pixel_xy (w, &x, &y);
aaff809b3a06 (Vmac_ts_active_input_buf) [USE_MAC_TSM]: Add extern.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents: 80517
diff changeset
709
aaff809b3a06 (Vmac_ts_active_input_buf) [USE_MAC_TSM]: Add extern.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents: 80517
diff changeset
710 /* Are we in a window whose display is up to date?
aaff809b3a06 (Vmac_ts_active_input_buf) [USE_MAC_TSM]: Add extern.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents: 80517
diff changeset
711 And verify the buffer's text has not changed. */
aaff809b3a06 (Vmac_ts_active_input_buf) [USE_MAC_TSM]: Add extern.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents: 80517
diff changeset
712 b = XBUFFER (w->buffer);
aaff809b3a06 (Vmac_ts_active_input_buf) [USE_MAC_TSM]: Add extern.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents: 80517
diff changeset
713 if (part == ON_TEXT
aaff809b3a06 (Vmac_ts_active_input_buf) [USE_MAC_TSM]: Add extern.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents: 80517
diff changeset
714 && EQ (w->window_end_valid, w->buffer)
aaff809b3a06 (Vmac_ts_active_input_buf) [USE_MAC_TSM]: Add extern.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents: 80517
diff changeset
715 && XINT (w->last_modified) == BUF_MODIFF (b)
aaff809b3a06 (Vmac_ts_active_input_buf) [USE_MAC_TSM]: Add extern.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents: 80517
diff changeset
716 && XINT (w->last_overlay_modified) == BUF_OVERLAY_MODIFF (b))
aaff809b3a06 (Vmac_ts_active_input_buf) [USE_MAC_TSM]: Add extern.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents: 80517
diff changeset
717 {
aaff809b3a06 (Vmac_ts_active_input_buf) [USE_MAC_TSM]: Add extern.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents: 80517
diff changeset
718 int hpos, vpos, area;
aaff809b3a06 (Vmac_ts_active_input_buf) [USE_MAC_TSM]: Add extern.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents: 80517
diff changeset
719 struct glyph *glyph;
aaff809b3a06 (Vmac_ts_active_input_buf) [USE_MAC_TSM]: Add extern.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents: 80517
diff changeset
720
aaff809b3a06 (Vmac_ts_active_input_buf) [USE_MAC_TSM]: Add extern.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents: 80517
diff changeset
721 /* Find the glyph under X/Y. */
aaff809b3a06 (Vmac_ts_active_input_buf) [USE_MAC_TSM]: Add extern.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents: 80517
diff changeset
722 glyph = x_y_to_hpos_vpos (w, x, y, &hpos, &vpos, 0, 0, &area);
aaff809b3a06 (Vmac_ts_active_input_buf) [USE_MAC_TSM]: Add extern.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents: 80517
diff changeset
723
aaff809b3a06 (Vmac_ts_active_input_buf) [USE_MAC_TSM]: Add extern.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents: 80517
diff changeset
724 if (glyph != NULL && area == TEXT_AREA)
aaff809b3a06 (Vmac_ts_active_input_buf) [USE_MAC_TSM]: Add extern.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents: 80517
diff changeset
725 {
aaff809b3a06 (Vmac_ts_active_input_buf) [USE_MAC_TSM]: Add extern.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents: 80517
diff changeset
726 byte_offset = ((glyph->charpos - BUF_BEGV (b))
aaff809b3a06 (Vmac_ts_active_input_buf) [USE_MAC_TSM]: Add extern.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents: 80517
diff changeset
727 * sizeof (UniChar));
aaff809b3a06 (Vmac_ts_active_input_buf) [USE_MAC_TSM]: Add extern.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents: 80517
diff changeset
728 region_class = kTSMInsideOfBody;
aaff809b3a06 (Vmac_ts_active_input_buf) [USE_MAC_TSM]: Add extern.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents: 80517
diff changeset
729 }
aaff809b3a06 (Vmac_ts_active_input_buf) [USE_MAC_TSM]: Add extern.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents: 80517
diff changeset
730 }
aaff809b3a06 (Vmac_ts_active_input_buf) [USE_MAC_TSM]: Add extern.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents: 80517
diff changeset
731 }
aaff809b3a06 (Vmac_ts_active_input_buf) [USE_MAC_TSM]: Add extern.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents: 80517
diff changeset
732
aaff809b3a06 (Vmac_ts_active_input_buf) [USE_MAC_TSM]: Add extern.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents: 80517
diff changeset
733 err = SetEventParameter (event, kEventParamTextInputReplyRegionClass,
aaff809b3a06 (Vmac_ts_active_input_buf) [USE_MAC_TSM]: Add extern.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents: 80517
diff changeset
734 typeLongInteger, sizeof (long),
aaff809b3a06 (Vmac_ts_active_input_buf) [USE_MAC_TSM]: Add extern.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents: 80517
diff changeset
735 &region_class);
aaff809b3a06 (Vmac_ts_active_input_buf) [USE_MAC_TSM]: Add extern.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents: 80517
diff changeset
736 if (err == noErr)
aaff809b3a06 (Vmac_ts_active_input_buf) [USE_MAC_TSM]: Add extern.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents: 80517
diff changeset
737 err = SetEventParameter (event, kEventParamTextInputReplyTextOffset,
aaff809b3a06 (Vmac_ts_active_input_buf) [USE_MAC_TSM]: Add extern.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents: 80517
diff changeset
738 typeLongInteger, sizeof (long),
aaff809b3a06 (Vmac_ts_active_input_buf) [USE_MAC_TSM]: Add extern.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents: 80517
diff changeset
739 &byte_offset);
aaff809b3a06 (Vmac_ts_active_input_buf) [USE_MAC_TSM]: Add extern.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents: 80517
diff changeset
740 if (err == noErr)
aaff809b3a06 (Vmac_ts_active_input_buf) [USE_MAC_TSM]: Add extern.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents: 80517
diff changeset
741 result = noErr;
aaff809b3a06 (Vmac_ts_active_input_buf) [USE_MAC_TSM]: Add extern.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents: 80517
diff changeset
742 }
aaff809b3a06 (Vmac_ts_active_input_buf) [USE_MAC_TSM]: Add extern.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents: 80517
diff changeset
743 break;
aaff809b3a06 (Vmac_ts_active_input_buf) [USE_MAC_TSM]: Add extern.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents: 80517
diff changeset
744
aaff809b3a06 (Vmac_ts_active_input_buf) [USE_MAC_TSM]: Add extern.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents: 80517
diff changeset
745 case kEventTextInputGetSelectedText:
aaff809b3a06 (Vmac_ts_active_input_buf) [USE_MAC_TSM]: Add extern.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents: 80517
diff changeset
746 {
aaff809b3a06 (Vmac_ts_active_input_buf) [USE_MAC_TSM]: Add extern.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents: 80517
diff changeset
747 struct frame *f = mac_focus_frame (&one_mac_display_info);
aaff809b3a06 (Vmac_ts_active_input_buf) [USE_MAC_TSM]: Add extern.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents: 80517
diff changeset
748 struct window *w = XWINDOW (f->selected_window);
aaff809b3a06 (Vmac_ts_active_input_buf) [USE_MAC_TSM]: Add extern.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents: 80517
diff changeset
749 struct buffer *b = XBUFFER (w->buffer);
aaff809b3a06 (Vmac_ts_active_input_buf) [USE_MAC_TSM]: Add extern.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents: 80517
diff changeset
750 CFRange sel_range;
aaff809b3a06 (Vmac_ts_active_input_buf) [USE_MAC_TSM]: Add extern.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents: 80517
diff changeset
751 int start, end;
aaff809b3a06 (Vmac_ts_active_input_buf) [USE_MAC_TSM]: Add extern.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents: 80517
diff changeset
752 UniChar *characters, c;
aaff809b3a06 (Vmac_ts_active_input_buf) [USE_MAC_TSM]: Add extern.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents: 80517
diff changeset
753
aaff809b3a06 (Vmac_ts_active_input_buf) [USE_MAC_TSM]: Add extern.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents: 80517
diff changeset
754 if (poll_suppress_count == 0 && !NILP (Vinhibit_quit))
aaff809b3a06 (Vmac_ts_active_input_buf) [USE_MAC_TSM]: Add extern.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents: 80517
diff changeset
755 /* Don't try to get buffer contents as the gap might be
aaff809b3a06 (Vmac_ts_active_input_buf) [USE_MAC_TSM]: Add extern.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents: 80517
diff changeset
756 being altered. */
aaff809b3a06 (Vmac_ts_active_input_buf) [USE_MAC_TSM]: Add extern.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents: 80517
diff changeset
757 break;
aaff809b3a06 (Vmac_ts_active_input_buf) [USE_MAC_TSM]: Add extern.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents: 80517
diff changeset
758
aaff809b3a06 (Vmac_ts_active_input_buf) [USE_MAC_TSM]: Add extern.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents: 80517
diff changeset
759 mac_get_selected_range (w, &sel_range);
aaff809b3a06 (Vmac_ts_active_input_buf) [USE_MAC_TSM]: Add extern.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents: 80517
diff changeset
760 if (sel_range.length == 0)
aaff809b3a06 (Vmac_ts_active_input_buf) [USE_MAC_TSM]: Add extern.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents: 80517
diff changeset
761 {
aaff809b3a06 (Vmac_ts_active_input_buf) [USE_MAC_TSM]: Add extern.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents: 80517
diff changeset
762 Boolean leading_edge_p;
aaff809b3a06 (Vmac_ts_active_input_buf) [USE_MAC_TSM]: Add extern.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents: 80517
diff changeset
763
aaff809b3a06 (Vmac_ts_active_input_buf) [USE_MAC_TSM]: Add extern.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents: 80517
diff changeset
764 err = GetEventParameter (event,
aaff809b3a06 (Vmac_ts_active_input_buf) [USE_MAC_TSM]: Add extern.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents: 80517
diff changeset
765 kEventParamTextInputReplyLeadingEdge,
aaff809b3a06 (Vmac_ts_active_input_buf) [USE_MAC_TSM]: Add extern.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents: 80517
diff changeset
766 typeBoolean, NULL, sizeof (Boolean), NULL,
aaff809b3a06 (Vmac_ts_active_input_buf) [USE_MAC_TSM]: Add extern.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents: 80517
diff changeset
767 &leading_edge_p);
aaff809b3a06 (Vmac_ts_active_input_buf) [USE_MAC_TSM]: Add extern.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents: 80517
diff changeset
768 if (err != noErr)
aaff809b3a06 (Vmac_ts_active_input_buf) [USE_MAC_TSM]: Add extern.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents: 80517
diff changeset
769 break;
aaff809b3a06 (Vmac_ts_active_input_buf) [USE_MAC_TSM]: Add extern.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents: 80517
diff changeset
770
aaff809b3a06 (Vmac_ts_active_input_buf) [USE_MAC_TSM]: Add extern.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents: 80517
diff changeset
771 start = BUF_BEGV (b) + sel_range.location;
aaff809b3a06 (Vmac_ts_active_input_buf) [USE_MAC_TSM]: Add extern.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents: 80517
diff changeset
772 if (!leading_edge_p)
aaff809b3a06 (Vmac_ts_active_input_buf) [USE_MAC_TSM]: Add extern.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents: 80517
diff changeset
773 start--;
aaff809b3a06 (Vmac_ts_active_input_buf) [USE_MAC_TSM]: Add extern.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents: 80517
diff changeset
774 end = start + 1;
aaff809b3a06 (Vmac_ts_active_input_buf) [USE_MAC_TSM]: Add extern.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents: 80517
diff changeset
775 characters = &c;
aaff809b3a06 (Vmac_ts_active_input_buf) [USE_MAC_TSM]: Add extern.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents: 80517
diff changeset
776
aaff809b3a06 (Vmac_ts_active_input_buf) [USE_MAC_TSM]: Add extern.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents: 80517
diff changeset
777 if (start < BUF_BEGV (b) || end > BUF_ZV (b))
aaff809b3a06 (Vmac_ts_active_input_buf) [USE_MAC_TSM]: Add extern.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents: 80517
diff changeset
778 break;
aaff809b3a06 (Vmac_ts_active_input_buf) [USE_MAC_TSM]: Add extern.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents: 80517
diff changeset
779 }
aaff809b3a06 (Vmac_ts_active_input_buf) [USE_MAC_TSM]: Add extern.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents: 80517
diff changeset
780 else
aaff809b3a06 (Vmac_ts_active_input_buf) [USE_MAC_TSM]: Add extern.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents: 80517
diff changeset
781 {
aaff809b3a06 (Vmac_ts_active_input_buf) [USE_MAC_TSM]: Add extern.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents: 80517
diff changeset
782 start = BUF_BEGV (b) + sel_range.location;
aaff809b3a06 (Vmac_ts_active_input_buf) [USE_MAC_TSM]: Add extern.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents: 80517
diff changeset
783 end = start + sel_range.length;
aaff809b3a06 (Vmac_ts_active_input_buf) [USE_MAC_TSM]: Add extern.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents: 80517
diff changeset
784 characters = xmalloc (sel_range.length * sizeof (UniChar));
aaff809b3a06 (Vmac_ts_active_input_buf) [USE_MAC_TSM]: Add extern.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents: 80517
diff changeset
785 }
aaff809b3a06 (Vmac_ts_active_input_buf) [USE_MAC_TSM]: Add extern.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents: 80517
diff changeset
786
aaff809b3a06 (Vmac_ts_active_input_buf) [USE_MAC_TSM]: Add extern.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents: 80517
diff changeset
787 if (mac_store_buffer_text_to_unicode_chars (b, start, end, characters))
aaff809b3a06 (Vmac_ts_active_input_buf) [USE_MAC_TSM]: Add extern.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents: 80517
diff changeset
788 err = SetEventParameter (event, kEventParamTextInputReplyText,
aaff809b3a06 (Vmac_ts_active_input_buf) [USE_MAC_TSM]: Add extern.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents: 80517
diff changeset
789 typeUnicodeText,
aaff809b3a06 (Vmac_ts_active_input_buf) [USE_MAC_TSM]: Add extern.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents: 80517
diff changeset
790 sel_range.length * sizeof (UniChar),
aaff809b3a06 (Vmac_ts_active_input_buf) [USE_MAC_TSM]: Add extern.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents: 80517
diff changeset
791 characters);
aaff809b3a06 (Vmac_ts_active_input_buf) [USE_MAC_TSM]: Add extern.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents: 80517
diff changeset
792 if (characters != &c)
aaff809b3a06 (Vmac_ts_active_input_buf) [USE_MAC_TSM]: Add extern.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents: 80517
diff changeset
793 xfree (characters);
aaff809b3a06 (Vmac_ts_active_input_buf) [USE_MAC_TSM]: Add extern.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents: 80517
diff changeset
794
aaff809b3a06 (Vmac_ts_active_input_buf) [USE_MAC_TSM]: Add extern.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents: 80517
diff changeset
795 if (err == noErr)
aaff809b3a06 (Vmac_ts_active_input_buf) [USE_MAC_TSM]: Add extern.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents: 80517
diff changeset
796 result = noErr;
aaff809b3a06 (Vmac_ts_active_input_buf) [USE_MAC_TSM]: Add extern.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents: 80517
diff changeset
797 }
aaff809b3a06 (Vmac_ts_active_input_buf) [USE_MAC_TSM]: Add extern.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents: 80517
diff changeset
798 break;
aaff809b3a06 (Vmac_ts_active_input_buf) [USE_MAC_TSM]: Add extern.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents: 80517
diff changeset
799 #endif /* MAC_OSX */
aaff809b3a06 (Vmac_ts_active_input_buf) [USE_MAC_TSM]: Add extern.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents: 80517
diff changeset
800
80446
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
801 default:
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
802 abort ();
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
803 }
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
804
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
805 if (!NILP (id_key))
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
806 err = mac_store_event_ref_as_apple_event (0, 0, Qtext_input, id_key,
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
807 event, num_params,
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
808 names, types);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
809 return result;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
810 }
80520
aaff809b3a06 (Vmac_ts_active_input_buf) [USE_MAC_TSM]: Add extern.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents: 80517
diff changeset
811
aaff809b3a06 (Vmac_ts_active_input_buf) [USE_MAC_TSM]: Add extern.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents: 80517
diff changeset
812 #if MAC_OS_X_VERSION_MAX_ALLOWED >= 1030
aaff809b3a06 (Vmac_ts_active_input_buf) [USE_MAC_TSM]: Add extern.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents: 80517
diff changeset
813 static pascal OSStatus
aaff809b3a06 (Vmac_ts_active_input_buf) [USE_MAC_TSM]: Add extern.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents: 80517
diff changeset
814 mac_handle_document_access_event (next_handler, event, data)
aaff809b3a06 (Vmac_ts_active_input_buf) [USE_MAC_TSM]: Add extern.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents: 80517
diff changeset
815 EventHandlerCallRef next_handler;
aaff809b3a06 (Vmac_ts_active_input_buf) [USE_MAC_TSM]: Add extern.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents: 80517
diff changeset
816 EventRef event;
aaff809b3a06 (Vmac_ts_active_input_buf) [USE_MAC_TSM]: Add extern.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents: 80517
diff changeset
817 void *data;
aaff809b3a06 (Vmac_ts_active_input_buf) [USE_MAC_TSM]: Add extern.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents: 80517
diff changeset
818 {
aaff809b3a06 (Vmac_ts_active_input_buf) [USE_MAC_TSM]: Add extern.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents: 80517
diff changeset
819 OSStatus err, result;
aaff809b3a06 (Vmac_ts_active_input_buf) [USE_MAC_TSM]: Add extern.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents: 80517
diff changeset
820 struct frame *f = mac_focus_frame (&one_mac_display_info);
aaff809b3a06 (Vmac_ts_active_input_buf) [USE_MAC_TSM]: Add extern.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents: 80517
diff changeset
821
aaff809b3a06 (Vmac_ts_active_input_buf) [USE_MAC_TSM]: Add extern.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents: 80517
diff changeset
822 result = CallNextEventHandler (next_handler, event);
aaff809b3a06 (Vmac_ts_active_input_buf) [USE_MAC_TSM]: Add extern.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents: 80517
diff changeset
823 if (result != eventNotHandledErr)
aaff809b3a06 (Vmac_ts_active_input_buf) [USE_MAC_TSM]: Add extern.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents: 80517
diff changeset
824 return result;
aaff809b3a06 (Vmac_ts_active_input_buf) [USE_MAC_TSM]: Add extern.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents: 80517
diff changeset
825
aaff809b3a06 (Vmac_ts_active_input_buf) [USE_MAC_TSM]: Add extern.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents: 80517
diff changeset
826 switch (GetEventKind (event))
aaff809b3a06 (Vmac_ts_active_input_buf) [USE_MAC_TSM]: Add extern.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents: 80517
diff changeset
827 {
aaff809b3a06 (Vmac_ts_active_input_buf) [USE_MAC_TSM]: Add extern.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents: 80517
diff changeset
828 case kEventTSMDocumentAccessGetLength:
aaff809b3a06 (Vmac_ts_active_input_buf) [USE_MAC_TSM]: Add extern.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents: 80517
diff changeset
829 {
aaff809b3a06 (Vmac_ts_active_input_buf) [USE_MAC_TSM]: Add extern.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents: 80517
diff changeset
830 CFIndex count = mac_ax_number_of_characters (f);
aaff809b3a06 (Vmac_ts_active_input_buf) [USE_MAC_TSM]: Add extern.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents: 80517
diff changeset
831
aaff809b3a06 (Vmac_ts_active_input_buf) [USE_MAC_TSM]: Add extern.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents: 80517
diff changeset
832 err = SetEventParameter (event, kEventParamTSMDocAccessCharacterCount,
aaff809b3a06 (Vmac_ts_active_input_buf) [USE_MAC_TSM]: Add extern.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents: 80517
diff changeset
833 typeCFIndex, sizeof (CFIndex), &count);
aaff809b3a06 (Vmac_ts_active_input_buf) [USE_MAC_TSM]: Add extern.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents: 80517
diff changeset
834 if (err == noErr)
aaff809b3a06 (Vmac_ts_active_input_buf) [USE_MAC_TSM]: Add extern.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents: 80517
diff changeset
835 result = noErr;
aaff809b3a06 (Vmac_ts_active_input_buf) [USE_MAC_TSM]: Add extern.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents: 80517
diff changeset
836 }
aaff809b3a06 (Vmac_ts_active_input_buf) [USE_MAC_TSM]: Add extern.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents: 80517
diff changeset
837 break;
aaff809b3a06 (Vmac_ts_active_input_buf) [USE_MAC_TSM]: Add extern.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents: 80517
diff changeset
838
aaff809b3a06 (Vmac_ts_active_input_buf) [USE_MAC_TSM]: Add extern.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents: 80517
diff changeset
839 case kEventTSMDocumentAccessGetSelectedRange:
aaff809b3a06 (Vmac_ts_active_input_buf) [USE_MAC_TSM]: Add extern.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents: 80517
diff changeset
840 {
aaff809b3a06 (Vmac_ts_active_input_buf) [USE_MAC_TSM]: Add extern.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents: 80517
diff changeset
841 CFRange sel_range;
aaff809b3a06 (Vmac_ts_active_input_buf) [USE_MAC_TSM]: Add extern.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents: 80517
diff changeset
842
aaff809b3a06 (Vmac_ts_active_input_buf) [USE_MAC_TSM]: Add extern.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents: 80517
diff changeset
843 mac_ax_selected_text_range (f, &sel_range);
aaff809b3a06 (Vmac_ts_active_input_buf) [USE_MAC_TSM]: Add extern.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents: 80517
diff changeset
844 err = SetEventParameter (event,
aaff809b3a06 (Vmac_ts_active_input_buf) [USE_MAC_TSM]: Add extern.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents: 80517
diff changeset
845 kEventParamTSMDocAccessReplyCharacterRange,
aaff809b3a06 (Vmac_ts_active_input_buf) [USE_MAC_TSM]: Add extern.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents: 80517
diff changeset
846 typeCFRange, sizeof (CFRange), &sel_range);
aaff809b3a06 (Vmac_ts_active_input_buf) [USE_MAC_TSM]: Add extern.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents: 80517
diff changeset
847 if (err == noErr)
aaff809b3a06 (Vmac_ts_active_input_buf) [USE_MAC_TSM]: Add extern.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents: 80517
diff changeset
848 result = noErr;
aaff809b3a06 (Vmac_ts_active_input_buf) [USE_MAC_TSM]: Add extern.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents: 80517
diff changeset
849 }
aaff809b3a06 (Vmac_ts_active_input_buf) [USE_MAC_TSM]: Add extern.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents: 80517
diff changeset
850 break;
aaff809b3a06 (Vmac_ts_active_input_buf) [USE_MAC_TSM]: Add extern.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents: 80517
diff changeset
851
aaff809b3a06 (Vmac_ts_active_input_buf) [USE_MAC_TSM]: Add extern.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents: 80517
diff changeset
852 case kEventTSMDocumentAccessGetCharacters:
aaff809b3a06 (Vmac_ts_active_input_buf) [USE_MAC_TSM]: Add extern.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents: 80517
diff changeset
853 {
aaff809b3a06 (Vmac_ts_active_input_buf) [USE_MAC_TSM]: Add extern.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents: 80517
diff changeset
854 struct buffer *b = XBUFFER (XWINDOW (f->selected_window)->buffer);
aaff809b3a06 (Vmac_ts_active_input_buf) [USE_MAC_TSM]: Add extern.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents: 80517
diff changeset
855 CFRange range;
aaff809b3a06 (Vmac_ts_active_input_buf) [USE_MAC_TSM]: Add extern.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents: 80517
diff changeset
856 Ptr characters;
aaff809b3a06 (Vmac_ts_active_input_buf) [USE_MAC_TSM]: Add extern.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents: 80517
diff changeset
857 int start, end;
aaff809b3a06 (Vmac_ts_active_input_buf) [USE_MAC_TSM]: Add extern.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents: 80517
diff changeset
858
aaff809b3a06 (Vmac_ts_active_input_buf) [USE_MAC_TSM]: Add extern.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents: 80517
diff changeset
859 if (poll_suppress_count == 0 && !NILP (Vinhibit_quit))
aaff809b3a06 (Vmac_ts_active_input_buf) [USE_MAC_TSM]: Add extern.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents: 80517
diff changeset
860 /* Don't try to get buffer contents as the gap might be
aaff809b3a06 (Vmac_ts_active_input_buf) [USE_MAC_TSM]: Add extern.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents: 80517
diff changeset
861 being altered. */
aaff809b3a06 (Vmac_ts_active_input_buf) [USE_MAC_TSM]: Add extern.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents: 80517
diff changeset
862 break;
aaff809b3a06 (Vmac_ts_active_input_buf) [USE_MAC_TSM]: Add extern.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents: 80517
diff changeset
863
aaff809b3a06 (Vmac_ts_active_input_buf) [USE_MAC_TSM]: Add extern.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents: 80517
diff changeset
864 err = GetEventParameter (event,
aaff809b3a06 (Vmac_ts_active_input_buf) [USE_MAC_TSM]: Add extern.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents: 80517
diff changeset
865 kEventParamTSMDocAccessSendCharacterRange,
aaff809b3a06 (Vmac_ts_active_input_buf) [USE_MAC_TSM]: Add extern.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents: 80517
diff changeset
866 typeCFRange, NULL, sizeof (CFRange), NULL,
aaff809b3a06 (Vmac_ts_active_input_buf) [USE_MAC_TSM]: Add extern.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents: 80517
diff changeset
867 &range);
aaff809b3a06 (Vmac_ts_active_input_buf) [USE_MAC_TSM]: Add extern.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents: 80517
diff changeset
868 if (err == noErr)
aaff809b3a06 (Vmac_ts_active_input_buf) [USE_MAC_TSM]: Add extern.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents: 80517
diff changeset
869 err = GetEventParameter (event,
aaff809b3a06 (Vmac_ts_active_input_buf) [USE_MAC_TSM]: Add extern.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents: 80517
diff changeset
870 kEventParamTSMDocAccessSendCharactersPtr,
aaff809b3a06 (Vmac_ts_active_input_buf) [USE_MAC_TSM]: Add extern.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents: 80517
diff changeset
871 typePtr, NULL, sizeof (Ptr), NULL,
aaff809b3a06 (Vmac_ts_active_input_buf) [USE_MAC_TSM]: Add extern.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents: 80517
diff changeset
872 &characters);
aaff809b3a06 (Vmac_ts_active_input_buf) [USE_MAC_TSM]: Add extern.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents: 80517
diff changeset
873 if (err != noErr)
aaff809b3a06 (Vmac_ts_active_input_buf) [USE_MAC_TSM]: Add extern.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents: 80517
diff changeset
874 break;
aaff809b3a06 (Vmac_ts_active_input_buf) [USE_MAC_TSM]: Add extern.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents: 80517
diff changeset
875
aaff809b3a06 (Vmac_ts_active_input_buf) [USE_MAC_TSM]: Add extern.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents: 80517
diff changeset
876 start = BUF_BEGV (b) + range.location;
aaff809b3a06 (Vmac_ts_active_input_buf) [USE_MAC_TSM]: Add extern.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents: 80517
diff changeset
877 end = start + range.length;
aaff809b3a06 (Vmac_ts_active_input_buf) [USE_MAC_TSM]: Add extern.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents: 80517
diff changeset
878 if (mac_store_buffer_text_to_unicode_chars (b, start, end,
aaff809b3a06 (Vmac_ts_active_input_buf) [USE_MAC_TSM]: Add extern.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents: 80517
diff changeset
879 (UniChar *) characters))
aaff809b3a06 (Vmac_ts_active_input_buf) [USE_MAC_TSM]: Add extern.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents: 80517
diff changeset
880 result = noErr;
aaff809b3a06 (Vmac_ts_active_input_buf) [USE_MAC_TSM]: Add extern.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents: 80517
diff changeset
881 }
aaff809b3a06 (Vmac_ts_active_input_buf) [USE_MAC_TSM]: Add extern.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents: 80517
diff changeset
882 break;
aaff809b3a06 (Vmac_ts_active_input_buf) [USE_MAC_TSM]: Add extern.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents: 80517
diff changeset
883
aaff809b3a06 (Vmac_ts_active_input_buf) [USE_MAC_TSM]: Add extern.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents: 80517
diff changeset
884 default:
aaff809b3a06 (Vmac_ts_active_input_buf) [USE_MAC_TSM]: Add extern.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents: 80517
diff changeset
885 abort ();
aaff809b3a06 (Vmac_ts_active_input_buf) [USE_MAC_TSM]: Add extern.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents: 80517
diff changeset
886 }
aaff809b3a06 (Vmac_ts_active_input_buf) [USE_MAC_TSM]: Add extern.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents: 80517
diff changeset
887
aaff809b3a06 (Vmac_ts_active_input_buf) [USE_MAC_TSM]: Add extern.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents: 80517
diff changeset
888 return result;
aaff809b3a06 (Vmac_ts_active_input_buf) [USE_MAC_TSM]: Add extern.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents: 80517
diff changeset
889 }
aaff809b3a06 (Vmac_ts_active_input_buf) [USE_MAC_TSM]: Add extern.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents: 80517
diff changeset
890 #endif
80446
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
891 #endif
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
892
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
893 OSStatus
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
894 install_application_handler ()
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
895 {
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
896 OSStatus err = noErr;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
897
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
898 if (err == noErr)
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
899 {
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
900 static const EventTypeSpec specs[] =
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
901 {{kEventClassKeyboard, kEventRawKeyDown},
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
902 {kEventClassKeyboard, kEventRawKeyRepeat},
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
903 {kEventClassKeyboard, kEventRawKeyUp}};
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
904
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
905 err = InstallApplicationEventHandler (NewEventHandlerUPP
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
906 (mac_handle_keyboard_event),
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
907 GetEventTypeCount (specs),
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
908 specs, NULL, NULL);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
909 }
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
910
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
911 if (err == noErr)
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
912 {
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
913 static const EventTypeSpec specs[] =
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
914 {{kEventClassCommand, kEventCommandProcess}};
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
915
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
916 err = InstallApplicationEventHandler (NewEventHandlerUPP
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
917 (mac_handle_command_event),
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
918 GetEventTypeCount (specs),
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
919 specs, NULL, NULL);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
920 }
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
921
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
922 if (err == noErr)
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
923 {
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
924 static const EventTypeSpec specs[] =
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
925 {{kEventClassMouse, kEventMouseWheelMoved}};
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
926
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
927 err = InstallApplicationEventHandler (NewEventHandlerUPP
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
928 (mac_handle_mouse_event),
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
929 GetEventTypeCount (specs),
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
930 specs, NULL, NULL);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
931 }
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
932
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
933 #if USE_MAC_TSM
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
934 if (err == noErr)
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
935 {
80517
086b32514483 (Vmac_ts_script_language_on_focus)
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents: 80464
diff changeset
936 static const EventTypeSpec specs[] =
80446
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
937 {{kEventClassTextInput, kEventTextInputUpdateActiveInputArea},
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
938 {kEventClassTextInput, kEventTextInputUnicodeForKeyEvent},
80520
aaff809b3a06 (Vmac_ts_active_input_buf) [USE_MAC_TSM]: Add extern.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents: 80517
diff changeset
939 {kEventClassTextInput, kEventTextInputOffsetToPos},
aaff809b3a06 (Vmac_ts_active_input_buf) [USE_MAC_TSM]: Add extern.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents: 80517
diff changeset
940 #ifdef MAC_OSX
aaff809b3a06 (Vmac_ts_active_input_buf) [USE_MAC_TSM]: Add extern.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents: 80517
diff changeset
941 {kEventClassTextInput, kEventTextInputPosToOffset},
aaff809b3a06 (Vmac_ts_active_input_buf) [USE_MAC_TSM]: Add extern.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents: 80517
diff changeset
942 {kEventClassTextInput, kEventTextInputGetSelectedText}
aaff809b3a06 (Vmac_ts_active_input_buf) [USE_MAC_TSM]: Add extern.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents: 80517
diff changeset
943 #endif
aaff809b3a06 (Vmac_ts_active_input_buf) [USE_MAC_TSM]: Add extern.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents: 80517
diff changeset
944 };
80446
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
945
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
946 err = InstallApplicationEventHandler (NewEventHandlerUPP
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
947 (mac_handle_text_input_event),
80517
086b32514483 (Vmac_ts_script_language_on_focus)
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents: 80464
diff changeset
948 GetEventTypeCount (specs),
086b32514483 (Vmac_ts_script_language_on_focus)
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents: 80464
diff changeset
949 specs, NULL, NULL);
80446
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
950 }
80520
aaff809b3a06 (Vmac_ts_active_input_buf) [USE_MAC_TSM]: Add extern.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents: 80517
diff changeset
951
aaff809b3a06 (Vmac_ts_active_input_buf) [USE_MAC_TSM]: Add extern.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents: 80517
diff changeset
952 #if MAC_OS_X_VERSION_MAX_ALLOWED >= 1030
aaff809b3a06 (Vmac_ts_active_input_buf) [USE_MAC_TSM]: Add extern.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents: 80517
diff changeset
953 if (err == noErr)
aaff809b3a06 (Vmac_ts_active_input_buf) [USE_MAC_TSM]: Add extern.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents: 80517
diff changeset
954 {
aaff809b3a06 (Vmac_ts_active_input_buf) [USE_MAC_TSM]: Add extern.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents: 80517
diff changeset
955 static const EventTypeSpec specs[] =
aaff809b3a06 (Vmac_ts_active_input_buf) [USE_MAC_TSM]: Add extern.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents: 80517
diff changeset
956 {{kEventClassTSMDocumentAccess, kEventTSMDocumentAccessGetLength},
aaff809b3a06 (Vmac_ts_active_input_buf) [USE_MAC_TSM]: Add extern.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents: 80517
diff changeset
957 {kEventClassTSMDocumentAccess, kEventTSMDocumentAccessGetSelectedRange},
aaff809b3a06 (Vmac_ts_active_input_buf) [USE_MAC_TSM]: Add extern.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents: 80517
diff changeset
958 {kEventClassTSMDocumentAccess, kEventTSMDocumentAccessGetCharacters}};
aaff809b3a06 (Vmac_ts_active_input_buf) [USE_MAC_TSM]: Add extern.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents: 80517
diff changeset
959
aaff809b3a06 (Vmac_ts_active_input_buf) [USE_MAC_TSM]: Add extern.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents: 80517
diff changeset
960 err = InstallApplicationEventHandler (mac_handle_document_access_event,
aaff809b3a06 (Vmac_ts_active_input_buf) [USE_MAC_TSM]: Add extern.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents: 80517
diff changeset
961 GetEventTypeCount (specs),
aaff809b3a06 (Vmac_ts_active_input_buf) [USE_MAC_TSM]: Add extern.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents: 80517
diff changeset
962 specs, NULL, NULL);
aaff809b3a06 (Vmac_ts_active_input_buf) [USE_MAC_TSM]: Add extern.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents: 80517
diff changeset
963 }
aaff809b3a06 (Vmac_ts_active_input_buf) [USE_MAC_TSM]: Add extern.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents: 80517
diff changeset
964 #endif
80446
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
965 #endif
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
966
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
967 if (err == noErr)
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
968 err = install_menu_target_item_handler ();
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
969
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
970 #ifdef MAC_OSX
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
971 if (err == noErr)
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
972 err = install_service_handler ();
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
973 #endif
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
974
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
975 return err;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
976 }
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
977 #endif /* TARGET_API_MAC_CARBON */
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
978
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
979
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
980 /************************************************************************
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
981 Windows
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
982 ************************************************************************/
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
983
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
984 #define DEFAULT_NUM_COLS 80
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
985
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
986 #define MIN_DOC_SIZE 64
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
987 #define MAX_DOC_SIZE 32767
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
988
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
989 /* Drag and Drop */
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
990 static OSErr install_drag_handler P_ ((WindowRef));
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
991 static void remove_drag_handler P_ ((WindowRef));
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
992
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
993 #if USE_CG_DRAWING
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
994 static void mac_prepare_for_quickdraw P_ ((struct frame *));
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
995 #endif
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
996
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
997 extern void mac_handle_visibility_change P_ ((struct frame *));
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
998 extern void mac_handle_origin_change P_ ((struct frame *));
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
999 extern void mac_handle_size_change P_ ((struct frame *, int, int));
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1000
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1001 #if TARGET_API_MAC_CARBON
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1002 #ifdef MAC_OSX
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1003 extern Lisp_Object Qwindow;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1004 extern Lisp_Object Qtoolbar_switch_mode;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1005 #endif
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1006 #endif
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1007
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1008 static void
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1009 do_window_update (WindowRef win)
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1010 {
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1011 struct frame *f = mac_window_to_frame (win);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1012
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1013 BeginUpdate (win);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1014
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1015 /* The tooltip has been drawn already. Avoid the SET_FRAME_GARBAGED
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1016 below. */
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1017 if (win != tip_window)
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1018 {
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1019 if (f->async_visible == 0)
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1020 {
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1021 /* Update events may occur when a frame gets iconified. */
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1022 #if 0
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1023 f->async_visible = 1;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1024 f->async_iconified = 0;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1025 SET_FRAME_GARBAGED (f);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1026 #endif
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1027 }
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1028 else
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1029 {
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1030 Rect r;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1031 #if TARGET_API_MAC_CARBON
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1032 RgnHandle region = NewRgn ();
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1033
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1034 GetPortVisibleRegion (GetWindowPort (win), region);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1035 GetRegionBounds (region, &r);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1036 expose_frame (f, r.left, r.top, r.right - r.left, r.bottom - r.top);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1037 #if USE_CG_DRAWING
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1038 mac_prepare_for_quickdraw (f);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1039 #endif
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1040 UpdateControls (win, region);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1041 DisposeRgn (region);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1042 #else
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1043 r = (*win->visRgn)->rgnBBox;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1044 expose_frame (f, r.left, r.top, r.right - r.left, r.bottom - r.top);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1045 UpdateControls (win, win->visRgn);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1046 #endif
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1047 }
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1048 }
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1049
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1050 EndUpdate (win);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1051 }
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1052
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1053 static int
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1054 is_emacs_window (WindowRef win)
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1055 {
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1056 Lisp_Object tail, frame;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1057
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1058 if (!win)
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1059 return 0;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1060
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1061 FOR_EACH_FRAME (tail, frame)
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1062 if (FRAME_MAC_P (XFRAME (frame)))
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1063 if (FRAME_MAC_WINDOW (XFRAME (frame)) == win)
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1064 return 1;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1065
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1066 return 0;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1067 }
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1068
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1069 /* Handle drags in size box. Based on code contributed by Ben
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1070 Mesander and IM - Window Manager A. */
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1071
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1072 static void
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1073 do_grow_window (w, e)
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1074 WindowRef w;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1075 const EventRecord *e;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1076 {
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1077 Rect limit_rect;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1078 int rows, columns, width, height;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1079 struct frame *f = mac_window_to_frame (w);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1080 XSizeHints *size_hints = FRAME_SIZE_HINTS (f);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1081 int min_width = MIN_DOC_SIZE, min_height = MIN_DOC_SIZE;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1082 #if TARGET_API_MAC_CARBON
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1083 Rect new_rect;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1084 #else
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1085 long grow_size;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1086 #endif
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1087
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1088 if (size_hints->flags & PMinSize)
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1089 {
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1090 min_width = size_hints->min_width;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1091 min_height = size_hints->min_height;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1092 }
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1093 SetRect (&limit_rect, min_width, min_height, MAX_DOC_SIZE, MAX_DOC_SIZE);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1094
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1095 #if TARGET_API_MAC_CARBON
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1096 if (!ResizeWindow (w, e->where, &limit_rect, &new_rect))
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1097 return;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1098 height = new_rect.bottom - new_rect.top;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1099 width = new_rect.right - new_rect.left;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1100 #else
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1101 grow_size = GrowWindow (w, e->where, &limit_rect);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1102 /* see if it really changed size */
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1103 if (grow_size == 0)
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1104 return;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1105 height = HiWord (grow_size);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1106 width = LoWord (grow_size);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1107 #endif
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1108
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1109 if (width != FRAME_PIXEL_WIDTH (f)
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1110 || height != FRAME_PIXEL_HEIGHT (f))
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1111 {
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1112 rows = FRAME_PIXEL_HEIGHT_TO_TEXT_LINES (f, height);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1113 columns = FRAME_PIXEL_WIDTH_TO_TEXT_COLS (f, width);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1114
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1115 x_set_window_size (f, 0, columns, rows);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1116 }
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1117 }
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1118
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1119 #if TARGET_API_MAC_CARBON
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1120 static Point
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1121 mac_get_ideal_size (f)
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1122 struct frame *f;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1123 {
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1124 struct mac_display_info *dpyinfo = FRAME_MAC_DISPLAY_INFO (f);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1125 WindowRef w = FRAME_MAC_WINDOW (f);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1126 Point ideal_size;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1127 Rect standard_rect;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1128 int height, width, columns, rows;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1129
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1130 ideal_size.h = FRAME_TEXT_COLS_TO_PIXEL_WIDTH (f, DEFAULT_NUM_COLS);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1131 ideal_size.v = dpyinfo->height;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1132 IsWindowInStandardState (w, &ideal_size, &standard_rect);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1133 /* Adjust the standard size according to character boundaries. */
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1134 width = standard_rect.right - standard_rect.left;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1135 height = standard_rect.bottom - standard_rect.top;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1136 columns = FRAME_PIXEL_WIDTH_TO_TEXT_COLS (f, width);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1137 rows = FRAME_PIXEL_HEIGHT_TO_TEXT_LINES (f, height);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1138 ideal_size.h = FRAME_TEXT_COLS_TO_PIXEL_WIDTH (f, columns);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1139 ideal_size.v = FRAME_TEXT_LINES_TO_PIXEL_HEIGHT (f, rows);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1140
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1141 return ideal_size;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1142 }
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1143
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1144 static pascal OSStatus
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1145 mac_handle_window_event (next_handler, event, data)
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1146 EventHandlerCallRef next_handler;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1147 EventRef event;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1148 void *data;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1149 {
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1150 WindowRef wp;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1151 OSStatus err, result = eventNotHandledErr;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1152 struct frame *f;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1153 UInt32 attributes;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1154 XSizeHints *size_hints;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1155
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1156 err = GetEventParameter (event, kEventParamDirectObject, typeWindowRef,
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1157 NULL, sizeof (WindowRef), NULL, &wp);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1158 if (err != noErr)
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1159 return eventNotHandledErr;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1160
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1161 f = mac_window_to_frame (wp);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1162 switch (GetEventKind (event))
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1163 {
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1164 /* -- window refresh events -- */
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1165
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1166 case kEventWindowUpdate:
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1167 result = CallNextEventHandler (next_handler, event);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1168 if (result != eventNotHandledErr)
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1169 break;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1170
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1171 do_window_update (wp);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1172 result = noErr;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1173 break;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1174
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1175 /* -- window state change events -- */
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1176
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1177 case kEventWindowShowing:
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1178 size_hints = FRAME_SIZE_HINTS (f);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1179 if (!(size_hints->flags & (USPosition | PPosition)))
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1180 {
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1181 struct frame *sf = SELECTED_FRAME ();
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1182
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1183 if (!(FRAME_MAC_P (sf) && sf->async_visible))
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1184 RepositionWindow (wp, NULL, kWindowCenterOnMainScreen);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1185 else
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1186 {
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1187 RepositionWindow (wp, FRAME_MAC_WINDOW (sf),
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1188 #if MAC_OS_X_VERSION_MAX_ALLOWED >= 1020
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1189 kWindowCascadeStartAtParentWindowScreen
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1190 #else
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1191 kWindowCascadeOnParentWindowScreen
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1192 #endif
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1193 );
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1194 #if USE_MAC_TOOLBAR
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1195 /* This is a workaround. RepositionWindow fails to put
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1196 a window at the cascading position when its parent
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1197 window has a Carbon HIToolbar. */
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1198 if ((f->left_pos == sf->left_pos
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1199 && f->top_pos == sf->top_pos)
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1200 || (f->left_pos == sf->left_pos + 10 * 2
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1201 && f->top_pos == sf->top_pos + 32 * 2))
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1202 MoveWindowStructure (wp, sf->left_pos + 10, sf->top_pos + 32);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1203 #endif
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1204 }
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1205 result = noErr;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1206 }
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1207 break;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1208
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1209 case kEventWindowHiding:
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1210 /* Before unmapping the window, update the WM_SIZE_HINTS
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1211 property to claim that the current position of the window is
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1212 user-specified, rather than program-specified, so that when
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1213 the window is mapped again, it will be placed at the same
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1214 location, without forcing the user to position it by hand
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1215 again (they have already done that once for this window.) */
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1216 x_wm_set_size_hint (f, (long) 0, 1);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1217 result = noErr;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1218 break;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1219
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1220 case kEventWindowShown:
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1221 case kEventWindowHidden:
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1222 case kEventWindowCollapsed:
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1223 case kEventWindowExpanded:
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1224 mac_handle_visibility_change (f);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1225 result = noErr;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1226 break;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1227
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1228 case kEventWindowBoundsChanging:
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1229 result = CallNextEventHandler (next_handler, event);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1230 if (result != eventNotHandledErr)
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1231 break;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1232
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1233 err = GetEventParameter (event, kEventParamAttributes, typeUInt32,
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1234 NULL, sizeof (UInt32), NULL, &attributes);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1235 if (err != noErr)
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1236 break;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1237
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1238 size_hints = FRAME_SIZE_HINTS (f);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1239 if ((attributes & kWindowBoundsChangeUserResize)
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1240 && ((size_hints->flags & (PResizeInc | PBaseSize | PMinSize))
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1241 == (PResizeInc | PBaseSize | PMinSize)))
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1242 {
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1243 Rect bounds;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1244 int width, height;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1245
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1246 err = GetEventParameter (event, kEventParamCurrentBounds,
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1247 typeQDRectangle, NULL, sizeof (Rect),
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1248 NULL, &bounds);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1249 if (err != noErr)
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1250 break;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1251
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1252 width = bounds.right - bounds.left;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1253 height = bounds.bottom - bounds.top;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1254
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1255 if (width < size_hints->min_width)
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1256 width = size_hints->min_width;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1257 else
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1258 width = size_hints->base_width
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1259 + (int) ((width - size_hints->base_width)
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1260 / (float) size_hints->width_inc + .5)
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1261 * size_hints->width_inc;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1262
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1263 if (height < size_hints->min_height)
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1264 height = size_hints->min_height;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1265 else
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1266 height = size_hints->base_height
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1267 + (int) ((height - size_hints->base_height)
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1268 / (float) size_hints->height_inc + .5)
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1269 * size_hints->height_inc;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1270
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1271 bounds.right = bounds.left + width;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1272 bounds.bottom = bounds.top + height;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1273 SetEventParameter (event, kEventParamCurrentBounds,
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1274 typeQDRectangle, sizeof (Rect), &bounds);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1275 result = noErr;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1276 }
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1277 break;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1278
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1279 case kEventWindowBoundsChanged:
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1280 err = GetEventParameter (event, kEventParamAttributes, typeUInt32,
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1281 NULL, sizeof (UInt32), NULL, &attributes);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1282 if (err != noErr)
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1283 break;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1284
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1285 if (attributes & kWindowBoundsChangeSizeChanged)
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1286 {
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1287 Rect bounds;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1288
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1289 err = GetEventParameter (event, kEventParamCurrentBounds,
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1290 typeQDRectangle, NULL, sizeof (Rect),
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1291 NULL, &bounds);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1292 if (err == noErr)
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1293 {
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1294 int width, height;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1295
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1296 width = bounds.right - bounds.left;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1297 height = bounds.bottom - bounds.top;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1298 mac_handle_size_change (f, width, height);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1299 mac_wakeup_from_rne ();
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1300 }
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1301 }
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1302
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1303 if (attributes & kWindowBoundsChangeOriginChanged)
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1304 mac_handle_origin_change (f);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1305
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1306 result = noErr;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1307 break;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1308
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1309 /* -- window action events -- */
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1310
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1311 case kEventWindowClose:
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1312 {
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1313 struct input_event buf;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1314
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1315 EVENT_INIT (buf);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1316 buf.kind = DELETE_WINDOW_EVENT;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1317 XSETFRAME (buf.frame_or_window, f);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1318 buf.arg = Qnil;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1319 kbd_buffer_store_event (&buf);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1320 }
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1321 result = noErr;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1322 break;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1323
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1324 case kEventWindowGetIdealSize:
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1325 result = CallNextEventHandler (next_handler, event);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1326 if (result != eventNotHandledErr)
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1327 break;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1328
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1329 {
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1330 Point ideal_size = mac_get_ideal_size (f);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1331
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1332 err = SetEventParameter (event, kEventParamDimensions,
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1333 typeQDPoint, sizeof (Point), &ideal_size);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1334 if (err == noErr)
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1335 result = noErr;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1336 }
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1337 break;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1338
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1339 #ifdef MAC_OSX
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1340 case kEventWindowToolbarSwitchMode:
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1341 {
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1342 static const EventParamName names[] = {kEventParamDirectObject,
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1343 kEventParamWindowMouseLocation,
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1344 kEventParamKeyModifiers,
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1345 kEventParamMouseButton,
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1346 kEventParamClickCount,
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1347 kEventParamMouseChord};
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1348 static const EventParamType types[] = {typeWindowRef,
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1349 typeQDPoint,
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1350 typeUInt32,
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1351 typeMouseButton,
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1352 typeUInt32,
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1353 typeUInt32};
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1354 int num_params = sizeof (names) / sizeof (names[0]);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1355
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1356 err = mac_store_event_ref_as_apple_event (0, 0,
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1357 Qwindow,
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1358 Qtoolbar_switch_mode,
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1359 event, num_params,
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1360 names, types);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1361 }
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1362 if (err == noErr)
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1363 result = noErr;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1364 break;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1365 #endif
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1366
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1367 #if USE_MAC_TSM
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1368 /* -- window focus events -- */
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1369
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1370 case kEventWindowFocusAcquired:
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1371 err = mac_tsm_resume ();
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1372 if (err == noErr)
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1373 result = noErr;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1374 break;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1375
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1376 case kEventWindowFocusRelinquish:
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1377 err = mac_tsm_suspend ();
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1378 if (err == noErr)
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1379 result = noErr;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1380 break;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1381 #endif
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1382
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1383 default:
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1384 abort ();
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1385 }
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1386
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1387 return result;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1388 }
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1389 #endif
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1390
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1391 /* Handle clicks in zoom box. Calculation of "standard state" based
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1392 on code in IM - Window Manager A and code contributed by Ben
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1393 Mesander. The standard state of an Emacs window is 80-characters
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1394 wide (DEFAULT_NUM_COLS) and as tall as will fit on the screen. */
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1395
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1396 static void
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1397 do_zoom_window (WindowRef w, int zoom_in_or_out)
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1398 {
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1399 Rect zoom_rect, port_rect;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1400 int width, height;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1401 struct frame *f = mac_window_to_frame (w);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1402 #if TARGET_API_MAC_CARBON
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1403 Point ideal_size = mac_get_ideal_size (f);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1404
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1405 GetWindowBounds (w, kWindowContentRgn, &port_rect);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1406 if (IsWindowInStandardState (w, &ideal_size, &zoom_rect)
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1407 && port_rect.left == zoom_rect.left
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1408 && port_rect.top == zoom_rect.top)
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1409 zoom_in_or_out = inZoomIn;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1410 else
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1411 zoom_in_or_out = inZoomOut;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1412
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1413 #ifdef MAC_OS8
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1414 mac_clear_area (f, 0, 0, port_rect.right - port_rect.left,
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1415 port_rect.bottom - port_rect.top);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1416 #endif
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1417 ZoomWindowIdeal (w, zoom_in_or_out, &ideal_size);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1418 #else /* not TARGET_API_MAC_CARBON */
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1419 GrafPtr save_port;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1420 Point top_left;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1421 int w_title_height, rows;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1422 struct mac_display_info *dpyinfo = FRAME_MAC_DISPLAY_INFO (f);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1423
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1424 GetPort (&save_port);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1425
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1426 SetPortWindowPort (w);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1427
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1428 /* Clear window to avoid flicker. */
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1429 EraseRect (&(w->portRect));
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1430 if (zoom_in_or_out == inZoomOut)
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1431 {
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1432 SetPt (&top_left, w->portRect.left, w->portRect.top);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1433 LocalToGlobal (&top_left);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1434
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1435 /* calculate height of window's title bar */
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1436 w_title_height = top_left.v - 1
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1437 - (**((WindowPeek) w)->strucRgn).rgnBBox.top + GetMBarHeight ();
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1438
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1439 /* get maximum height of window into zoom_rect.bottom - zoom_rect.top */
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1440 zoom_rect = qd.screenBits.bounds;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1441 zoom_rect.top += w_title_height;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1442 InsetRect (&zoom_rect, 8, 4); /* not too tight */
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1443
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1444 zoom_rect.right = zoom_rect.left
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1445 + FRAME_TEXT_COLS_TO_PIXEL_WIDTH (f, DEFAULT_NUM_COLS);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1446
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1447 /* Adjust the standard size according to character boundaries. */
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1448 rows = FRAME_PIXEL_HEIGHT_TO_TEXT_LINES (f, zoom_rect.bottom - zoom_rect.top);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1449 zoom_rect.bottom =
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1450 zoom_rect.top + FRAME_TEXT_LINES_TO_PIXEL_HEIGHT (f, rows);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1451
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1452 (**((WStateDataHandle) ((WindowPeek) w)->dataHandle)).stdState
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1453 = zoom_rect;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1454 }
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1455
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1456 ZoomWindow (w, zoom_in_or_out, f == mac_focus_frame (dpyinfo));
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1457
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1458 SetPort (save_port);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1459 #endif /* not TARGET_API_MAC_CARBON */
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1460
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1461 #if !TARGET_API_MAC_CARBON
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1462 /* retrieve window size and update application values */
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1463 port_rect = w->portRect;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1464 height = port_rect.bottom - port_rect.top;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1465 width = port_rect.right - port_rect.left;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1466
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1467 mac_handle_size_change (f, width, height);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1468 mac_handle_origin_change (f);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1469 #endif
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1470 }
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1471
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1472 static OSStatus
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1473 install_window_handler (window)
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1474 WindowRef window;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1475 {
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1476 OSStatus err = noErr;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1477
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1478 #if TARGET_API_MAC_CARBON
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1479 if (err == noErr)
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1480 {
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1481 static const EventTypeSpec specs[] =
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1482 {
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1483 /* -- window refresh events -- */
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1484 {kEventClassWindow, kEventWindowUpdate},
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1485 /* -- window state change events -- */
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1486 {kEventClassWindow, kEventWindowShowing},
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1487 {kEventClassWindow, kEventWindowHiding},
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1488 {kEventClassWindow, kEventWindowShown},
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1489 {kEventClassWindow, kEventWindowHidden},
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1490 {kEventClassWindow, kEventWindowCollapsed},
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1491 {kEventClassWindow, kEventWindowExpanded},
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1492 {kEventClassWindow, kEventWindowBoundsChanging},
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1493 {kEventClassWindow, kEventWindowBoundsChanged},
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1494 /* -- window action events -- */
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1495 {kEventClassWindow, kEventWindowClose},
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1496 {kEventClassWindow, kEventWindowGetIdealSize},
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1497 #ifdef MAC_OSX
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1498 {kEventClassWindow, kEventWindowToolbarSwitchMode},
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1499 #endif
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1500 #if USE_MAC_TSM
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1501 /* -- window focus events -- */
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1502 {kEventClassWindow, kEventWindowFocusAcquired},
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1503 {kEventClassWindow, kEventWindowFocusRelinquish},
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1504 #endif
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1505 };
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1506 static EventHandlerUPP handle_window_eventUPP = NULL;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1507
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1508 if (handle_window_eventUPP == NULL)
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1509 handle_window_eventUPP = NewEventHandlerUPP (mac_handle_window_event);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1510
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1511 err = InstallWindowEventHandler (window, handle_window_eventUPP,
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1512 GetEventTypeCount (specs),
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1513 specs, NULL, NULL);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1514 }
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1515 #endif
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1516
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1517 if (err == noErr)
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1518 err = install_drag_handler (window);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1519
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1520 return err;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1521 }
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1522
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1523 static void
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1524 remove_window_handler (window)
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1525 WindowRef window;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1526 {
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1527 remove_drag_handler (window);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1528 }
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1529
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1530 void
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1531 mac_get_window_bounds (f, inner, outer)
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1532 struct frame *f;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1533 Rect *inner, *outer;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1534 {
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1535 #if TARGET_API_MAC_CARBON
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1536 GetWindowBounds (FRAME_MAC_WINDOW (f), kWindowContentRgn, inner);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1537 GetWindowBounds (FRAME_MAC_WINDOW (f), kWindowStructureRgn, outer);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1538 #else /* not TARGET_API_MAC_CARBON */
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1539 RgnHandle region = NewRgn ();
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1540
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1541 GetWindowRegion (FRAME_MAC_WINDOW (f), kWindowContentRgn, region);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1542 *inner = (*region)->rgnBBox;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1543 GetWindowRegion (FRAME_MAC_WINDOW (f), kWindowStructureRgn, region);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1544 *outer = (*region)->rgnBBox;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1545 DisposeRgn (region);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1546 #endif /* not TARGET_API_MAC_CARBON */
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1547 }
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1548
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1549 Rect *
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1550 mac_get_frame_bounds (f, r)
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1551 struct frame *f;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1552 Rect *r;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1553 {
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1554 #if TARGET_API_MAC_CARBON
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1555 return GetWindowPortBounds (FRAME_MAC_WINDOW (f), r);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1556 #else
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1557 *r = FRAME_MAC_WINDOW (f)->portRect;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1558
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1559 return r;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1560 #endif
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1561 }
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1562
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1563 void
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1564 mac_get_frame_mouse (f, point)
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1565 struct frame *f;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1566 Point *point;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1567 {
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1568 #if TARGET_API_MAC_CARBON
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1569 GetGlobalMouse (point);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1570 point->h -= f->left_pos + FRAME_OUTER_TO_INNER_DIFF_X (f);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1571 point->v -= f->top_pos + FRAME_OUTER_TO_INNER_DIFF_Y (f);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1572 #else
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1573 SetPortWindowPort (FRAME_MAC_WINDOW (f));
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1574 GetMouse (point);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1575 #endif
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1576 }
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1577
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1578 void
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1579 mac_convert_frame_point_to_global (f, x, y)
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1580 struct frame *f;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1581 int *x, *y;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1582 {
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1583 *x += f->left_pos + FRAME_OUTER_TO_INNER_DIFF_X (f);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1584 *y += f->top_pos + FRAME_OUTER_TO_INNER_DIFF_Y (f);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1585 }
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1586
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1587 #if TARGET_API_MAC_CARBON
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1588 void
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1589 mac_update_proxy_icon (f)
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1590 struct frame *f;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1591 {
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1592 OSStatus err;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1593 Lisp_Object file_name =
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1594 XBUFFER (XWINDOW (FRAME_SELECTED_WINDOW (f))->buffer)->filename;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1595 Window w = FRAME_MAC_WINDOW (f);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1596 AliasHandle alias = NULL;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1597
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1598 err = GetWindowProxyAlias (w, &alias);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1599 if (err == errWindowDoesNotHaveProxy && !STRINGP (file_name))
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1600 return;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1601
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1602 if (STRINGP (file_name))
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1603 {
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1604 AEDesc desc;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1605 #ifdef MAC_OSX
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1606 FSRef fref, fref_proxy;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1607 #else
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1608 FSSpec fss, fss_proxy;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1609 #endif
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1610 Boolean changed;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1611 Lisp_Object encoded_file_name = ENCODE_FILE (file_name);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1612
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1613 #ifdef MAC_OSX
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1614 err = AECoercePtr (TYPE_FILE_NAME, SDATA (encoded_file_name),
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1615 SBYTES (encoded_file_name), typeFSRef, &desc);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1616 #else
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1617 SetPortWindowPort (w);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1618 err = AECoercePtr (TYPE_FILE_NAME, SDATA (encoded_file_name),
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1619 SBYTES (encoded_file_name), typeFSS, &desc);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1620 #endif
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1621 if (err == noErr)
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1622 {
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1623 #ifdef MAC_OSX
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1624 err = AEGetDescData (&desc, &fref, sizeof (FSRef));
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1625 #else
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1626 err = AEGetDescData (&desc, &fss, sizeof (FSSpec));
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1627 #endif
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1628 AEDisposeDesc (&desc);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1629 }
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1630 if (err == noErr)
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1631 {
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1632 if (alias)
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1633 {
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1634 /* (FS)ResolveAlias never sets `changed' to true if
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1635 `alias' is minimal. */
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1636 #ifdef MAC_OSX
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1637 err = FSResolveAlias (NULL, alias, &fref_proxy, &changed);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1638 if (err == noErr)
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1639 err = FSCompareFSRefs (&fref, &fref_proxy);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1640 #else
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1641 err = ResolveAlias (NULL, alias, &fss_proxy, &changed);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1642 if (err == noErr)
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1643 err = !(fss.vRefNum == fss_proxy.vRefNum
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1644 && fss.parID == fss_proxy.parID
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1645 && EqualString (fss.name, fss_proxy.name,
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1646 false, true));
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1647 #endif
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1648 }
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1649 if (err != noErr || alias == NULL)
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1650 {
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1651 if (alias)
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1652 DisposeHandle ((Handle) alias);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1653 #ifdef MAC_OSX
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1654 err = FSNewAliasMinimal (&fref, &alias);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1655 #else
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1656 err = NewAliasMinimal (&fss, &alias);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1657 #endif
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1658 changed = true;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1659 }
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1660 }
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1661 if (err == noErr)
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1662 if (changed)
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1663 err = SetWindowProxyAlias (w, alias);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1664 }
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1665
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1666 if (alias)
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1667 DisposeHandle ((Handle) alias);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1668
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1669 if (err != noErr || !STRINGP (file_name))
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1670 RemoveWindowProxy (w);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1671 }
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1672 #endif
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1673
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1674 /* Mac replacement for XSetWindowBackground. */
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1675
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1676 void
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1677 mac_set_frame_window_background (f, color)
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1678 struct frame *f;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1679 unsigned long color;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1680 {
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1681 WindowRef w = FRAME_MAC_WINDOW (f);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1682 #if !TARGET_API_MAC_CARBON
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1683 AuxWinHandle aw_handle;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1684 CTabHandle ctab_handle;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1685 ColorSpecPtr ct_table;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1686 short ct_size;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1687 #endif
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1688 RGBColor bg_color;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1689
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1690 bg_color.red = RED16_FROM_ULONG (color);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1691 bg_color.green = GREEN16_FROM_ULONG (color);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1692 bg_color.blue = BLUE16_FROM_ULONG (color);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1693
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1694 #if TARGET_API_MAC_CARBON
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1695 SetWindowContentColor (w, &bg_color);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1696 #else
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1697 if (GetAuxWin (w, &aw_handle))
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1698 {
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1699 ctab_handle = (*aw_handle)->awCTable;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1700 HandToHand ((Handle *) &ctab_handle);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1701 ct_table = (*ctab_handle)->ctTable;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1702 ct_size = (*ctab_handle)->ctSize;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1703 while (ct_size > -1)
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1704 {
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1705 if (ct_table->value == 0)
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1706 {
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1707 ct_table->rgb = bg_color;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1708 CTabChanged (ctab_handle);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1709 SetWinColor (w, (WCTabHandle) ctab_handle);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1710 }
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1711 ct_size--;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1712 }
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1713 }
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1714 #endif
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1715 }
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1716
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1717 /* Flush display of frame F, or of all frames if F is null. */
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1718
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1719 void
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1720 x_flush (f)
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1721 struct frame *f;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1722 {
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1723 #if TARGET_API_MAC_CARBON
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1724 BLOCK_INPUT;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1725 #if USE_CG_DRAWING
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1726 mac_prepare_for_quickdraw (f);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1727 #endif
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1728 if (f)
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1729 QDFlushPortBuffer (GetWindowPort (FRAME_MAC_WINDOW (f)), NULL);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1730 else
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1731 QDFlushPortBuffer (GetQDGlobalsThePort (), NULL);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1732 UNBLOCK_INPUT;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1733 #endif
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1734 }
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1735
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1736 #if USE_CG_DRAWING
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1737 void
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1738 mac_flush_display_optional (f)
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1739 struct frame *f;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1740 {
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1741 BLOCK_INPUT;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1742 mac_prepare_for_quickdraw (f);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1743 UNBLOCK_INPUT;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1744 }
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1745 #endif
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1746
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1747 void
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1748 mac_update_begin (f)
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1749 struct frame *f;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1750 {
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1751 #if TARGET_API_MAC_CARBON
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1752 /* During update of a frame, availability of input events is
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1753 periodically checked with ReceiveNextEvent if
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1754 redisplay-dont-pause is nil. That normally flushes window buffer
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1755 changes for every check, and thus screen update looks waving even
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1756 if no input is available. So we disable screen updates during
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1757 update of a frame. */
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1758 DisableScreenUpdates ();
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1759 #endif
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1760 }
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1761
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1762 void
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1763 mac_update_end (f)
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1764 struct frame *f;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1765 {
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1766 #if TARGET_API_MAC_CARBON
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1767 EnableScreenUpdates ();
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1768 #endif
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1769 }
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1770
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1771 void
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1772 mac_frame_up_to_date (f)
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1773 struct frame *f;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1774 {
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1775 /* Nothing to do. */
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1776 }
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1777
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1778 void
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1779 mac_create_frame_window (f, tooltip_p)
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1780 struct frame *f;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1781 int tooltip_p;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1782 {
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1783 Rect r;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1784 #if TARGET_API_MAC_CARBON
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1785 WindowClass window_class;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1786 WindowAttributes attributes;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1787 #else
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1788 short proc_id;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1789 WindowRef behind;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1790 Boolean go_away_flag;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1791 #endif
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1792
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1793 if (!tooltip_p)
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1794 {
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1795 SetRect (&r, f->left_pos, f->top_pos,
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1796 f->left_pos + FRAME_PIXEL_WIDTH (f),
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1797 f->top_pos + FRAME_PIXEL_HEIGHT (f));
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1798 #if TARGET_API_MAC_CARBON
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1799 window_class = kDocumentWindowClass;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1800 attributes = (kWindowStandardDocumentAttributes
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1801 #ifdef MAC_OSX
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1802 | kWindowToolbarButtonAttribute
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1803 #endif
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1804 );
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1805 #else
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1806 proc_id = zoomDocProc;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1807 behind = (WindowRef) -1;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1808 go_away_flag = true;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1809 #endif
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1810 }
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1811 else
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1812 {
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1813 SetRect (&r, 0, 0, 1, 1);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1814 #if TARGET_API_MAC_CARBON
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1815 window_class = kHelpWindowClass;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1816 attributes = (kWindowNoUpdatesAttribute
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1817 | kWindowNoActivatesAttribute
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1818 #if MAC_OS_X_VERSION_MAX_ALLOWED >= 1020
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1819 | kWindowIgnoreClicksAttribute
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1820 #endif
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1821 );
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1822 #else
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1823 proc_id = plainDBox;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1824 behind = NULL;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1825 go_away_flag = false;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1826 #endif
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1827 }
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1828
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1829 #if TARGET_API_MAC_CARBON
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1830 CreateNewWindow (window_class, attributes, &r, &FRAME_MAC_WINDOW (f));
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1831 if (FRAME_MAC_WINDOW (f))
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1832 {
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1833 SetWRefCon (FRAME_MAC_WINDOW (f), (long) f->output_data.mac);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1834 if (!tooltip_p)
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1835 if (install_window_handler (FRAME_MAC_WINDOW (f)) != noErr)
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1836 {
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1837 DisposeWindow (FRAME_MAC_WINDOW (f));
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1838 FRAME_MAC_WINDOW (f) = NULL;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1839 }
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1840 }
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1841 #else /* !TARGET_API_MAC_CARBON */
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1842 FRAME_MAC_WINDOW (f)
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1843 = NewCWindow (NULL, &r, "\p", false, proc_id, behind, go_away_flag,
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1844 (long) f->output_data.mac);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1845 #endif /* !TARGET_API_MAC_CARBON */
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1846 /* so that update events can find this mac_output struct */
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1847 f->output_data.mac->mFP = f; /* point back to emacs frame */
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1848
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1849 #ifndef MAC_OSX
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1850 if (!tooltip_p)
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1851 if (FRAME_MAC_WINDOW (f))
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1852 {
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1853 ControlRef root_control;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1854
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1855 if (CreateRootControl (FRAME_MAC_WINDOW (f), &root_control) != noErr)
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1856 {
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1857 DisposeWindow (FRAME_MAC_WINDOW (f));
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1858 FRAME_MAC_WINDOW (f) = NULL;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1859 }
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1860 }
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1861 #endif
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1862 }
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1863
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1864 /* Dispose of the Mac window of the frame F. */
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1865
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1866 void
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1867 mac_dispose_frame_window (f)
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1868 struct frame *f;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1869 {
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1870 WindowRef window = FRAME_MAC_WINDOW (f);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1871
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1872 if (window != tip_window)
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1873 remove_window_handler (window);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1874
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1875 #if USE_CG_DRAWING
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1876 mac_prepare_for_quickdraw (f);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1877 #endif
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1878 DisposeWindow (window);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1879 }
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1880
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1881
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1882 /************************************************************************
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1883 View and Drawing
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1884 ************************************************************************/
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1885
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1886 #if USE_CG_DRAWING
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1887 #define FRAME_CG_CONTEXT(f) ((f)->output_data.mac->cg_context)
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1888
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1889 CGContextRef
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1890 mac_begin_cg_clip (f, gc)
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1891 struct frame *f;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1892 GC gc;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1893 {
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1894 CGContextRef context = FRAME_CG_CONTEXT (f);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1895
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1896 if (!context)
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1897 {
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1898 QDBeginCGContext (GetWindowPort (FRAME_MAC_WINDOW (f)), &context);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1899 FRAME_CG_CONTEXT (f) = context;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1900 }
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1901
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1902 CGContextSaveGState (context);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1903 CGContextTranslateCTM (context, 0, FRAME_PIXEL_HEIGHT (f));
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1904 CGContextScaleCTM (context, 1, -1);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1905 if (gc && gc->n_clip_rects)
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1906 CGContextClipToRects (context, gc->clip_rects, gc->n_clip_rects);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1907
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1908 return context;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1909 }
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1910
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1911 void
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1912 mac_end_cg_clip (f)
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1913 struct frame *f;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1914 {
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1915 CGContextRestoreGState (FRAME_CG_CONTEXT (f));
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1916 }
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1917
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1918 static void
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1919 mac_prepare_for_quickdraw (f)
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1920 struct frame *f;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1921 {
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1922 if (f == NULL)
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1923 {
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1924 Lisp_Object rest, frame;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1925 FOR_EACH_FRAME (rest, frame)
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1926 if (FRAME_MAC_P (XFRAME (frame)))
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1927 mac_prepare_for_quickdraw (XFRAME (frame));
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1928 }
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1929 else
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1930 {
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1931 CGContextRef context = FRAME_CG_CONTEXT (f);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1932
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1933 if (context)
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1934 {
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1935 CGContextSynchronize (context);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1936 QDEndCGContext (GetWindowPort (FRAME_MAC_WINDOW (f)),
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1937 &FRAME_CG_CONTEXT (f));
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1938 }
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1939 }
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1940 }
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1941 #endif
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1942
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1943 static RgnHandle saved_port_clip_region = NULL;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1944
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1945 void
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1946 mac_begin_clip (f, gc)
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1947 struct frame *f;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1948 GC gc;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1949 {
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1950 static RgnHandle new_region = NULL;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1951
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1952 if (saved_port_clip_region == NULL)
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1953 saved_port_clip_region = NewRgn ();
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1954 if (new_region == NULL)
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1955 new_region = NewRgn ();
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1956
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1957 #if USE_CG_DRAWING
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1958 mac_prepare_for_quickdraw (f);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1959 #endif
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1960 SetPortWindowPort (FRAME_MAC_WINDOW (f));
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1961
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1962 if (gc && gc->n_clip_rects)
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1963 {
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1964 GetClip (saved_port_clip_region);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1965 SectRgn (saved_port_clip_region, gc->clip_region, new_region);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1966 SetClip (new_region);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1967 }
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1968 }
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1969
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1970 void
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1971 mac_end_clip (f, gc)
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1972 struct frame *f;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1973 GC gc;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1974 {
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1975 if (gc && gc->n_clip_rects)
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1976 SetClip (saved_port_clip_region);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1977 }
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1978
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1979 #if TARGET_API_MAC_CARBON
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1980 /* Mac replacement for XCopyArea: used only for scrolling. */
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1981
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1982 void
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1983 mac_scroll_area (f, gc, src_x, src_y, width, height, dest_x, dest_y)
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1984 struct frame *f;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1985 GC gc;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1986 int src_x, src_y;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1987 unsigned int width, height;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1988 int dest_x, dest_y;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1989 {
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1990 Rect src_r;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1991 RgnHandle dummy = NewRgn (); /* For avoiding update events. */
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1992
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1993 SetRect (&src_r, src_x, src_y, src_x + width, src_y + height);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1994 #if USE_CG_DRAWING
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1995 mac_prepare_for_quickdraw (f);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1996 #endif
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1997 ScrollWindowRect (FRAME_MAC_WINDOW (f),
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1998 &src_r, dest_x - src_x, dest_y - src_y,
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
1999 kScrollWindowNoOptions, dummy);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2000 DisposeRgn (dummy);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2001 }
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2002 #endif
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2003
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2004
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2005 /************************************************************************
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2006 Scroll bars
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2007 ************************************************************************/
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2008
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2009 extern struct scroll_bar *tracked_scroll_bar;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2010 extern Lisp_Object last_mouse_scroll_bar;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2011 extern Time last_mouse_movement_time;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2012
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2013 static void x_scroll_bar_handle_click P_ ((struct scroll_bar *,
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2014 ControlPartCode,
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2015 const EventRecord *,
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2016 struct input_event *));
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2017 #ifndef USE_TOOLKIT_SCROLL_BARS
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2018 static void x_scroll_bar_note_movement P_ ((struct scroll_bar *, int, Time));
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2019 #else /* USE_TOOLKIT_SCROLL_BARS */
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2020 static void x_scroll_bar_handle_press P_ ((struct scroll_bar *,
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2021 ControlPartCode, Point,
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2022 struct input_event *));
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2023 static void x_scroll_bar_handle_release P_ ((struct scroll_bar *,
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2024 struct input_event *));
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2025 static void x_scroll_bar_handle_drag P_ ((WindowRef, struct scroll_bar *,
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2026 Point, struct input_event *));
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2027 static pascal void scroll_bar_timer_callback P_ ((EventLoopTimerRef, void *));
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2028 static OSStatus install_scroll_bar_timer P_ ((void));
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2029 static OSStatus set_scroll_bar_timer P_ ((EventTimerInterval));
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2030 static int control_part_code_to_scroll_bar_part P_ ((ControlPartCode));
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2031 static void construct_scroll_bar_click P_ ((struct scroll_bar *, int,
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2032 struct input_event *));
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2033 static OSStatus get_control_part_bounds P_ ((ControlRef, ControlPartCode,
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2034 Rect *));
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2035 static void update_scroll_bar_track_info P_ ((struct scroll_bar *));
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2036
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2037 /* Last scroll bar part sent in x_scroll_bar_handle_*. */
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2038
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2039 static int last_scroll_bar_part;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2040
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2041 static EventLoopTimerRef scroll_bar_timer;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2042
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2043 static int scroll_bar_timer_event_posted_p;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2044
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2045 #define SCROLL_BAR_FIRST_DELAY 0.5
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2046 #define SCROLL_BAR_CONTINUOUS_DELAY (1.0 / 15)
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2047
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2048 static pascal void
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2049 scroll_bar_timer_callback (timer, data)
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2050 EventLoopTimerRef timer;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2051 void *data;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2052 {
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2053 OSStatus err;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2054
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2055 err = mac_post_mouse_moved_event ();
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2056 if (err == noErr)
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2057 scroll_bar_timer_event_posted_p = 1;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2058 }
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2059
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2060 static OSStatus
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2061 install_scroll_bar_timer ()
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2062 {
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2063 static EventLoopTimerUPP scroll_bar_timer_callbackUPP = NULL;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2064
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2065 if (scroll_bar_timer_callbackUPP == NULL)
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2066 scroll_bar_timer_callbackUPP =
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2067 NewEventLoopTimerUPP (scroll_bar_timer_callback);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2068
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2069 if (scroll_bar_timer == NULL)
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2070 /* Mac OS X and CarbonLib 1.5 and later allow us to specify
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2071 kEventDurationForever as delays. */
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2072 return
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2073 InstallEventLoopTimer (GetCurrentEventLoop (),
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2074 kEventDurationForever, kEventDurationForever,
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2075 scroll_bar_timer_callbackUPP, NULL,
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2076 &scroll_bar_timer);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2077 }
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2078
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2079 static OSStatus
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2080 set_scroll_bar_timer (delay)
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2081 EventTimerInterval delay;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2082 {
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2083 if (scroll_bar_timer == NULL)
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2084 install_scroll_bar_timer ();
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2085
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2086 scroll_bar_timer_event_posted_p = 0;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2087
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2088 return SetEventLoopTimerNextFireTime (scroll_bar_timer, delay);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2089 }
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2090
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2091 static int
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2092 control_part_code_to_scroll_bar_part (part_code)
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2093 ControlPartCode part_code;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2094 {
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2095 switch (part_code)
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2096 {
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2097 case kControlUpButtonPart: return scroll_bar_up_arrow;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2098 case kControlDownButtonPart: return scroll_bar_down_arrow;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2099 case kControlPageUpPart: return scroll_bar_above_handle;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2100 case kControlPageDownPart: return scroll_bar_below_handle;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2101 case kControlIndicatorPart: return scroll_bar_handle;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2102 }
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2103
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2104 return -1;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2105 }
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2106
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2107 static void
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2108 construct_scroll_bar_click (bar, part, bufp)
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2109 struct scroll_bar *bar;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2110 int part;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2111 struct input_event *bufp;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2112 {
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2113 bufp->kind = SCROLL_BAR_CLICK_EVENT;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2114 bufp->frame_or_window = bar->window;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2115 bufp->arg = Qnil;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2116 bufp->part = part;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2117 bufp->code = 0;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2118 XSETINT (bufp->x, 0);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2119 XSETINT (bufp->y, 0);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2120 bufp->modifiers = 0;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2121 }
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2122
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2123 static OSStatus
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2124 get_control_part_bounds (ch, part_code, rect)
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2125 ControlRef ch;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2126 ControlPartCode part_code;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2127 Rect *rect;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2128 {
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2129 RgnHandle region = NewRgn ();
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2130 OSStatus err;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2131
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2132 err = GetControlRegion (ch, part_code, region);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2133 if (err == noErr)
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2134 GetRegionBounds (region, rect);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2135 DisposeRgn (region);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2136
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2137 return err;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2138 }
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2139
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2140 static void
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2141 x_scroll_bar_handle_press (bar, part_code, mouse_pos, bufp)
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2142 struct scroll_bar *bar;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2143 ControlPartCode part_code;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2144 Point mouse_pos;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2145 struct input_event *bufp;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2146 {
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2147 int part = control_part_code_to_scroll_bar_part (part_code);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2148
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2149 if (part < 0)
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2150 return;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2151
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2152 if (part != scroll_bar_handle)
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2153 {
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2154 construct_scroll_bar_click (bar, part, bufp);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2155 HiliteControl (SCROLL_BAR_CONTROL_REF (bar), part_code);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2156 set_scroll_bar_timer (SCROLL_BAR_FIRST_DELAY);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2157 bar->dragging = Qnil;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2158 }
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2159 else
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2160 {
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2161 Rect r;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2162
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2163 get_control_part_bounds (SCROLL_BAR_CONTROL_REF (bar),
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2164 kControlIndicatorPart, &r);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2165 XSETINT (bar->dragging, - (mouse_pos.v - r.top) - 1);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2166 }
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2167
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2168 last_scroll_bar_part = part;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2169 tracked_scroll_bar = bar;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2170 }
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2171
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2172 static void
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2173 x_scroll_bar_handle_release (bar, bufp)
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2174 struct scroll_bar *bar;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2175 struct input_event *bufp;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2176 {
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2177 if (last_scroll_bar_part != scroll_bar_handle
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2178 || (INTEGERP (bar->dragging) && XINT (bar->dragging) >= 0))
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2179 construct_scroll_bar_click (bar, scroll_bar_end_scroll, bufp);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2180
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2181 HiliteControl (SCROLL_BAR_CONTROL_REF (bar), 0);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2182 set_scroll_bar_timer (kEventDurationForever);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2183
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2184 last_scroll_bar_part = -1;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2185 bar->dragging = Qnil;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2186 tracked_scroll_bar = NULL;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2187 }
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2188
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2189 static void
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2190 x_scroll_bar_handle_drag (win, bar, mouse_pos, bufp)
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2191 WindowRef win;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2192 struct scroll_bar *bar;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2193 Point mouse_pos;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2194 struct input_event *bufp;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2195 {
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2196 ControlRef ch = SCROLL_BAR_CONTROL_REF (bar);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2197
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2198 if (last_scroll_bar_part == scroll_bar_handle)
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2199 {
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2200 int top, top_range;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2201 Rect r;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2202
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2203 get_control_part_bounds (SCROLL_BAR_CONTROL_REF (bar),
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2204 kControlIndicatorPart, &r);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2205
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2206 if (INTEGERP (bar->dragging) && XINT (bar->dragging) < 0)
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2207 XSETINT (bar->dragging, - (XINT (bar->dragging) + 1));
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2208
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2209 top = mouse_pos.v - XINT (bar->dragging) - XINT (bar->track_top);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2210 top_range = XINT (bar->track_height) - XINT (bar->min_handle);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2211
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2212 if (top < 0)
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2213 top = 0;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2214 if (top > top_range)
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2215 top = top_range;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2216
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2217 construct_scroll_bar_click (bar, scroll_bar_handle, bufp);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2218 XSETINT (bufp->x, top);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2219 XSETINT (bufp->y, top_range);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2220 }
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2221 else
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2222 {
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2223 ControlPartCode part_code;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2224 int unhilite_p = 0, part;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2225
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2226 if (ch != FindControlUnderMouse (mouse_pos, win, &part_code))
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2227 unhilite_p = 1;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2228 else
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2229 {
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2230 part = control_part_code_to_scroll_bar_part (part_code);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2231
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2232 switch (last_scroll_bar_part)
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2233 {
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2234 case scroll_bar_above_handle:
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2235 case scroll_bar_below_handle:
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2236 if (part != scroll_bar_above_handle
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2237 && part != scroll_bar_below_handle)
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2238 unhilite_p = 1;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2239 break;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2240
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2241 case scroll_bar_up_arrow:
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2242 case scroll_bar_down_arrow:
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2243 if (part != scroll_bar_up_arrow
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2244 && part != scroll_bar_down_arrow)
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2245 unhilite_p = 1;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2246 break;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2247 }
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2248 }
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2249
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2250 if (unhilite_p)
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2251 HiliteControl (SCROLL_BAR_CONTROL_REF (bar), 0);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2252 else if (part != last_scroll_bar_part
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2253 || scroll_bar_timer_event_posted_p)
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2254 {
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2255 construct_scroll_bar_click (bar, part, bufp);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2256 last_scroll_bar_part = part;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2257 HiliteControl (SCROLL_BAR_CONTROL_REF (bar), part_code);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2258 set_scroll_bar_timer (SCROLL_BAR_CONTINUOUS_DELAY);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2259 }
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2260 }
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2261 }
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2262
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2263 /* Update BAR->track_top, BAR->track_height, and BAR->min_handle for
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2264 the scroll bar BAR. This function should be called when the bounds
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2265 of the scroll bar is changed. */
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2266
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2267 static void
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2268 update_scroll_bar_track_info (bar)
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2269 struct scroll_bar *bar;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2270 {
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2271 ControlRef ch = SCROLL_BAR_CONTROL_REF (bar);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2272 Rect r0, r1;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2273
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2274 GetControlBounds (ch, &r0);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2275
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2276 if (r0.right - r0.left >= r0.bottom - r0.top
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2277 #ifdef MAC_OSX
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2278 || r0.right - r0.left < MAC_AQUA_SMALL_VERTICAL_SCROLL_BAR_WIDTH
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2279 #endif
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2280 )
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2281 {
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2282 XSETINT (bar->track_top, 0);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2283 XSETINT (bar->track_height, 0);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2284 XSETINT (bar->min_handle, 0);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2285 }
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2286 else
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2287 {
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2288 BLOCK_INPUT;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2289
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2290 SetControl32BitMinimum (ch, 0);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2291 SetControl32BitMaximum (ch, 1 << 30);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2292 SetControlViewSize (ch, 1);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2293
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2294 /* Move the scroll bar thumb to the top. */
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2295 SetControl32BitValue (ch, 0);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2296 get_control_part_bounds (ch, kControlIndicatorPart, &r0);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2297
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2298 /* Move the scroll bar thumb to the bottom. */
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2299 SetControl32BitValue (ch, 1 << 30);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2300 get_control_part_bounds (ch, kControlIndicatorPart, &r1);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2301
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2302 UnionRect (&r0, &r1, &r0);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2303 XSETINT (bar->track_top, r0.top);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2304 XSETINT (bar->track_height, r0.bottom - r0.top);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2305 XSETINT (bar->min_handle, r1.bottom - r1.top);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2306
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2307 /* Don't show the scroll bar if its height is not enough to
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2308 display the scroll bar thumb. */
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2309 if (r0.bottom - r0.top > 0)
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2310 ShowControl (ch);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2311
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2312 UNBLOCK_INPUT;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2313 }
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2314 }
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2315
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2316 /* Set the thumb size and position of scroll bar BAR. We are currently
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2317 displaying PORTION out of a whole WHOLE, and our position POSITION. */
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2318
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2319 void
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2320 x_set_toolkit_scroll_bar_thumb (bar, portion, position, whole)
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2321 struct scroll_bar *bar;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2322 int portion, position, whole;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2323 {
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2324 ControlRef ch = SCROLL_BAR_CONTROL_REF (bar);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2325 int value, viewsize, maximum;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2326
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2327 if (XINT (bar->track_height) == 0)
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2328 return;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2329
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2330 if (whole <= portion)
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2331 value = 0, viewsize = 1, maximum = 0;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2332 else
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2333 {
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2334 float scale;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2335
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2336 maximum = XINT (bar->track_height) - XINT (bar->min_handle);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2337 scale = (float) maximum / (whole - portion);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2338 value = position * scale + 0.5f;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2339 viewsize = (int) (portion * scale + 0.5f) + XINT (bar->min_handle);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2340 }
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2341
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2342 BLOCK_INPUT;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2343
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2344 if (GetControlViewSize (ch) != viewsize
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2345 || GetControl32BitValue (ch) != value
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2346 || GetControl32BitMaximum (ch) != maximum)
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2347 {
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2348 /* Temporarily hide the scroll bar to avoid multiple redraws. */
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2349 SetControlVisibility (ch, false, false);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2350
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2351 SetControl32BitMaximum (ch, maximum);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2352 SetControl32BitValue (ch, value);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2353 SetControlViewSize (ch, viewsize);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2354
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2355 SetControlVisibility (ch, true, true);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2356 }
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2357
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2358 UNBLOCK_INPUT;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2359 }
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2360
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2361 #endif /* USE_TOOLKIT_SCROLL_BARS */
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2362
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2363 /* Create a scroll bar control for BAR. BOUNDS and VISIBLE specifies
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2364 the initial geometry and visibility, respectively. The created
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2365 control is stored in some members of BAR. */
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2366
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2367 void
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2368 mac_create_scroll_bar (bar, bounds, visible)
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2369 struct scroll_bar *bar;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2370 const Rect *bounds;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2371 Boolean visible;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2372 {
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2373 struct frame *f = XFRAME (WINDOW_FRAME (XWINDOW (bar->window)));
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2374 ControlRef ch;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2375
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2376 #if USE_CG_DRAWING
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2377 mac_prepare_for_quickdraw (f);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2378 #endif
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2379 ch = NewControl (FRAME_MAC_WINDOW (f), bounds, "\p", visible, 0, 0, 0,
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2380 #if TARGET_API_MAC_CARBON
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2381 kControlScrollBarProc,
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2382 #else
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2383 scrollBarProc,
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2384 #endif
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2385 (SInt32) bar);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2386 SET_SCROLL_BAR_CONTROL_REF (bar, ch);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2387
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2388 XSETINT (bar->start, 0);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2389 XSETINT (bar->end, 0);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2390 bar->dragging = Qnil;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2391
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2392 #ifdef USE_TOOLKIT_SCROLL_BARS
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2393 update_scroll_bar_track_info (bar);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2394 #endif
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2395 }
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2396
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2397 /* Dispose of the scroll bar control stored in some members of
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2398 BAR. */
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2399
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2400 void
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2401 mac_dispose_scroll_bar (bar)
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2402 struct scroll_bar *bar;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2403 {
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2404 #if USE_CG_DRAWING
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2405 struct frame *f = XFRAME (WINDOW_FRAME (XWINDOW (bar->window)));
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2406
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2407 mac_prepare_for_quickdraw (f);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2408 #endif
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2409 DisposeControl (SCROLL_BAR_CONTROL_REF (bar));
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2410 }
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2411
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2412 /* Set bounds of the scroll bar BAR to BOUNDS. */
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2413
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2414 void
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2415 mac_set_scroll_bar_bounds (bar, bounds)
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2416 struct scroll_bar *bar;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2417 const Rect *bounds;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2418 {
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2419 ControlRef ch = SCROLL_BAR_CONTROL_REF (bar);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2420 SInt16 width, height;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2421 #if USE_CG_DRAWING
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2422 struct frame *f = XFRAME (WINDOW_FRAME (XWINDOW (bar->window)));
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2423
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2424 mac_prepare_for_quickdraw (f);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2425 #endif
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2426
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2427 width = bounds->right - bounds->left;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2428 height = bounds->bottom - bounds->top;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2429 HideControl (ch);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2430 MoveControl (ch, bounds->left, bounds->top);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2431 SizeControl (ch, width, height);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2432 #ifdef USE_TOOLKIT_SCROLL_BARS
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2433 update_scroll_bar_track_info (bar);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2434 #else
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2435 if (width < height)
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2436 ShowControl (ch);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2437 #endif
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2438 }
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2439
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2440 /* Draw the scroll bar BAR. */
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2441
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2442 void
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2443 mac_redraw_scroll_bar (bar)
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2444 struct scroll_bar *bar;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2445 {
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2446 #if USE_CG_DRAWING
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2447 struct frame *f = XFRAME (WINDOW_FRAME (XWINDOW (bar->window)));
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2448
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2449 mac_prepare_for_quickdraw (f);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2450 #endif
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2451 Draw1Control (SCROLL_BAR_CONTROL_REF (bar));
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2452 }
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2453
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2454 /* Handle a mouse click on the scroll bar BAR. If *EMACS_EVENT's kind
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2455 is set to something other than NO_EVENT, it is enqueued.
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2456
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2457 This may be called from a signal handler, so we have to ignore GC
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2458 mark bits. */
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2459
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2460 static void
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2461 x_scroll_bar_handle_click (bar, part_code, er, bufp)
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2462 struct scroll_bar *bar;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2463 ControlPartCode part_code;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2464 const EventRecord *er;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2465 struct input_event *bufp;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2466 {
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2467 int win_y, top_range;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2468
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2469 if (! GC_WINDOWP (bar->window))
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2470 abort ();
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2471
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2472 bufp->kind = SCROLL_BAR_CLICK_EVENT;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2473 bufp->frame_or_window = bar->window;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2474 bufp->arg = Qnil;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2475
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2476 bar->dragging = Qnil;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2477
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2478 switch (part_code)
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2479 {
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2480 case kControlUpButtonPart:
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2481 bufp->part = scroll_bar_up_arrow;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2482 break;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2483 case kControlDownButtonPart:
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2484 bufp->part = scroll_bar_down_arrow;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2485 break;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2486 case kControlPageUpPart:
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2487 bufp->part = scroll_bar_above_handle;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2488 break;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2489 case kControlPageDownPart:
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2490 bufp->part = scroll_bar_below_handle;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2491 break;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2492 #if TARGET_API_MAC_CARBON
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2493 default:
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2494 #else
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2495 case kControlIndicatorPart:
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2496 #endif
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2497 if (er->what == mouseDown)
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2498 bar->dragging = make_number (0);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2499 XSETVECTOR (last_mouse_scroll_bar, bar);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2500 bufp->part = scroll_bar_handle;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2501 break;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2502 }
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2503
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2504 win_y = XINT (bufp->y) - XINT (bar->top);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2505 top_range = VERTICAL_SCROLL_BAR_TOP_RANGE (0/*dummy*/, XINT (bar->height));
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2506
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2507 win_y -= VERTICAL_SCROLL_BAR_TOP_BORDER;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2508
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2509 win_y -= 24;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2510
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2511 if (! NILP (bar->dragging))
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2512 win_y -= XINT (bar->dragging);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2513
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2514 if (win_y < 0)
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2515 win_y = 0;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2516 if (win_y > top_range)
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2517 win_y = top_range;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2518
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2519 XSETINT (bufp->x, win_y);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2520 XSETINT (bufp->y, top_range);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2521 }
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2522
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2523 /* Return information to the user about the current position of the mouse
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2524 on the scroll bar. */
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2525
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2526 void
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2527 x_scroll_bar_report_motion (fp, bar_window, part, x, y, time)
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2528 FRAME_PTR *fp;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2529 Lisp_Object *bar_window;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2530 enum scroll_bar_part *part;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2531 Lisp_Object *x, *y;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2532 unsigned long *time;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2533 {
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2534 struct scroll_bar *bar = XSCROLL_BAR (last_mouse_scroll_bar);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2535 ControlRef ch = SCROLL_BAR_CONTROL_REF (bar);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2536 #if TARGET_API_MAC_CARBON
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2537 WindowRef wp = GetControlOwner (ch);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2538 #else
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2539 WindowRef wp = (*ch)->contrlOwner;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2540 #endif
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2541 Point mouse_pos;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2542 struct frame *f = mac_window_to_frame (wp);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2543 int win_y, top_range;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2544
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2545 #if TARGET_API_MAC_CARBON
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2546 GetGlobalMouse (&mouse_pos);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2547 mouse_pos.h -= f->left_pos + FRAME_OUTER_TO_INNER_DIFF_X (f);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2548 mouse_pos.v -= f->top_pos + FRAME_OUTER_TO_INNER_DIFF_Y (f);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2549 #else
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2550 SetPortWindowPort (wp);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2551 GetMouse (&mouse_pos);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2552 #endif
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2553
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2554 win_y = mouse_pos.v - XINT (bar->top);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2555 top_range = VERTICAL_SCROLL_BAR_TOP_RANGE (f, XINT (bar->height));
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2556
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2557 win_y -= VERTICAL_SCROLL_BAR_TOP_BORDER;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2558
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2559 win_y -= 24;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2560
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2561 if (! NILP (bar->dragging))
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2562 win_y -= XINT (bar->dragging);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2563
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2564 if (win_y < 0)
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2565 win_y = 0;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2566 if (win_y > top_range)
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2567 win_y = top_range;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2568
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2569 *fp = f;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2570 *bar_window = bar->window;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2571
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2572 if (! NILP (bar->dragging))
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2573 *part = scroll_bar_handle;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2574 else if (win_y < XINT (bar->start))
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2575 *part = scroll_bar_above_handle;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2576 else if (win_y < XINT (bar->end) + VERTICAL_SCROLL_BAR_MIN_HANDLE)
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2577 *part = scroll_bar_handle;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2578 else
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2579 *part = scroll_bar_below_handle;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2580
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2581 XSETINT (*x, win_y);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2582 XSETINT (*y, top_range);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2583
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2584 f->mouse_moved = 0;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2585 last_mouse_scroll_bar = Qnil;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2586
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2587 *time = last_mouse_movement_time;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2588 }
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2589
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2590 #ifndef USE_TOOLKIT_SCROLL_BARS
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2591 /* Draw BAR's handle in the proper position.
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2592
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2593 If the handle is already drawn from START to END, don't bother
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2594 redrawing it, unless REBUILD is non-zero; in that case, always
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2595 redraw it. (REBUILD is handy for drawing the handle after expose
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2596 events.)
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2597
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2598 Normally, we want to constrain the start and end of the handle to
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2599 fit inside its rectangle, but if the user is dragging the scroll
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2600 bar handle, we want to let them drag it down all the way, so that
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2601 the bar's top is as far down as it goes; otherwise, there's no way
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2602 to move to the very end of the buffer. */
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2603
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2604 void
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2605 x_scroll_bar_set_handle (bar, start, end, rebuild)
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2606 struct scroll_bar *bar;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2607 int start, end;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2608 int rebuild;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2609 {
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2610 int dragging = ! NILP (bar->dragging);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2611 ControlRef ch = SCROLL_BAR_CONTROL_REF (bar);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2612 FRAME_PTR f = XFRAME (WINDOW_FRAME (XWINDOW (bar->window)));
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2613 int top_range = VERTICAL_SCROLL_BAR_TOP_RANGE (f, XINT (bar->height));
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2614 int length = end - start;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2615
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2616 /* If the display is already accurate, do nothing. */
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2617 if (! rebuild
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2618 && start == XINT (bar->start)
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2619 && end == XINT (bar->end))
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2620 return;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2621
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2622 BLOCK_INPUT;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2623
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2624 /* Make sure the values are reasonable, and try to preserve the
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2625 distance between start and end. */
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2626 if (start < 0)
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2627 start = 0;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2628 else if (start > top_range)
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2629 start = top_range;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2630 end = start + length;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2631
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2632 if (end < start)
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2633 end = start;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2634 else if (end > top_range && ! dragging)
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2635 end = top_range;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2636
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2637 /* Store the adjusted setting in the scroll bar. */
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2638 XSETINT (bar->start, start);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2639 XSETINT (bar->end, end);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2640
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2641 /* Clip the end position, just for display. */
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2642 if (end > top_range)
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2643 end = top_range;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2644
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2645 /* Draw bottom positions VERTICAL_SCROLL_BAR_MIN_HANDLE pixels below
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2646 top positions, to make sure the handle is always at least that
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2647 many pixels tall. */
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2648 end += VERTICAL_SCROLL_BAR_MIN_HANDLE;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2649
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2650 SetControlMinimum (ch, 0);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2651 /* Don't inadvertently activate deactivated scroll bars */
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2652 if (GetControlMaximum (ch) != -1)
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2653 SetControlMaximum (ch, top_range + VERTICAL_SCROLL_BAR_MIN_HANDLE
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2654 - (end - start));
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2655 SetControlValue (ch, start);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2656 #if TARGET_API_MAC_CARBON
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2657 SetControlViewSize (ch, end - start);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2658 #endif
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2659
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2660 UNBLOCK_INPUT;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2661 }
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2662
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2663 /* Handle some mouse motion while someone is dragging the scroll bar.
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2664
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2665 This may be called from a signal handler, so we have to ignore GC
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2666 mark bits. */
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2667
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2668 static void
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2669 x_scroll_bar_note_movement (bar, y_pos, t)
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2670 struct scroll_bar *bar;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2671 int y_pos;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2672 Time t;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2673 {
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2674 FRAME_PTR f = XFRAME (XWINDOW (bar->window)->frame);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2675
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2676 last_mouse_movement_time = t;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2677
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2678 f->mouse_moved = 1;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2679 XSETVECTOR (last_mouse_scroll_bar, bar);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2680
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2681 /* If we're dragging the bar, display it. */
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2682 if (! GC_NILP (bar->dragging))
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2683 {
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2684 /* Where should the handle be now? */
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2685 int new_start = y_pos - 24;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2686
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2687 if (new_start != XINT (bar->start))
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2688 {
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2689 int new_end = new_start + (XINT (bar->end) - XINT (bar->start));
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2690
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2691 x_scroll_bar_set_handle (bar, new_start, new_end, 0);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2692 }
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2693 }
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2694 }
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2695 #endif /* !USE_TOOLKIT_SCROLL_BARS */
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2696
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2697
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2698 /***********************************************************************
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2699 Tool-bars
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2700 ***********************************************************************/
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2701
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2702 #if USE_MAC_TOOLBAR
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2703 /* In identifiers such as function/variable names, Emacs tool bar is
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2704 referred to as `tool_bar', and Carbon HIToolbar as `toolbar'. */
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2705
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2706 #define TOOLBAR_IDENTIFIER (CFSTR ("org.gnu.Emacs.toolbar"))
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2707 #define TOOLBAR_ICON_ITEM_IDENTIFIER (CFSTR ("org.gnu.Emacs.toolbar.icon"))
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2708
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2709 #define TOOLBAR_ITEM_COMMAND_ID_OFFSET 'Tb\0\0'
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2710 #define TOOLBAR_ITEM_COMMAND_ID_P(id) \
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2711 (((id) & ~0xffff) == TOOLBAR_ITEM_COMMAND_ID_OFFSET)
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2712 #define TOOLBAR_ITEM_COMMAND_ID_VALUE(id) \
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2713 ((id) - TOOLBAR_ITEM_COMMAND_ID_OFFSET)
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2714 #define TOOLBAR_ITEM_MAKE_COMMAND_ID(value) \
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2715 ((value) + TOOLBAR_ITEM_COMMAND_ID_OFFSET)
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2716
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2717 static OSStatus mac_handle_toolbar_command_event P_ ((EventHandlerCallRef,
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2718 EventRef, void *));
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2719
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2720 extern Rect last_mouse_glyph;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2721
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2722 extern void mac_move_window_with_gravity P_ ((struct frame *, int,
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2723 short, short));
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2724 extern void mac_get_window_origin_with_gravity P_ ((struct frame *, int,
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2725 short *, short *));
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2726 extern CGImageRef mac_image_spec_to_cg_image P_ ((struct frame *,
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2727 Lisp_Object));
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2728
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2729 static OSStatus
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2730 mac_handle_toolbar_event (next_handler, event, data)
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2731 EventHandlerCallRef next_handler;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2732 EventRef event;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2733 void *data;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2734 {
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2735 OSStatus result = eventNotHandledErr;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2736
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2737 switch (GetEventKind (event))
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2738 {
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2739 case kEventToolbarGetDefaultIdentifiers:
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2740 result = noErr;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2741 break;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2742
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2743 case kEventToolbarGetAllowedIdentifiers:
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2744 {
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2745 CFMutableArrayRef array;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2746
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2747 GetEventParameter (event, kEventParamMutableArray,
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2748 typeCFMutableArrayRef, NULL,
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2749 sizeof (CFMutableArrayRef), NULL, &array);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2750 CFArrayAppendValue (array, TOOLBAR_ICON_ITEM_IDENTIFIER);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2751 result = noErr;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2752 }
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2753 break;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2754
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2755 case kEventToolbarCreateItemWithIdentifier:
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2756 {
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2757 CFStringRef identifier;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2758 HIToolbarItemRef item = NULL;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2759
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2760 GetEventParameter (event, kEventParamToolbarItemIdentifier,
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2761 typeCFStringRef, NULL,
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2762 sizeof (CFStringRef), NULL, &identifier);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2763
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2764 if (CFStringCompare (identifier, TOOLBAR_ICON_ITEM_IDENTIFIER, 0)
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2765 == kCFCompareEqualTo)
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2766 HIToolbarItemCreate (identifier,
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2767 kHIToolbarItemAllowDuplicates
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2768 | kHIToolbarItemCantBeRemoved, &item);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2769
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2770 if (item)
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2771 {
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2772 SetEventParameter (event, kEventParamToolbarItem,
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2773 typeHIToolbarItemRef,
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2774 sizeof (HIToolbarItemRef), &item);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2775 result = noErr;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2776 }
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2777 }
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2778 break;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2779
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2780 default:
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2781 abort ();
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2782 }
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2783
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2784 return result;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2785 }
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2786
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2787 /* Create a tool bar for frame F. */
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2788
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2789 static OSStatus
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2790 mac_create_frame_tool_bar (f)
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2791 FRAME_PTR f;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2792 {
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2793 OSStatus err;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2794 HIToolbarRef toolbar;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2795
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2796 err = HIToolbarCreate (TOOLBAR_IDENTIFIER, kHIToolbarNoAttributes,
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2797 &toolbar);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2798 if (err == noErr)
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2799 {
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2800 static const EventTypeSpec specs[] =
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2801 {{kEventClassToolbar, kEventToolbarGetDefaultIdentifiers},
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2802 {kEventClassToolbar, kEventToolbarGetAllowedIdentifiers},
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2803 {kEventClassToolbar, kEventToolbarCreateItemWithIdentifier}};
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2804
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2805 err = InstallEventHandler (HIObjectGetEventTarget (toolbar),
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2806 mac_handle_toolbar_event,
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2807 GetEventTypeCount (specs), specs,
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2808 f, NULL);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2809 }
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2810
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2811 if (err == noErr)
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2812 err = HIToolbarSetDisplayMode (toolbar, kHIToolbarDisplayModeIconOnly);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2813 if (err == noErr)
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2814 {
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2815 static const EventTypeSpec specs[] =
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2816 {{kEventClassCommand, kEventCommandProcess}};
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2817
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2818 err = InstallWindowEventHandler (FRAME_MAC_WINDOW (f),
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2819 mac_handle_toolbar_command_event,
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2820 GetEventTypeCount (specs),
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2821 specs, f, NULL);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2822 }
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2823 if (err == noErr)
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2824 err = SetWindowToolbar (FRAME_MAC_WINDOW (f), toolbar);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2825
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2826 if (toolbar)
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2827 CFRelease (toolbar);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2828
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2829 return err;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2830 }
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2831
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2832 /* Update the tool bar for frame F. Add new buttons and remove old. */
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2833
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2834 void
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2835 update_frame_tool_bar (f)
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2836 FRAME_PTR f;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2837 {
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2838 HIToolbarRef toolbar = NULL;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2839 short left, top;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2840 CFArrayRef old_items = NULL;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2841 CFIndex old_count;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2842 int i, pos, win_gravity = f->output_data.mac->toolbar_win_gravity;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2843 struct mac_display_info *dpyinfo = FRAME_MAC_DISPLAY_INFO (f);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2844
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2845 BLOCK_INPUT;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2846
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2847 GetWindowToolbar (FRAME_MAC_WINDOW (f), &toolbar);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2848 if (toolbar == NULL)
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2849 {
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2850 mac_create_frame_tool_bar (f);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2851 GetWindowToolbar (FRAME_MAC_WINDOW (f), &toolbar);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2852 if (toolbar == NULL)
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2853 goto out;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2854 if (win_gravity >= NorthWestGravity && win_gravity <= SouthEastGravity)
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2855 mac_get_window_origin_with_gravity (f, win_gravity, &left, &top);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2856 }
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2857
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2858 HIToolbarCopyItems (toolbar, &old_items);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2859 if (old_items == NULL)
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2860 goto out;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2861
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2862 old_count = CFArrayGetCount (old_items);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2863 pos = 0;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2864 for (i = 0; i < f->n_tool_bar_items; ++i)
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2865 {
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2866 #define PROP(IDX) AREF (f->tool_bar_items, i * TOOL_BAR_ITEM_NSLOTS + (IDX))
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2867
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2868 int enabled_p = !NILP (PROP (TOOL_BAR_ITEM_ENABLED_P));
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2869 int selected_p = !NILP (PROP (TOOL_BAR_ITEM_SELECTED_P));
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2870 int idx;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2871 Lisp_Object image;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2872 CGImageRef cg_image;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2873 CFStringRef label;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2874 HIToolbarItemRef item;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2875
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2876 /* If image is a vector, choose the image according to the
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2877 button state. */
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2878 image = PROP (TOOL_BAR_ITEM_IMAGES);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2879 if (VECTORP (image))
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2880 {
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2881 if (enabled_p)
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2882 idx = (selected_p
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2883 ? TOOL_BAR_IMAGE_ENABLED_SELECTED
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2884 : TOOL_BAR_IMAGE_ENABLED_DESELECTED);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2885 else
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2886 idx = (selected_p
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2887 ? TOOL_BAR_IMAGE_DISABLED_SELECTED
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2888 : TOOL_BAR_IMAGE_DISABLED_DESELECTED);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2889
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2890 xassert (ASIZE (image) >= idx);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2891 image = AREF (image, idx);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2892 }
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2893 else
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2894 idx = -1;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2895
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2896 cg_image = mac_image_spec_to_cg_image (f, image);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2897 /* Ignore invalid image specifications. */
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2898 if (cg_image == NULL)
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2899 continue;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2900
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2901 label = cfstring_create_with_string (PROP (TOOL_BAR_ITEM_CAPTION));
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2902 if (label == NULL)
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2903 label = CFSTR ("");
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2904
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2905 if (pos < old_count)
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2906 {
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2907 CGImageRef old_cg_image = NULL;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2908 CFStringRef old_label = NULL;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2909 Boolean old_enabled_p;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2910
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2911 item = (HIToolbarItemRef) CFArrayGetValueAtIndex (old_items, pos);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2912
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2913 HIToolbarItemCopyImage (item, &old_cg_image);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2914 if (cg_image != old_cg_image)
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2915 HIToolbarItemSetImage (item, cg_image);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2916 CGImageRelease (old_cg_image);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2917
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2918 HIToolbarItemCopyLabel (item, &old_label);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2919 if (CFStringCompare (label, old_label, 0) != kCFCompareEqualTo)
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2920 HIToolbarItemSetLabel (item, label);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2921 CFRelease (old_label);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2922
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2923 old_enabled_p = HIToolbarItemIsEnabled (item);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2924 if ((enabled_p || idx >= 0) != old_enabled_p)
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2925 HIToolbarItemSetEnabled (item, (enabled_p || idx >= 0));
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2926 }
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2927 else
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2928 {
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2929 item = NULL;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2930 HIToolbarCreateItemWithIdentifier (toolbar,
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2931 TOOLBAR_ICON_ITEM_IDENTIFIER,
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2932 NULL, &item);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2933 if (item)
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2934 {
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2935 HIToolbarItemSetImage (item, cg_image);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2936 HIToolbarItemSetLabel (item, label);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2937 HIToolbarItemSetEnabled (item, (enabled_p || idx >= 0));
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2938 HIToolbarAppendItem (toolbar, item);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2939 CFRelease (item);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2940 }
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2941 }
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2942
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2943 CFRelease (label);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2944 if (item)
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2945 {
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2946 HIToolbarItemSetCommandID (item, TOOLBAR_ITEM_MAKE_COMMAND_ID (i));
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2947 pos++;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2948 }
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2949 }
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2950
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2951 CFRelease (old_items);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2952
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2953 while (pos < old_count)
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2954 HIToolbarRemoveItemAtIndex (toolbar, --old_count);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2955
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2956 ShowHideWindowToolbar (FRAME_MAC_WINDOW (f), true,
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2957 !win_gravity && f == mac_focus_frame (dpyinfo));
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2958 /* Mac OS X 10.3 does not issue kEventWindowBoundsChanged events on
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2959 toolbar visibility change. */
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2960 mac_handle_origin_change (f);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2961 if (win_gravity >= NorthWestGravity && win_gravity <= SouthEastGravity)
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2962 {
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2963 mac_move_window_with_gravity (f, win_gravity, left, top);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2964 /* If the title bar is completely outside the screen, adjust the
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2965 position. */
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2966 ConstrainWindowToScreen (FRAME_MAC_WINDOW (f), kWindowTitleBarRgn,
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2967 kWindowConstrainMoveRegardlessOfFit
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2968 | kWindowConstrainAllowPartial, NULL, NULL);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2969 f->output_data.mac->toolbar_win_gravity = 0;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2970 }
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2971
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2972 out:
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2973 UNBLOCK_INPUT;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2974 }
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2975
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2976 /* Hide the tool bar on frame F. Unlike the counterpart on GTK+, it
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2977 doesn't deallocate the resources. */
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2978
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2979 void
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2980 free_frame_tool_bar (f)
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2981 FRAME_PTR f;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2982 {
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2983 if (IsWindowToolbarVisible (FRAME_MAC_WINDOW (f)))
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2984 {
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2985 struct mac_display_info *dpyinfo = FRAME_MAC_DISPLAY_INFO (f);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2986
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2987 BLOCK_INPUT;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2988 ShowHideWindowToolbar (FRAME_MAC_WINDOW (f), false,
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2989 (NILP (find_symbol_value
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2990 (intern ("frame-notice-user-settings")))
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2991 && f == mac_focus_frame (dpyinfo)));
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2992 /* Mac OS X 10.3 does not issue kEventWindowBoundsChanged events
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2993 on toolbar visibility change. */
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2994 mac_handle_origin_change (f);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2995 UNBLOCK_INPUT;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2996 }
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2997 }
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2998
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
2999 /* Report a mouse movement over toolbar to the mainstream Emacs
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3000 code. */
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3001
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3002 static void
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3003 mac_tool_bar_note_mouse_movement (f, event)
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3004 struct frame *f;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3005 EventRef event;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3006 {
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3007 OSStatus err;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3008 struct mac_display_info *dpyinfo = FRAME_MAC_DISPLAY_INFO (f);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3009 int mouse_down_p;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3010 WindowRef window;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3011 WindowPartCode part_code;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3012 HIViewRef item_view;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3013 UInt32 command_id;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3014
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3015 mouse_down_p = (dpyinfo->grabbed
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3016 && f == last_mouse_frame
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3017 && FRAME_LIVE_P (f));
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3018 if (mouse_down_p)
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3019 return;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3020
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3021 err = GetEventParameter (event, kEventParamWindowRef, typeWindowRef, NULL,
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3022 sizeof (WindowRef), NULL, &window);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3023 if (err != noErr || window != FRAME_MAC_WINDOW (f))
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3024 return;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3025
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3026 err = GetEventParameter (event, kEventParamWindowPartCode,
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3027 typeWindowPartCode, NULL,
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3028 sizeof (WindowPartCode), NULL, &part_code);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3029 if (err != noErr || part_code != inStructure)
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3030 return;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3031
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3032 err = HIViewGetViewForMouseEvent (HIViewGetRoot (window), event, &item_view);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3033 /* This doesn't work on Mac OS X 10.2. On Mac OS X 10.3 and 10.4, a
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3034 toolbar item view seems to have the same command ID with that of
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3035 the toolbar item. */
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3036 if (err == noErr)
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3037 err = GetControlCommandID (item_view, &command_id);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3038 if (err == noErr && TOOLBAR_ITEM_COMMAND_ID_P (command_id))
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3039 {
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3040 int i = TOOLBAR_ITEM_COMMAND_ID_VALUE (command_id);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3041
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3042 if (i < f->n_tool_bar_items)
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3043 {
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3044 HIRect bounds;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3045 HIViewRef content_view;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3046
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3047 err = HIViewGetBounds (item_view, &bounds);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3048 if (err == noErr)
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3049 err = HIViewFindByID (HIViewGetRoot (window),
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3050 kHIViewWindowContentID, &content_view);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3051 if (err == noErr)
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3052 err = HIViewConvertRect (&bounds, item_view, content_view);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3053 if (err == noErr)
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3054 SetRect (&last_mouse_glyph,
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3055 CGRectGetMinX (bounds), CGRectGetMinY (bounds),
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3056 CGRectGetMaxX (bounds), CGRectGetMaxY (bounds));
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3057
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3058 help_echo_object = help_echo_window = Qnil;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3059 help_echo_pos = -1;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3060 help_echo_string = PROP (TOOL_BAR_ITEM_HELP);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3061 if (NILP (help_echo_string))
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3062 help_echo_string = PROP (TOOL_BAR_ITEM_CAPTION);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3063 }
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3064 }
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3065 }
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3066
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3067 static OSStatus
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3068 mac_handle_toolbar_command_event (next_handler, event, data)
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3069 EventHandlerCallRef next_handler;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3070 EventRef event;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3071 void *data;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3072 {
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3073 OSStatus err, result = eventNotHandledErr;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3074 struct frame *f = (struct frame *) data;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3075 HICommand command;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3076
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3077 err = GetEventParameter (event, kEventParamDirectObject,
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3078 typeHICommand, NULL,
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3079 sizeof (HICommand), NULL, &command);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3080 if (err != noErr)
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3081 return result;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3082
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3083 switch (GetEventKind (event))
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3084 {
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3085 case kEventCommandProcess:
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3086 if (!TOOLBAR_ITEM_COMMAND_ID_P (command.commandID))
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3087 result = CallNextEventHandler (next_handler, event);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3088 else
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3089 {
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3090 int i = TOOLBAR_ITEM_COMMAND_ID_VALUE (command.commandID);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3091
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3092 if (i < f->n_tool_bar_items
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3093 && !NILP (PROP (TOOL_BAR_ITEM_ENABLED_P)))
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3094 {
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3095 Lisp_Object frame;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3096 struct input_event buf;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3097
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3098 EVENT_INIT (buf);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3099
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3100 XSETFRAME (frame, f);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3101 buf.kind = TOOL_BAR_EVENT;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3102 buf.frame_or_window = frame;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3103 buf.arg = frame;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3104 kbd_buffer_store_event (&buf);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3105
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3106 buf.kind = TOOL_BAR_EVENT;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3107 buf.frame_or_window = frame;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3108 buf.arg = PROP (TOOL_BAR_ITEM_KEY);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3109 buf.modifiers = mac_event_to_emacs_modifiers (event);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3110 kbd_buffer_store_event (&buf);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3111
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3112 result = noErr;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3113 }
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3114 }
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3115 break;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3116
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3117 default:
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3118 abort ();
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3119 }
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3120 #undef PROP
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3121
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3122 return result;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3123 }
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3124 #endif /* USE_MAC_TOOLBAR */
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3125
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3126
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3127 /***********************************************************************
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3128 Font Panel
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3129 ***********************************************************************/
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3130
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3131 #if USE_MAC_FONT_PANEL
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3132 /* Whether Font Panel has been shown before. The first call to font
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3133 panel functions (FPIsFontPanelVisible, SetFontInfoForSelection) is
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3134 slow. This variable is used for deferring such a call as much as
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3135 possible. */
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3136 static int font_panel_shown_p = 0;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3137
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3138 extern Lisp_Object Qpanel_closed, Qselection;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3139 extern Lisp_Object Qfont;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3140
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3141 /* Whether the font panel is currently visible. */
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3142
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3143 int
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3144 mac_font_panel_visible_p ()
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3145 {
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3146 return font_panel_shown_p && FPIsFontPanelVisible ();
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3147 }
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3148
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3149 static pascal OSStatus
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3150 mac_handle_font_event (next_handler, event, data)
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3151 EventHandlerCallRef next_handler;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3152 EventRef event;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3153 void *data;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3154 {
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3155 OSStatus result, err;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3156 Lisp_Object id_key;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3157 int num_params;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3158 const EventParamName *names;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3159 const EventParamType *types;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3160 static const EventParamName names_sel[] = {kEventParamATSUFontID,
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3161 kEventParamATSUFontSize,
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3162 kEventParamFMFontFamily,
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3163 kEventParamFMFontStyle,
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3164 kEventParamFMFontSize,
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3165 kEventParamFontColor};
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3166 static const EventParamType types_sel[] = {typeATSUFontID,
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3167 typeATSUSize,
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3168 typeFMFontFamily,
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3169 typeFMFontStyle,
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3170 typeFMFontSize,
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3171 typeFontColor};
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3172
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3173 result = CallNextEventHandler (next_handler, event);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3174 if (result != eventNotHandledErr)
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3175 return result;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3176
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3177 switch (GetEventKind (event))
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3178 {
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3179 case kEventFontPanelClosed:
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3180 id_key = Qpanel_closed;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3181 num_params = 0;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3182 names = NULL;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3183 types = NULL;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3184 break;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3185
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3186 case kEventFontSelection:
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3187 id_key = Qselection;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3188 num_params = sizeof (names_sel) / sizeof (names_sel[0]);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3189 names = names_sel;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3190 types = types_sel;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3191 break;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3192 }
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3193
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3194 err = mac_store_event_ref_as_apple_event (0, 0, Qfont, id_key,
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3195 event, num_params,
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3196 names, types);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3197 if (err == noErr)
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3198 result = noErr;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3199
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3200 return result;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3201 }
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3202
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3203 /* Toggle visiblity of the font panel. */
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3204
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3205 OSStatus
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3206 mac_show_hide_font_panel ()
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3207 {
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3208 if (!font_panel_shown_p)
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3209 {
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3210 OSStatus err;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3211
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3212 static const EventTypeSpec specs[] =
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3213 {{kEventClassFont, kEventFontPanelClosed},
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3214 {kEventClassFont, kEventFontSelection}};
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3215
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3216 err = InstallApplicationEventHandler (mac_handle_font_event,
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3217 GetEventTypeCount (specs),
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3218 specs, NULL, NULL);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3219 if (err != noErr)
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3220 return err;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3221
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3222 font_panel_shown_p = 1;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3223 }
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3224
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3225 return FPShowHideFontPanel ();
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3226 }
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3227
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3228 /* Set the font selected in the font panel to the one corresponding to
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3229 the face FACE_ID and the charcacter C in the frame F. */
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3230
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3231 OSStatus
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3232 mac_set_font_info_for_selection (f, face_id, c)
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3233 struct frame *f;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3234 int face_id, c;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3235 {
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3236 OSStatus err;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3237 EventTargetRef target = NULL;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3238 XFontStruct *font = NULL;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3239
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3240 if (!mac_font_panel_visible_p ())
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3241 return noErr;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3242
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3243 if (f)
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3244 {
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3245 target = GetWindowEventTarget (FRAME_MAC_WINDOW (f));
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3246
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3247 if (FRAME_FACE_CACHE (f) && CHAR_VALID_P (c, 0))
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3248 {
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3249 struct face *face;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3250
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3251 face_id = FACE_FOR_CHAR (f, FACE_FROM_ID (f, face_id), c);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3252 face = FACE_FROM_ID (f, face_id);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3253 font = face->font;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3254 }
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3255 }
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3256
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3257 if (font == NULL)
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3258 err = SetFontInfoForSelection (kFontSelectionATSUIType, 0, NULL, target);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3259 else
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3260 {
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3261 if (font->mac_fontnum != -1)
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3262 {
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3263 FontSelectionQDStyle qd_style;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3264
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3265 qd_style.version = kFontSelectionQDStyleVersionZero;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3266 qd_style.instance.fontFamily = font->mac_fontnum;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3267 qd_style.instance.fontStyle = font->mac_fontface;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3268 qd_style.size = font->mac_fontsize;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3269 qd_style.hasColor = false;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3270
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3271 err = SetFontInfoForSelection (kFontSelectionQDType,
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3272 1, &qd_style, target);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3273 }
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3274 else
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3275 err = SetFontInfoForSelection (kFontSelectionATSUIType,
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3276 1, &font->mac_style, target);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3277 }
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3278
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3279 return err;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3280 }
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3281 #endif /* USE_MAC_FONT_PANEL */
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3282
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3283
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3284 /************************************************************************
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3285 Event Handling
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3286 ************************************************************************/
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3287
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3288 /* Non-zero means that a HELP_EVENT has been generated since Emacs
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3289 start. */
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3290
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3291 static int any_help_event_p;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3292
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3293 /* Last window where we saw the mouse. Used by mouse-autoselect-window. */
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3294 static Lisp_Object last_window;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3295
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3296 static Point saved_menu_event_location;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3297
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3298 extern struct frame *pending_autoraise_frame;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3299
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3300 extern FRAME_PTR last_mouse_glyph_frame;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3301
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3302 #ifdef __STDC__
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3303 extern int volatile input_signal_count;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3304 #else
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3305 extern int input_signal_count;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3306 #endif
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3307
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3308 extern int mac_screen_config_changed;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3309
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3310 extern Lisp_Object Vmac_emulate_three_button_mouse;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3311 #if TARGET_API_MAC_CARBON
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3312 extern int mac_wheel_button_is_mouse_2;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3313 extern int mac_pass_command_to_system;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3314 extern int mac_pass_control_to_system;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3315 #endif /* TARGET_API_MAC_CARBON */
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3316 extern int mac_ready_for_apple_events;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3317
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3318 extern void mac_focus_changed P_ ((int, struct mac_display_info *,
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3319 struct frame *, struct input_event *));
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3320 extern int mac_get_emulated_btn P_ ((UInt32));
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3321 extern int note_mouse_movement P_ ((FRAME_PTR, Point *));
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3322 extern void mac_get_screen_info P_ ((struct mac_display_info *));
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3323
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3324 /* The focus may have changed. Figure out if it is a real focus change,
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3325 by checking both FocusIn/Out and Enter/LeaveNotify events.
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3326
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3327 Returns FOCUS_IN_EVENT event in *BUFP. */
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3328
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3329 static void
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3330 x_detect_focus_change (dpyinfo, event, bufp)
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3331 struct mac_display_info *dpyinfo;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3332 const EventRecord *event;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3333 struct input_event *bufp;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3334 {
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3335 struct frame *frame;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3336
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3337 frame = mac_window_to_frame ((WindowRef) event->message);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3338 if (! frame)
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3339 return;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3340
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3341 /* On Mac, this is only called from focus events, so no switch needed. */
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3342 mac_focus_changed ((event->modifiers & activeFlag),
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3343 dpyinfo, frame, bufp);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3344 }
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3345
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3346 #if TARGET_API_MAC_CARBON
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3347 /* Obtains the event modifiers from the event EVENTREF and then calls
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3348 mac_to_emacs_modifiers. */
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3349
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3350 static int
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3351 mac_event_to_emacs_modifiers (EventRef eventRef)
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3352 {
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3353 UInt32 mods = 0, class;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3354
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3355 GetEventParameter (eventRef, kEventParamKeyModifiers, typeUInt32, NULL,
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3356 sizeof (UInt32), NULL, &mods);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3357 class = GetEventClass (eventRef);
80517
086b32514483 (Vmac_ts_script_language_on_focus)
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents: 80464
diff changeset
3358 if (!NILP (Vmac_emulate_three_button_mouse)
086b32514483 (Vmac_ts_script_language_on_focus)
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents: 80464
diff changeset
3359 && (class == kEventClassMouse || class == kEventClassCommand))
80446
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3360 {
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3361 mods &= ~(optionKey | cmdKey);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3362 }
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3363 return mac_to_emacs_modifiers (mods, 0);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3364 }
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3365
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3366 /* Given an event REF, return the code to use for the mouse button
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3367 code in the emacs input_event. */
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3368
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3369 static int
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3370 mac_get_mouse_btn (EventRef ref)
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3371 {
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3372 EventMouseButton result = kEventMouseButtonPrimary;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3373 GetEventParameter (ref, kEventParamMouseButton, typeMouseButton, NULL,
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3374 sizeof (EventMouseButton), NULL, &result);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3375 switch (result)
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3376 {
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3377 case kEventMouseButtonPrimary:
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3378 if (NILP (Vmac_emulate_three_button_mouse))
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3379 return 0;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3380 else {
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3381 UInt32 mods = 0;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3382 GetEventParameter (ref, kEventParamKeyModifiers, typeUInt32, NULL,
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3383 sizeof (UInt32), NULL, &mods);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3384 return mac_get_emulated_btn(mods);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3385 }
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3386 case kEventMouseButtonSecondary:
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3387 return mac_wheel_button_is_mouse_2 ? 2 : 1;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3388 case kEventMouseButtonTertiary:
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3389 case 4: /* 4 is the number for the mouse wheel button */
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3390 return mac_wheel_button_is_mouse_2 ? 1 : 2;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3391 default:
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3392 return 0;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3393 }
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3394 }
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3395
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3396 /* Normally, ConvertEventRefToEventRecord will correctly handle all
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3397 events. However the click of the mouse wheel is not converted to a
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3398 mouseDown or mouseUp event. Likewise for dead key events. This
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3399 calls ConvertEventRefToEventRecord, but then checks to see if it is
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3400 a mouse up/down, or a dead key Carbon event that has not been
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3401 converted, and if so, converts it by hand (to be picked up in the
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3402 XTread_socket loop). */
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3403 static Boolean mac_convert_event_ref (EventRef eventRef, EventRecord *eventRec)
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3404 {
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3405 OSStatus err;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3406 Boolean result = ConvertEventRefToEventRecord (eventRef, eventRec);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3407 EventKind action;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3408
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3409 if (result)
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3410 return result;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3411
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3412 switch (GetEventClass (eventRef))
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3413 {
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3414 case kEventClassMouse:
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3415 switch (GetEventKind (eventRef))
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3416 {
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3417 case kEventMouseDown:
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3418 eventRec->what = mouseDown;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3419 result = 1;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3420 break;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3421
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3422 case kEventMouseUp:
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3423 eventRec->what = mouseUp;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3424 result = 1;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3425 break;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3426
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3427 default:
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3428 break;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3429 }
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3430 break;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3431
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3432 case kEventClassKeyboard:
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3433 switch (GetEventKind (eventRef))
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3434 {
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3435 case kEventRawKeyDown:
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3436 action = keyDown;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3437 goto keystroke_common;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3438 case kEventRawKeyRepeat:
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3439 action = autoKey;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3440 goto keystroke_common;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3441 case kEventRawKeyUp:
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3442 action = keyUp;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3443 keystroke_common:
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3444 {
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3445 unsigned char char_codes;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3446 UInt32 key_code;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3447
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3448 err = GetEventParameter (eventRef, kEventParamKeyMacCharCodes,
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3449 typeChar, NULL, sizeof (char),
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3450 NULL, &char_codes);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3451 if (err == noErr)
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3452 err = GetEventParameter (eventRef, kEventParamKeyCode,
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3453 typeUInt32, NULL, sizeof (UInt32),
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3454 NULL, &key_code);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3455 if (err == noErr)
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3456 {
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3457 eventRec->what = action;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3458 eventRec->message = char_codes | ((key_code & 0xff) << 8);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3459 result = 1;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3460 }
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3461 }
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3462 break;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3463
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3464 default:
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3465 break;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3466 }
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3467 break;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3468
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3469 default:
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3470 break;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3471 }
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3472
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3473 if (result)
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3474 {
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3475 /* Need where and when. */
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3476 UInt32 mods = 0;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3477
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3478 GetEventParameter (eventRef, kEventParamMouseLocation, typeQDPoint,
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3479 NULL, sizeof (Point), NULL, &eventRec->where);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3480 /* Use two step process because new event modifiers are 32-bit
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3481 and old are 16-bit. Currently, only loss is NumLock & Fn. */
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3482 GetEventParameter (eventRef, kEventParamKeyModifiers, typeUInt32,
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3483 NULL, sizeof (UInt32), NULL, &mods);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3484 eventRec->modifiers = mods;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3485
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3486 eventRec->when = EventTimeToTicks (GetEventTime (eventRef));
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3487 }
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3488
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3489 return result;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3490 }
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3491 #endif /* TARGET_API_MAC_CARBON */
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3492
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3493 #if !TARGET_API_MAC_CARBON
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3494 static RgnHandle mouse_region = NULL;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3495
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3496 Boolean
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3497 mac_wait_next_event (er, sleep_time, dequeue)
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3498 EventRecord *er;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3499 UInt32 sleep_time;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3500 Boolean dequeue;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3501 {
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3502 static EventRecord er_buf = {nullEvent};
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3503 UInt32 target_tick, current_tick;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3504 EventMask event_mask;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3505
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3506 if (mouse_region == NULL)
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3507 mouse_region = NewRgn ();
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3508
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3509 event_mask = everyEvent;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3510 if (!mac_ready_for_apple_events)
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3511 event_mask -= highLevelEventMask;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3512
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3513 current_tick = TickCount ();
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3514 target_tick = current_tick + sleep_time;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3515
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3516 if (er_buf.what == nullEvent)
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3517 while (!WaitNextEvent (event_mask, &er_buf,
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3518 target_tick - current_tick, mouse_region))
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3519 {
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3520 current_tick = TickCount ();
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3521 if (target_tick <= current_tick)
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3522 return false;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3523 }
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3524
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3525 *er = er_buf;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3526 if (dequeue)
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3527 er_buf.what = nullEvent;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3528 return true;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3529 }
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3530 #endif /* not TARGET_API_MAC_CARBON */
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3531
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3532 #if TARGET_API_MAC_CARBON
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3533 OSStatus
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3534 mac_post_mouse_moved_event ()
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3535 {
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3536 EventRef event = NULL;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3537 OSStatus err;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3538
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3539 err = CreateEvent (NULL, kEventClassMouse, kEventMouseMoved, 0,
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3540 kEventAttributeNone, &event);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3541 if (err == noErr)
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3542 {
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3543 Point mouse_pos;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3544
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3545 GetGlobalMouse (&mouse_pos);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3546 err = SetEventParameter (event, kEventParamMouseLocation, typeQDPoint,
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3547 sizeof (Point), &mouse_pos);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3548 }
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3549 if (err == noErr)
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3550 {
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3551 UInt32 modifiers = GetCurrentKeyModifiers ();
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3552
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3553 err = SetEventParameter (event, kEventParamKeyModifiers, typeUInt32,
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3554 sizeof (UInt32), &modifiers);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3555 }
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3556 if (err == noErr)
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3557 err = PostEventToQueue (GetCurrentEventQueue (), event,
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3558 kEventPriorityStandard);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3559 if (event)
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3560 ReleaseEvent (event);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3561
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3562 return err;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3563 }
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3564 #endif
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3565
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3566 #ifdef MAC_OSX
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3567 /* Run the current run loop in the default mode until some input
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3568 happens or TIMEOUT seconds passes unless it is negative. Return
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3569 true if timeout occurs first. */
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3570
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3571 Boolean
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3572 mac_run_loop_run_once (timeout)
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3573 EventTimeout timeout;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3574 {
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3575 #if USE_CG_DRAWING
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3576 mac_prepare_for_quickdraw (NULL);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3577 #endif
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3578 return (CFRunLoopRunInMode (kCFRunLoopDefaultMode,
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3579 timeout >= 0 ? timeout : 100000, true)
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3580 == kCFRunLoopRunTimedOut);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3581 }
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3582 #endif
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3583
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3584 /* Emacs calls this whenever it wants to read an input event from the
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3585 user. */
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3586
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3587 int
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3588 XTread_socket (sd, expected, hold_quit)
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3589 int sd, expected;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3590 struct input_event *hold_quit;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3591 {
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3592 struct input_event inev;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3593 int count = 0;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3594 #if TARGET_API_MAC_CARBON
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3595 EventRef eventRef;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3596 EventTargetRef toolbox_dispatcher;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3597 #endif
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3598 EventRecord er;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3599 struct mac_display_info *dpyinfo = &one_mac_display_info;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3600
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3601 if (interrupt_input_blocked)
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3602 {
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3603 interrupt_input_pending = 1;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3604 return -1;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3605 }
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3606
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3607 interrupt_input_pending = 0;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3608 BLOCK_INPUT;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3609
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3610 /* So people can tell when we have read the available input. */
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3611 input_signal_count++;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3612
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3613 ++handling_signal;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3614
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3615 #if TARGET_API_MAC_CARBON
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3616 toolbox_dispatcher = GetEventDispatcherTarget ();
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3617
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3618 while (
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3619 #if USE_CG_DRAWING
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3620 mac_prepare_for_quickdraw (NULL),
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3621 #endif
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3622 !ReceiveNextEvent (0, NULL, kEventDurationNoWait,
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3623 kEventRemoveFromQueue, &eventRef))
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3624 #else /* !TARGET_API_MAC_CARBON */
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3625 while (mac_wait_next_event (&er, 0, true))
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3626 #endif /* !TARGET_API_MAC_CARBON */
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3627 {
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3628 int do_help = 0;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3629 struct frame *f;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3630 unsigned long timestamp;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3631
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3632 EVENT_INIT (inev);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3633 inev.kind = NO_EVENT;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3634 inev.arg = Qnil;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3635
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3636 #if TARGET_API_MAC_CARBON
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3637 timestamp = GetEventTime (eventRef) / kEventDurationMillisecond;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3638
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3639 if (!mac_convert_event_ref (eventRef, &er))
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3640 goto OTHER;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3641 #else /* !TARGET_API_MAC_CARBON */
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3642 timestamp = er.when * (1000 / 60); /* ticks to milliseconds */
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3643 #endif /* !TARGET_API_MAC_CARBON */
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3644
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3645 switch (er.what)
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3646 {
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3647 case mouseDown:
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3648 case mouseUp:
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3649 {
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3650 WindowRef window_ptr;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3651 ControlPartCode part_code;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3652 int tool_bar_p = 0;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3653
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3654 #if TARGET_API_MAC_CARBON
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3655 OSStatus err;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3656
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3657 /* This is needed to send mouse events like aqua window
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3658 buttons to the correct handler. */
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3659 read_socket_inev = &inev;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3660 err = SendEventToEventTarget (eventRef, toolbox_dispatcher);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3661 read_socket_inev = NULL;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3662 if (err != eventNotHandledErr)
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3663 break;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3664 #endif
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3665 last_mouse_glyph_frame = 0;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3666
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3667 if (dpyinfo->grabbed && last_mouse_frame
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3668 && FRAME_LIVE_P (last_mouse_frame))
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3669 {
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3670 window_ptr = FRAME_MAC_WINDOW (last_mouse_frame);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3671 part_code = inContent;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3672 }
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3673 else
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3674 {
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3675 part_code = FindWindow (er.where, &window_ptr);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3676 if (tip_window && window_ptr == tip_window)
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3677 {
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3678 HideWindow (tip_window);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3679 part_code = FindWindow (er.where, &window_ptr);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3680 }
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3681 }
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3682
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3683 if (er.what != mouseDown
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3684 && (part_code != inContent || dpyinfo->grabbed == 0))
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3685 break;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3686
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3687 switch (part_code)
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3688 {
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3689 case inMenuBar:
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3690 f = mac_focus_frame (dpyinfo);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3691 saved_menu_event_location = er.where;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3692 inev.kind = MENU_BAR_ACTIVATE_EVENT;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3693 XSETFRAME (inev.frame_or_window, f);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3694 break;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3695
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3696 case inContent:
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3697 if (
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3698 #if TARGET_API_MAC_CARBON
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3699 FrontNonFloatingWindow ()
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3700 #else
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3701 FrontWindow ()
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3702 #endif
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3703 != window_ptr
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3704 || (mac_window_to_frame (window_ptr)
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3705 != dpyinfo->x_focus_frame))
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3706 SelectWindow (window_ptr);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3707 else
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3708 {
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3709 ControlPartCode control_part_code;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3710 ControlRef ch;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3711 Point mouse_loc;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3712 #ifdef MAC_OSX
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3713 ControlKind control_kind;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3714 #endif
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3715
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3716 f = mac_window_to_frame (window_ptr);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3717 /* convert to local coordinates of new window */
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3718 mouse_loc.h = (er.where.h
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3719 - (f->left_pos
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3720 + FRAME_OUTER_TO_INNER_DIFF_X (f)));
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3721 mouse_loc.v = (er.where.v
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3722 - (f->top_pos
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3723 + FRAME_OUTER_TO_INNER_DIFF_Y (f)));
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3724 #if TARGET_API_MAC_CARBON
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3725 ch = FindControlUnderMouse (mouse_loc, window_ptr,
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3726 &control_part_code);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3727 #ifdef MAC_OSX
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3728 if (ch)
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3729 GetControlKind (ch, &control_kind);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3730 #endif
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3731 #else
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3732 control_part_code = FindControl (mouse_loc, window_ptr,
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3733 &ch);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3734 #endif
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3735
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3736 #if TARGET_API_MAC_CARBON
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3737 inev.code = mac_get_mouse_btn (eventRef);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3738 inev.modifiers = mac_event_to_emacs_modifiers (eventRef);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3739 #else
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3740 inev.code = mac_get_emulated_btn (er.modifiers);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3741 inev.modifiers = mac_to_emacs_modifiers (er.modifiers, 0);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3742 #endif
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3743 XSETINT (inev.x, mouse_loc.h);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3744 XSETINT (inev.y, mouse_loc.v);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3745
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3746 if ((dpyinfo->grabbed && tracked_scroll_bar)
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3747 || (ch != 0
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3748 #ifndef USE_TOOLKIT_SCROLL_BARS
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3749 /* control_part_code becomes kControlNoPart if
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3750 a progress indicator is clicked. */
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3751 && control_part_code != kControlNoPart
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3752 #else /* USE_TOOLKIT_SCROLL_BARS */
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3753 #ifdef MAC_OSX
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3754 && control_kind.kind == kControlKindScrollBar
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3755 #endif /* MAC_OSX */
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3756 #endif /* USE_TOOLKIT_SCROLL_BARS */
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3757 ))
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3758 {
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3759 struct scroll_bar *bar;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3760
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3761 if (dpyinfo->grabbed && tracked_scroll_bar)
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3762 {
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3763 bar = tracked_scroll_bar;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3764 #ifndef USE_TOOLKIT_SCROLL_BARS
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3765 control_part_code = kControlIndicatorPart;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3766 #endif
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3767 }
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3768 else
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3769 bar = (struct scroll_bar *) GetControlReference (ch);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3770 #ifdef USE_TOOLKIT_SCROLL_BARS
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3771 /* Make the "Ctrl-Mouse-2 splits window" work
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3772 for toolkit scroll bars. */
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3773 if (inev.modifiers & ctrl_modifier)
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3774 x_scroll_bar_handle_click (bar, control_part_code,
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3775 &er, &inev);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3776 else if (er.what == mouseDown)
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3777 x_scroll_bar_handle_press (bar, control_part_code,
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3778 mouse_loc, &inev);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3779 else
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3780 x_scroll_bar_handle_release (bar, &inev);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3781 #else /* not USE_TOOLKIT_SCROLL_BARS */
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3782 x_scroll_bar_handle_click (bar, control_part_code,
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3783 &er, &inev);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3784 if (er.what == mouseDown
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3785 && control_part_code == kControlIndicatorPart)
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3786 tracked_scroll_bar = bar;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3787 else
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3788 tracked_scroll_bar = NULL;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3789 #endif /* not USE_TOOLKIT_SCROLL_BARS */
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3790 }
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3791 else
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3792 {
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3793 Lisp_Object window;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3794 int x = mouse_loc.h;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3795 int y = mouse_loc.v;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3796
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3797 window = window_from_coordinates (f, x, y, 0, 0, 0, 1);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3798 if (EQ (window, f->tool_bar_window))
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3799 {
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3800 if (er.what == mouseDown)
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3801 handle_tool_bar_click (f, x, y, 1, 0);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3802 else
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3803 handle_tool_bar_click (f, x, y, 0,
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3804 inev.modifiers);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3805 tool_bar_p = 1;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3806 }
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3807 else
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3808 {
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3809 XSETFRAME (inev.frame_or_window, f);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3810 inev.kind = MOUSE_CLICK_EVENT;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3811 }
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3812 }
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3813
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3814 if (er.what == mouseDown)
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3815 {
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3816 dpyinfo->grabbed |= (1 << inev.code);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3817 last_mouse_frame = f;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3818
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3819 if (!tool_bar_p)
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3820 last_tool_bar_item = -1;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3821 }
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3822 else
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3823 {
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3824 if ((dpyinfo->grabbed & (1 << inev.code)) == 0)
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3825 /* If a button is released though it was not
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3826 previously pressed, that would be because
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3827 of multi-button emulation. */
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3828 dpyinfo->grabbed = 0;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3829 else
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3830 dpyinfo->grabbed &= ~(1 << inev.code);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3831 }
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3832
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3833 /* Ignore any mouse motion that happened before
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3834 this event; any subsequent mouse-movement Emacs
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3835 events should reflect only motion after the
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3836 ButtonPress. */
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3837 if (f != 0)
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3838 f->mouse_moved = 0;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3839
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3840 #ifdef USE_TOOLKIT_SCROLL_BARS
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3841 if (inev.kind == MOUSE_CLICK_EVENT
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3842 || (inev.kind == SCROLL_BAR_CLICK_EVENT
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3843 && (inev.modifiers & ctrl_modifier)))
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3844 #endif
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3845 switch (er.what)
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3846 {
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3847 case mouseDown:
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3848 inev.modifiers |= down_modifier;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3849 break;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3850 case mouseUp:
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3851 inev.modifiers |= up_modifier;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3852 break;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3853 }
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3854 }
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3855 break;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3856
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3857 case inDrag:
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3858 #if TARGET_API_MAC_CARBON
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3859 case inProxyIcon:
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3860 if (IsWindowPathSelectClick (window_ptr, &er))
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3861 {
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3862 WindowPathSelect (window_ptr, NULL, NULL);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3863 break;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3864 }
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3865 if (part_code == inProxyIcon
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3866 && (TrackWindowProxyDrag (window_ptr, er.where)
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3867 != errUserWantsToDragWindow))
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3868 break;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3869 DragWindow (window_ptr, er.where, NULL);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3870 #else /* not TARGET_API_MAC_CARBON */
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3871 DragWindow (window_ptr, er.where, &qd.screenBits.bounds);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3872 /* Update the frame parameters. */
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3873 {
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3874 struct frame *f = mac_window_to_frame (window_ptr);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3875
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3876 if (f && !f->async_iconified)
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3877 mac_handle_origin_change (f);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3878 }
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3879 #endif /* not TARGET_API_MAC_CARBON */
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3880 break;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3881
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3882 case inGoAway:
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3883 if (TrackGoAway (window_ptr, er.where))
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3884 {
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3885 inev.kind = DELETE_WINDOW_EVENT;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3886 XSETFRAME (inev.frame_or_window,
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3887 mac_window_to_frame (window_ptr));
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3888 }
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3889 break;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3890
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3891 /* window resize handling added --ben */
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3892 case inGrow:
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3893 do_grow_window (window_ptr, &er);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3894 break;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3895
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3896 /* window zoom handling added --ben */
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3897 case inZoomIn:
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3898 case inZoomOut:
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3899 if (TrackBox (window_ptr, er.where, part_code))
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3900 do_zoom_window (window_ptr, part_code);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3901 break;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3902
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3903 #if USE_MAC_TOOLBAR
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3904 case inStructure:
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3905 {
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3906 OSStatus err;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3907 HIViewRef ch;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3908
80517
086b32514483 (Vmac_ts_script_language_on_focus)
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents: 80464
diff changeset
3909 if (FrontNonFloatingWindow () != window_ptr)
086b32514483 (Vmac_ts_script_language_on_focus)
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents: 80464
diff changeset
3910 SelectWindow (window_ptr);
086b32514483 (Vmac_ts_script_language_on_focus)
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents: 80464
diff changeset
3911
80446
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3912 err = HIViewGetViewForMouseEvent (HIViewGetRoot (window_ptr),
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3913 eventRef, &ch);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3914 /* This doesn't work on Mac OS X 10.2. */
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3915 if (err == noErr)
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3916 HIViewClick (ch, eventRef);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3917 }
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3918 break;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3919 #endif /* USE_MAC_TOOLBAR */
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3920
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3921 default:
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3922 break;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3923 }
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3924 }
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3925 break;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3926
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3927 #if !TARGET_API_MAC_CARBON
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3928 case updateEvt:
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3929 do_window_update ((WindowRef) er.message);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3930 break;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3931 #endif
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3932
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3933 case osEvt:
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3934 #if TARGET_API_MAC_CARBON
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3935 if (SendEventToEventTarget (eventRef, toolbox_dispatcher)
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3936 != eventNotHandledErr)
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3937 break;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3938 #endif
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3939 switch ((er.message >> 24) & 0x000000FF)
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3940 {
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3941 #if USE_MAC_TSM
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3942 case suspendResumeMessage:
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3943 if (er.message & resumeFlag)
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3944 mac_tsm_resume ();
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3945 else
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3946 mac_tsm_suspend ();
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3947 break;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3948 #endif
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3949
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3950 case mouseMovedMessage:
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3951 #if !TARGET_API_MAC_CARBON
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3952 SetRectRgn (mouse_region, er.where.h, er.where.v,
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3953 er.where.h + 1, er.where.v + 1);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3954 #endif
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3955 previous_help_echo_string = help_echo_string;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3956 help_echo_string = Qnil;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3957
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3958 if (dpyinfo->grabbed && last_mouse_frame
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3959 && FRAME_LIVE_P (last_mouse_frame))
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3960 f = last_mouse_frame;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3961 else
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3962 f = dpyinfo->x_focus_frame;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3963
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3964 if (dpyinfo->mouse_face_hidden)
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3965 {
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3966 dpyinfo->mouse_face_hidden = 0;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3967 clear_mouse_face (dpyinfo);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3968 }
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3969
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3970 if (f)
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3971 {
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3972 WindowRef wp = FRAME_MAC_WINDOW (f);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3973 Point mouse_pos;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3974
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3975 mouse_pos.h = (er.where.h
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3976 - (f->left_pos
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3977 + FRAME_OUTER_TO_INNER_DIFF_X (f)));
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3978 mouse_pos.v = (er.where.v
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3979 - (f->top_pos
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3980 + FRAME_OUTER_TO_INNER_DIFF_Y (f)));
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3981 if (dpyinfo->grabbed && tracked_scroll_bar)
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3982 #ifdef USE_TOOLKIT_SCROLL_BARS
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3983 x_scroll_bar_handle_drag (wp, tracked_scroll_bar,
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3984 mouse_pos, &inev);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3985 #else /* not USE_TOOLKIT_SCROLL_BARS */
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3986 x_scroll_bar_note_movement (tracked_scroll_bar,
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3987 mouse_pos.v
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3988 - XINT (tracked_scroll_bar->top),
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3989 er.when * (1000 / 60));
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3990 #endif /* not USE_TOOLKIT_SCROLL_BARS */
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3991 else
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3992 {
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3993 /* Generate SELECT_WINDOW_EVENTs when needed. */
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3994 if (!NILP (Vmouse_autoselect_window))
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3995 {
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3996 Lisp_Object window;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3997
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3998 window = window_from_coordinates (f,
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
3999 mouse_pos.h,
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4000 mouse_pos.v,
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4001 0, 0, 0, 0);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4002
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4003 /* Window will be selected only when it is
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4004 not selected now and last mouse movement
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4005 event was not in it. Minibuffer window
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4006 will be selected only when it is active. */
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4007 if (WINDOWP (window)
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4008 && !EQ (window, last_window)
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4009 && !EQ (window, selected_window)
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4010 /* For click-to-focus window managers
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4011 create event iff we don't leave the
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4012 selected frame. */
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4013 && (focus_follows_mouse
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4014 || (EQ (XWINDOW (window)->frame,
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4015 XWINDOW (selected_window)->frame))))
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4016 {
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4017 inev.kind = SELECT_WINDOW_EVENT;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4018 inev.frame_or_window = window;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4019 }
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4020
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4021 last_window=window;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4022 }
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4023 if (!note_mouse_movement (f, &mouse_pos))
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4024 help_echo_string = previous_help_echo_string;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4025 #if USE_MAC_TOOLBAR
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4026 else
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4027 mac_tool_bar_note_mouse_movement (f, eventRef);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4028 #endif
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4029 }
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4030 }
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4031
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4032 /* If the contents of the global variable
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4033 help_echo_string has changed, generate a
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4034 HELP_EVENT. */
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4035 if (!NILP (help_echo_string) || !NILP (previous_help_echo_string))
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4036 do_help = 1;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4037 break;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4038 }
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4039 break;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4040
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4041 case activateEvt:
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4042 {
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4043 WindowRef window_ptr = (WindowRef) er.message;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4044 OSErr err;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4045 ControlRef root_control;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4046
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4047 if (window_ptr == tip_window)
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4048 {
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4049 HideWindow (tip_window);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4050 break;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4051 }
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4052
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4053 if (!is_emacs_window (window_ptr))
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4054 goto OTHER;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4055
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4056 f = mac_window_to_frame (window_ptr);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4057
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4058 if ((er.modifiers & activeFlag) != 0)
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4059 {
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4060 /* A window has been activated */
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4061 Point mouse_loc;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4062
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4063 err = GetRootControl (FRAME_MAC_WINDOW (f), &root_control);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4064 if (err == noErr)
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4065 ActivateControl (root_control);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4066
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4067 x_detect_focus_change (dpyinfo, &er, &inev);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4068
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4069 mouse_loc.h = (er.where.h
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4070 - (f->left_pos
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4071 + FRAME_OUTER_TO_INNER_DIFF_X (f)));
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4072 mouse_loc.v = (er.where.v
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4073 - (f->top_pos
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4074 + FRAME_OUTER_TO_INNER_DIFF_Y (f)));
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4075 /* Window-activated event counts as mouse movement,
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4076 so update things that depend on mouse position. */
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4077 note_mouse_movement (f, &mouse_loc);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4078 }
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4079 else
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4080 {
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4081 /* A window has been deactivated */
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4082 err = GetRootControl (FRAME_MAC_WINDOW (f), &root_control);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4083 if (err == noErr)
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4084 DeactivateControl (root_control);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4085
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4086 #ifdef USE_TOOLKIT_SCROLL_BARS
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4087 if (dpyinfo->grabbed && tracked_scroll_bar)
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4088 {
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4089 struct input_event event;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4090
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4091 EVENT_INIT (event);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4092 event.kind = NO_EVENT;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4093 x_scroll_bar_handle_release (tracked_scroll_bar, &event);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4094 if (event.kind != NO_EVENT)
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4095 {
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4096 event.timestamp = timestamp;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4097 kbd_buffer_store_event_hold (&event, hold_quit);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4098 count++;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4099 }
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4100 }
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4101 #endif
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4102 dpyinfo->grabbed = 0;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4103
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4104 x_detect_focus_change (dpyinfo, &er, &inev);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4105
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4106 if (f == dpyinfo->mouse_face_mouse_frame)
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4107 {
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4108 /* If we move outside the frame, then we're
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4109 certainly no longer on any text in the
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4110 frame. */
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4111 clear_mouse_face (dpyinfo);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4112 dpyinfo->mouse_face_mouse_frame = 0;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4113 }
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4114
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4115 /* Generate a nil HELP_EVENT to cancel a help-echo.
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4116 Do it only if there's something to cancel.
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4117 Otherwise, the startup message is cleared when the
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4118 mouse leaves the frame. */
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4119 if (any_help_event_p)
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4120 do_help = -1;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4121 }
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4122 }
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4123 break;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4124
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4125 case keyDown:
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4126 case keyUp:
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4127 case autoKey:
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4128 ObscureCursor ();
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4129
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4130 f = mac_focus_frame (dpyinfo);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4131 XSETFRAME (inev.frame_or_window, f);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4132
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4133 /* If mouse-highlight is an integer, input clears out mouse
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4134 highlighting. */
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4135 if (!dpyinfo->mouse_face_hidden && INTEGERP (Vmouse_highlight)
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4136 && !EQ (f->tool_bar_window, dpyinfo->mouse_face_window))
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4137 {
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4138 clear_mouse_face (dpyinfo);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4139 dpyinfo->mouse_face_hidden = 1;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4140 }
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4141
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4142 {
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4143 UInt32 modifiers = er.modifiers, mapped_modifiers;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4144 UInt32 key_code = (er.message & keyCodeMask) >> 8;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4145
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4146 #ifdef MAC_OSX
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4147 GetEventParameter (eventRef, kEventParamKeyModifiers,
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4148 typeUInt32, NULL,
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4149 sizeof (UInt32), NULL, &modifiers);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4150 #endif
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4151 mapped_modifiers = mac_mapped_modifiers (modifiers, key_code);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4152
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4153 #if TARGET_API_MAC_CARBON
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4154 if (!(mapped_modifiers
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4155 & ~(mac_pass_command_to_system ? cmdKey : 0)
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4156 & ~(mac_pass_control_to_system ? controlKey : 0)))
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4157 goto OTHER;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4158 else
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4159 #endif
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4160 if (er.what != keyUp)
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4161 do_keystroke (er.what, er.message & charCodeMask,
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4162 key_code, modifiers, timestamp, &inev);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4163 }
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4164 break;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4165
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4166 case kHighLevelEvent:
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4167 AEProcessAppleEvent (&er);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4168 break;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4169
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4170 default:
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4171 OTHER:
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4172 #if TARGET_API_MAC_CARBON
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4173 {
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4174 OSStatus err;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4175
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4176 read_socket_inev = &inev;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4177 err = SendEventToEventTarget (eventRef, toolbox_dispatcher);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4178 read_socket_inev = NULL;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4179 }
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4180 #endif
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4181 break;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4182 }
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4183 #if TARGET_API_MAC_CARBON
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4184 ReleaseEvent (eventRef);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4185 #endif
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4186
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4187 if (inev.kind != NO_EVENT)
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4188 {
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4189 inev.timestamp = timestamp;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4190 kbd_buffer_store_event_hold (&inev, hold_quit);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4191 count++;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4192 }
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4193
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4194 if (do_help
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4195 && !(hold_quit && hold_quit->kind != NO_EVENT))
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4196 {
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4197 Lisp_Object frame;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4198
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4199 if (f)
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4200 XSETFRAME (frame, f);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4201 else
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4202 frame = Qnil;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4203
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4204 if (do_help > 0)
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4205 {
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4206 any_help_event_p = 1;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4207 gen_help_event (help_echo_string, frame, help_echo_window,
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4208 help_echo_object, help_echo_pos);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4209 }
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4210 else
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4211 {
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4212 help_echo_string = Qnil;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4213 gen_help_event (Qnil, frame, Qnil, Qnil, 0);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4214 }
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4215 count++;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4216 }
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4217 }
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4218
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4219 /* If the focus was just given to an autoraising frame,
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4220 raise it now. */
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4221 /* ??? This ought to be able to handle more than one such frame. */
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4222 if (pending_autoraise_frame)
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4223 {
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4224 x_raise_frame (pending_autoraise_frame);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4225 pending_autoraise_frame = 0;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4226 }
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4227
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4228 if (mac_screen_config_changed)
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4229 {
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4230 mac_get_screen_info (dpyinfo);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4231 mac_screen_config_changed = 0;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4232 }
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4233
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4234 #if !TARGET_API_MAC_CARBON
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4235 /* Check which frames are still visible. We do this here because
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4236 there doesn't seem to be any direct notification from the Window
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4237 Manager that the visibility of a window has changed (at least,
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4238 not in all cases). */
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4239 {
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4240 Lisp_Object tail, frame;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4241
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4242 FOR_EACH_FRAME (tail, frame)
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4243 {
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4244 struct frame *f = XFRAME (frame);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4245
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4246 /* The tooltip has been drawn already. Avoid the
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4247 SET_FRAME_GARBAGED in mac_handle_visibility_change. */
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4248 if (EQ (frame, tip_frame))
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4249 continue;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4250
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4251 if (FRAME_MAC_P (f))
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4252 mac_handle_visibility_change (f);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4253 }
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4254 }
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4255 #endif
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4256
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4257 --handling_signal;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4258 UNBLOCK_INPUT;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4259 return count;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4260 }
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4261
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4262
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4263 /***********************************************************************
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4264 Busy cursor
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4265 ***********************************************************************/
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4266
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4267 #if TARGET_API_MAC_CARBON
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4268 /* Show the spinning progress indicator for the frame F. Create it if
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4269 it doesn't exist yet. */
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4270
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4271 void
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4272 mac_show_hourglass (f)
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4273 struct frame *f;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4274 {
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4275 #if USE_CG_DRAWING
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4276 mac_prepare_for_quickdraw (f);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4277 #endif
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4278 if (!f->output_data.mac->hourglass_control)
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4279 {
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4280 Window w = FRAME_MAC_WINDOW (f);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4281 Rect r;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4282 ControlRef c;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4283
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4284 GetWindowPortBounds (w, &r);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4285 r.left = r.right - HOURGLASS_WIDTH;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4286 r.bottom = r.top + HOURGLASS_HEIGHT;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4287 if (CreateChasingArrowsControl (w, &r, &c) == noErr)
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4288 f->output_data.mac->hourglass_control = c;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4289 }
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4290
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4291 if (f->output_data.mac->hourglass_control)
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4292 ShowControl (f->output_data.mac->hourglass_control);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4293 }
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4294
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4295 /* Hide the spinning progress indicator for the frame F. Do nothing
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4296 it doesn't exist yet. */
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4297
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4298 void
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4299 mac_hide_hourglass (f)
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4300 struct frame *f;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4301 {
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4302 if (f->output_data.mac->hourglass_control)
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4303 {
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4304 #if USE_CG_DRAWING
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4305 mac_prepare_for_quickdraw (f);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4306 #endif
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4307 HideControl (f->output_data.mac->hourglass_control);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4308 }
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4309 }
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4310
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4311 /* Reposition the spinning progress indicator for the frame F. Do
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4312 nothing it doesn't exist yet. */
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4313
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4314 void
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4315 mac_reposition_hourglass (f)
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4316 struct frame *f;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4317 {
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4318 if (f->output_data.mac->hourglass_control)
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4319 {
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4320 #if USE_CG_DRAWING
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4321 mac_prepare_for_quickdraw (f);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4322 #endif
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4323 MoveControl (f->output_data.mac->hourglass_control,
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4324 FRAME_PIXEL_WIDTH (f) - HOURGLASS_WIDTH, 0);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4325 }
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4326 }
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4327 #endif /* TARGET_API_MAC_CARBON */
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4328
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4329
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4330 /***********************************************************************
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4331 File selection dialog
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4332 ***********************************************************************/
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4333
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4334 #if TARGET_API_MAC_CARBON
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4335 extern Lisp_Object Qfile_name_history;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4336
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4337 static pascal void mac_nav_event_callback P_ ((NavEventCallbackMessage,
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4338 NavCBRecPtr, void *));
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4339
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4340 /* The actual implementation of Fx_file_dialog. */
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4341
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4342 Lisp_Object
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4343 mac_file_dialog (prompt, dir, default_filename, mustmatch, only_dir_p)
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4344 Lisp_Object prompt, dir, default_filename, mustmatch, only_dir_p;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4345 {
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4346 Lisp_Object file = Qnil;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4347 int count = SPECPDL_INDEX ();
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4348 struct gcpro gcpro1, gcpro2, gcpro3, gcpro4, gcpro5, gcpro6;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4349 char filename[MAXPATHLEN];
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4350 static NavEventUPP mac_nav_event_callbackUPP = NULL;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4351
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4352 check_mac ();
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4353
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4354 GCPRO6 (prompt, dir, default_filename, mustmatch, file, only_dir_p);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4355 CHECK_STRING (prompt);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4356 CHECK_STRING (dir);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4357
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4358 /* Create the dialog with PROMPT as title, using DIR as initial
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4359 directory and using "*" as pattern. */
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4360 dir = Fexpand_file_name (dir, Qnil);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4361
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4362 {
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4363 OSStatus status;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4364 NavDialogCreationOptions options;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4365 NavDialogRef dialogRef;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4366 NavTypeListHandle fileTypes = NULL;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4367 NavUserAction userAction;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4368 CFStringRef message=NULL, saveName = NULL;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4369
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4370 BLOCK_INPUT;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4371 /* No need for a callback function because we are modal */
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4372 NavGetDefaultDialogCreationOptions(&options);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4373 options.modality = kWindowModalityAppModal;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4374 options.location.h = options.location.v = -1;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4375 options.optionFlags = kNavDefaultNavDlogOptions;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4376 options.optionFlags |= kNavAllFilesInPopup; /* All files allowed */
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4377 options.optionFlags |= kNavSelectAllReadableItem;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4378 options.optionFlags &= ~kNavAllowMultipleFiles;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4379 if (!NILP(prompt))
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4380 {
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4381 message = cfstring_create_with_string (prompt);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4382 options.message = message;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4383 }
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4384 /* Don't set the application, let it use default.
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4385 options.clientName = CFSTR ("Emacs");
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4386 */
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4387
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4388 if (mac_nav_event_callbackUPP == NULL)
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4389 mac_nav_event_callbackUPP = NewNavEventUPP (mac_nav_event_callback);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4390
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4391 if (!NILP (only_dir_p))
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4392 status = NavCreateChooseFolderDialog(&options, mac_nav_event_callbackUPP,
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4393 NULL, NULL, &dialogRef);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4394 else if (NILP (mustmatch))
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4395 {
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4396 /* This is a save dialog */
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4397 options.optionFlags |= kNavDontConfirmReplacement;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4398 options.actionButtonLabel = CFSTR ("Ok");
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4399 options.windowTitle = CFSTR ("Enter name");
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4400
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4401 if (STRINGP (default_filename))
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4402 {
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4403 Lisp_Object utf8 = ENCODE_UTF_8 (default_filename);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4404 char *begPtr = SDATA(utf8);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4405 char *filePtr = begPtr + SBYTES(utf8);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4406 while (filePtr != begPtr && !IS_DIRECTORY_SEP(filePtr[-1]))
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4407 filePtr--;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4408 saveName = cfstring_create_with_utf8_cstring (filePtr);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4409 options.saveFileName = saveName;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4410 options.optionFlags |= kNavSelectDefaultLocation;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4411 }
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4412 status = NavCreatePutFileDialog(&options,
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4413 'TEXT', kNavGenericSignature,
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4414 mac_nav_event_callbackUPP, NULL,
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4415 &dialogRef);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4416 }
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4417 else
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4418 {
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4419 /* This is an open dialog*/
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4420 status = NavCreateChooseFileDialog(&options, fileTypes,
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4421 mac_nav_event_callbackUPP, NULL,
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4422 NULL, NULL, &dialogRef);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4423 }
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4424
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4425 /* Set the default location and continue*/
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4426 if (status == noErr)
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4427 {
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4428 Lisp_Object encoded_dir = ENCODE_FILE (dir);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4429 AEDesc defLocAed;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4430
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4431 status = AECreateDesc (TYPE_FILE_NAME, SDATA (encoded_dir),
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4432 SBYTES (encoded_dir), &defLocAed);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4433 if (status == noErr)
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4434 {
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4435 NavCustomControl(dialogRef, kNavCtlSetLocation, (void*) &defLocAed);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4436 AEDisposeDesc(&defLocAed);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4437 }
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4438 status = NavDialogRun(dialogRef);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4439 }
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4440
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4441 if (saveName) CFRelease(saveName);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4442 if (message) CFRelease(message);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4443
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4444 if (status == noErr) {
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4445 userAction = NavDialogGetUserAction(dialogRef);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4446 switch (userAction)
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4447 {
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4448 case kNavUserActionNone:
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4449 case kNavUserActionCancel:
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4450 break; /* Treat cancel like C-g */
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4451 case kNavUserActionOpen:
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4452 case kNavUserActionChoose:
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4453 case kNavUserActionSaveAs:
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4454 {
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4455 NavReplyRecord reply;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4456 Size len;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4457
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4458 status = NavDialogGetReply(dialogRef, &reply);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4459 if (status != noErr)
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4460 break;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4461 status = AEGetNthPtr (&reply.selection, 1, TYPE_FILE_NAME,
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4462 NULL, NULL, filename,
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4463 sizeof (filename) - 1, &len);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4464 if (status == noErr)
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4465 {
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4466 len = min (len, sizeof (filename) - 1);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4467 filename[len] = '\0';
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4468 if (reply.saveFileName)
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4469 {
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4470 /* If it was a saved file, we need to add the file name */
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4471 if (len && len < sizeof (filename) - 1
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4472 && filename[len-1] != '/')
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4473 filename[len++] = '/';
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4474 CFStringGetCString(reply.saveFileName, filename+len,
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4475 sizeof (filename) - len,
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4476 #ifdef MAC_OSX
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4477 kCFStringEncodingUTF8
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4478 #else
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4479 CFStringGetSystemEncoding ()
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4480 #endif
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4481 );
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4482 }
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4483 file = DECODE_FILE (make_unibyte_string (filename,
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4484 strlen (filename)));
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4485 }
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4486 NavDisposeReply(&reply);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4487 }
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4488 break;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4489 }
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4490 NavDialogDispose(dialogRef);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4491 UNBLOCK_INPUT;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4492 }
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4493 else {
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4494 UNBLOCK_INPUT;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4495 /* Fall back on minibuffer if there was a problem */
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4496 file = Fcompleting_read (prompt, intern ("read-file-name-internal"),
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4497 dir, mustmatch, dir, Qfile_name_history,
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4498 default_filename, Qnil);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4499 }
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4500 }
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4501
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4502 UNGCPRO;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4503
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4504 /* Make "Cancel" equivalent to C-g. */
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4505 if (NILP (file))
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4506 Fsignal (Qquit, Qnil);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4507
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4508 return unbind_to (count, file);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4509 }
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4510
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4511 /* Need to register some event callback function for enabling drag and
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4512 drop in Navigation Service dialogs. */
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4513 static pascal void
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4514 mac_nav_event_callback (selector, parms, data)
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4515 NavEventCallbackMessage selector;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4516 NavCBRecPtr parms;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4517 void *data;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4518 {
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4519 }
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4520 #endif
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4521
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4522
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4523 /************************************************************************
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4524 Menu
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4525 ************************************************************************/
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4526
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4527 #if !TARGET_API_MAC_CARBON
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4528 #include <MacTypes.h>
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4529 #include <Menus.h>
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4530 #include <Quickdraw.h>
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4531 #include <ToolUtils.h>
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4532 #include <Fonts.h>
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4533 #include <Controls.h>
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4534 #include <Windows.h>
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4535 #include <Events.h>
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4536 #if defined (__MRC__) || (__MSL__ >= 0x6000)
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4537 #include <ControlDefinitions.h>
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4538 #endif
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4539 #endif /* not TARGET_API_MAC_CARBON */
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4540
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4541 extern int menu_item_selection;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4542 extern int popup_activated_flag;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4543 extern int name_is_separator P_ ((const char *));
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4544 extern void find_and_call_menu_selection P_ ((FRAME_PTR, int, Lisp_Object,
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4545 void *));
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4546 extern void set_frame_menubar P_ ((FRAME_PTR, int, int));
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4547
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4548 enum mac_menu_kind { /* Menu ID range */
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4549 MAC_MENU_APPLE, /* 0 (Reserved by Apple) */
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4550 MAC_MENU_MENU_BAR, /* 1 .. 233 */
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4551 MAC_MENU_M_APPLE, /* 234 (== M_APPLE) */
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4552 MAC_MENU_POPUP, /* 235 */
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4553 MAC_MENU_DRIVER, /* 236 .. 255 (Reserved) */
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4554 MAC_MENU_MENU_BAR_SUB, /* 256 .. 16383 */
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4555 MAC_MENU_POPUP_SUB, /* 16384 .. 32767 */
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4556 MAC_MENU_END /* 32768 */
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4557 };
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4558
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4559 static const int min_menu_id[] = {0, 1, 234, 235, 236, 256, 16384, 32768};
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4560
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4561 static int fill_menu P_ ((MenuRef, widget_value *, enum mac_menu_kind, int));
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4562 static void dispose_menus P_ ((enum mac_menu_kind, int));
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4563
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4564 #if !TARGET_API_MAC_CARBON
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4565 static void
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4566 do_apple_menu (SInt16 menu_item)
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4567 {
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4568 Str255 item_name;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4569 SInt16 da_driver_refnum;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4570
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4571 if (menu_item == I_ABOUT)
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4572 NoteAlert (ABOUT_ALERT_ID, NULL);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4573 else
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4574 {
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4575 GetMenuItemText (GetMenuRef (M_APPLE), menu_item, item_name);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4576 da_driver_refnum = OpenDeskAcc (item_name);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4577 }
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4578 }
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4579 #endif /* !TARGET_API_MAC_CARBON */
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4580
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4581 /* Activate the menu bar of frame F.
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4582 This is called from keyboard.c when it gets the
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4583 MENU_BAR_ACTIVATE_EVENT out of the Emacs event queue.
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4584
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4585 To activate the menu bar, we use the button-press event location
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4586 that was saved in saved_menu_event_location.
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4587
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4588 But first we recompute the menu bar contents (the whole tree).
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4589
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4590 The reason for saving the button event until here, instead of
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4591 passing it to the toolkit right away, is that we can safely
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4592 execute Lisp code. */
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4593
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4594 void
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4595 x_activate_menubar (f)
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4596 FRAME_PTR f;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4597 {
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4598 SInt32 menu_choice;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4599 SInt16 menu_id, menu_item;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4600
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4601 set_frame_menubar (f, 0, 1);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4602 BLOCK_INPUT;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4603
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4604 popup_activated_flag = 1;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4605 menu_choice = MenuSelect (saved_menu_event_location);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4606 popup_activated_flag = 0;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4607 menu_id = HiWord (menu_choice);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4608 menu_item = LoWord (menu_choice);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4609
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4610 #if !TARGET_API_MAC_CARBON
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4611 if (menu_id == min_menu_id[MAC_MENU_M_APPLE])
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4612 do_apple_menu (menu_item);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4613 else
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4614 #endif
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4615 if (menu_id)
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4616 {
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4617 MenuRef menu = GetMenuRef (menu_id);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4618
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4619 if (menu)
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4620 {
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4621 UInt32 refcon;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4622
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4623 GetMenuItemRefCon (menu, menu_item, &refcon);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4624 find_and_call_menu_selection (f, f->menu_bar_items_used,
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4625 f->menu_bar_vector, (void *) refcon);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4626 }
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4627 }
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4628
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4629 HiliteMenu (0);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4630
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4631 UNBLOCK_INPUT;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4632 }
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4633
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4634 #if TARGET_API_MAC_CARBON
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4635 extern Lisp_Object Vshow_help_function;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4636
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4637 static Lisp_Object
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4638 restore_show_help_function (old_show_help_function)
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4639 Lisp_Object old_show_help_function;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4640 {
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4641 Vshow_help_function = old_show_help_function;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4642
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4643 return Qnil;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4644 }
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4645
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4646 static pascal OSStatus
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4647 menu_target_item_handler (next_handler, event, data)
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4648 EventHandlerCallRef next_handler;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4649 EventRef event;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4650 void *data;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4651 {
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4652 OSStatus err;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4653 MenuRef menu;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4654 MenuItemIndex menu_item;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4655 Lisp_Object help;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4656 GrafPtr port;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4657 int specpdl_count = SPECPDL_INDEX ();
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4658
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4659 /* Don't be bothered with the overflowed toolbar items menu. */
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4660 if (!popup_activated ())
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4661 return eventNotHandledErr;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4662
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4663 err = GetEventParameter (event, kEventParamDirectObject, typeMenuRef,
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4664 NULL, sizeof (MenuRef), NULL, &menu);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4665 if (err == noErr)
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4666 err = GetEventParameter (event, kEventParamMenuItemIndex,
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4667 typeMenuItemIndex, NULL,
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4668 sizeof (MenuItemIndex), NULL, &menu_item);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4669 if (err == noErr)
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4670 err = GetMenuItemProperty (menu, menu_item,
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4671 MAC_EMACS_CREATOR_CODE, 'help',
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4672 sizeof (Lisp_Object), NULL, &help);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4673 if (err != noErr)
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4674 help = Qnil;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4675
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4676 /* Temporarily bind Vshow_help_function to Qnil because we don't
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4677 want tooltips during menu tracking. */
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4678 record_unwind_protect (restore_show_help_function, Vshow_help_function);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4679 Vshow_help_function = Qnil;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4680 GetPort (&port);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4681 show_help_echo (help, Qnil, Qnil, Qnil, 1);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4682 SetPort (port);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4683 unbind_to (specpdl_count, Qnil);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4684
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4685 return err == noErr ? noErr : eventNotHandledErr;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4686 }
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4687
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4688 /* Showing help echo string during menu tracking. */
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4689
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4690 static OSStatus
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4691 install_menu_target_item_handler ()
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4692 {
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4693 static const EventTypeSpec specs[] =
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4694 {{kEventClassMenu, kEventMenuTargetItem}};
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4695
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4696 return InstallApplicationEventHandler (NewEventHandlerUPP
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4697 (menu_target_item_handler),
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4698 GetEventTypeCount (specs),
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4699 specs, NULL, NULL);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4700 }
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4701 #endif /* TARGET_API_MAC_CARBON */
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4702
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4703 /* Event handler function that pops down a menu on C-g. We can only pop
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4704 down menus if CancelMenuTracking is present (OSX 10.3 or later). */
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4705
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4706 #if MAC_OS_X_VERSION_MAX_ALLOWED >= 1030
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4707 static pascal OSStatus
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4708 menu_quit_handler (nextHandler, theEvent, userData)
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4709 EventHandlerCallRef nextHandler;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4710 EventRef theEvent;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4711 void* userData;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4712 {
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4713 OSStatus err;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4714 UInt32 keyCode;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4715 UInt32 keyModifiers;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4716
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4717 err = GetEventParameter (theEvent, kEventParamKeyCode,
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4718 typeUInt32, NULL, sizeof(UInt32), NULL, &keyCode);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4719
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4720 if (err == noErr)
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4721 err = GetEventParameter (theEvent, kEventParamKeyModifiers,
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4722 typeUInt32, NULL, sizeof(UInt32),
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4723 NULL, &keyModifiers);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4724
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4725 if (err == noErr && mac_quit_char_key_p (keyModifiers, keyCode))
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4726 {
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4727 MenuRef menu = userData != 0
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4728 ? (MenuRef)userData : AcquireRootMenu ();
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4729
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4730 CancelMenuTracking (menu, true, 0);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4731 if (!userData) ReleaseMenu (menu);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4732 return noErr;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4733 }
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4734
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4735 return CallNextEventHandler (nextHandler, theEvent);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4736 }
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4737 #endif /* MAC_OS_X_VERSION_MAX_ALLOWED >= 1030 */
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4738
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4739 /* Add event handler to all menus that belong to KIND so we can detect
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4740 C-g. ROOT_MENU is the root menu of the tracking session to dismiss
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4741 when C-g is detected. NULL means the menu bar. If
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4742 CancelMenuTracking isn't available, do nothing. */
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4743
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4744 static void
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4745 install_menu_quit_handler (kind, root_menu)
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4746 enum mac_menu_kind kind;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4747 MenuRef root_menu;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4748 {
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4749 #if MAC_OS_X_VERSION_MAX_ALLOWED >= 1030
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4750 static const EventTypeSpec typesList[] =
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4751 {{kEventClassKeyboard, kEventRawKeyDown}};
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4752 int id;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4753
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4754 #if MAC_OS_X_VERSION_MIN_REQUIRED == 1020
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4755 if (CancelMenuTracking == NULL)
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4756 return;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4757 #endif
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4758 for (id = min_menu_id[kind]; id < min_menu_id[kind + 1]; id++)
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4759 {
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4760 MenuRef menu = GetMenuRef (id);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4761
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4762 if (menu == NULL)
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4763 break;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4764 InstallMenuEventHandler (menu, menu_quit_handler,
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4765 GetEventTypeCount (typesList),
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4766 typesList, root_menu, NULL);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4767 }
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4768 #endif /* MAC_OS_X_VERSION_MAX_ALLOWED >= 1030 */
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4769 }
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4770
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4771 static Lisp_Object
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4772 pop_down_menu (arg)
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4773 Lisp_Object arg;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4774 {
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4775 struct Lisp_Save_Value *p = XSAVE_VALUE (arg);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4776 FRAME_PTR f = p->pointer;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4777 MenuRef menu = GetMenuRef (min_menu_id[MAC_MENU_POPUP]);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4778
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4779 BLOCK_INPUT;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4780
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4781 /* Must reset this manually because the button release event is not
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4782 passed to Emacs event loop. */
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4783 FRAME_MAC_DISPLAY_INFO (f)->grabbed = 0;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4784
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4785 /* delete all menus */
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4786 dispose_menus (MAC_MENU_POPUP_SUB, 0);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4787 DeleteMenu (min_menu_id[MAC_MENU_POPUP]);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4788 DisposeMenu (menu);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4789
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4790 UNBLOCK_INPUT;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4791
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4792 return Qnil;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4793 }
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4794
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4795 /* Pop up the menu for frame F defined by FIRST_WV at X/Y and loop
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4796 until the menu pops down. Return the selection. */
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4797
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4798 void
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4799 create_and_show_popup_menu (f, first_wv, x, y, for_click)
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4800 FRAME_PTR f;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4801 widget_value *first_wv;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4802 int x;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4803 int y;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4804 int for_click;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4805 {
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4806 int result = 0;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4807 MenuRef menu = NewMenu (min_menu_id[MAC_MENU_POPUP], "\p");
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4808 int menu_item_choice;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4809 int specpdl_count = SPECPDL_INDEX ();
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4810
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4811 InsertMenu (menu, -1);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4812 fill_menu (menu, first_wv->contents, MAC_MENU_POPUP_SUB,
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4813 min_menu_id[MAC_MENU_POPUP_SUB]);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4814
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4815 /* Add event handler so we can detect C-g. */
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4816 install_menu_quit_handler (MAC_MENU_POPUP, menu);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4817 install_menu_quit_handler (MAC_MENU_POPUP_SUB, menu);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4818
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4819 record_unwind_protect (pop_down_menu, make_save_value (f, 0));
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4820
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4821 /* Adjust coordinates to be root-window-relative. */
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4822 x += f->left_pos + FRAME_OUTER_TO_INNER_DIFF_X (f);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4823 y += f->top_pos + FRAME_OUTER_TO_INNER_DIFF_Y (f);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4824
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4825 /* Display the menu. */
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4826 popup_activated_flag = 1;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4827 menu_item_choice = PopUpMenuSelect (menu, y, x, 0);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4828 popup_activated_flag = 0;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4829
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4830 /* Get the refcon to find the correct item */
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4831 if (menu_item_choice)
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4832 {
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4833 MenuRef sel_menu = GetMenuRef (HiWord (menu_item_choice));
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4834
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4835 if (sel_menu)
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4836 GetMenuItemRefCon (sel_menu, LoWord (menu_item_choice),
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4837 (UInt32 *) &result);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4838 }
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4839
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4840 unbind_to (specpdl_count, Qnil);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4841
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4842 menu_item_selection = result;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4843 }
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4844
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4845 static void
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4846 add_menu_item (menu, pos, wv)
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4847 MenuRef menu;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4848 int pos;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4849 widget_value *wv;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4850 {
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4851 #if TARGET_API_MAC_CARBON
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4852 CFStringRef item_name;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4853 #else
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4854 Str255 item_name;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4855 #endif
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4856
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4857 if (name_is_separator (wv->name))
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4858 AppendMenu (menu, "\p-");
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4859 else
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4860 {
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4861 AppendMenu (menu, "\pX");
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4862
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4863 #if TARGET_API_MAC_CARBON
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4864 item_name = cfstring_create_with_utf8_cstring (wv->name);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4865
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4866 if (wv->key != NULL)
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4867 {
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4868 CFStringRef name, key;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4869
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4870 name = item_name;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4871 key = cfstring_create_with_utf8_cstring (wv->key);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4872 item_name = CFStringCreateWithFormat (NULL, NULL, CFSTR ("%@ %@"),
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4873 name, key);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4874 CFRelease (name);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4875 CFRelease (key);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4876 }
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4877
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4878 SetMenuItemTextWithCFString (menu, pos, item_name);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4879 CFRelease (item_name);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4880
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4881 if (wv->enabled)
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4882 EnableMenuItem (menu, pos);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4883 else
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4884 DisableMenuItem (menu, pos);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4885
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4886 if (STRINGP (wv->help))
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4887 SetMenuItemProperty (menu, pos, MAC_EMACS_CREATOR_CODE, 'help',
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4888 sizeof (Lisp_Object), &wv->help);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4889 #else /* ! TARGET_API_MAC_CARBON */
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4890 item_name[sizeof (item_name) - 1] = '\0';
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4891 strncpy (item_name, wv->name, sizeof (item_name) - 1);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4892 if (wv->key != NULL)
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4893 {
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4894 int len = strlen (item_name);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4895
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4896 strncpy (item_name + len, " ", sizeof (item_name) - 1 - len);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4897 len = strlen (item_name);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4898 strncpy (item_name + len, wv->key, sizeof (item_name) - 1 - len);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4899 }
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4900 c2pstr (item_name);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4901 SetMenuItemText (menu, pos, item_name);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4902
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4903 if (wv->enabled)
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4904 EnableItem (menu, pos);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4905 else
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4906 DisableItem (menu, pos);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4907 #endif /* ! TARGET_API_MAC_CARBON */
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4908
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4909 /* Draw radio buttons and tickboxes. */
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4910 if (wv->selected && (wv->button_type == BUTTON_TYPE_TOGGLE
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4911 || wv->button_type == BUTTON_TYPE_RADIO))
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4912 SetItemMark (menu, pos, checkMark);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4913 else
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4914 SetItemMark (menu, pos, noMark);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4915
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4916 SetMenuItemRefCon (menu, pos, (UInt32) wv->call_data);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4917 }
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4918 }
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4919
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4920 /* Construct native Mac OS menu based on widget_value tree. */
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4921
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4922 static int
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4923 fill_menu (menu, wv, kind, submenu_id)
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4924 MenuRef menu;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4925 widget_value *wv;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4926 enum mac_menu_kind kind;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4927 int submenu_id;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4928 {
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4929 int pos;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4930
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4931 for (pos = 1; wv != NULL; wv = wv->next, pos++)
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4932 {
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4933 add_menu_item (menu, pos, wv);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4934 if (wv->contents && submenu_id < min_menu_id[kind + 1])
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4935 {
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4936 MenuRef submenu = NewMenu (submenu_id, "\pX");
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4937
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4938 InsertMenu (submenu, -1);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4939 #if TARGET_API_MAC_CARBON
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4940 SetMenuItemHierarchicalMenu (menu, pos, submenu);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4941 #else
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4942 SetMenuItemHierarchicalID (menu, pos, submenu_id);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4943 #endif
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4944 submenu_id = fill_menu (submenu, wv->contents, kind, submenu_id + 1);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4945 }
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4946 }
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4947
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4948 return submenu_id;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4949 }
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4950
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4951 /* Fill menu bar with the items defined by WV. If DEEP_P, consider
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4952 the entire menu trees we supply, rather than just the menu bar item
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4953 names. */
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4954
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4955 void
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4956 mac_fill_menubar (wv, deep_p)
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4957 widget_value *wv;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4958 int deep_p;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4959 {
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4960 int id, submenu_id;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4961 #if !TARGET_API_MAC_CARBON
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4962 int title_changed_p = 0;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4963 #endif
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4964
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4965 /* Clean up the menu bar when filled by the entire menu trees. */
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4966 if (deep_p)
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4967 {
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4968 dispose_menus (MAC_MENU_MENU_BAR, 0);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4969 dispose_menus (MAC_MENU_MENU_BAR_SUB, 0);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4970 #if !TARGET_API_MAC_CARBON
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4971 title_changed_p = 1;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4972 #endif
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4973 }
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4974
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4975 /* Fill menu bar titles and submenus. Reuse the existing menu bar
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4976 titles as much as possible to minimize redraw (if !deep_p). */
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4977 submenu_id = min_menu_id[MAC_MENU_MENU_BAR_SUB];
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4978 for (id = min_menu_id[MAC_MENU_MENU_BAR];
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4979 wv != NULL && id < min_menu_id[MAC_MENU_MENU_BAR + 1];
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4980 wv = wv->next, id++)
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4981 {
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4982 OSStatus err = noErr;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4983 MenuRef menu;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4984 #if TARGET_API_MAC_CARBON
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4985 CFStringRef title;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4986
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4987 title = CFStringCreateWithCString (NULL, wv->name,
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4988 kCFStringEncodingMacRoman);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4989 #else
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4990 Str255 title;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4991
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4992 strncpy (title, wv->name, 255);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4993 title[255] = '\0';
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4994 c2pstr (title);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4995 #endif
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4996
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4997 menu = GetMenuRef (id);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4998 if (menu)
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
4999 {
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5000 #if TARGET_API_MAC_CARBON
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5001 CFStringRef old_title;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5002
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5003 err = CopyMenuTitleAsCFString (menu, &old_title);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5004 if (err == noErr)
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5005 {
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5006 if (CFStringCompare (title, old_title, 0) != kCFCompareEqualTo)
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5007 {
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5008 #ifdef MAC_OSX
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5009 if (id + 1 == min_menu_id[MAC_MENU_MENU_BAR + 1]
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5010 || GetMenuRef (id + 1) == NULL)
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5011 {
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5012 /* This is a workaround for Mac OS X 10.5 where
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5013 just calling SetMenuTitleWithCFString fails
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5014 to change the title of the last (Help) menu
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5015 in the menu bar. */
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5016 DeleteMenu (id);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5017 DisposeMenu (menu);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5018 menu = NULL;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5019 }
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5020 else
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5021 #endif /* MAC_OSX */
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5022 err = SetMenuTitleWithCFString (menu, title);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5023 }
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5024 CFRelease (old_title);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5025 }
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5026 else
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5027 err = SetMenuTitleWithCFString (menu, title);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5028 #else /* !TARGET_API_MAC_CARBON */
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5029 if (!EqualString (title, (*menu)->menuData, false, false))
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5030 {
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5031 DeleteMenu (id);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5032 DisposeMenu (menu);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5033 menu = NewMenu (id, title);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5034 InsertMenu (menu, GetMenuRef (id + 1) ? id + 1 : 0);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5035 title_changed_p = 1;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5036 }
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5037 #endif /* !TARGET_API_MAC_CARBON */
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5038 }
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5039
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5040 if (!menu)
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5041 {
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5042 #if TARGET_API_MAC_CARBON
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5043 err = CreateNewMenu (id, 0, &menu);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5044 if (err == noErr)
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5045 err = SetMenuTitleWithCFString (menu, title);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5046 #else
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5047 menu = NewMenu (id, title);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5048 #endif
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5049 if (err == noErr)
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5050 {
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5051 InsertMenu (menu, 0);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5052 #if !TARGET_API_MAC_CARBON
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5053 title_changed_p = 1;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5054 #endif
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5055 }
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5056 }
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5057 #if TARGET_API_MAC_CARBON
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5058 CFRelease (title);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5059 #endif
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5060
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5061 if (err == noErr)
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5062 if (wv->contents)
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5063 submenu_id = fill_menu (menu, wv->contents, MAC_MENU_MENU_BAR_SUB,
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5064 submenu_id);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5065 }
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5066
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5067 if (id < min_menu_id[MAC_MENU_MENU_BAR + 1] && GetMenuRef (id))
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5068 {
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5069 dispose_menus (MAC_MENU_MENU_BAR, id);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5070 #if !TARGET_API_MAC_CARBON
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5071 title_changed_p = 1;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5072 #endif
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5073 }
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5074
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5075 #if !TARGET_API_MAC_CARBON
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5076 if (title_changed_p)
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5077 InvalMenuBar ();
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5078 #endif
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5079
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5080 /* Add event handler so we can detect C-g. */
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5081 install_menu_quit_handler (MAC_MENU_MENU_BAR, NULL);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5082 install_menu_quit_handler (MAC_MENU_MENU_BAR_SUB, NULL);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5083 }
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5084
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5085 /* Dispose of menus that belong to KIND, and remove them from the menu
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5086 list. ID is the lower bound of menu IDs that will be processed. */
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5087
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5088 static void
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5089 dispose_menus (kind, id)
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5090 enum mac_menu_kind kind;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5091 int id;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5092 {
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5093 for (id = max (id, min_menu_id[kind]); id < min_menu_id[kind + 1]; id++)
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5094 {
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5095 MenuRef menu = GetMenuRef (id);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5096
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5097 if (menu == NULL)
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5098 break;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5099 DeleteMenu (id);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5100 DisposeMenu (menu);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5101 }
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5102 }
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5103
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5104 static void
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5105 init_menu_bar ()
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5106 {
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5107 #ifdef MAC_OSX
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5108 OSStatus err;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5109 MenuRef menu;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5110 MenuItemIndex menu_index;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5111
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5112 err = GetIndMenuItemWithCommandID (NULL, kHICommandQuit, 1,
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5113 &menu, &menu_index);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5114 if (err == noErr)
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5115 SetMenuItemCommandKey (menu, menu_index, false, 0);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5116 EnableMenuCommand (NULL, kHICommandPreferences);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5117 err = GetIndMenuItemWithCommandID (NULL, kHICommandPreferences, 1,
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5118 &menu, &menu_index);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5119 if (err == noErr)
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5120 {
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5121 SetMenuItemCommandKey (menu, menu_index, false, 0);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5122 InsertMenuItemTextWithCFString (menu, NULL,
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5123 0, kMenuItemAttrSeparator, 0);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5124 InsertMenuItemTextWithCFString (menu, CFSTR ("About Emacs"),
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5125 0, 0, kHICommandAbout);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5126 }
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5127 #else /* !MAC_OSX */
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5128 #if TARGET_API_MAC_CARBON
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5129 SetMenuItemCommandID (GetMenuRef (M_APPLE), I_ABOUT, kHICommandAbout);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5130 #endif
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5131 #endif
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5132 }
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5133
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5134
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5135 /***********************************************************************
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5136 Popup Dialog
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5137 ***********************************************************************/
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5138
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5139 #if TARGET_API_MAC_CARBON
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5140 #define DIALOG_BUTTON_COMMAND_ID_OFFSET 'Bt\0\0'
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5141 #define DIALOG_BUTTON_COMMAND_ID_P(id) \
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5142 (((id) & ~0xffff) == DIALOG_BUTTON_COMMAND_ID_OFFSET)
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5143 #define DIALOG_BUTTON_COMMAND_ID_VALUE(id) \
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5144 ((id) - DIALOG_BUTTON_COMMAND_ID_OFFSET)
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5145 #define DIALOG_BUTTON_MAKE_COMMAND_ID(value) \
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5146 ((value) + DIALOG_BUTTON_COMMAND_ID_OFFSET)
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5147
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5148 extern EMACS_TIME timer_check P_ ((int));
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5149 static int quit_dialog_event_loop;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5150
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5151 static pascal OSStatus
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5152 mac_handle_dialog_event (next_handler, event, data)
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5153 EventHandlerCallRef next_handler;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5154 EventRef event;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5155 void *data;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5156 {
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5157 OSStatus err, result = eventNotHandledErr;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5158 WindowRef window = (WindowRef) data;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5159
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5160 switch (GetEventClass (event))
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5161 {
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5162 case kEventClassCommand:
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5163 {
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5164 HICommand command;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5165
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5166 err = GetEventParameter (event, kEventParamDirectObject,
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5167 typeHICommand, NULL, sizeof (HICommand),
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5168 NULL, &command);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5169 if (err == noErr)
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5170 if (DIALOG_BUTTON_COMMAND_ID_P (command.commandID))
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5171 {
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5172 SetWRefCon (window, command.commandID);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5173 quit_dialog_event_loop = 1;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5174 break;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5175 }
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5176
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5177 result = CallNextEventHandler (next_handler, event);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5178 }
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5179 break;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5180
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5181 case kEventClassKeyboard:
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5182 {
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5183 OSStatus result;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5184 char char_code;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5185
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5186 result = CallNextEventHandler (next_handler, event);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5187 if (result != eventNotHandledErr)
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5188 break;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5189
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5190 err = GetEventParameter (event, kEventParamKeyMacCharCodes,
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5191 typeChar, NULL, sizeof (char),
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5192 NULL, &char_code);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5193 if (err == noErr)
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5194 switch (char_code)
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5195 {
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5196 case kEscapeCharCode:
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5197 quit_dialog_event_loop = 1;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5198 break;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5199
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5200 default:
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5201 {
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5202 UInt32 modifiers, key_code;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5203
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5204 err = GetEventParameter (event, kEventParamKeyModifiers,
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5205 typeUInt32, NULL, sizeof (UInt32),
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5206 NULL, &modifiers);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5207 if (err == noErr)
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5208 err = GetEventParameter (event, kEventParamKeyCode,
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5209 typeUInt32, NULL, sizeof (UInt32),
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5210 NULL, &key_code);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5211 if (err == noErr)
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5212 if (mac_quit_char_key_p (modifiers, key_code))
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5213 quit_dialog_event_loop = 1;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5214 }
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5215 break;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5216 }
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5217 }
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5218 break;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5219
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5220 default:
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5221 abort ();
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5222 }
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5223
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5224 if (quit_dialog_event_loop)
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5225 {
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5226 err = QuitEventLoop (GetCurrentEventLoop ());
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5227 if (err == noErr)
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5228 result = noErr;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5229 }
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5230
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5231 return result;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5232 }
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5233
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5234 static OSStatus
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5235 install_dialog_event_handler (window)
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5236 WindowRef window;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5237 {
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5238 static const EventTypeSpec specs[] =
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5239 {{kEventClassCommand, kEventCommandProcess},
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5240 {kEventClassKeyboard, kEventRawKeyDown}};
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5241 static EventHandlerUPP handle_dialog_eventUPP = NULL;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5242
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5243 if (handle_dialog_eventUPP == NULL)
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5244 handle_dialog_eventUPP = NewEventHandlerUPP (mac_handle_dialog_event);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5245 return InstallWindowEventHandler (window, handle_dialog_eventUPP,
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5246 GetEventTypeCount (specs), specs,
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5247 window, NULL);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5248 }
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5249
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5250 static Lisp_Object
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5251 pop_down_dialog (arg)
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5252 Lisp_Object arg;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5253 {
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5254 struct Lisp_Save_Value *p = XSAVE_VALUE (arg);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5255 WindowRef window = p->pointer;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5256
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5257 BLOCK_INPUT;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5258
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5259 if (popup_activated_flag)
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5260 EndAppModalStateForWindow (window);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5261 DisposeWindow (window);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5262 popup_activated_flag = 0;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5263
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5264 UNBLOCK_INPUT;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5265
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5266 return Qnil;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5267 }
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5268
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5269 /* Pop up the dialog for frame F defined by FIRST_WV and loop until the
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5270 dialog pops down.
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5271 menu_item_selection will be set to the selection. */
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5272
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5273 void
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5274 create_and_show_dialog (f, first_wv)
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5275 FRAME_PTR f;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5276 widget_value *first_wv;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5277 {
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5278 OSStatus err;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5279 char *dialog_name, *message;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5280 int nb_buttons, first_group_count, i, result = 0;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5281 widget_value *wv;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5282 short buttons_height, text_height, inner_width, inner_height;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5283 Rect empty_rect, *rects;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5284 WindowRef window = NULL;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5285 ControlRef *buttons, default_button = NULL, text;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5286 int specpdl_count = SPECPDL_INDEX ();
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5287
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5288 dialog_name = first_wv->name;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5289 nb_buttons = dialog_name[1] - '0';
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5290 first_group_count = nb_buttons - (dialog_name[4] - '0');
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5291
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5292 wv = first_wv->contents;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5293 message = wv->value;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5294
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5295 wv = wv->next;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5296 SetRect (&empty_rect, 0, 0, 0, 0);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5297
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5298 /* Create dialog window. */
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5299 err = CreateNewWindow (kMovableModalWindowClass,
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5300 kWindowStandardHandlerAttribute,
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5301 &empty_rect, &window);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5302 if (err == noErr)
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5303 {
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5304 record_unwind_protect (pop_down_dialog, make_save_value (window, 0));
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5305 err = SetThemeWindowBackground (window, kThemeBrushMovableModalBackground,
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5306 true);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5307 }
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5308 if (err == noErr)
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5309 err = SetWindowTitleWithCFString (window, (dialog_name[0] == 'Q'
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5310 ? CFSTR ("Question")
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5311 : CFSTR ("Information")));
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5312
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5313 /* Create button controls and measure their optimal bounds. */
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5314 if (err == noErr)
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5315 {
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5316 buttons = alloca (sizeof (ControlRef) * nb_buttons);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5317 rects = alloca (sizeof (Rect) * nb_buttons);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5318 for (i = 0; i < nb_buttons; i++)
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5319 {
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5320 CFStringRef label = cfstring_create_with_utf8_cstring (wv->value);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5321
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5322 if (label == NULL)
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5323 err = memFullErr;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5324 else
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5325 {
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5326 err = CreatePushButtonControl (window, &empty_rect,
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5327 label, &buttons[i]);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5328 CFRelease (label);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5329 }
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5330 if (err == noErr)
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5331 {
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5332 if (!wv->enabled)
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5333 {
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5334 #ifdef MAC_OSX
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5335 err = DisableControl (buttons[i]);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5336 #else
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5337 err = DeactivateControl (buttons[i]);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5338 #endif
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5339 }
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5340 else if (default_button == NULL)
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5341 default_button = buttons[i];
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5342 }
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5343 if (err == noErr)
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5344 {
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5345 SInt16 unused;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5346
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5347 rects[i] = empty_rect;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5348 err = GetBestControlRect (buttons[i], &rects[i], &unused);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5349 }
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5350 if (err == noErr)
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5351 {
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5352 UInt32 command_id;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5353
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5354 OffsetRect (&rects[i], -rects[i].left, -rects[i].top);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5355 if (rects[i].right < DIALOG_BUTTON_MIN_WIDTH)
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5356 rects[i].right = DIALOG_BUTTON_MIN_WIDTH;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5357 else if (rects[i].right > DIALOG_MAX_INNER_WIDTH)
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5358 rects[i].right = DIALOG_MAX_INNER_WIDTH;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5359
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5360 command_id = DIALOG_BUTTON_MAKE_COMMAND_ID ((int) wv->call_data);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5361 err = SetControlCommandID (buttons[i], command_id);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5362 }
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5363 if (err != noErr)
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5364 break;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5365 wv = wv->next;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5366 }
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5367 }
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5368
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5369 /* Layout buttons. rects[i] is set relative to the bottom-right
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5370 corner of the inner box. */
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5371 if (err == noErr)
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5372 {
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5373 short bottom, right, max_height, left_align_shift;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5374
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5375 inner_width = DIALOG_MIN_INNER_WIDTH;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5376 bottom = right = max_height = 0;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5377 for (i = 0; i < nb_buttons; i++)
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5378 {
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5379 if (right - rects[i].right < - inner_width)
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5380 {
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5381 if (i != first_group_count
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5382 && right - rects[i].right >= - DIALOG_MAX_INNER_WIDTH)
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5383 inner_width = - (right - rects[i].right);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5384 else
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5385 {
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5386 bottom -= max_height + DIALOG_BUTTON_BUTTON_VERTICAL_SPACE;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5387 right = max_height = 0;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5388 }
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5389 }
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5390 if (max_height < rects[i].bottom)
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5391 max_height = rects[i].bottom;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5392 OffsetRect (&rects[i], right - rects[i].right,
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5393 bottom - rects[i].bottom);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5394 right = rects[i].left - DIALOG_BUTTON_BUTTON_HORIZONTAL_SPACE;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5395 if (i == first_group_count - 1)
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5396 right -= DIALOG_BUTTON_BUTTON_HORIZONTAL_SPACE;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5397 }
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5398 buttons_height = - (bottom - max_height);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5399
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5400 left_align_shift = - (inner_width + rects[nb_buttons - 1].left);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5401 for (i = nb_buttons - 1; i >= first_group_count; i--)
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5402 {
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5403 if (bottom != rects[i].bottom)
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5404 {
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5405 left_align_shift = - (inner_width + rects[i].left);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5406 bottom = rects[i].bottom;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5407 }
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5408 OffsetRect (&rects[i], left_align_shift, 0);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5409 }
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5410 }
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5411
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5412 /* Create a static text control and measure its bounds. */
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5413 if (err == noErr)
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5414 {
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5415 CFStringRef message_string;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5416 Rect bounds;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5417
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5418 message_string = cfstring_create_with_utf8_cstring (message);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5419 if (message_string == NULL)
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5420 err = memFullErr;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5421 else
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5422 {
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5423 ControlFontStyleRec text_style;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5424
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5425 text_style.flags = 0;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5426 SetRect (&bounds, 0, 0, inner_width, 0);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5427 err = CreateStaticTextControl (window, &bounds, message_string,
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5428 &text_style, &text);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5429 CFRelease (message_string);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5430 }
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5431 if (err == noErr)
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5432 {
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5433 SInt16 unused;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5434
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5435 bounds = empty_rect;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5436 err = GetBestControlRect (text, &bounds, &unused);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5437 }
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5438 if (err == noErr)
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5439 {
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5440 text_height = bounds.bottom - bounds.top;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5441 if (text_height < DIALOG_TEXT_MIN_HEIGHT)
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5442 text_height = DIALOG_TEXT_MIN_HEIGHT;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5443 }
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5444 }
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5445
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5446 /* Place buttons. */
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5447 if (err == noErr)
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5448 {
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5449 inner_height = (text_height + DIALOG_TEXT_BUTTONS_VERTICAL_SPACE
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5450 + buttons_height);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5451
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5452 for (i = 0; i < nb_buttons; i++)
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5453 {
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5454 OffsetRect (&rects[i], DIALOG_LEFT_MARGIN + inner_width,
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5455 DIALOG_TOP_MARGIN + inner_height);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5456 SetControlBounds (buttons[i], &rects[i]);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5457 }
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5458 }
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5459
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5460 /* Place text. */
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5461 if (err == noErr)
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5462 {
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5463 Rect bounds;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5464
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5465 SetRect (&bounds, DIALOG_LEFT_MARGIN, DIALOG_TOP_MARGIN,
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5466 DIALOG_LEFT_MARGIN + inner_width,
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5467 DIALOG_TOP_MARGIN + text_height);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5468 SetControlBounds (text, &bounds);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5469 }
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5470
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5471 /* Create the application icon at the upper-left corner. */
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5472 if (err == noErr)
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5473 {
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5474 ControlButtonContentInfo content;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5475 ControlRef icon;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5476 static const ProcessSerialNumber psn = {0, kCurrentProcess};
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5477 #ifdef MAC_OSX
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5478 FSRef app_location;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5479 #else
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5480 ProcessInfoRec pinfo;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5481 FSSpec app_spec;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5482 #endif
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5483 SInt16 unused;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5484
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5485 content.contentType = kControlContentIconRef;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5486 #ifdef MAC_OSX
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5487 err = GetProcessBundleLocation (&psn, &app_location);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5488 if (err == noErr)
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5489 err = GetIconRefFromFileInfo (&app_location, 0, NULL, 0, NULL,
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5490 kIconServicesNormalUsageFlag,
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5491 &content.u.iconRef, &unused);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5492 #else
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5493 bzero (&pinfo, sizeof (ProcessInfoRec));
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5494 pinfo.processInfoLength = sizeof (ProcessInfoRec);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5495 pinfo.processAppSpec = &app_spec;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5496 err = GetProcessInformation (&psn, &pinfo);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5497 if (err == noErr)
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5498 err = GetIconRefFromFile (&app_spec, &content.u.iconRef, &unused);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5499 #endif
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5500 if (err == noErr)
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5501 {
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5502 Rect bounds;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5503
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5504 SetRect (&bounds, DIALOG_ICON_LEFT_MARGIN, DIALOG_ICON_TOP_MARGIN,
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5505 DIALOG_ICON_LEFT_MARGIN + DIALOG_ICON_WIDTH,
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5506 DIALOG_ICON_TOP_MARGIN + DIALOG_ICON_HEIGHT);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5507 err = CreateIconControl (window, &bounds, &content, true, &icon);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5508 ReleaseIconRef (content.u.iconRef);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5509 }
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5510 }
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5511
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5512 /* Show the dialog window and run event loop. */
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5513 if (err == noErr)
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5514 if (default_button)
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5515 err = SetWindowDefaultButton (window, default_button);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5516 if (err == noErr)
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5517 err = install_dialog_event_handler (window);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5518 if (err == noErr)
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5519 {
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5520 SizeWindow (window,
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5521 DIALOG_LEFT_MARGIN + inner_width + DIALOG_RIGHT_MARGIN,
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5522 DIALOG_TOP_MARGIN + inner_height + DIALOG_BOTTOM_MARGIN,
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5523 true);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5524 err = RepositionWindow (window, FRAME_MAC_WINDOW (f),
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5525 kWindowAlertPositionOnParentWindow);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5526 }
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5527 if (err == noErr)
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5528 {
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5529 SetWRefCon (window, 0);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5530 ShowWindow (window);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5531 BringToFront (window);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5532 popup_activated_flag = 1;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5533 err = BeginAppModalStateForWindow (window);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5534 }
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5535 if (err == noErr)
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5536 {
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5537 EventTargetRef toolbox_dispatcher = GetEventDispatcherTarget ();
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5538
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5539 quit_dialog_event_loop = 0;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5540 while (1)
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5541 {
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5542 EMACS_TIME next_time = timer_check (1);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5543 long secs = EMACS_SECS (next_time);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5544 long usecs = EMACS_USECS (next_time);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5545 EventTimeout timeout;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5546 EventRef event;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5547
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5548 if (secs < 0 || (secs == 0 && usecs == 0))
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5549 {
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5550 /* Sometimes timer_check returns -1 (no timers) even if
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5551 there are timers. So do a timeout anyway. */
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5552 secs = 1;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5553 usecs = 0;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5554 }
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5555
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5556 timeout = (secs * kEventDurationSecond
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5557 + usecs * kEventDurationMicrosecond);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5558 err = ReceiveNextEvent (0, NULL, timeout, kEventRemoveFromQueue,
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5559 &event);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5560 if (err == noErr)
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5561 {
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5562 SendEventToEventTarget (event, toolbox_dispatcher);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5563 ReleaseEvent (event);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5564 }
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5565 #if 0 /* defined (MAC_OSX) */
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5566 else if (err != eventLoopTimedOutErr)
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5567 {
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5568 if (err == eventLoopQuitErr)
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5569 err = noErr;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5570 break;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5571 }
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5572 #else
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5573 /* The return value of ReceiveNextEvent seems to be
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5574 unreliable. Use our own global variable instead. */
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5575 if (quit_dialog_event_loop)
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5576 {
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5577 err = noErr;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5578 break;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5579 }
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5580 #endif
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5581 }
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5582 }
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5583 if (err == noErr)
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5584 {
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5585 UInt32 command_id = GetWRefCon (window);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5586
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5587 if (DIALOG_BUTTON_COMMAND_ID_P (command_id))
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5588 result = DIALOG_BUTTON_COMMAND_ID_VALUE (command_id);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5589 }
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5590
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5591 unbind_to (specpdl_count, Qnil);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5592
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5593 menu_item_selection = result;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5594 }
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5595 #else /* not TARGET_API_MAC_CARBON */
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5596 #define DIALOG_WINDOW_RESOURCE 130
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5597
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5598 int
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5599 mac_dialog (widget_value *wv)
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5600 {
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5601 char *dialog_name;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5602 char *prompt;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5603 char **button_labels;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5604 UInt32 *ref_cons;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5605 int nb_buttons;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5606 int left_count;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5607 int i;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5608 int dialog_width;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5609 Rect rect;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5610 WindowRef window_ptr;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5611 ControlRef ch;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5612 int left;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5613 EventRecord event_record;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5614 SInt16 part_code;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5615 int control_part_code;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5616 Point mouse;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5617
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5618 dialog_name = wv->name;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5619 nb_buttons = dialog_name[1] - '0';
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5620 left_count = nb_buttons - (dialog_name[4] - '0');
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5621 button_labels = (char **) alloca (sizeof (char *) * nb_buttons);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5622 ref_cons = (UInt32 *) alloca (sizeof (UInt32) * nb_buttons);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5623
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5624 wv = wv->contents;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5625 prompt = (char *) alloca (strlen (wv->value) + 1);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5626 strcpy (prompt, wv->value);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5627 c2pstr (prompt);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5628
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5629 wv = wv->next;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5630 for (i = 0; i < nb_buttons; i++)
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5631 {
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5632 button_labels[i] = wv->value;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5633 button_labels[i] = (char *) alloca (strlen (wv->value) + 1);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5634 strcpy (button_labels[i], wv->value);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5635 c2pstr (button_labels[i]);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5636 ref_cons[i] = (UInt32) wv->call_data;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5637 wv = wv->next;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5638 }
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5639
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5640 window_ptr = GetNewCWindow (DIALOG_WINDOW_RESOURCE, NULL, (WindowRef) -1);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5641
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5642 SetPortWindowPort (window_ptr);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5643
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5644 TextFont (0);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5645 /* Left and right margins in the dialog are 13 pixels each.*/
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5646 dialog_width = 14;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5647 /* Calculate width of dialog box: 8 pixels on each side of the text
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5648 label in each button, 12 pixels between buttons. */
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5649 for (i = 0; i < nb_buttons; i++)
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5650 dialog_width += StringWidth (button_labels[i]) + 16 + 12;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5651
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5652 if (left_count != 0 && nb_buttons - left_count != 0)
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5653 dialog_width += 12;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5654
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5655 dialog_width = max (dialog_width, StringWidth (prompt) + 26);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5656
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5657 SizeWindow (window_ptr, dialog_width, 78, 0);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5658 ShowWindow (window_ptr);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5659
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5660 SetPortWindowPort (window_ptr);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5661
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5662 TextFont (0);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5663
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5664 MoveTo (13, 29);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5665 DrawString (prompt);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5666
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5667 left = 13;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5668 for (i = 0; i < nb_buttons; i++)
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5669 {
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5670 int button_width = StringWidth (button_labels[i]) + 16;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5671 SetRect (&rect, left, 45, left + button_width, 65);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5672 ch = NewControl (window_ptr, &rect, button_labels[i], 1, 0, 0, 0,
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5673 kControlPushButtonProc, ref_cons[i]);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5674 left += button_width + 12;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5675 if (i == left_count - 1)
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5676 left += 12;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5677 }
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5678
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5679 i = 0;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5680 while (!i)
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5681 {
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5682 if (WaitNextEvent (mDownMask, &event_record, 10, NULL))
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5683 if (event_record.what == mouseDown)
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5684 {
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5685 part_code = FindWindow (event_record.where, &window_ptr);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5686 if (part_code == inContent)
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5687 {
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5688 mouse = event_record.where;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5689 GlobalToLocal (&mouse);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5690 control_part_code = FindControl (mouse, window_ptr, &ch);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5691 if (control_part_code == kControlButtonPart)
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5692 if (TrackControl (ch, mouse, NULL))
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5693 i = GetControlReference (ch);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5694 }
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5695 }
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5696 }
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5697
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5698 DisposeWindow (window_ptr);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5699
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5700 return i;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5701 }
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5702 #endif /* not TARGET_API_MAC_CARBON */
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5703
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5704
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5705 /***********************************************************************
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5706 Selection support
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5707 ***********************************************************************/
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5708
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5709 #if !TARGET_API_MAC_CARBON
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5710 #include <Scrap.h>
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5711 #include <Endian.h>
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5712 #endif
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5713
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5714 extern Lisp_Object Vselection_converter_alist;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5715 extern Lisp_Object Qmac_scrap_name, Qmac_ostype;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5716
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5717 static ScrapFlavorType get_flavor_type_from_symbol P_ ((Lisp_Object,
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5718 Selection));
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5719
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5720 /* Get a reference to the selection corresponding to the symbol SYM.
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5721 The reference is set to *SEL, and it becomes NULL if there's no
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5722 corresponding selection. Clear the selection if CLEAR_P is
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5723 non-zero. */
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5724
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5725 OSStatus
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5726 mac_get_selection_from_symbol (sym, clear_p, sel)
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5727 Lisp_Object sym;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5728 int clear_p;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5729 Selection *sel;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5730 {
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5731 OSStatus err = noErr;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5732 Lisp_Object str = Fget (sym, Qmac_scrap_name);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5733
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5734 if (!STRINGP (str))
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5735 *sel = NULL;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5736 else
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5737 {
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5738 #if TARGET_API_MAC_CARBON
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5739 #ifdef MAC_OSX
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5740 CFStringRef scrap_name = cfstring_create_with_string (str);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5741 OptionBits options = (clear_p ? kScrapClearNamedScrap
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5742 : kScrapGetNamedScrap);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5743
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5744 err = GetScrapByName (scrap_name, options, sel);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5745 CFRelease (scrap_name);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5746 #else /* !MAC_OSX */
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5747 if (clear_p)
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5748 err = ClearCurrentScrap ();
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5749 if (err == noErr)
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5750 err = GetCurrentScrap (sel);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5751 #endif /* !MAC_OSX */
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5752 #else /* !TARGET_API_MAC_CARBON */
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5753 if (clear_p)
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5754 err = ZeroScrap ();
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5755 if (err == noErr)
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5756 *sel = 1;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5757 #endif /* !TARGET_API_MAC_CARBON */
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5758 }
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5759
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5760 return err;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5761 }
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5762
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5763 /* Get a scrap flavor type from the symbol SYM. Return 0 if no
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5764 corresponding flavor type. If SEL is non-zero, the return value is
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5765 non-zero only when the SEL has the flavor type. */
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5766
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5767 static ScrapFlavorType
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5768 get_flavor_type_from_symbol (sym, sel)
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5769 Lisp_Object sym;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5770 Selection sel;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5771 {
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5772 Lisp_Object str = Fget (sym, Qmac_ostype);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5773 ScrapFlavorType flavor_type;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5774
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5775 if (STRINGP (str) && SBYTES (str) == 4)
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5776 flavor_type = EndianU32_BtoN (*((UInt32 *) SDATA (str)));
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5777 else
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5778 flavor_type = 0;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5779
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5780 if (flavor_type && sel)
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5781 {
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5782 #if TARGET_API_MAC_CARBON
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5783 OSStatus err;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5784 ScrapFlavorFlags flags;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5785
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5786 err = GetScrapFlavorFlags (sel, flavor_type, &flags);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5787 if (err != noErr)
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5788 flavor_type = 0;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5789 #else /* !TARGET_API_MAC_CARBON */
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5790 SInt32 size, offset;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5791
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5792 size = GetScrap (NULL, flavor_type, &offset);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5793 if (size < 0)
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5794 flavor_type = 0;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5795 #endif /* !TARGET_API_MAC_CARBON */
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5796 }
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5797
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5798 return flavor_type;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5799 }
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5800
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5801 /* Check if the symbol SYM has a corresponding selection target type. */
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5802
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5803 int
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5804 mac_valid_selection_target_p (sym)
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5805 Lisp_Object sym;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5806 {
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5807 return get_flavor_type_from_symbol (sym, 0) != 0;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5808 }
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5809
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5810 /* Clear the selection whose reference is *SEL. */
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5811
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5812 OSStatus
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5813 mac_clear_selection (sel)
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5814 Selection *sel;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5815 {
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5816 #if TARGET_API_MAC_CARBON
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5817 #ifdef MAC_OSX
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5818 return ClearScrap (sel);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5819 #else
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5820 OSStatus err;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5821
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5822 err = ClearCurrentScrap ();
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5823 if (err == noErr)
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5824 err = GetCurrentScrap (sel);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5825 return err;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5826 #endif
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5827 #else /* !TARGET_API_MAC_CARBON */
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5828 return ZeroScrap ();
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5829 #endif /* !TARGET_API_MAC_CARBON */
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5830 }
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5831
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5832 /* Get ownership information for SEL. Emacs can detect a change of
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5833 the ownership by comparing saved and current values of the
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5834 ownership information. */
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5835
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5836 Lisp_Object
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5837 mac_get_selection_ownership_info (sel)
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5838 Selection sel;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5839 {
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5840 #if TARGET_API_MAC_CARBON
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5841 return long_to_cons ((unsigned long) sel);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5842 #else /* !TARGET_API_MAC_CARBON */
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5843 ScrapStuffPtr scrap_info = InfoScrap ();
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5844
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5845 return make_number (scrap_info->scrapCount);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5846 #endif /* !TARGET_API_MAC_CARBON */
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5847 }
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5848
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5849 /* Return non-zero if VALUE is a valid selection value for TARGET. */
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5850
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5851 int
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5852 mac_valid_selection_value_p (value, target)
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5853 Lisp_Object value, target;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5854 {
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5855 return STRINGP (value);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5856 }
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5857
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5858 /* Put Lisp object VALUE to the selection SEL. The target type is
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5859 specified by TARGET. */
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5860
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5861 OSStatus
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5862 mac_put_selection_value (sel, target, value)
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5863 Selection sel;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5864 Lisp_Object target, value;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5865 {
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5866 ScrapFlavorType flavor_type = get_flavor_type_from_symbol (target, 0);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5867
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5868 if (flavor_type == 0 || !STRINGP (value))
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5869 return noTypeErr;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5870
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5871 #if TARGET_API_MAC_CARBON
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5872 return PutScrapFlavor (sel, flavor_type, kScrapFlavorMaskNone,
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5873 SBYTES (value), SDATA (value));
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5874 #else /* !TARGET_API_MAC_CARBON */
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5875 return PutScrap (SBYTES (value), flavor_type, SDATA (value));
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5876 #endif /* !TARGET_API_MAC_CARBON */
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5877 }
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5878
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5879 /* Check if data for the target type TARGET is available in SEL. */
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5880
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5881 int
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5882 mac_selection_has_target_p (sel, target)
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5883 Selection sel;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5884 Lisp_Object target;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5885 {
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5886 return get_flavor_type_from_symbol (target, sel) != 0;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5887 }
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5888
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5889 /* Get data for the target type TARGET from SEL and create a Lisp
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5890 string. Return nil if failed to get data. */
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5891
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5892 Lisp_Object
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5893 mac_get_selection_value (sel, target)
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5894 Selection sel;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5895 Lisp_Object target;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5896 {
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5897 OSStatus err;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5898 Lisp_Object result = Qnil;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5899 ScrapFlavorType flavor_type = get_flavor_type_from_symbol (target, sel);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5900 #if TARGET_API_MAC_CARBON
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5901 Size size;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5902
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5903 if (flavor_type)
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5904 {
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5905 err = GetScrapFlavorSize (sel, flavor_type, &size);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5906 if (err == noErr)
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5907 {
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5908 do
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5909 {
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5910 result = make_uninit_string (size);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5911 err = GetScrapFlavorData (sel, flavor_type,
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5912 &size, SDATA (result));
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5913 if (err != noErr)
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5914 result = Qnil;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5915 else if (size < SBYTES (result))
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5916 result = make_unibyte_string (SDATA (result), size);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5917 }
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5918 while (STRINGP (result) && size > SBYTES (result));
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5919 }
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5920 }
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5921 #else
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5922 Handle handle;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5923 SInt32 size, offset;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5924
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5925 if (flavor_type)
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5926 size = GetScrap (NULL, flavor_type, &offset);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5927 if (size >= 0)
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5928 {
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5929 handle = NewHandle (size);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5930 HLock (handle);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5931 size = GetScrap (handle, flavor_type, &offset);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5932 if (size >= 0)
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5933 result = make_unibyte_string (*handle, size);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5934 DisposeHandle (handle);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5935 }
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5936 #endif
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5937
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5938 return result;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5939 }
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5940
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5941 /* Get the list of target types in SEL. The return value is a list of
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5942 target type symbols possibly followed by scrap flavor type
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5943 strings. */
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5944
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5945 Lisp_Object
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5946 mac_get_selection_target_list (sel)
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5947 Selection sel;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5948 {
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5949 Lisp_Object result = Qnil, rest, target;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5950 #if TARGET_API_MAC_CARBON
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5951 OSStatus err;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5952 UInt32 count, i, type;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5953 ScrapFlavorInfo *flavor_info = NULL;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5954 Lisp_Object strings = Qnil;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5955
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5956 err = GetScrapFlavorCount (sel, &count);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5957 if (err == noErr)
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5958 flavor_info = xmalloc (sizeof (ScrapFlavorInfo) * count);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5959 err = GetScrapFlavorInfoList (sel, &count, flavor_info);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5960 if (err != noErr)
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5961 {
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5962 xfree (flavor_info);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5963 flavor_info = NULL;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5964 }
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5965 if (flavor_info == NULL)
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5966 count = 0;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5967 #endif
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5968 for (rest = Vselection_converter_alist; CONSP (rest); rest = XCDR (rest))
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5969 {
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5970 ScrapFlavorType flavor_type = 0;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5971
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5972 if (CONSP (XCAR (rest))
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5973 && (target = XCAR (XCAR (rest)),
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5974 SYMBOLP (target))
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5975 && (flavor_type = get_flavor_type_from_symbol (target, sel)))
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5976 {
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5977 result = Fcons (target, result);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5978 #if TARGET_API_MAC_CARBON
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5979 for (i = 0; i < count; i++)
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5980 if (flavor_info[i].flavorType == flavor_type)
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5981 {
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5982 flavor_info[i].flavorType = 0;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5983 break;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5984 }
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5985 #endif
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5986 }
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5987 }
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5988 #if TARGET_API_MAC_CARBON
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5989 if (flavor_info)
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5990 {
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5991 for (i = 0; i < count; i++)
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5992 if (flavor_info[i].flavorType)
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5993 {
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5994 type = EndianU32_NtoB (flavor_info[i].flavorType);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5995 strings = Fcons (make_unibyte_string ((char *) &type, 4), strings);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5996 }
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5997 result = nconc2 (result, strings);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5998 xfree (flavor_info);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
5999 }
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
6000 #endif
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
6001
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
6002 return result;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
6003 }
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
6004
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
6005
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
6006 /***********************************************************************
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
6007 Apple event support
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
6008 ***********************************************************************/
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
6009
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
6010 extern pascal OSErr mac_handle_apple_event P_ ((const AppleEvent *,
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
6011 AppleEvent *, SInt32));
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
6012 extern void cleanup_all_suspended_apple_events P_ ((void));
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
6013
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
6014 void
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
6015 init_apple_event_handler ()
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
6016 {
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
6017 OSErr err;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
6018 long result;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
6019
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
6020 /* Make sure we have Apple events before starting. */
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
6021 err = Gestalt (gestaltAppleEventsAttr, &result);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
6022 if (err != noErr)
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
6023 abort ();
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
6024
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
6025 if (!(result & (1 << gestaltAppleEventsPresent)))
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
6026 abort ();
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
6027
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
6028 err = AEInstallEventHandler (typeWildCard, typeWildCard,
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
6029 #if TARGET_API_MAC_CARBON
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
6030 NewAEEventHandlerUPP (mac_handle_apple_event),
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
6031 #else
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
6032 NewAEEventHandlerProc (mac_handle_apple_event),
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
6033 #endif
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
6034 0L, false);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
6035 if (err != noErr)
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
6036 abort ();
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
6037
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
6038 atexit (cleanup_all_suspended_apple_events);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
6039 }
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
6040
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
6041
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
6042 /***********************************************************************
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
6043 Drag and drop support
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
6044 ***********************************************************************/
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
6045
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
6046 #if TARGET_API_MAC_CARBON
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
6047 extern Lisp_Object Vmac_dnd_known_types;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
6048
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
6049 static pascal OSErr mac_do_track_drag P_ ((DragTrackingMessage, WindowRef,
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
6050 void *, DragRef));
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
6051 static pascal OSErr mac_do_receive_drag P_ ((WindowRef, void *, DragRef));
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
6052 static DragTrackingHandlerUPP mac_do_track_dragUPP = NULL;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
6053 static DragReceiveHandlerUPP mac_do_receive_dragUPP = NULL;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
6054
80517
086b32514483 (Vmac_ts_script_language_on_focus)
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents: 80464
diff changeset
6055 static OSErr
086b32514483 (Vmac_ts_script_language_on_focus)
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents: 80464
diff changeset
6056 create_apple_event_from_drag_ref (drag, num_types, types, result)
086b32514483 (Vmac_ts_script_language_on_focus)
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents: 80464
diff changeset
6057 DragRef drag;
086b32514483 (Vmac_ts_script_language_on_focus)
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents: 80464
diff changeset
6058 UInt32 num_types;
086b32514483 (Vmac_ts_script_language_on_focus)
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents: 80464
diff changeset
6059 const FlavorType *types;
086b32514483 (Vmac_ts_script_language_on_focus)
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents: 80464
diff changeset
6060 AppleEvent *result;
086b32514483 (Vmac_ts_script_language_on_focus)
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents: 80464
diff changeset
6061 {
086b32514483 (Vmac_ts_script_language_on_focus)
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents: 80464
diff changeset
6062 OSErr err;
086b32514483 (Vmac_ts_script_language_on_focus)
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents: 80464
diff changeset
6063 UInt16 num_items;
086b32514483 (Vmac_ts_script_language_on_focus)
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents: 80464
diff changeset
6064 AppleEvent items;
086b32514483 (Vmac_ts_script_language_on_focus)
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents: 80464
diff changeset
6065 long index;
086b32514483 (Vmac_ts_script_language_on_focus)
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents: 80464
diff changeset
6066 char *buf = NULL;
086b32514483 (Vmac_ts_script_language_on_focus)
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents: 80464
diff changeset
6067
086b32514483 (Vmac_ts_script_language_on_focus)
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents: 80464
diff changeset
6068 err = CountDragItems (drag, &num_items);
086b32514483 (Vmac_ts_script_language_on_focus)
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents: 80464
diff changeset
6069 if (err != noErr)
086b32514483 (Vmac_ts_script_language_on_focus)
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents: 80464
diff changeset
6070 return err;
086b32514483 (Vmac_ts_script_language_on_focus)
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents: 80464
diff changeset
6071 err = AECreateList (NULL, 0, false, &items);
086b32514483 (Vmac_ts_script_language_on_focus)
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents: 80464
diff changeset
6072 if (err != noErr)
086b32514483 (Vmac_ts_script_language_on_focus)
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents: 80464
diff changeset
6073 return err;
086b32514483 (Vmac_ts_script_language_on_focus)
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents: 80464
diff changeset
6074
086b32514483 (Vmac_ts_script_language_on_focus)
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents: 80464
diff changeset
6075 for (index = 1; index <= num_items; index++)
086b32514483 (Vmac_ts_script_language_on_focus)
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents: 80464
diff changeset
6076 {
086b32514483 (Vmac_ts_script_language_on_focus)
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents: 80464
diff changeset
6077 ItemReference item;
086b32514483 (Vmac_ts_script_language_on_focus)
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents: 80464
diff changeset
6078 DescType desc_type = typeNull;
086b32514483 (Vmac_ts_script_language_on_focus)
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents: 80464
diff changeset
6079 Size size;
086b32514483 (Vmac_ts_script_language_on_focus)
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents: 80464
diff changeset
6080
086b32514483 (Vmac_ts_script_language_on_focus)
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents: 80464
diff changeset
6081 err = GetDragItemReferenceNumber (drag, index, &item);
086b32514483 (Vmac_ts_script_language_on_focus)
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents: 80464
diff changeset
6082 if (err == noErr)
086b32514483 (Vmac_ts_script_language_on_focus)
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents: 80464
diff changeset
6083 {
086b32514483 (Vmac_ts_script_language_on_focus)
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents: 80464
diff changeset
6084 int i;
086b32514483 (Vmac_ts_script_language_on_focus)
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents: 80464
diff changeset
6085
086b32514483 (Vmac_ts_script_language_on_focus)
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents: 80464
diff changeset
6086 for (i = 0; i < num_types; i++)
086b32514483 (Vmac_ts_script_language_on_focus)
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents: 80464
diff changeset
6087 {
086b32514483 (Vmac_ts_script_language_on_focus)
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents: 80464
diff changeset
6088 err = GetFlavorDataSize (drag, item, types[i], &size);
086b32514483 (Vmac_ts_script_language_on_focus)
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents: 80464
diff changeset
6089 if (err == noErr)
086b32514483 (Vmac_ts_script_language_on_focus)
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents: 80464
diff changeset
6090 {
086b32514483 (Vmac_ts_script_language_on_focus)
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents: 80464
diff changeset
6091 buf = xrealloc (buf, size);
086b32514483 (Vmac_ts_script_language_on_focus)
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents: 80464
diff changeset
6092 err = GetFlavorData (drag, item, types[i], buf, &size, 0);
086b32514483 (Vmac_ts_script_language_on_focus)
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents: 80464
diff changeset
6093 }
086b32514483 (Vmac_ts_script_language_on_focus)
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents: 80464
diff changeset
6094 if (err == noErr)
086b32514483 (Vmac_ts_script_language_on_focus)
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents: 80464
diff changeset
6095 {
086b32514483 (Vmac_ts_script_language_on_focus)
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents: 80464
diff changeset
6096 desc_type = types[i];
086b32514483 (Vmac_ts_script_language_on_focus)
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents: 80464
diff changeset
6097 break;
086b32514483 (Vmac_ts_script_language_on_focus)
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents: 80464
diff changeset
6098 }
086b32514483 (Vmac_ts_script_language_on_focus)
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents: 80464
diff changeset
6099 }
086b32514483 (Vmac_ts_script_language_on_focus)
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents: 80464
diff changeset
6100 }
086b32514483 (Vmac_ts_script_language_on_focus)
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents: 80464
diff changeset
6101 err = AEPutPtr (&items, index, desc_type,
086b32514483 (Vmac_ts_script_language_on_focus)
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents: 80464
diff changeset
6102 desc_type != typeNull ? buf : NULL,
086b32514483 (Vmac_ts_script_language_on_focus)
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents: 80464
diff changeset
6103 desc_type != typeNull ? size : 0);
086b32514483 (Vmac_ts_script_language_on_focus)
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents: 80464
diff changeset
6104 if (err != noErr)
086b32514483 (Vmac_ts_script_language_on_focus)
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents: 80464
diff changeset
6105 break;
086b32514483 (Vmac_ts_script_language_on_focus)
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents: 80464
diff changeset
6106 }
086b32514483 (Vmac_ts_script_language_on_focus)
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents: 80464
diff changeset
6107 if (buf)
086b32514483 (Vmac_ts_script_language_on_focus)
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents: 80464
diff changeset
6108 xfree (buf);
086b32514483 (Vmac_ts_script_language_on_focus)
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents: 80464
diff changeset
6109
086b32514483 (Vmac_ts_script_language_on_focus)
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents: 80464
diff changeset
6110 if (err == noErr)
086b32514483 (Vmac_ts_script_language_on_focus)
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents: 80464
diff changeset
6111 {
086b32514483 (Vmac_ts_script_language_on_focus)
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents: 80464
diff changeset
6112 err = create_apple_event (0, 0, result); /* Dummy class and ID. */
086b32514483 (Vmac_ts_script_language_on_focus)
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents: 80464
diff changeset
6113 if (err == noErr)
086b32514483 (Vmac_ts_script_language_on_focus)
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents: 80464
diff changeset
6114 err = AEPutParamDesc (result, keyDirectObject, &items);
086b32514483 (Vmac_ts_script_language_on_focus)
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents: 80464
diff changeset
6115 if (err != noErr)
086b32514483 (Vmac_ts_script_language_on_focus)
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents: 80464
diff changeset
6116 AEDisposeDesc (result);
086b32514483 (Vmac_ts_script_language_on_focus)
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents: 80464
diff changeset
6117 }
086b32514483 (Vmac_ts_script_language_on_focus)
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents: 80464
diff changeset
6118
086b32514483 (Vmac_ts_script_language_on_focus)
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents: 80464
diff changeset
6119 AEDisposeDesc (&items);
086b32514483 (Vmac_ts_script_language_on_focus)
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents: 80464
diff changeset
6120
086b32514483 (Vmac_ts_script_language_on_focus)
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents: 80464
diff changeset
6121 return err;
086b32514483 (Vmac_ts_script_language_on_focus)
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents: 80464
diff changeset
6122 }
086b32514483 (Vmac_ts_script_language_on_focus)
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents: 80464
diff changeset
6123
80446
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
6124 static void
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
6125 mac_store_drag_event (window, mouse_pos, modifiers, desc)
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
6126 WindowRef window;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
6127 Point mouse_pos;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
6128 SInt16 modifiers;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
6129 const AEDesc *desc;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
6130 {
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
6131 struct input_event buf;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
6132
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
6133 EVENT_INIT (buf);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
6134
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
6135 buf.kind = DRAG_N_DROP_EVENT;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
6136 buf.modifiers = mac_to_emacs_modifiers (modifiers, 0);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
6137 buf.timestamp = TickCount () * (1000 / 60);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
6138 XSETINT (buf.x, mouse_pos.h);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
6139 XSETINT (buf.y, mouse_pos.v);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
6140 XSETFRAME (buf.frame_or_window, mac_window_to_frame (window));
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
6141 buf.arg = mac_aedesc_to_lisp (desc);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
6142 kbd_buffer_store_event (&buf);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
6143 }
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
6144
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
6145 static pascal OSErr
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
6146 mac_do_track_drag (message, window, refcon, drag)
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
6147 DragTrackingMessage message;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
6148 WindowRef window;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
6149 void *refcon;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
6150 DragRef drag;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
6151 {
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
6152 OSErr err = noErr;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
6153 static int can_accept;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
6154 UInt16 num_items, index;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
6155
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
6156 if (GetFrontWindowOfClass (kMovableModalWindowClass, false))
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
6157 return dragNotAcceptedErr;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
6158
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
6159 switch (message)
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
6160 {
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
6161 case kDragTrackingEnterHandler:
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
6162 err = CountDragItems (drag, &num_items);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
6163 if (err != noErr)
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
6164 break;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
6165 can_accept = 0;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
6166 for (index = 1; index <= num_items; index++)
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
6167 {
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
6168 ItemReference item;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
6169 FlavorFlags flags;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
6170 Lisp_Object rest;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
6171
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
6172 err = GetDragItemReferenceNumber (drag, index, &item);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
6173 if (err != noErr)
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
6174 continue;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
6175 for (rest = Vmac_dnd_known_types; CONSP (rest); rest = XCDR (rest))
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
6176 {
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
6177 Lisp_Object str;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
6178 FlavorType type;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
6179
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
6180 str = XCAR (rest);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
6181 if (!(STRINGP (str) && SBYTES (str) == 4))
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
6182 continue;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
6183 type = EndianU32_BtoN (*((UInt32 *) SDATA (str)));
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
6184
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
6185 err = GetFlavorFlags (drag, item, type, &flags);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
6186 if (err == noErr)
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
6187 {
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
6188 can_accept = 1;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
6189 break;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
6190 }
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
6191 }
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
6192 }
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
6193 break;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
6194
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
6195 case kDragTrackingEnterWindow:
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
6196 if (can_accept)
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
6197 {
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
6198 RgnHandle hilite_rgn = NewRgn ();
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
6199
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
6200 if (hilite_rgn)
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
6201 {
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
6202 Rect r;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
6203
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
6204 GetWindowPortBounds (window, &r);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
6205 OffsetRect (&r, -r.left, -r.top);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
6206 RectRgn (hilite_rgn, &r);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
6207 ShowDragHilite (drag, hilite_rgn, true);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
6208 DisposeRgn (hilite_rgn);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
6209 }
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
6210 SetThemeCursor (kThemeCopyArrowCursor);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
6211 }
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
6212 break;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
6213
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
6214 case kDragTrackingInWindow:
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
6215 break;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
6216
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
6217 case kDragTrackingLeaveWindow:
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
6218 if (can_accept)
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
6219 {
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
6220 HideDragHilite (drag);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
6221 SetThemeCursor (kThemeArrowCursor);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
6222 }
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
6223 break;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
6224
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
6225 case kDragTrackingLeaveHandler:
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
6226 break;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
6227 }
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
6228
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
6229 if (err != noErr)
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
6230 return dragNotAcceptedErr;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
6231 return noErr;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
6232 }
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
6233
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
6234 static pascal OSErr
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
6235 mac_do_receive_drag (window, refcon, drag)
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
6236 WindowRef window;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
6237 void *refcon;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
6238 DragRef drag;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
6239 {
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
6240 OSErr err;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
6241 int num_types, i;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
6242 Lisp_Object rest, str;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
6243 FlavorType *types;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
6244 AppleEvent apple_event;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
6245 Point mouse_pos;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
6246 SInt16 modifiers;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
6247
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
6248 if (GetFrontWindowOfClass (kMovableModalWindowClass, false))
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
6249 return dragNotAcceptedErr;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
6250
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
6251 num_types = 0;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
6252 for (rest = Vmac_dnd_known_types; CONSP (rest); rest = XCDR (rest))
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
6253 {
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
6254 str = XCAR (rest);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
6255 if (STRINGP (str) && SBYTES (str) == 4)
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
6256 num_types++;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
6257 }
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
6258
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
6259 types = xmalloc (sizeof (FlavorType) * num_types);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
6260 i = 0;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
6261 for (rest = Vmac_dnd_known_types; CONSP (rest); rest = XCDR (rest))
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
6262 {
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
6263 str = XCAR (rest);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
6264 if (STRINGP (str) && SBYTES (str) == 4)
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
6265 types[i++] = EndianU32_BtoN (*((UInt32 *) SDATA (str)));
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
6266 }
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
6267
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
6268 err = create_apple_event_from_drag_ref (drag, num_types, types,
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
6269 &apple_event);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
6270 xfree (types);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
6271
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
6272 if (err == noErr)
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
6273 err = GetDragMouse (drag, &mouse_pos, NULL);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
6274 if (err == noErr)
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
6275 {
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
6276 GlobalToLocal (&mouse_pos);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
6277 err = GetDragModifiers (drag, NULL, NULL, &modifiers);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
6278 }
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
6279 if (err == noErr)
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
6280 {
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
6281 UInt32 key_modifiers = modifiers;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
6282
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
6283 err = AEPutParamPtr (&apple_event, kEventParamKeyModifiers,
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
6284 typeUInt32, &key_modifiers, sizeof (UInt32));
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
6285 }
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
6286
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
6287 if (err == noErr)
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
6288 {
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
6289 mac_store_drag_event (window, mouse_pos, 0, &apple_event);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
6290 AEDisposeDesc (&apple_event);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
6291 mac_wakeup_from_rne ();
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
6292 return noErr;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
6293 }
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
6294 else
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
6295 return dragNotAcceptedErr;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
6296 }
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
6297 #endif /* TARGET_API_MAC_CARBON */
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
6298
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
6299 static OSErr
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
6300 install_drag_handler (window)
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
6301 WindowRef window;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
6302 {
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
6303 OSErr err = noErr;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
6304
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
6305 #if TARGET_API_MAC_CARBON
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
6306 if (mac_do_track_dragUPP == NULL)
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
6307 mac_do_track_dragUPP = NewDragTrackingHandlerUPP (mac_do_track_drag);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
6308 if (mac_do_receive_dragUPP == NULL)
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
6309 mac_do_receive_dragUPP = NewDragReceiveHandlerUPP (mac_do_receive_drag);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
6310
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
6311 err = InstallTrackingHandler (mac_do_track_dragUPP, window, NULL);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
6312 if (err == noErr)
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
6313 err = InstallReceiveHandler (mac_do_receive_dragUPP, window, NULL);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
6314 #endif
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
6315
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
6316 return err;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
6317 }
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
6318
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
6319 static void
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
6320 remove_drag_handler (window)
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
6321 WindowRef window;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
6322 {
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
6323 #if TARGET_API_MAC_CARBON
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
6324 if (mac_do_track_dragUPP)
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
6325 RemoveTrackingHandler (mac_do_track_dragUPP, window);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
6326 if (mac_do_receive_dragUPP)
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
6327 RemoveReceiveHandler (mac_do_receive_dragUPP, window);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
6328 #endif
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
6329 }
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
6330
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
6331 #if TARGET_API_MAC_CARBON
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
6332 /* Return default value for mac-dnd-known-types. */
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
6333
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
6334 Lisp_Object
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
6335 mac_dnd_default_known_types ()
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
6336 {
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
6337 Lisp_Object result = list4 (build_string ("hfs "), build_string ("utxt"),
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
6338 build_string ("TEXT"), build_string ("TIFF"));
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
6339
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
6340 #ifdef MAC_OSX
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
6341 result = Fcons (build_string ("furl"), result);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
6342 #endif
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
6343
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
6344 return result;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
6345 }
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
6346 #endif
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
6347
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
6348
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
6349 /***********************************************************************
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
6350 Services menu support
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
6351 ***********************************************************************/
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
6352
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
6353 #ifdef MAC_OSX
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
6354 extern Lisp_Object Qservice, Qpaste, Qperform;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
6355 extern Lisp_Object Vmac_service_selection;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
6356
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
6357 static OSStatus
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
6358 mac_store_service_event (event)
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
6359 EventRef event;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
6360 {
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
6361 OSStatus err;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
6362 Lisp_Object id_key;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
6363 int num_params;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
6364 const EventParamName *names;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
6365 const EventParamType *types;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
6366 static const EventParamName names_pfm[] =
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
6367 {kEventParamServiceMessageName, kEventParamServiceUserData};
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
6368 static const EventParamType types_pfm[] =
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
6369 {typeCFStringRef, typeCFStringRef};
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
6370
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
6371 switch (GetEventKind (event))
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
6372 {
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
6373 case kEventServicePaste:
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
6374 id_key = Qpaste;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
6375 num_params = 0;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
6376 names = NULL;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
6377 types = NULL;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
6378 break;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
6379
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
6380 case kEventServicePerform:
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
6381 id_key = Qperform;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
6382 num_params = sizeof (names_pfm) / sizeof (names_pfm[0]);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
6383 names = names_pfm;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
6384 types = types_pfm;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
6385 break;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
6386
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
6387 default:
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
6388 abort ();
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
6389 }
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
6390
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
6391 err = mac_store_event_ref_as_apple_event (0, 0, Qservice, id_key,
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
6392 event, num_params,
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
6393 names, types);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
6394
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
6395 return err;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
6396 }
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
6397
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
6398 static OSStatus
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
6399 copy_scrap_flavor_data (from_scrap, to_scrap, flavor_type)
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
6400 ScrapRef from_scrap, to_scrap;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
6401 ScrapFlavorType flavor_type;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
6402 {
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
6403 OSStatus err;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
6404 Size size, size_allocated;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
6405 char *buf = NULL;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
6406
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
6407 err = GetScrapFlavorSize (from_scrap, flavor_type, &size);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
6408 if (err == noErr)
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
6409 buf = xmalloc (size);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
6410 while (buf)
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
6411 {
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
6412 size_allocated = size;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
6413 err = GetScrapFlavorData (from_scrap, flavor_type, &size, buf);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
6414 if (err != noErr)
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
6415 {
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
6416 xfree (buf);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
6417 buf = NULL;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
6418 }
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
6419 else if (size_allocated < size)
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
6420 buf = xrealloc (buf, size);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
6421 else
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
6422 break;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
6423 }
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
6424 if (err == noErr)
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
6425 {
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
6426 if (buf == NULL)
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
6427 err = memFullErr;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
6428 else
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
6429 {
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
6430 err = PutScrapFlavor (to_scrap, flavor_type, kScrapFlavorMaskNone,
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
6431 size, buf);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
6432 xfree (buf);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
6433 }
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
6434 }
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
6435
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
6436 return err;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
6437 }
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
6438
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
6439 static OSStatus
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
6440 mac_handle_service_event (call_ref, event, data)
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
6441 EventHandlerCallRef call_ref;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
6442 EventRef event;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
6443 void *data;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
6444 {
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
6445 OSStatus err = noErr;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
6446 ScrapRef cur_scrap, specific_scrap;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
6447 UInt32 event_kind = GetEventKind (event);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
6448 CFMutableArrayRef copy_types, paste_types;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
6449 CFStringRef type;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
6450 Lisp_Object rest;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
6451 ScrapFlavorType flavor_type;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
6452
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
6453 /* Check if Vmac_service_selection is a valid selection that has a
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
6454 corresponding scrap. */
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
6455 if (!SYMBOLP (Vmac_service_selection))
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
6456 err = eventNotHandledErr;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
6457 else
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
6458 err = mac_get_selection_from_symbol (Vmac_service_selection, 0, &cur_scrap);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
6459 if (!(err == noErr && cur_scrap))
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
6460 return eventNotHandledErr;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
6461
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
6462 switch (event_kind)
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
6463 {
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
6464 case kEventServiceGetTypes:
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
6465 /* Set paste types. */
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
6466 err = GetEventParameter (event, kEventParamServicePasteTypes,
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
6467 typeCFMutableArrayRef, NULL,
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
6468 sizeof (CFMutableArrayRef), NULL,
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
6469 &paste_types);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
6470 if (err != noErr)
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
6471 break;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
6472
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
6473 for (rest = Vselection_converter_alist; CONSP (rest);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
6474 rest = XCDR (rest))
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
6475 if (CONSP (XCAR (rest)) && SYMBOLP (XCAR (XCAR (rest)))
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
6476 && (flavor_type =
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
6477 get_flavor_type_from_symbol (XCAR (XCAR (rest)), 0)))
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
6478 {
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
6479 type = CreateTypeStringWithOSType (flavor_type);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
6480 if (type)
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
6481 {
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
6482 CFArrayAppendValue (paste_types, type);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
6483 CFRelease (type);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
6484 }
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
6485 }
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
6486
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
6487 /* Set copy types. */
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
6488 err = GetEventParameter (event, kEventParamServiceCopyTypes,
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
6489 typeCFMutableArrayRef, NULL,
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
6490 sizeof (CFMutableArrayRef), NULL,
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
6491 &copy_types);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
6492 if (err != noErr)
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
6493 break;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
6494
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
6495 if (NILP (Fx_selection_owner_p (Vmac_service_selection)))
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
6496 break;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
6497 else
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
6498 goto copy_all_flavors;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
6499
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
6500 case kEventServiceCopy:
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
6501 err = GetEventParameter (event, kEventParamScrapRef,
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
6502 typeScrapRef, NULL,
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
6503 sizeof (ScrapRef), NULL, &specific_scrap);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
6504 if (err != noErr
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
6505 || NILP (Fx_selection_owner_p (Vmac_service_selection)))
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
6506 {
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
6507 err = eventNotHandledErr;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
6508 break;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
6509 }
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
6510
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
6511 copy_all_flavors:
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
6512 {
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
6513 UInt32 count, i;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
6514 ScrapFlavorInfo *flavor_info = NULL;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
6515 ScrapFlavorFlags flags;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
6516
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
6517 err = GetScrapFlavorCount (cur_scrap, &count);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
6518 if (err == noErr)
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
6519 flavor_info = xmalloc (sizeof (ScrapFlavorInfo) * count);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
6520 err = GetScrapFlavorInfoList (cur_scrap, &count, flavor_info);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
6521 if (err != noErr)
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
6522 {
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
6523 xfree (flavor_info);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
6524 flavor_info = NULL;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
6525 }
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
6526 if (flavor_info == NULL)
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
6527 break;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
6528
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
6529 for (i = 0; i < count; i++)
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
6530 {
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
6531 flavor_type = flavor_info[i].flavorType;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
6532 err = GetScrapFlavorFlags (cur_scrap, flavor_type, &flags);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
6533 if (err == noErr && !(flags & kScrapFlavorMaskSenderOnly))
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
6534 {
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
6535 if (event_kind == kEventServiceCopy)
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
6536 err = copy_scrap_flavor_data (cur_scrap, specific_scrap,
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
6537 flavor_type);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
6538 else /* event_kind == kEventServiceGetTypes */
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
6539 {
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
6540 type = CreateTypeStringWithOSType (flavor_type);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
6541 if (type)
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
6542 {
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
6543 CFArrayAppendValue (copy_types, type);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
6544 CFRelease (type);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
6545 }
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
6546 }
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
6547 }
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
6548 }
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
6549 xfree (flavor_info);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
6550 }
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
6551 break;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
6552
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
6553 case kEventServicePaste:
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
6554 case kEventServicePerform:
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
6555 {
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
6556 int data_exists_p = 0;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
6557
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
6558 err = GetEventParameter (event, kEventParamScrapRef, typeScrapRef,
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
6559 NULL, sizeof (ScrapRef), NULL,
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
6560 &specific_scrap);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
6561 if (err == noErr)
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
6562 err = mac_clear_selection (&cur_scrap);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
6563 if (err == noErr)
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
6564 for (rest = Vselection_converter_alist; CONSP (rest);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
6565 rest = XCDR (rest))
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
6566 {
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
6567 if (! (CONSP (XCAR (rest)) && SYMBOLP (XCAR (XCAR (rest)))))
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
6568 continue;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
6569 flavor_type = get_flavor_type_from_symbol (XCAR (XCAR (rest)),
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
6570 specific_scrap);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
6571 if (flavor_type == 0)
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
6572 continue;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
6573 err = copy_scrap_flavor_data (specific_scrap, cur_scrap,
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
6574 flavor_type);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
6575 if (err == noErr)
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
6576 data_exists_p = 1;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
6577 }
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
6578 if (!data_exists_p)
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
6579 err = eventNotHandledErr;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
6580 else
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
6581 err = mac_store_service_event (event);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
6582 }
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
6583 break;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
6584 }
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
6585
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
6586 if (err != noErr)
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
6587 err = eventNotHandledErr;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
6588 return err;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
6589 }
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
6590
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
6591 static OSStatus
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
6592 install_service_handler ()
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
6593 {
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
6594 static const EventTypeSpec specs[] =
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
6595 {{kEventClassService, kEventServiceGetTypes},
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
6596 {kEventClassService, kEventServiceCopy},
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
6597 {kEventClassService, kEventServicePaste},
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
6598 {kEventClassService, kEventServicePerform}};
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
6599
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
6600 return InstallApplicationEventHandler (NewEventHandlerUPP
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
6601 (mac_handle_service_event),
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
6602 GetEventTypeCount (specs),
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
6603 specs, NULL, NULL);
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
6604 }
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
6605 #endif /* MAC_OSX */
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
6606
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
6607
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
6608 /***********************************************************************
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
6609 Initialization
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
6610 ***********************************************************************/
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
6611
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
6612 void
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
6613 mac_toolbox_initialize ()
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
6614 {
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
6615 any_help_event_p = 0;
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
6616
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
6617 init_menu_bar ();
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
6618
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
6619 #ifdef MAC_OSX
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
6620 init_apple_event_handler ();
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
6621 #endif
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
6622 #if USE_MAC_TSM
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
6623 init_tsm ();
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
6624 #endif
cb749087dcc9 New file.
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
parents:
diff changeset
6625 }
80464
8db0c1448dec Add arch tagline
Miles Bader <miles@gnu.org>
parents: 80446
diff changeset
6626
8db0c1448dec Add arch tagline
Miles Bader <miles@gnu.org>
parents: 80446
diff changeset
6627 /* arch-tag: 71a597a8-6e9f-47b0-8b89-5a5ae3e16516
8db0c1448dec Add arch tagline
Miles Bader <miles@gnu.org>
parents: 80446
diff changeset
6628 (do not change this comment) */