TweetFollow Us on Twitter

Jan 89 Mousehole
Volume Number:5
Issue Number:1
Column Tag:Mousehole Report

Mousehole Report

By Rusty Hodge & Larry Nedry, Mousehole BBS

From:emmayche (Mark Hartman, Fullerton, CA)

Subject: Re: scroll bars

Inside Mac says that the “standard” width is 16 pixels; however, you can get some really strange effects at different widths.

From: asc (Alex Colwell, Redondo Beach, CA)

Subject: Using PAP Manager

Has anybody used the PAP Manager lately? I had reviewed the two “Mac Tutor” articles : Feb 1986 “Laser Print DA for Postscript” by Mike Schuster and Sep 1986 “Postscript Driver, LightSpeed C” by Bob Denny. However, when I tried to implement this into my application. I always get “Printer Not Found” using LaserWriter 5.0, System & Finder 6.0.1. I suspect the old LaserWriter driver and the new LaserWriter PAP Manager has changed where the articles are currently out-of-date. Does anybody has any ideas. Thanks.

From: dsa (Dave Stine, Saugus, CA)

Subject: Re: Using PAP Manager

If you can’t figure out what the problem is, I could upload a newer version of the PAP Driver interface. The LaserWriter has changed somewhat since Bob’s article in MacTutor, but we have a current copy here.

BTW, you should make sure that you have selected a LaserWriter by the full name, including any trailing spaces. The old ‘Namer’ application has a habit of appending trailing spaces to LaserWriter names which are odd-length when unpadded. (Silly, but that’s what they do...)

From: rustyt (Rusty Tucker, Irvine, CA)

Subject: BitMap to Region

A while ago I thought that I saw something posted about code that will convert an Icon Bitmap into a region. Does any body know where I could find this, or have any examples or ideas on how to do this? Any help at all will be appreciated!!

From: emmayche (Mark Hartman, Fullerton, CA)

Subject: Re: BitMap to Region call

There exists a BitMapRgn() call from DTS. It’s a (believe it or not) separately licensable product. We have a copy; as far as I can tell, I can only distribute it with Photon Paint.

What it does is to convert a BitMap (no PixMaps here) to a Region. FAST. What used to take 2 minutes now takes virtually no time. Great stuff. Give a call or drop some e-mail if you need any more info.

From: asc (Alex Colwell, Redondo Beach, CA)

Subject: RE: Using PAP Manager

Could you possibly upload the newer version of the PAP Driver interface? Yes, I believe, I am using the correct LaserWriter name by extracting the printer name from the ‘PAPA’ resource with the resource ID # 0xE000. Then I pass the printer name to the “PAPOpen” routine without any modifications.

I wrote a little text editor using Capp’s LSC PE edit routines. With this I want to send the Postscript code from my text editor straight to the LaserWriter. So any information you have concerning the PAP Manager would be greatly appreciated.

From: dirck (Dirck Blaskey, Highland, CA)

Subject: LSC 3.0 stdio lib

LSC 2.0 -> 3.0 library file stdfile_pos.c, function fseek():

around line 90, the code that looks like this:

           pb.ioMisc = (char *) offset; 
           if (err = who->last_error = PBSetEOF(&pb, false)) 
                 errno = err;
           return(err);

should look like this:

           pb.ioMisc = (char *) offset;
           if (err = who->last_error = PBSetEOF(&pb, false)) 
                {
                    errno = err; 
                    return(err); 
                }

this bug has the following symptoms:

if a call to fseek() causes the file to be extended, the file position will not be changed.

From: bobe (Bob Estes, Somerville, MA)

Subject: Re: LSC 3.0 math-library problem

You need to use the Math881.h header file. It’s different from plain old math.h. That sounds like it’s your problem.

From: chally (Mark Chally, West Covina, CA)

Subject: 3.0.1 and VBLs

Yes....VBLs DO get time when your application gets time--HOWEVER, they don’t get time when your application DOESN’T get time--which to me seems to defeat the purpose of a VBL. What you have to do in the case that your application needs that time is to push your VBL (and the procedure it calls) into system memory. This is tricky and I’m not too sure about doing it myself because I’m just learning assembly (and on a 8088 at school)...however, I do have information from Tech Support at Apple documenting such a practice...if’ you still need the info, I can get you a copy...leave me mail.

Oh...by the way..._DO_ get version 3.0.1 and get 2.5 megs (go for four if you can, you’ll want {not need} it.)

From: lsr (Larry Rosenstein, Cupertino, CA)

Subject: Re: 3.0.1 and VBLs

Only the VBL block needs to be in the System Heap, in order for the VBL to get time when your application doesn’t. The code that it calls can be in your application heap. You have to be careful because your application doesn’t get switched in when the VBL gets time, so you can’t rely on the CurrentA5 low memory variable. You have to stash your application’s A5 in a place relative to the VBL block, so that the VBL code can find it.

From: joehow (Joe Howell, Defuniak Springs, FL)

Subject: c compilers & development systems

Here is a chance for all experienced c macophiles to get on their soapbox. I am beginning a new development project on an application development language. I have been messing around with AZTEC C. Of all current C development systems, which is the “best” for a full scale development project.???? thanks........joe

From: emmayche (Mark Hartman, Fullerton, CA)

Subject: Re: c compilers & development systems

Having used none of them but LightSpeed(tm) C, I can safely say that it is the best I have ever used.

From: lnedry (Larry Nedry, Anaheim, CA)

Subject: Re: c compilers & development systems

I am hooked on Lightspeed C 3.0 Great debugger and fast turn around time from edit to compile to run.

From: thecloud (Ken Mcleod, La Habra, CA)

Subject: Re: c compilers & development systems

I would consider MPW C for a very large project, but my personal preference is Lightspeed C! :-)

From: adept (Roy Lovejoy, Silicon Valley)

Subject: Re: c compilers & development systems

I would have to agree on LSC 3.0x, but ONLY if there is one developer!! (try SIX some time with it!!!)

From: rdclark (Richard Clark, Tustin, CA)

Subject: Re: c compilers & development systems

LSC is the best from the standpoint of speed, debugging, and overall usability. (MPW is sooo slow!) However, if you need support for the latest and greatest operating system features, then you should use MPW since Apple has been pretty good about keeping it up to date. However, and this seems to be the consensus, I prefer LSC.

From: chenette (Philip Chenette, Los Angeles, CA)

Subject: Double Clicks

This is probably a silly question, but I can’t figure out how to detect a double-click of the mouse. I want to open up a dialog box when the user double-clicks on an object, but it seems there’s no event message for this. What am I missing? (Using LSP 1.11) Thanks!

From: thecloud (Ken Mcleod, La Habra, CA)

Subject: Re: Double Clicks

You’re right, there’s no DblClikEvt... you need to compare the time and location of a mouseUp event with those of the next mouseDown event, and if they’re sufficiently close, the user double-clicked. Read Inside Macintosh Vol. 1, pp 255-56. If you’re still having trouble, I can dig up some sample source code.

From: adept (Roy Lovejoy, Silicon Valley)

Re: Double Clicks

Basically, you handle double clicks in your mouse down handler, but keep a global around that is the ‘last-when’ of the event. You then compare it with the current event record’s ‘when’ field , and if the difference is less than the global ‘DoubleTime’ (long int stored at $2F0.. Control panel setting) It is a double click.. (you might also want to see if the “where”’s are within a specific range.. Hope this helps.

From: rdclark (Richard Clark, Tustin, CA)

Subject: Re: Double Clicks

The mouse isn’t supposed to move more than 3 pixels between the 2 clicks, otherwise, it’s considered a click-and-drag operation. Also, looking at the low memory global DoubleTime isn’t such a good idea, as Apple is discouraging any direct access to the low memory globals. Use GetDblTime() instead. Now for some code:

#define abs(x) ((x) >= 0 ? (x) : (0-x))
Boolean IsDoubleClick(where)
           Point where;
   {     static Point oldLoc;
     static long  oldTime = 0;
     long now = TickCount(); 
    Boolean idc;
         idc = FALSE;
     /* First, see if the 2 clicks are close enough in time */
     if ((now - oldTime) < GetDblTime())
     /* They are, so see if they are close enough in space */
       if ((abs(where.h - oldLoc.h) <= 3) && (abs(where.v -oldLoc.v) 
<= 3))
         idc = TRUE; 
    oldTime = now;
     oldLoc = where;
     return idc; }

From: emmayche (Mark Hartman, Fullerton, CA)

Subject: Re: Double Clicks and further checks

Richard is correct, as far as he goes; however, don’t forget to check that the clicks are still within the same screen area (for example, the object on which your user will double-click to get that dialog). If he’s real close to the edge on the first click, and just barely outside on the second click, it shouldn’t be considered a double-click.

(I generally set a flag called checkDoubleClick in my main dispatch loop which checks the time and object, and let the routine which handles the object decide if it was indeed a double-click.)

From: dsa (Dave Stine, Saugus, CA)

Subject: MPW _RTExit routine

Just nailed a real weird one. I have a driver which patches the ExitToShell trap for applications which open a communications session in said driver. This is done because drivers running under MultiFinder don’t receive a “goodBye kiss”.

Well, it would seem that applications written in MPW C don’t call the ExitToShell code in the normal manner; I think that in the _RTInit routine, they filch out the current routine in the ExitToShell trap address, stash this off in some parameter block, and it would appear that in _RTExit, they JSR (a0) to this entry point directly.

All of which means that if something patched ExitToShell *after* the _RTInit routine has run (which is caqlled before you main() entry is), you patch does not get invoked at program exit time. Can anyone confirm this for me, or am I just blowing smoke thru my hat?

From: rdclark (Richard Clark, Tustin, CA)

Subject: Re: MPW _RTExit routine

Yes, MPW C is doing something strange with ExitToShell(), and it seems that patching around the trap cannot be done. However, if you look at IM II-59, you’ll see an “Assembly-language note” which implies that ExitToShell() calls Launch(). (And a quick test with MacsBug seems to confirm this. However, I couldn’t see the “launch” execution under MultiFinder -- I had to re-run the test under “flat” finder.) I dunno, this stuff sounds pretty dangerous.

From: dsa (Dave Stine, Saugus, CA)

Subject: Re: MPW _RTExit routine

Actually, the only reason I need to have the program come thru ExitToShell() is because MultiFlounder doesn’t call drivers with the “goodBye Kiss” that the normal Finder does. So.... if some application has a network session open thru my driver, and doesn’t take care to close said session before exiting, there will be some grief Real Soon Afterwards.

So, the folks at Apple DTS told me to patch ExitToShell() to get around this “improvement” that MF made. So I did. And now, I find that yet another piece of Apple code has put a ditch in my path.

Yes, your suspicion about ExitToShell calling _Launch is correct -- in the nominal Finder case. Under MF, things get much more hairy. When an application exits, MF must tear down the “sub-heap” that was created for the app to run in, and do some other funky things. If you want to see the beginnings of how MF launches an app, see Goldman’s article in Aug. ’88 Byte (of all places), wherein he describes some of what MF does. This was an especially nice article, full of info you simply can’t get from DTS, even if you ask. (I did)

Anyway, I have already hopped around the problem for the time being. Thanks for your time.

From: adail (Alan Dail, Hampton, VA)

Subject: Re: MPW _RTExit routine

Rather than waiting for ExitToShell to be called for you, why don’t you just call ExitToShell yourself when your program is done?

From: dsa (Dave Stine, Saugus, CA)

Subject: Re: MPW _RTExit routine

‘Cuz my stuff is a driver, which is being used by the application which calls _RTExit, which doesn’t call ExitToShell().

Calling ExitToShell() for a client application from a driver often result in much sadness.

From: rdclark (Richard Clark, Tustin, CA)

Subject: Re: MPW _RTExit routine

Whoa! If you look at the original post, it’s the App which is supposed to call ExitToShell() -- the driver is trying to intercept THAT call so it can close itself.

However, another ugly problem rears its head -- many applications don’t use ExitToShell(). Instead, they simply execute an RTS when done, which returns them to a place within the Launch() trap (which then returns them to the Finder or whatever). Time to go digging for some other way of shutting things down cleanly.

 
AAPL
$118.93
Apple Inc.
-0.07
MSFT
$47.81
Microsoft Corpora
+0.06
GOOG
$541.83
Google Inc.
+1.46

MacTech Search:
Community Search:

Software Updates via MacUpdate

Adobe Photoshop Elements 13.0 - Consumer...
Adobe Photoshop Elements 12--the #1 selling consumer photo editing software--helps you edit pictures with powerful, easy-to-use options and share them via print, the web, Facebook, and more.Version... Read more
Skype 7.2.0.412 - Voice-over-internet ph...
Skype allows you to talk to friends, family and co-workers across the Internet without the inconvenience of long distance telephone charges. Using peer-to-peer data transmission technology, Skype... Read more
HoudahSpot 3.9.6 - Advanced file search...
HoudahSpot is a powerful file search tool built upon MacOS X Spotlight. Spotlight unleashed Create detailed queries to locate the exact file you need Narrow down searches. Zero in on files Save... Read more
RapidWeaver 6.0.3 - Create template-base...
RapidWeaver is a next-generation Web design application to help you easily create professional-looking Web sites in minutes. No knowledge of complex code is required, RapidWeaver will take care of... Read more
iPhoto Library Manager 4.1.10 - Manage m...
iPhoto Library Manager lets you organize your photos into multiple iPhoto libraries. Separate your high school and college photos from your latest summer vacation pictures. Or keep some photo... Read more
iExplorer 3.5.1.9 - View and transfer al...
iExplorer is an iPhone browser for Mac lets you view the files on your iOS device. By using a drag and drop interface, you can quickly copy files and folders between your Mac and your iPhone or... Read more
MacUpdate Desktop 6.0.3 - Discover and i...
MacUpdate Desktop 6 brings seamless 1-click installs and version updates to your Mac. With a free MacUpdate account and MacUpdate Desktop 6, Mac users can now install almost any Mac app on macupdate.... Read more
SteerMouse 4.2.2 - Powerful third-party...
SteerMouse is an advanced driver for USB and Bluetooth mice. It also supports Apple Mighty Mouse very well. SteerMouse can assign various functions to buttons that Apple's software does not allow,... Read more
iMazing 1.1 - Complete iOS device manage...
iMazing (was DiskAid) is the ultimate iOS device manager with capabilities far beyond what iTunes offers. With iMazing and your iOS device (iPhone, iPad, or iPod), you can: Copy music to and from... Read more
PopChar X 7.0 - Floating window shows av...
PopChar X helps you get the most out of your font collection. With its crystal-clear interface, PopChar X provides a frustration-free way to access any font's special characters. Expanded... Read more

Latest Forum Discussions

See All

Mystery Case Files: Dire Grove, Sacred G...
Mystery Case Files: Dire Grove, Sacred Grove HD Review By Jennifer Allen on November 28th, 2014 Our Rating: iPad Only App - Designed for the iPad A decent new installment for the popular Mystery Case Files series.   | Read more »
Castaway Paradise – Tips, Tricks, and St...
Ahoy there, castaways: Were you curious about our own thoughts regarding this pristine shipwreck? Check out our Castaway Paradise review! Castaway Paradise is out for iOS, finally giving mobile gamers the opportunity to enjoy the idyllic lifestyle... | Read more »
Castaway Paradise VIP Subs are on Sale f...
Castaway Paradise VIP Subs are on Sale for a Limited Time, and a Special Holiday Update is Coming Soon Posted by Rob Rich on November 28th, 2014 [ | Read more »
Primitive Review
Primitive Review By Jordan Minor on November 28th, 2014 Our Rating: :: FOLK ARTUniversal App - Designed for iPhone and iPad True to its name, Primitive is about as straightforward as runners get.   | Read more »
7 tips to get ahead of the competition i...
7 tips to get ahead of the competition in Dynasty of Dungeons Posted by Simon Reed on November 28th, 2014 [ permalink ] Playcrab has launched their action-packed new dungeon crawler, Dynasty of Dungeons, today. | Read more »
Master of Tea Kung Fu Review
Master of Tea Kung Fu Review By Jordan Minor on November 28th, 2014 Our Rating: :: ONE DROP RULESUniversal App - Designed for iPhone and iPad Master of Tea Kung Fu is a creative and complex caffeinated brawler.   | Read more »
Monster Strike Review
Monster Strike Review By Campbell Bird on November 28th, 2014 Our Rating: :: BILLIARD STRATEGYUniversal App - Designed for iPhone and iPad Collect monsters and battle by flinging them across the battlefield in this strangely... | Read more »
Proun+ Review
Proun+ Review By Jennifer Allen on November 28th, 2014 Our Rating: :: TWITCHY RACINGUniversal App - Designed for iPhone and iPad Twitchy racing aplenty in Proun+, an enjoyably tricky title.   | Read more »
Lucha Amigos (Games)
Lucha Amigos 1.0 Device: iOS Universal Category: Games Price: $1.99, Version: 1.0 (iTunes) Description: Forget Ninja Turtles, and meet Wrestlers Turtles! Crazier, Spicier and…Bouncier! Sling carapaces of 7 Luchadores to knock all... | Read more »
Record of Agarest War Zero (Games)
Record of Agarest War Zero 1.0 Device: iOS Universal Category: Games Price: $7.99, Version: 1.0 (iTunes) Description: HyperDevbox Holiday Turkey Black Friday Special Pricing! To celebrate the opening of the holiday season HyperDevbox... | Read more »

Price Scanner via MacPrices.net

Up To 75% Off Infovole Text Apps Over Black F...
Infovole’s entire range of apps, including the Textkraft family of word processors for iPads and iPhones, is being offered at 50-75% off over the Black Friday and Cyber Monday weekend. The five-day... Read more
Black Friday: Up to $60 off Mac minis, NY tax...
 B&H Photo has new 2014 Mac minis on sale for up to $60 off MSRP as part of their Black Friday sale. Shipping is free, and B&H charges NY sales tax only: - 1.4GHz Mac mini: $449.99 $50 off... Read more
Black Friday: 27-inch 5K iMac for $2299, save...
 B&H Photo continues to offer Black Friday sale prices on the 27″ 3.5GHz 5K iMac, in stock today and on sale for $2299 including free shipping plus NY sales tax only. Their price is $200 off MSRP... Read more
Karalux Announces 24K Gold-Plated iPhone 6
Karalux, a Vietnam-based jewellery firm, has launched a unique 24 karat gold-plated iPhone 6 version with gold-cast monolithic dragon on its back panel. The real 24 karat gold plated enclosure doesn’... Read more
Black Friday: 13-inch 2.6GHz Retina MacBook P...
 B&H Photo has lowered their price for the 13″ 2.6GHz/128GB Retina MacBook Pro to $1159 for Black Friday. That’s $140 off MSRP, and it’s the lowest price for this model (except for Apple’s $1099... Read more
View all the Black Friday sales on our Mac Pr...
We’ve updated our Mac Price Trackers with the latest information on prices, bundles, and availability on systems from Apple’s authorized internet/catalog resellers. View Black Friday sale prices at a... Read more
Black Friday: 11-inch MacBook Air for $779, s...
 Best Buy has lowered their price for the 2014 11″ 1.4GHz/128GB MacBook Air to $779.99 for Black Friday. That’s $120 off MSRP. Choose free shipping or free local store pickup (if available). Sale... Read more
Apple Store Black Friday sale for 2014: $100...
BLACK FRIDAY The Apple Store has posted their Black Friday deals for 2014. Receive a $100 PRODUCT(RED) branded iTunes gift card with the purchase of select Macs, $50 with iPads, and $25 with iPods,... Read more
Black Friday: 15% off iTunes Gift Cards
Staples is offering 15% off $50 and $100 iTunes Gift Cards on their online store as part of their Black Friday sale. Click here for more information. Shipping is free. Best Buy is offering $100... Read more
BEVL Releases Dock Tailored for iPhone 6 and...
Seattle based BEVL has released their first product: an iPhone dock that is divergent in build quality, rock-solid function and visual simplicity to complement the iPhone. BEVL is now accepting... Read more

Jobs Board

*Apple* Solutions Consultant (ASC) - Apple (...
**Job Summary** The ASC is an Apple employee who serves as an Apple brand ambassador and influencer in a Reseller's store. The ASC's role is to grow Apple Read more
Senior Event Manager, *Apple* Retail Market...
…This senior level position is responsible for leading and imagining the Apple Retail Team's global event strategy. Delivering an overarching brand story; in-store, Read more
*Apple* Retail - Multiple Positions (US) - A...
Sales Specialist - Retail Customer Service and Sales Transform Apple Store visitors into loyal Apple customers. When customers enter the store, you're also the Read more
*Apple* Solutions Consultant (ASC) - Apple (...
**Job Summary** The ASC is an Apple employee who serves as an Apple brand ambassador and influencer in a Reseller's store. The ASC's role is to grow Apple Read more
*Apple* Solutions Consultant (ASC) - Apple (...
**Job Summary** The ASC is an Apple employee who serves as an Apple brand ambassador and influencer in a Reseller's store. The ASC's role is to grow Apple Read more
All contents are Copyright 1984-2011 by Xplain Corporation. All rights reserved. Theme designed by Icreon.