TweetFollow Us on Twitter

Aug 95 Tips
Volume Number:11
Issue Number:8
Column Tag:Tips & Tidbits

Tips & Tidbits

By Steve Sisak, Contributing Editor

Note: Source code files accompanying article are located on MacTech CD-ROM or source code disks.

TIP OF THE MONTH

While developing an init that installs a system wide patch I needed a simple way to enable or disable it (forcing it to call the original patch) from the controlling application.

I found that the Gestalt manager could come in useful. In fact the procedure that installs a new selector, used in this case to check for the existence of the init, requires you to specify a response function which gets executed whenever the new selector is called. Being the function itself is part of the init, it is able to change the value of a status variable and return its state: assuming that the variable is a boolean. With two gestalt calls (max) it is possible to change the patch status. Follow some code fragments:

// global constants
#define kPatchSelector    'Test'   // must be OSType
#define kPatchNotPresent  0
#define kPatchPresent1

// INIT FRAGMENT
// INIT globals
Boolean gUsePatch = 3Dfalse;
SelectorFunctionUPPgGestaltSelectorFunction;

// install new gestalt selector
OSErr InstallGestalt(void) 
{
 OSErr  error;

 long   oldA4;
 oldA4 =3D SetUpA4();

 gGestaltSelectorFunction = 
 3DNewSelectorFunctionProc(PatchGestalt);
 error = 3DNewGestalt(kPatchSelector, 
 gGestaltSelectorFunction);

 RestoreA4(oldA4);
 return error;
}

//gestalt response function
pascal OSErr PatchGestalt(OSType gestaltSelector,long* 
 gestaltResponse)
{
    // use the global data in _this file_
 long oldA4;
 oldA4 = 3D SetUpA4();

 if (gUsePatch) { 
 *gestaltResponse = 3DkPatchNotPresent;
 gUsePatch = 3Dfalse;
 }
 else {
 *gestaltResponse = 3DkPatchPresent;
 gUsePatch=3Dtrue;
 }

 // restore the a4 world
 RestoreA4(oldA4);
 
 return noErr;
}
// APPLICATION FRAGMENT
OSErr TogglePatch(Boolean engage)
{
 OSErr  error=3DnoErr;
 long   gestaltFeature=3D0;

    //this call switches the = patch status
 error = 3DGestalt(kPatchSelector,&gestaltFeature);

 if (engage) {
    // was = already engaged; turn it back on
 if ((error = 3D = 3DnoErr) &&     
 (gestaltFeature = 3D = 3DkPatchNotPresent))
 error = 3DGestalt(kPatchSelector,&gestaltFeature);
 }
 else {
    // was = already disabled; turn it back off
 if ((error=3D=3DnoErr) && 
 (gestaltFeature=3D=3DkPatchPresent))
 error=3DGestalt(kPatchSelector,&gestaltFeature);
 }

 return error;
}

- Luigi Belverato
Milano, Italy

HandleMenuChoice

This tip may be a little obvious, I caught it right away, but some people may not have noticed the problem yet. Some people may have coded around it to begin with, but I didn't.

System 7.5 was the first time I saw the "Apple Menu Options" control panel. It is an extremely useful tool, I love it and use it constantly. But, there may be a slight difference in the way your application needs to handle menu highliting now that this control panel exists.

Here is the assumption I had been making for a long time: When the user selects a menu item, MenuSelect (and MenuKey) leave the menu title hilited. The application performs the indicated action and then unhilites the menu title. When no menu item is selected by the user (MenuSelect or MenuKey return 0L), the menu titles are not left hilited after the call.

The Apple Menu Options control panel is an exception. A menu selection in a submenu of the apple menu will leave the apple menu hilited, but MenuSelect will return 0L.

In the event handling code I have calls like this:

HandleMenuChoice( MenuSelect( event->where ) );
HandleMenuChoice( MenuKey( event->message & charCodeMask ) );

HandleMenuChoice looked like this:

void  HandleMenuChoice( long menuChoice )
{
 short  menu;
 short  item;
 
 if ( menuChoice != 0L ) {
 menu = HiWord( menuChoice );
 item = LoWord( menuChoice );
 
 switch ( menu ) {
 case mApple:
 HandleAppleChoice( item );
 break;
 case mFile:
 HandleFileChoice( item );
 break;
    // Other menus go here.
 }
 HiliteMenu( 0 );
 }
}

With this code, if the user selected an item in a submenu of the apple menu, the system will switch to the Finder and open the selected item (thanks to Apple Menu Options). When you switch back to your application, the apple menu will still be hilited (even if you call DrawMenuBar on the switch).

The work around is simple, call HiliteMenu( 0 ) even if MenuSelect returns 0L.

HandleMenuChoice should look like this:

void  HandleMenuChoice( long menuChoice )
{
 short  menu;
 short  item;
 
 if ( menuChoice != 0L ) {
 menu = HiWord( menuChoice );
 item = LoWord( menuChoice );
 
 switch ( menu ) {
 case mApple:
 HandleAppleChoice( item );
 break;
 case mFile:
 HandleFileChoice( item );
 break;
 // Other menus
 }
 // HiliteMenu( 0 ) was here
 }
 HiliteMenu( 0 );  // moved it to here
}

Your code may not look anything like this, but the idea is to call HiliteMenu( 0 ) even if MenuSelect returns 0L.

- Don Bresee
Los Angeles, CA

The Lost Paper

True story: I was once typing in some text in a word processor, when the computer suddenly crashed on me. I didn’t save a copy on to the hard-disk yet. I had to restart the computer and type it all over again. “But wait, the paper is still in the machine” I thought to myself. You see, when you restart all of the computer’s memory doesn’t get cleared, it just stays to what it was until it gets replaced with other information (usually, much like the behavior of a hard-disk). I had one thing going for me, I had MacsBug installed. Here are the steps I took to recover the paper:

First, I logged all of the work I was doing in MacsBug to a file. I did this using the “log” command. All you need to give the command is the name of the new file to log to. I named it “MyPaper” Good, now all of my MacsBug session will be on the hard-disk, so I can open it up with a normal text editor when I’m done.

Next, I needed to find where in memory my paper was. I did this using the “f” command. The first two parameters for this command is the range in memory in which you want MacsBug to search through. I wanted to search through all of my memory, which is 8 megs, so I typed in: “f 0 (400 * 400 * 8) “any string””. Where 0 is the beginning of memory and 8 megs is the top of it. The last parameter is the search string, balanced between two single quotes. I wanted to pick a distinct string, otherwise I would have hit other parts of memory that had it too, making the process take longer. I knew the word aardvark was mentioned in my paper, so I typed in this for the find command:

f 0 (400 * 400 * 8) “aardvark”

MacsBug then started searching for me. It came up with a small memory dump of something with the word arrdvark in it, but the words after it were not mine. (Which meant that I found another part of memory instead of my paper.) I then hit return to tell MacsBug to keep on searching. It then came up with a dump from my paper:

Searching for “aardvark” from 00000000 to 007FFFFF
  00358200  6161 7264 7661 726B  8000 0000 0000 002C  aardvark answer,

Which was very good news indeed! This told me that the string “aardvark answer” could be found at address 00358200. (I got this address from the leftmost number given.)

Now that I knew where it was, the rest my task would be easy. I used MacsBug’s display memory ASCII command to show me what came after it, by typing in: “dma 00358200”. (You might not have this command, in which case you’ll have to use plain old dm, instead of dma.) I hit return until my paper was done being displayed.

Note: You can subract a number from the address to see what was before it. For instance, subracting #200 from an address will give you the address of the first byte of the 200 byte block before it.

I then typed in “log” again, which closed my log. I finally went out of MacsBug and opened the log file with SimpleText. Remember, the log had my whole session, not just the paper, so I had to delete the addresses and such from it, (which really isn’t that hard to do, if you know how to use your mouse and your delete key efficiently). The paper was saved.

Warning: In your search you might stumble upon MacsBug’s very own memory, with its own copy of your search string. To get out of this recursive loop, start the search over again with the base search address being outside of MacsBug’s memory.

- Macneil Shonle
Yarmouth Maine, MacneilS@aol.com

 

Community Search:
MacTech Search:

Software Updates via MacUpdate

Latest Forum Discussions

See All

Six fantastic ways to spend National Vid...
As if anyone needed an excuse to play games today, I am about to give you one: it is National Video Games Day. A day for us to play games, like we no doubt do every day. Let’s not look a gift horse in the mouth. Instead, feast your eyes on this... | Read more »
Old School RuneScape players turn out in...
The sheer leap in technological advancements in our lifetime has been mind-blowing. We went from Commodore 64s to VR glasses in what feels like a heartbeat, but more importantly, the internet. It can be a dark mess, but it also brought hundreds of... | Read more »
Today's Best Mobile Game Discounts...
Every day, we pick out a curated list of the best mobile discounts on the App Store and post them here. This list won't be comprehensive, but it every game on it is recommended. Feel free to check out the coverage we did on them in the links below... | Read more »
Nintendo and The Pokémon Company's...
Unless you have been living under a rock, you know that Nintendo has been locked in an epic battle with Pocketpair, creator of the obvious Pokémon rip-off Palworld. Nintendo often resorts to legal retaliation at the drop of a hat, but it seems this... | Read more »
Apple exclusive mobile games don’t make...
If you are a gamer on phones, no doubt you have been as distressed as I am on one huge sticking point: exclusivity. For years, Xbox and PlayStation have done battle, and before this was the Sega Genesis and the Nintendo NES. On console, it makes... | Read more »
Regionally exclusive events make no sens...
Last week, over on our sister site AppSpy, I babbled excitedly about the Pokémon GO Safari Days event. You can get nine Eevees with an explorer hat per day. Or, can you? Specifically, you, reader. Do you have the time or funds to possibly fly for... | Read more »
As Jon Bellamy defends his choice to can...
Back in March, Jagex announced the appointment of a new CEO, Jon Bellamy. Mr Bellamy then decided to almost immediately paint a huge target on his back by cancelling the Runescapes Pride event. This led to widespread condemnation about his perceived... | Read more »
Marvel Contest of Champions adds two mor...
When I saw the latest two Marvel Contest of Champions characters, I scoffed. Mr Knight and Silver Samurai, thought I, they are running out of good choices. Then I realised no, I was being far too cynical. This is one of the things that games do best... | Read more »
Grass is green, and water is wet: Pokémo...
It must be a day that ends in Y, because Pokémon Trading Card Game Pocket has kicked off its Zoroark Drop Event. Here you can get a promo version of another card, and look forward to the next Wonder Pick Event and the next Mass Outbreak that will be... | Read more »
Enter the Gungeon review
It took me a minute to get around to reviewing this game for a couple of very good reasons. The first is that Enter the Gungeon's style of roguelike bullet-hell action is teetering on the edge of being straight-up malicious, which made getting... | Read more »

Price Scanner via MacPrices.net

Take $150 off every Apple 11-inch M3 iPad Air
Amazon is offering a $150 discount on 11-inch M3 WiFi iPad Airs right now. Shipping is free: – 11″ 128GB M3 WiFi iPad Air: $449, $150 off – 11″ 256GB M3 WiFi iPad Air: $549, $150 off – 11″ 512GB M3... Read more
Apple iPad minis back on sale for $100 off MS...
Amazon is offering $100 discounts (up to 20% off) on Apple’s newest 2024 WiFi iPad minis, each with free shipping. These are the lowest prices available for new minis among the Apple retailers we... Read more
Apple’s 16-inch M4 Max MacBook Pros are on sa...
Amazon has 16-inch M4 Max MacBook Pros (Silver and Black colors) on sale for up to $410 off Apple’s MSRP right now. Shipping is free. Be sure to select Amazon as the seller, rather than a third-party... Read more
Red Pocket Mobile is offering a $150 rebate o...
Red Pocket Mobile has new Apple iPhone 17’s on sale for $150 off MSRP when you switch and open up a new line of service. Red Pocket Mobile is a nationwide MVNO using all the major wireless carrier... Read more
Switch to Verizon, and get any iPhone 16 for...
With yesterday’s introduction of the new iPhone 17 models, Verizon responded by running “on us” promos across much of the iPhone 16 lineup: iPhone 16 and 16 Plus show as $0/mo for 36 months with bill... Read more
Here is a summary of the new features in Appl...
Apple’s September 2025 event introduced major updates across its most popular product lines, focusing on health, performance, and design breakthroughs. The AirPods Pro 3 now feature best-in-class... Read more
Apple’s Smartphone Lineup Could Use A Touch o...
COMMENTARY – Whatever happened to the old adage, “less is more”? Apple’s smartphone lineup. — which is due for its annual refresh either this month or next (possibly at an Apple Event on September 9... Read more
Take $50 off every 11th-generation A16 WiFi i...
Amazon has Apple’s 11th-generation A16 WiFi iPads in stock on sale for $50 off MSRP right now. Shipping is free: – 11″ 11th-generation 128GB WiFi iPads: $299 $50 off MSRP – 11″ 11th-generation 256GB... Read more
Sunday Sale: 14-inch M4 MacBook Pros for up t...
Don’t pay full price! Amazon has Apple’s 14-inch M4 MacBook Pros (Silver and Black colors) on sale for up to $220 off MSRP right now. Shipping is free. Be sure to select Amazon as the seller, rather... Read more
Mac mini with M4 Pro CPU back on sale for $12...
B&H Photo has Apple’s Mac mini with the M4 Pro CPU back on sale for $1259, $140 off MSRP. B&H offers free 1-2 day shipping to most US addresses: – Mac mini M4 Pro CPU (24GB/512GB): $1259, $... Read more

Jobs Board

All contents are Copyright 1984-2011 by Xplain Corporation. All rights reserved. Theme designed by Icreon.