-/* $Id: mac.c,v 1.1.2.19 1999/03/28 02:06:10 ben Exp $ */
+/* $Id: mac.c,v 1.1.2.25 1999/08/02 08:04:31 ben Exp $ */
/*
* Copyright (c) 1999 Ben Harris
* All rights reserved.
#include <Menus.h>
#include <TextEdit.h>
#include <Appearance.h>
+#include <CodeFragments.h>
#include <Dialogs.h>
#include <Devices.h>
#include <DiskInit.h>
#include <Gestalt.h>
+#include <Resources.h>
#include <ToolUtils.h>
+#include <assert.h>
#include <limits.h>
#include <stdarg.h>
#include <stdlib.h> /* putty.h needs size_t */
static void mac_event(EventRecord *);
static void mac_contentclick(WindowPtr, EventRecord *);
static void mac_growwindow(WindowPtr, EventRecord *);
-static void mac_activatewindow(WindowPtr, Boolean);
+static void mac_activatewindow(WindowPtr, EventRecord *);
+static void mac_activateabout(WindowPtr, EventRecord *);
static void mac_updatewindow(WindowPtr);
static void mac_keypress(EventRecord *);
static int mac_windowtype(WindowPtr);
static void mac_menucommand(long);
+static void mac_openabout(void);
static void mac_adjustcursor(RgnHandle);
static void mac_adjustmenus(void);
static void mac_closewindow(WindowPtr);
#pragma noreturn (mac_shutdown)
struct mac_windows {
- WindowPtr terminal; /* XXX: Temporary */
WindowPtr about;
WindowPtr licence;
};
mac_gestalts.apprvers = 0x0100;
else
mac_gestalts.apprvers = 0;
+ /* Paranoia: Did we manage to pull in AppearanceLib? */
+ if (&RegisterAppearanceClient == kUnresolvedCFragSymbolAddress)
+ mac_gestalts.apprvers = 0;
/* Mac OS 8.5 Control Manager (proportional scrollbars)? */
if (Gestalt(gestaltControlMgrAttr, &mac_gestalts.cntlattr) != noErr)
mac_gestalts.cntlattr = 0;
mac_adjustmenus();
DrawMenuBar();
InitCursor();
- windows.terminal = NULL;
windows.about = NULL;
windows.licence = NULL;
+
+ /* Initialise networking */
+#ifdef WITH_OPENTRANSPORT
+ if ((*opentpt_stack.init)() == 0)
+ net_stack = &opentpt_stack;
+ else
+#endif
+#ifdef WITH_MACTCP
+ if ((*mactcp_stack.init)() == 0)
+ net_stack = &mactcp_stack;
+ else
+#endif
+ fatalbox("No useful TCP/IP stack found");
+
+
+
}
static void mac_eventloop(void) {
mac_adjustcursor(cursrgn);
if (gotevent)
mac_event(&event);
+ net_poll();
}
DisposeRgn(cursrgn);
}
mac_keypress(event);
break;
case activateEvt:
- mac_activatewindow((WindowPtr)event->message,
- (event->modifiers & activeFlag) != 0);
+ mac_activatewindow((WindowPtr)event->message, event);
break;
case updateEvt:
mac_updatewindow((WindowPtr)event->message);
}
}
-static void mac_activatewindow(WindowPtr window, Boolean active) {
+static void mac_activatewindow(WindowPtr window, EventRecord *event) {
+ int active;
+ active = (event->modifiers & activeFlag) != 0;
mac_adjustmenus();
switch (mac_windowtype(window)) {
case wTerminal:
mac_activateterm(window, active);
break;
+ case wAbout:
+ mac_activateabout(window, event);
+ break;
}
}
+static void mac_activateabout(WindowPtr window, EventRecord *event) {
+ DialogItemType itemtype;
+ Handle itemhandle;
+ short item;
+ Rect itemrect;
+ int active;
+
+ active = (event->modifiers & activeFlag) != 0;
+ GetDialogItem(window, wiAboutLicence, &itemtype, &itemhandle, &itemrect);
+ HiliteControl((ControlHandle)itemhandle, active ? 0 : 255);
+ DialogSelect(event, &window, &item);
+}
+
static void mac_updatewindow(WindowPtr window) {
switch (mac_windowtype(window)) {
* Check for a command-key combination, but ignore it if it counts
* as a meta-key combination and we're in a terminal window.
*/
- if (event->what == keyDown && (event->modifiers & cmdKey) &&
+ if (event->what == keyDown && (event->modifiers & cmdKey) /*&&
!((event->modifiers & cfg.meta_modifiers) == cfg.meta_modifiers &&
- mac_windowtype(window) == wTerminal)) {
+ mac_windowtype(window) == wTerminal)*/) {
mac_adjustmenus();
mac_menucommand(MenuKey(event->message & charCodeMask));
} else {
case mApple:
switch (item) {
case iAbout:
- if (windows.about)
- SelectWindow(windows.about);
- else
- windows.about = GetNewDialog(wAbout, NULL, (WindowPtr)-1);
+ mac_openabout();
goto done;
default:
GetMenuItemText(GetMenuHandle(mApple), item, da);
HiliteMenu(0);
}
+static void mac_openabout(void) {
+ DialogItemType itemtype;
+ Handle item;
+ VersRecHndl vers;
+ Rect box;
+ StringPtr longvers;
+
+ if (windows.about)
+ SelectWindow(windows.about);
+ else {
+ windows.about = GetNewDialog(wAbout, NULL, (WindowPtr)-1);
+ /* XXX check we're using the right resource file? */
+ vers = (VersRecHndl)GetResource('vers', 1);
+ assert(vers != NULL && *vers != NULL);
+ longvers = (*vers)->shortVersion + (*vers)->shortVersion[0] + 1;
+ GetDialogItem(windows.about, wiAboutVersion, &itemtype, &item, &box);
+ assert(itemtype & kStaticTextDialogItem);
+ SetDialogItemText(item, longvers);
+ ShowWindow(windows.about);
+ }
+}
+
static void mac_closewindow(WindowPtr window) {
switch (mac_windowtype(window)) {
static void mac_shutdown(void) {
+ net_shutdown();
exit(0);
}