-/* $Id: macdlg.c,v 1.7 2003/01/25 14:04:47 ben Exp $ */
+/* $Id: macdlg.c,v 1.12 2003/02/15 16:22:15 ben Exp $ */
/*
* Copyright (c) 2002 Ben Harris
* All rights reserved.
#include <AEDataModel.h>
#include <AppleEvents.h>
#include <Dialogs.h>
+#include <Navigation.h>
#include <Resources.h>
#include <StandardFile.h>
#include <Windows.h>
#include "macresid.h"
#include "storage.h"
+static void mac_clickdlg(WindowPtr, EventRecord *);
+static void mac_activatedlg(WindowPtr, EventRecord *);
+static void mac_updatedlg(WindowPtr);
+static void mac_adjustdlgmenus(WindowPtr);
+
void mac_newsession(void)
{
Session *s;
+ WinInfo *wi;
/* This should obviously be initialised by other means */
s = smalloc(sizeof(*s));
memset(s, 0, sizeof(*s));
do_defaults(NULL, &s->cfg);
- s->back = &loop_backend;
s->hasfile = FALSE;
- s->settings_window = GetNewDialog(wSettings, NULL, (WindowPtr)-1);
-
- SetWRefCon(s->settings_window, (long)s);
+ s->settings_window =
+ GetDialogWindow(GetNewDialog(wSettings, NULL, (WindowPtr)-1));
+
+ wi = smalloc(sizeof(*wi));
+ memset(wi, 0, sizeof(*wi));
+ wi->s = s;
+ wi->wtype = wSettings;
+ wi->update = &mac_updatedlg;
+ wi->click = &mac_clickdlg;
+ wi->activate = &mac_activatedlg;
+ wi->adjustmenus = &mac_adjustdlgmenus;
+ SetWRefCon(s->settings_window, (long)wi);
ShowWindow(s->settings_window);
}
+void mac_dupsession(void)
+{
+ Session *s1 = mac_windowsession(FrontWindow());
+ Session *s2;
+
+ s2 = smalloc(sizeof(*s2));
+ memset(s2, 0, sizeof(*s2));
+ s2->cfg = s1->cfg;
+ s2->hasfile = s1->hasfile;
+ s2->savefile = s1->savefile;
+
+ mac_startsession(s2);
+}
+
static OSErr mac_opensessionfrom(FSSpec *fss)
{
FInfo fi;
Session *s;
void *sesshandle;
- int i;
OSErr err;
s = smalloc(sizeof(*s));
load_open_settings(sesshandle, TRUE, &s->cfg);
close_settings_r(sesshandle);
- /*
- * Select protocol. This is farmed out into a table in a
- * separate file to enable an ssh-free variant.
- */
- s->back = NULL;
- for (i = 0; backends[i].backend != NULL; i++)
- if (backends[i].protocol == s->cfg.protocol) {
- s->back = backends[i].backend;
- break;
- }
- if (s->back == NULL) {
- fatalbox("Unsupported protocol number found");
- }
mac_startsession(s);
return noErr;
return err;
}
-void mac_opensession(void) {
- StandardFileReply sfr;
- static const OSType sftypes[] = { 'Sess', 0, 0, 0 };
+static OSErr mac_openlist(AEDesc docs)
+{
+ OSErr err;
+ long ndocs, i;
+ FSSpec fss;
+ AEKeyword keywd;
+ DescType type;
+ Size size;
- StandardGetFile(NULL, 1, sftypes, &sfr);
- if (!sfr.sfGood) return;
+ err = AECountItems(&docs, &ndocs);
+ if (err != noErr) return err;
- mac_opensessionfrom(&sfr.sfFile);
- /* XXX handle error */
+ for (i = 0; i < ndocs; i++) {
+ err = AEGetNthPtr(&docs, i + 1, typeFSS,
+ &keywd, &type, &fss, sizeof(fss), &size);
+ if (err != noErr) return err;;
+ err = mac_opensessionfrom(&fss);
+ if (err != noErr) return err;
+ }
+ return noErr;
+}
+
+void mac_opensession(void)
+{
+
+ if (mac_gestalts.navsvers > 0) {
+ NavReplyRecord navr;
+ NavDialogOptions navopts;
+ NavTypeListHandle navtypes;
+ AEDesc defaultloc = { 'null', NULL };
+ AEDesc *navdefault = NULL;
+ short vol;
+ long dirid;
+ FSSpec fss;
+
+ if (NavGetDefaultDialogOptions(&navopts) != noErr) return;
+ /* XXX should we create sessions dir? */
+ if (get_session_dir(FALSE, &vol, &dirid) == noErr &&
+ FSMakeFSSpec(vol, dirid, NULL, &fss) == noErr &&
+ AECreateDesc(typeFSS, &fss, sizeof(fss), &defaultloc) == noErr)
+ navdefault = &defaultloc;
+ /* Can't meaningfully preview a saved session yet */
+ navopts.dialogOptionFlags &= ~kNavAllowPreviews;
+ navtypes = (NavTypeListHandle)GetResource('open', open_pTTY);
+ if (NavGetFile(navdefault, &navr, &navopts, NULL, NULL, NULL, navtypes,
+ NULL) == noErr && navr.validRecord)
+ mac_openlist(navr.selection);
+ NavDisposeReply(&navr);
+ if (navtypes != NULL)
+ ReleaseResource((Handle)navtypes);
+ }
+#if !TARGET_API_MAC_CARBON /* XXX Navigation Services */
+ else {
+ StandardFileReply sfr;
+ static const OSType sftypes[] = { 'Sess', 0, 0, 0 };
+
+ StandardGetFile(NULL, 1, sftypes, &sfr);
+ if (!sfr.sfGood) return;
+
+ mac_opensessionfrom(&sfr.sfFile);
+ /* XXX handle error */
+ }
+#endif
}
void mac_savesession(void)
{
- Session *s = (Session *)GetWRefCon(FrontWindow());
+ Session *s = mac_windowsession(FrontWindow());
void *sesshandle;
assert(s->hasfile);
void mac_savesessionas(void)
{
- Session *s = (Session *)GetWRefCon(FrontWindow());
+#if !TARGET_API_MAC_CARBON /* XXX Navigation Services */
+ Session *s = mac_windowsession(FrontWindow());
StandardFileReply sfr;
void *sesshandle;
close_settings_w(sesshandle);
s->hasfile = TRUE;
s->savefile = sfr.sfFile;
+#endif
}
pascal OSErr mac_aevt_oapp(const AppleEvent *req, AppleEvent *reply,
long refcon)
{
DescType type;
- AEKeyword keywd;
Size size;
AEDescList docs = { typeNull, NULL };
OSErr err;
- long ndocs, i;
- FSSpec fss;
err = AEGetParamDesc(req, keyDirectObject, typeAEList, &docs);
if (err != noErr) goto out;
goto out;
}
- err = AECountItems(&docs, &ndocs);
- if (err != noErr) goto out;
-
- for (i = 0; i < ndocs; i++) {
- err = AEGetNthPtr(&docs, i + 1, typeFSS,
- &keywd, &type, &fss, sizeof(fss), &size);
- if (err != noErr) goto out;
- err = mac_opensessionfrom(&fss);
- if (err != noErr) goto out;
- }
+ err = mac_openlist(docs);
out:
AEDisposeDesc(&docs);
return errAEEventNotHandled;
}
-void mac_activatedlg(WindowPtr window, EventRecord *event)
+static void mac_activatedlg(WindowPtr window, EventRecord *event)
{
DialogItemType itemtype;
Handle itemhandle;
short item;
Rect itemrect;
int active;
+ DialogRef dialog = GetDialogFromWindow(window);
active = (event->modifiers & activeFlag) != 0;
- GetDialogItem(window, wiSettingsOpen, &itemtype, &itemhandle, &itemrect);
+ GetDialogItem(dialog, wiSettingsOpen, &itemtype, &itemhandle, &itemrect);
HiliteControl((ControlHandle)itemhandle, active ? 0 : 255);
- DialogSelect(event, &window, &item);
+ DialogSelect(event, &dialog, &item);
}
-void mac_clickdlg(WindowPtr window, EventRecord *event)
+static void mac_clickdlg(WindowPtr window, EventRecord *event)
{
short item;
- Session *s = (Session *)GetWRefCon(window);
+ Session *s = mac_windowsession(window);
+ DialogRef dialog = GetDialogFromWindow(window);
- if (DialogSelect(event, &window, &item))
+ if (DialogSelect(event, &dialog, &item))
switch (item) {
case wiSettingsOpen:
- CloseWindow(window);
+ HideWindow(window);
mac_startsession(s);
break;
}
}
+static void mac_updatedlg(WindowPtr window)
+{
+#if TARGET_API_MAC_CARBON
+ RgnHandle rgn;
+#endif
+
+ BeginUpdate(window);
+#if TARGET_API_MAC_CARBON
+ rgn = NewRgn();
+ GetPortVisibleRegion(GetWindowPort(window), rgn);
+ UpdateDialog(GetDialogFromWindow(window), rgn);
+ DisposeRgn(rgn);
+#else
+ UpdateDialog(window, window->visRgn);
+#endif
+ EndUpdate(window);
+}
+
+#if TARGET_API_MAC_CARBON
+#define EnableItem EnableMenuItem
+#define DisableItem DisableMenuItem
+#endif
+static void mac_adjustdlgmenus(WindowPtr window)
+{
+ MenuHandle menu;
+
+ menu = GetMenuHandle(mFile);
+ DisableItem(menu, iSave); /* XXX enable if modified */
+ EnableItem(menu, iSaveAs);
+ EnableItem(menu, iDuplicate);
+
+ menu = GetMenuHandle(mEdit);
+ DisableItem(menu, 0);
+}
+
/*
* Local Variables:
* c-file-style: "simon"