TweetFollow Us on Twitter

GoodbyE Kiss
Volume Number:3
Issue Number:2
Column Tag:Tech Notes

GoodbyE Kiss

by Dan Weston

I'd like to inform the Mac community of a bug in the generic desk accessories that appear in my book, The Complete Book of Macintosh Assembly Language Programming, Vol I. Kirk Austin pointed out to me that the desk accessories crashed when receiving a goodbye kiss. The goodbye kiss is supposed to let your desk accessory clean up after itself if the application over which the accessory is running is terminated. For example, if your DA maintained open disk files or messed with low memory globals, you would normally close the files and reset the globals when a user closed the desk accessory. The goodbye kiss is provided by the Mac system software for those cases where the user quits an application without first closing the desk accessories. The underlying application doesn't need to be concerned with the goodbye kiss; it is handled totally by the Mac system software as it reinitializes the heap for the next program.

If you want your desk accessory to receive the goodbye kiss you must set bit #12 of the first word in the DA header. When an application terminates, the system software looks at each open desk accessory and sends a goodbye kiss if the appropriate bit is set in the DA header.

The goodbye kiss is a good idea. It prevents your desk accessory from being blown away without warning. The problem is that Inside Macintosh doesn't document how the goodbye kiss is implemented. In my book, I said that the goodbye kiss invoked the desk accessory's close routine. Now, after investigating a little further as a result of Kirk's letter, I find that the goodbye kiss doesn't invoke the close routine. Instead, the goodbye kiss is a control call with CSCode = -1. This causes big problems for my DA code because I use a jump table based on the belief that CSCode will ALWAYS be between 64 and 73. When the -1 CSCode hits the jump table it heads for ozone city; reach for the reset button.

The solution is to put a special case at the beginning of the control routine to watch for the goodbye control call and route it around the jump table (or just disable the goodbye call in the header, as Kirk did).

The modified code section follows:

;--------------------------------- 
; Control handles the control messages, which are the heart
; of the driver. Code values range from 64-73 (*** and -1
; for goodbye kiss ***) enter with pointer to DCE in A1 
; and pointer to Paramblock in A0 

Control 
 
 MOVEM.LA3-A4,-(SP); preserve A3 - A4  
 MOVE.L A1,A4    ; keep DCE ptr in A4 
 MOVE.L A0,A3    ; keep Pblock ptr in A3
 MOVE.W CSCode(A3),D0; get control opCode Pblock 
 ;******* 
 CMP.W  #-1,D0   ; is this the goodbye kiss? 
 BEQ    DoGoodbye; goodbye routine 
 ;******* 
 SUB.W  #64,D0   ; adjust range to 0-9 
 ADD.W  D0,D0    ; multiply by 2 for table 
 MOVE.W ControlTable(D0),D0 ; offset to routine 
 JMP    ControlTable(D0)  ; jump to it  

;---------- Offset table for Control routines --------- 
; **almost** all possible control messages that can be sent to
; a DA are here. All the routines mentioned here should 
; return by branching to CtlDone. 

ControlTable:
   
DC.W  DoEvent-ControlTable; an event (64) 
DC.W  DoPeriodic-ControlTable ; a periodic interupt (65) 
DC.W  DoCursor-ControlTable ; adjust cursor on DA wind (66) DC.W
 DoMenu-ControlTable ; menu selection (67) 
DC.W  DoUndo-ControlTable ; undo (68)  
DC.W  CtlDone-ControlTable; *** code 69 is not used *** DC.W   DoCut-ControlTable
 ; cut (70)
DC.W  DoCopy-ControlTable ; copy (71) 
DC.W  DoPaste-ControlTable; paste (72) 
DC.W  DoClear-ControlTable; clear (73)  

;--------------------------------------------   
CtlDone:  
 MOVE.L A4,A1    ; return DCE ptr to A1
 MOVE.L A3,A0    ; return PBlock ptr to A0
 MOVEM.L(SP)+,A3-A4; A3 - A4 restored 

 MOVE.W #0,D0    ; no error 
 RTS    ; go back to calling program 

;----------------------------------------------------   
DoGoodBye:
 MOVE.L A4,A1    ; return DCE ptr to A1
 MOVE.L A3,A0    ; return PBlock ptr to A0
 MOVEM.L(SP)+,A3-A4; A3 - A4 restored  
 MOVE.W #0,D0    ; no error
 MOVE.L JIODone,-(SP); return vector for asynch calls 
 RTS    ; go back to calling program 
 
 BRA.S  CtlDone  
;-------------------------------------------------------- 

One other detail that is important to note is that the goodbye kiss is an asynchronous control call. All other calls to desk accessories are synchronous, which means that they can return with a simple RTS. Asynchronous calls, on the other hand, must return via the JIODone routine. The low memery global JIODone, holds a pointer to this system routine, which clears the request from the I/O queue. We move this pointer onto the stack and then RTS. This routes our return through the JIODone routine.

Thanks to Kirk for bringing this to my attention. If anyone else has bugs to report from the book I'd love to hear about them. As best I can, I'll fix the bugs and post the information here in Mactutor.

 
AAPL
$556.97
Apple Inc.
-4.31
GOOG
$600.80
Google Inc.
-13.31
MSFT
$29.76
Microsoft Corpora
+0.01
MacNews Search:
Community Search:
view counter

view counter
view counter
dockXtender
view counter
view counter
view counter
view counter
view counter
view counter

Gourmet Pixel and Virgin Limited Edition...
Virgin Limted Edition and Gourmet Pixel have just released an iPad app for guests staying at Richard Branson’s private game reserve. The game reserve borders on Kruger National Park in South Africa’s Mpumalanga province and, while the vast majority of us and our readers will probably never use this app or visit this location, we think that this... | Read more »
Emerge, A Kickstarter Project For A Plat...
Kickstarter is a great place to find new, upcoming games for iOS but sometimes it’s hard to sort through all the projects to find one really worth pledging those hard earned dollars. We think Emerge by independent developer, Lucas Best, could be one of those worth funding. | Read more »
Quick Discreet Text Review
Quick Discreet Text Review By Jennifer Allen on May 22nd, 2012 Our Rating: :: TIME SAVINGiPhone App - Designed for the iPhone, compatible with the iPad An app that will save regular SMS users some time.   | Read more »
Tivoli Releases Free Tivoli Radio App
Tivoli Audio has just released an iPhone app, Tivoli Radio, for listening to high quality radio stations chosen by the listeners of their popular audio equipment. | Read more »
Rabbit Journey Review
Rabbit Journey Review By Rob Rich on May 22nd, 2012 Our Rating: :: FIX THE JUMPINGiPhone App - Designed for the iPhone, compatible with the iPad Rabbit Journey has more than a few cool concepts but the controls really drag it down.   | Read more »
The Portable Podcast, Episode 138
The most hirsute iOS podcast in the world! On This Episode: Carter and guest co-host/beard-enthusiast Jared Nelson discuss the recent Sonic 4: Episode 2 release, and just what kept it from being a truly great game. Carter and Jared discuss games with in-app purchases, in particular regarding comments on games like Polymer and Hero Academy and... | Read more »
Rage of Bahamut Review
Rage of Bahamut Review By Rob Rich on May 22nd, 2012 Our Rating: :: BETTER THAN IT LOOKSiPhone App - Designed for the iPhone, compatible with the iPad It’s got one heck of an ugly and not very intuitive interface, but Rage of Bahamut is still an unexpectedly great CCG.   | Read more »
Plenty of Baking Ideas From 50 Easiest E...
Who likes cake and other baked goods? Nearly everyone, right? 50 Easiest ever baking recipes from olive magazine provides exactly what it says: 50 easy to bake recipes. Every skill level is catered for here and, in reality, over 50 recipes from easy cupcakes to cookies and New York-style baked cheesecakes. | Read more »
Chuck Darwin’s Extinction Squad Review
Chuck Darwin’s Extinction Squad Review By Carter Dotson on May 22nd, 2012 Our Rating: :: WORTH RESCUINGUniversal App - Designed for iPhone and iPad Chuck Darwin’s Extinction Squad has players trying to keep rare animals from going “SPLAT!” on the ground by rescuing them with a trampoline.   | Read more »
National Geographic Releases Look &...
National Geographic has just released a new bundle of educational apps for iOS, aimed at young children. The bundle, Look & Learn: Animals Vol. 1, includes Animal Bounce, Animal Match and Animal Words. Each title encourages children to discover more about the natural world through some great animal sounds and age-appropriate games. Throughout... | Read more »
All contents are Copyright 1984-2010 by Xplain Corporation. All rights reserved. Theme designed by Icreon.