1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
|
/*
* Copyright 1987, 1988 by MIT Student Information Processing Board.
*
* For copyright info, see mit-sipb-copyright.h.
*/
#include <stdio.h>
#include <string.h>
#include "mit-sipb-copyright.h"
#if defined(HAVE_STDARG_H) || defined(_MSDOS) || defined(_WIN32) || defined (_MACINTOSH)
#include <stdarg.h>
#else
#include <varargs.h>
#define VARARGS
#endif
#ifdef _MACINTOSH
#include "icons.h"
#endif
#include "error_table.h"
#include "internal.h"
#ifdef notdef
/*
* Protect us from header version (externally visible) of com_err, so
* we can survive in a <varargs.h> environment. I think.
*/
#define com_err com_err_external
#include "com_err.h"
#undef com_err
#endif
/* We have problems with varargs definitions if we include com_err.h */
/*
* XXX for now, we define error_message by hand. Ultimately, we
* should fix up com_err.h so that it's safe to #include here
* directly.
*/
#if defined(__STDC__) || defined(_MSDOS) || defined(_WIN32)
KRB5_DLLIMP extern char const FAR * KRB5_CALLCONV error_message (long);
#else
extern char * error_message ();
#endif
static void
#if defined(__STDC__) || defined(_MSDOS) || defined(_WIN32)
default_com_err_proc (const char *whoami, long code, const char *fmt, va_list args)
#else
default_com_err_proc (whoami, code, fmt, args)
const char *whoami;
long code;
const char *fmt;
va_list args;
#endif
{
static char errbuf[1024]; /* For those w/o stdio */
*errbuf = '\0';
if (whoami) {
strcat (errbuf, whoami);
strcat (errbuf, ": ");
}
if (code) {
strcat (errbuf, error_message(code));
strcat (errbuf, " ");
}
if (fmt) {
vsprintf (errbuf + strlen (errbuf), fmt, args);
}
#if defined(_MSDOS) || defined(_WIN32)
MessageBox (NULL, errbuf, "Kerboros", MB_ICONEXCLAMATION);
#else
#ifdef _MACINTOSH
{
WindowPtr errWindow;
ControlHandle errOkButton;
Rect errOkButtonRect = { 120, 220, 140, 280 };
Rect errRect = { 0, 0, 150, 300 };
GDHandle mainDevice = GetMainDevice();
Rect mainRect = (**mainDevice).gdRect;
Rect tmpRect;
Rect errTextRect = { 10, 70, 110, 290 };
Rect errIconRect = { 10, 10, 10 + 32, 10 + 32 };
EventRecord theEvent;
Point localPt;
Boolean done;
/* Find Centered rect for window */
tmpRect.top = (mainRect.bottom + mainRect.top)/2 - (errRect.bottom + errRect.top)/2;
tmpRect.bottom = tmpRect.top + (errRect.bottom - errRect.top);
tmpRect.left = (mainRect.right + mainRect.left)/2 - (errRect.right + errRect.left)/2;
tmpRect.right = tmpRect.left + (errRect.right - errRect.left);
/* Create the error window - as a dialog window */
errWindow = NewWindow(NULL, &tmpRect, "\p", TRUE, dBoxProc, (WindowPtr) -1, FALSE, 0L);
SetPort(errWindow);
TextFont(systemFont);
TextSize(12);
errOkButton = NewControl(errWindow,&errOkButtonRect,"\pOk",TRUE,0,0,1,pushButProc,0L);
DrawControls(errWindow);
InsetRect(&errOkButtonRect, -4, -4);
PenSize(3,3);
FrameRoundRect(&errOkButtonRect, 15,15);
PenSize(1,1);
InsetRect(&errOkButtonRect, 4, 4);
/* Draw the error text */
TextBox(errbuf, strlen(errbuf), &errTextRect, teForceLeft);
/* Draw the Stop icon */
PlotIcon(&errIconRect, GetResource('ICON', 0));
/* mini event loop here */
done = FALSE;
while(!done)
{
GetNextEvent(mDownMask | mUpMask | keyDownMask, &theEvent);
if (theEvent.what == mouseDown)
{
localPt = theEvent.where;
GlobalToLocal(&localPt);
if (TestControl(errOkButton, localPt) && TrackControl(errOkButton, localPt, NULL))
{
done = TRUE;
}
} else if (theEvent.what == keyDown &&
(theEvent.message & 0xff) == 0x0d || /* CR */
(theEvent.message & 0xff) == 0x03 || /* Enter */
(theEvent.message & 0xff) == 0x1b /* Escape */
)
{
long t;
HiliteControl(errOkButton, 1); // Hilite the button for a bit
Delay(5, &t);
HiliteControl(errOkButton, 0); // Dehilite the button
done = TRUE;
}
}
/* Dispose of the Window, disposes of controls */
DisposeWindow(errWindow);
}
#else
fputs (errbuf, stderr);
/* should do this only on a tty in raw mode */
putc('\r', stderr);
putc('\n', stderr);
fflush(stderr);
#endif
#endif
}
#if defined(__STDC__) || defined(_MSDOS) || defined(_WIN32)
typedef void (*errf) (const char *, long, const char *, va_list);
#else
typedef void (*errf) ();
#endif
errf com_err_hook = default_com_err_proc;
void com_err_va (whoami, code, fmt, args)
const char *whoami;
long code;
const char *fmt;
va_list args;
{
(*com_err_hook) (whoami, code, fmt, args);
}
#ifndef VARARGS
KRB5_DLLIMP void KRB5_CALLCONV_C com_err (const char *whoami,
long code,
const char *fmt, ...)
{
#else
KRB5_DLLIMP void KRB5_CALLCONV_C com_err (va_alist)
va_dcl
{
const char *whoami, *fmt;
long code;
#endif
va_list pvar;
if (!com_err_hook)
com_err_hook = default_com_err_proc;
#ifdef VARARGS
va_start (pvar);
whoami = va_arg (pvar, const char *);
code = va_arg (pvar, long);
fmt = va_arg (pvar, const char *);
#else
va_start(pvar, fmt);
#endif
com_err_va (whoami, code, fmt, pvar);
va_end(pvar);
}
errf set_com_err_hook (new_proc)
errf new_proc;
{
errf x = com_err_hook;
if (new_proc)
com_err_hook = new_proc;
else
com_err_hook = default_com_err_proc;
return x;
}
errf reset_com_err_hook () {
errf x = com_err_hook;
com_err_hook = default_com_err_proc;
return x;
}
|