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
$102.13
Apple Inc.
+1.24
MSFT
$44.87
Microsoft Corpora
-0.14
GOOG
$571.00
Google Inc.
-6.86

MacTech Search:
Community Search:

Software Updates via MacUpdate

Get Lyrical 3.8 - Auto-magically adds ly...
Get Lyrical auto-magically add lyrics to songs in iTunes. You can choose either a selection of tracks, or the current track. Or turn on "Active Tagging" to get lyrics for songs as you play them.... Read more
Viber 4.2.2 - Send messages and make cal...
Viber lets you send free messages and make free calls to other Viber users, on any device and network, in any country! Viber syncs your contacts, messages and call history with your mobile device,... Read more
Cocktail 7.6 - General maintenance and o...
Cocktail is a general purpose utility for OS X that lets you clean, repair and optimize your Mac. It is a powerful digital toolset that helps hundreds of thousands of Mac users around the world get... Read more
LaunchBar 6.1 - Powerful file/URL/email...
LaunchBar is an award-winning productivity utility that offers an amazingly intuitive and efficient way to search and access any kind of information stored on your computer or on the Web. It provides... Read more
Maya 2015 - Professional 3D modeling and...
Maya is an award-winning software and powerful, integrated 3D modeling, animation, visual effects, and rendering solution. Because Maya is based on an open architecture, all your work can be scripted... Read more
BBEdit 10.5.12 - Powerful text and HTML...
BBEdit is the leading professional HTML and text editor for the Mac. Specifically crafted in response to the needs of Web authors and software developers, this award-winning product provides a... Read more
Microsoft Office 2011 14.4.4 - Popular p...
Microsoft Office 2011 helps you create professional documents and presentations. And since Office for Mac 2011 is compatible with Office for Windows, you can work on documents with virtually anyone... Read more
TextWrangler 4.5.10 - Free general purpo...
TextWrangler is the powerful general purpose text editor, and Unix and server administrator's tool. Oh, and also, like the best things in life, it's free. TextWrangler is the "little brother" to... Read more
BitTorrent Sync 1.4.72 - Sync files secu...
BitTorrent Sync allows you to sync unlimited files between your own devices, or share a folder with friends and family to automatically sync anything. File transfers are encrypted. Your information... Read more
Cyberduck 4.5.2 - FTP and SFTP browser....
Cyberduck is a robust FTP/FTP-TLS/SFTP browser for the Mac whose lack of visual clutter and cleverly intuitive features make it easy to use. Support for external editors and system technologies such... Read more

Latest Forum Discussions

See All

ALONE... (Games)
ALONE... 1.0.1 Device: iOS Universal Category: Games Price: $1.99, Version: 1.0.1 (iTunes) Description: ALONE is a handcrafted, intense survival journey through space. Navigate caves, rip through rocky debris, dodge rocks and comets... | Read more »
Almightree: The Last Dreamer (Games)
Almightree: The Last Dreamer 1.0 Device: iOS Universal Category: Games Price: $1.99, Version: 1.0 (iTunes) Description: The world is shattering and you are the only hope to restore the balance. A thrilling and challenging 3D puzzle... | Read more »
The Nightmare Cooperative (Games)
The Nightmare Cooperative 1.1 Device: iOS Universal Category: Games Price: $3.99, Version: 1.1 (iTunes) Description: Fiendishly difficult! Adorably cute! Utterly engrossing!How much gold can you get before your entire team is... | Read more »
Mobile Convolution (Music)
Mobile Convolution 1.0.0 Device: iOS Universal Category: Music Price: $9.99, Version: 1.0.0 (iTunes) Description: | Read more »
Invaders! From Outer Space Review
Invaders! From Outer Space Review By Rob Thomas on August 27th, 2014 Our Rating: :: RETRO NOSTALGIAUniversal App - Designed for iPhone and iPad It’s a shame that Invaders! doesn’t offer deeper gameplay, as this retro-inspired... | Read more »
Spooklands Review
Spooklands Review By Jennifer Allen on August 27th, 2014 Our Rating: :: ONE-TOUCH SHOOTERUniversal App - Designed for iPhone and iPad One-touch simultaneously controls your direction and your weapon in this unique arena shooter.   | Read more »
Heroes of Order & Chaos Add Twitch I...
Heroes of Order & Chaos Add Twitch Integration, New Heroes, and More Posted by Ellis Spice on August 27th, 2014 [ permalink ] | Read more »
Foodie Yama Review
Foodie Yama Review By Jennifer Allen on August 27th, 2014 Our Rating: :: BRIEFLY HOOKSUniversal App - Designed for iPhone and iPad Foodie Yama will draw you in for a brief while, and you’ll never be entirely sure why.   | Read more »
Spotify Connect Turns One, Now Supports...
Spotify Connect Turns One, Now Supports New Devices Posted by Ellis Spice on August 27th, 2014 [ permalink ] Universal App - Designed for iPhone and iPad | Read more »
The Rise of PicsaStock and How You Can M...
We all take plenty of photos, right? That’s the joy of having a reasonably powerful camera in your pocket, thanks to your trusty iPhone and a bevy of similarly useful apps. Wouldn’t it be great to make some money out of those snaps? While your... | Read more »

Price Scanner via MacPrices.net

12-Inch MacBook Air Coming in 4Q14 or 2015 –...
Digitimes’ Aaron Lee and Joseph Tsai report that according to Taiwan-based upstream supply chain insiders, Apple plans to launch a thinner MacBook model either at year end 2014 or in 2015, and that... Read more
Sapphire Screen “Most Wanted” iPhone 6 New Fe...
According to the ‘uSell.com iPhone Most Wanted Survey’ — a representative survey of 1,000 U.S. smartphone users conducted by used iPhone marketplace uSell.com — close to half of all smartphone users... Read more
The iPad’s Real Competitive Challenger (Not S...
It’s been my contention for some time that the iPad is suffering from something of an identity crisis, and I suspect that may be a factor in slackening sales this year. Apple can’t seem to decide... Read more
13-inch 2.6GHz/256GB Retina MacBook Pro on sa...
B&H Photo has the 13″ 2.6GHz/256GB Retina MacBook Pro on sale for $1379 including free shipping plus NY sales tax only. Their price is $120 off MSRP. Read more
Life Inventory iOS Apps – Learn to Know Thyse...
James Hollender’s Life Inventory apps s are now on sale with 20% off thru Labor Day, 09/01/2014. This is a great opportunity to get started on that Moral Inventory you’ve been putting off doing for... Read more
Pocket Watch, LLC. Reveals Cloud Server For P...
Beaumont, Texas based Pocket Watch, LLC. has announced the availability of its new ActivePrint Cloud Server Powered by Raspberry Pi. With this small standalone box almost any USB printer or available... Read more
902it Simplifies Area Code Changes For Nova S...
The east coast Canadian provinces of Nova Scotia and Prince Edward Island are phasing in 10 digit telephone dialing, to be fully in place by November, in order to accommodate a second area code to... Read more
Boomerang iPad Stand Mounts Your iPad Anywher...
Boomerang, a Mountable Stand with Multiple Viewing Angles, is now available for iPad Air. Boomerang combines several functions that aim to expand your iPad’s potential in one, elegant product. The... Read more
Retina MacBook Pros available starting at $10...
The Apple Store has Apple Certified Refurbished 13″ and 15″ MacBook Pros available starting at $929. Apple’s one-year warranty is standard, and shipping is free: - 13″ 2.5GHz MacBook Pros (4GB RAM/... Read more
Apple 27-inch Thunderbolt Display (refurbishe...
The Apple Store has Apple Certified Refurbished 27″ Thunderbolt Displays available for $799 including free shipping. That’s $200 off the cost of new models. Read more

Jobs Board

*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
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* 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
Project Manager / Business Analyst, WW *Appl...
…a senior project manager / business analyst to work within our Worldwide Apple Fulfillment Operations and the Business Process Re-engineering team. This role will work Read more
Position Opening at *Apple* - Apple (United...
…customers purchase our products, you're the one who helps them get more out of their new Apple technology. Your day in the Apple Store is filled with a range of Read more
All contents are Copyright 1984-2011 by Xplain Corporation. All rights reserved. Theme designed by Icreon.