]> git.saurik.com Git - wxWidgets.git/blame - wxPython/wxSWIG/swig_lib/tcl/mactkinit.c
handle accel keys for owner drawn menu items (based on the patch 657105)
[wxWidgets.git] / wxPython / wxSWIG / swig_lib / tcl / mactkinit.c
CommitLineData
c90f71dd
RD
1/* This is a support file needed to build a new version of Wish
2 Normally, this capability is found in TkAppInit.c, but this creates
3 tons of namespace problems for many applications. */
4
5#include <Gestalt.h>
6#include <ToolUtils.h>
7#include <Fonts.h>
8#include <Dialogs.h>
9#include <SegLoad.h>
10#include <Traps.h>
11
12#include "tk.h"
13#include "tkInt.h"
14#include "tkMacInt.h"
15
16typedef int (*TclMacConvertEventPtr) _ANSI_ARGS_((EventRecord *eventPtr));
17Tcl_Interp *gStdoutInterp = NULL;
18
19void TclMacSetEventProc _ANSI_ARGS_((TclMacConvertEventPtr procPtr));
20int TkMacConvertEvent _ANSI_ARGS_((EventRecord *eventPtr));
21
22/*
23 * Prototypes for functions the ANSI library needs to link against.
24 */
25short InstallConsole _ANSI_ARGS_((short fd));
26void RemoveConsole _ANSI_ARGS_((void));
27long WriteCharsToConsole _ANSI_ARGS_((char *buff, long n));
28long ReadCharsFromConsole _ANSI_ARGS_((char *buff, long n));
29extern char * __ttyname _ANSI_ARGS_((long fildes));
30short SIOUXHandleOneEvent _ANSI_ARGS_((EventRecord *event));
31
32/*
33 * Forward declarations for procedures defined later in this file:
34 */
35
36/*
37 *----------------------------------------------------------------------
38 *
39 * MacintoshInit --
40 *
41 * This procedure calls Mac specific initilization calls. Most of
42 * these calls must be made as soon as possible in the startup
43 * process.
44 *
45 * Results:
46 * Returns TCL_OK if everything went fine. If it didn't the
47 * application should probably fail.
48 *
49 * Side effects:
50 * Inits the application.
51 *
52 *----------------------------------------------------------------------
53 */
54
55int
56MacintoshInit()
57{
58 int i;
59 long result, mask = 0x0700; /* mask = system 7.x */
60
61 /*
62 * Tk needs us to set the qd pointer it uses. This is needed
63 * so Tk doesn't have to assume the availablity of the qd global
64 * variable. Which in turn allows Tk to be used in code resources.
65 */
66 tcl_macQdPtr = &qd;
67
68 InitGraf(&tcl_macQdPtr->thePort);
69 InitFonts();
70 InitWindows();
71 InitMenus();
72 InitDialogs((long) NULL);
73 InitCursor();
74
75 /*
76 * Make sure we are running on system 7 or higher
77 */
78
79 if ((NGetTrapAddress(_Gestalt, ToolTrap) ==
80 NGetTrapAddress(_Unimplemented, ToolTrap))
81 || (((Gestalt(gestaltSystemVersion, &result) != noErr)
82 || (mask != (result & mask))))) {
83 panic("Tcl/Tk requires System 7 or higher.");
84 }
85
86 /*
87 * Make sure we have color quick draw
88 * (this means we can't run on 68000 macs)
89 */
90
91 if (((Gestalt(gestaltQuickdrawVersion, &result) != noErr)
92 || (result < gestalt32BitQD13))) {
93 panic("Tk requires Color QuickDraw.");
94 }
95
96
97 FlushEvents(everyEvent, 0);
98 SetEventMask(everyEvent);
99
100 /*
101 * Set up stack & heap sizes
102 */
103 /* TODO: stack size
104 size = StackSpace();
105 SetAppLimit(GetAppLimit() - 8192);
106 */
107 MaxApplZone();
108 for (i = 0; i < 4; i++) {
109 (void) MoreMasters();
110 }
111
112 TclMacSetEventProc(TkMacConvertEvent);
113 TkConsoleCreate();
114
115 return TCL_OK;
116}
117
118/*
119 *----------------------------------------------------------------------
120 *
121 * SetupMainInterp --
122 *
123 * This procedure calls initalization routines require a Tcl
124 * interp as an argument. This call effectively makes the passed
125 * iterpreter the "main" interpreter for the application.
126 *
127 * Results:
128 * Returns TCL_OK if everything went fine. If it didn't the
129 * application should probably fail.
130 *
131 * Side effects:
132 * More initilization.
133 *
134 *----------------------------------------------------------------------
135 */
136
137int
138SetupMainInterp(
139 Tcl_Interp *interp)
140{
141 /*
142 * Initialize the console only if we are running as an interactive
143 * application.
144 */
145
146 TkMacInitAppleEvents(interp);
147 TkMacInitMenus(interp);
148
149 if (strcmp(Tcl_GetVar(interp, "tcl_interactive", TCL_GLOBAL_ONLY), "1")
150 == 0) {
151 if (TkConsoleInit(interp) == TCL_ERROR) {
152 goto error;
153 }
154 }
155
156 /*
157 * Attach the global interpreter to tk's expected global console
158 */
159
160 gStdoutInterp = interp;
161
162 return TCL_OK;
163
164error:
165 panic(interp->result);
166 return TCL_ERROR;
167}
168
169/*
170 *----------------------------------------------------------------------
171 *
172 * InstallConsole, RemoveConsole, etc. --
173 *
174 * The following functions provide the UI for the console package.
175 * Users wishing to replace SIOUX with their own console package
176 * need only provide the four functions below in a library.
177 *
178 * Results:
179 * See SIOUX documentation for details.
180 *
181 * Side effects:
182 * See SIOUX documentation for details.
183 *
184 *----------------------------------------------------------------------
185 */
186
187short
188InstallConsole(short fd)
189{
190#pragma unused (fd)
191
192 return 0;
193}
194
195void
196RemoveConsole(void)
197{
198}
199
200long
201WriteCharsToConsole(char *buffer, long n)
202{
203 TkConsolePrint(gStdoutInterp, TCL_STDOUT, buffer, n);
204 return n;
205}
206
207long
208ReadCharsFromConsole(char *buffer, long n)
209{
210 return 0;
211}
212
213extern char *
214__ttyname(long fildes)
215{
216 static char *__devicename = "null device";
217
218 if (fildes >= 0 && fildes <= 2) {
219 return (__devicename);
220 }
221
222 return (0L);
223}
224
225short
226SIOUXHandleOneEvent(EventRecord *event)
227{
228 return 0;
229}