From 60b6419de57df73fd461d825672db40667c458dc Mon Sep 17 00:00:00 2001 From: Ben Harris Date: Sun, 2 Feb 2003 15:59:00 +0000 Subject: [PATCH] Add support for using Navigation Services to open saved sessions. Support for saving sessions using Navigation Services will come later. [originally from svn r2779] --- mac/mac.c | 8 ++++- mac/mac.h | 1 + mac/mac_res.r | 26 +++++++++++++++- mac/macdlg.c | 80 +++++++++++++++++++++++++++++++++++++------------- mac/macresid.h | 5 +++- mkfiles.pl | 3 ++ 6 files changed, 100 insertions(+), 23 deletions(-) diff --git a/mac/mac.c b/mac/mac.c index 34a1d2b7..0af40dfc 100644 --- a/mac/mac.c +++ b/mac/mac.c @@ -1,4 +1,4 @@ -/* $Id: mac.c,v 1.42 2003/02/01 23:42:30 ben Exp $ */ +/* $Id: mac.c,v 1.43 2003/02/02 15:59:00 ben Exp $ */ /* * Copyright (c) 1999 Ben Harris * All rights reserved. @@ -43,6 +43,7 @@ #include #include #include +#include #include #include #include @@ -175,6 +176,11 @@ static void mac_startup(void) { mac_gestalts.uncvattr = (*ti)->tecUnicodeConverterFeatures; DisposeHandle((Handle)ti); } + /* Navigation Services? */ + if (NavServicesAvailable()) + mac_gestalts.navsvers = NavLibraryVersion(); + else + mac_gestalts.navsvers = 0; sk_init(); diff --git a/mac/mac.h b/mac/mac.h index 50ed142a..1f14a0d1 100644 --- a/mac/mac.h +++ b/mac/mac.h @@ -28,6 +28,7 @@ struct mac_gestalts { long windattr; long encvvers; /* TEC version (from TECGetInfo()) */ long uncvattr; /* Unicode Converter attributes (frem TECGetInfo()) */ + long navsvers; /* Navigation Services version */ }; extern struct mac_gestalts mac_gestalts; diff --git a/mac/mac_res.r b/mac/mac_res.r index 8f1beafa..6105a559 100644 --- a/mac/mac_res.r +++ b/mac/mac_res.r @@ -1,4 +1,4 @@ -/* $Id: mac_res.r,v 1.24 2003/01/27 23:46:03 ben Exp $ */ +/* $Id: mac_res.r,v 1.25 2003/02/02 15:59:00 ben Exp $ */ /* * Copyright (c) 1999, 2002 Ben Harris * All rights reserved. @@ -142,6 +142,30 @@ resource 'BNDL' (129, purgeable) { }; }; +/* Open resource, for the Translation Manager and Navigation Services */ +resource 'open' (open_pTTY) { + 'pTTY', + { 'Sess' } +}; + +/* Kind resources, for Navigation services etc. */ +resource 'kind' (128) { + 'pTTY', + verBritain, + { + 'Sess', "PuTTY saved session", + } +}; + +resource 'kind' (129) { + 'pTTI', + verBritain, + { + 'HKey', "PuTTY host key database", + 'Seed', "PuTTY random number seed", + } +}; + /* Icons, courtesy of DeRez */ /* Application icon */ diff --git a/mac/macdlg.c b/mac/macdlg.c index 56f2d9a8..3da50831 100644 --- a/mac/macdlg.c +++ b/mac/macdlg.c @@ -1,4 +1,4 @@ -/* $Id: macdlg.c,v 1.9 2003/02/01 23:55:00 ben Exp $ */ +/* $Id: macdlg.c,v 1.10 2003/02/02 15:59:00 ben Exp $ */ /* * Copyright (c) 2002 Ben Harris * All rights reserved. @@ -33,6 +33,7 @@ #include #include #include +#include #include #include #include @@ -112,17 +113,68 @@ static OSErr mac_opensessionfrom(FSSpec *fss) return err; } +static OSErr mac_openlist(AEDesc docs) +{ + OSErr err; + long ndocs, i; + FSSpec fss; + AEKeyword keywd; + DescType type; + Size size; + + err = AECountItems(&docs, &ndocs); + if (err != noErr) return err; + + 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 */ - StandardFileReply sfr; - static const OSType sftypes[] = { 'Sess', 0, 0, 0 }; + else { + StandardFileReply sfr; + static const OSType sftypes[] = { 'Sess', 0, 0, 0 }; - StandardGetFile(NULL, 1, sftypes, &sfr); - if (!sfr.sfGood) return; + StandardGetFile(NULL, 1, sftypes, &sfr); + if (!sfr.sfGood) return; - mac_opensessionfrom(&sfr.sfFile); - /* XXX handle error */ + mac_opensessionfrom(&sfr.sfFile); + /* XXX handle error */ + } #endif } @@ -180,12 +232,9 @@ pascal OSErr mac_aevt_odoc(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; @@ -196,16 +245,7 @@ pascal OSErr mac_aevt_odoc(const AppleEvent *req, AppleEvent *reply, 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); diff --git a/mac/macresid.h b/mac/macresid.h index c2380acb..1cfc5ccf 100644 --- a/mac/macresid.h +++ b/mac/macresid.h @@ -1,4 +1,4 @@ -/* $Id: macresid.h,v 1.7 2003/01/27 00:33:49 ben Exp $ */ +/* $Id: macresid.h,v 1.8 2003/02/02 15:59:00 ben Exp $ */ /* * macresid.h -- Mac resource IDs @@ -12,6 +12,9 @@ /* Menu bar IDs */ #define MBAR_Main 128 +/* Open IDs */ +#define open_pTTY 128 + /* Menu IDs */ #define mApple 128 #define mFile 129 diff --git a/mkfiles.pl b/mkfiles.pl index 8c23269a..2ac8e160 100755 --- a/mkfiles.pl +++ b/mkfiles.pl @@ -624,6 +624,7 @@ Libs_68K = "{CLibraries}StdCLib.far.o" \xb6 "{Libraries}MathLib.far.o" \xb6 "{Libraries}IntEnv.far.o" \xb6 "{Libraries}Interface.o" \xb6 + "{Libraries}Navigation.far.o" \xb6 "{Libraries}OpenTransport.o" \xb6 "{Libraries}OpenTransportApp.o" \xb6 "{Libraries}OpenTptInet.o" \xb6 @@ -633,6 +634,8 @@ Libs_CFM = "{SharedLibraries}InterfaceLib" \xb6 "{SharedLibraries}StdCLib" \xb6 "{SharedLibraries}AppearanceLib" \xb6 -weaklib AppearanceLib \xb6 + "{SharedLibraries}NavigationLib" \xb6 + -weaklib NavigationLib \xb6 "{SharedLibraries}TextCommon" \xb6 -weaklib TextCommon \xb6 "{SharedLibraries}UnicodeConverter" \xb6