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.

 

Community Search:
MacTech Search:

Software Updates via MacUpdate

RoboForm 8.9.0 - Password manager; syncs...
RoboForm is a password manager that offers one-click login, mobile syncing, easy form filling, and reliable security. Password Manager. RoboForm remembers your passwords so you don't have to! Just... Read more
Remotix 6.1.6 - Access all your computer...
Remotix is a fast and powerful application to easily access multiple Macs (and PCs) from your own Mac. Features: Complete Apple Screen Sharing support - including Mac OS X login, clipboard... Read more
Sibelius 2020.6 - Music notation solutio...
Sibelius is the world's best-selling music notation software for Mac. It is as intuitive to use as a pen, yet so powerful that it does most things in less than the blink of an eye. The demo includes... Read more
Bookends 13.4.2 - Reference management a...
Bookends is a full-featured bibliography/reference and information-management system for students and professionals. Bookends uses the cloud to sync reference libraries on all the Macs you use.... Read more
OmniGraffle Pro 7.16 - Create diagrams,...
OmniGraffle Pro helps you draw beautiful diagrams, family trees, flow charts, org charts, layouts, and (mathematically speaking) any other directed or non-directed graphs. We've had people use... Read more
Drive Genius 6.1.0 - $79.00
Drive Genius features a comprehensive Malware Scan. Automate your malware protection. Protect your investment from any threat. The Malware Scan is part of the automated DrivePulse utility. DrivePulse... Read more
Tor Browser 9.5 - Anonymize Web browsing...
The Tor Browser Bundle is an easy-to-use portable package of Tor, Vidalia, Torbutton, and a Firefox fork preconfigured to work together out of the box. It contains a modified copy of Firefox that... Read more
VueScan 9.7.28 - Scanner software with a...
VueScan is a scanning program that works with most high-quality flatbed and film scanners to produce scans that have excellent color fidelity and color balance. VueScan is easy to use, and has... Read more
OmniGraffle 7.16 - Create diagrams, flow...
OmniGraffle helps you draw beautiful diagrams, family trees, flow charts, org charts, layouts, and (mathematically speaking) any other directed or non-directed graphs. We've had people use Graffle to... Read more
WALTR 2 2.6.26 - $39.95
WALTR 2 helps you wirelessly drag-and-drop any music, ringtones, videos, PDF, and ePub files onto your iPhone, iPad, or iPod without iTunes. It is the second major version of Softorino's critically-... Read more

Latest Forum Discussions

See All

Star Chef 2 is a restaurant and cooking...
Star Chef 2 is the follow up to the financially successful Star Chef and it's available now for iOS and Android. 99 Games' original has reportedly pulled in over $30 million in lifetime revenue. [Read more] | Read more »
Clash Royale Tier List - Best and Worst...
To kick off Clash Royale's twelfth season, we thought it would be fun to start a new feature for the game where we rank cards. And what better cards to start with than the oh-so-rare Legendaries that can really transform the kinds of decks you can... | Read more »
Willy Jetman: Astromonkey's Revenge...
Barcelona-based developer Last Chicken Games are set to bring their game Willy Jetman: Astromonkey's Revenge to both iOS and Android on 9th July. The Metroidvania is already available on the likes of PS4, Switch and PC but now mobile folk will be... | Read more »
The 5 Best Mobile Real Time Strategy Gam...
Real-time strategy games feel like they’d be a perfect fit for mobile, but they’re trickier to pull off that you might think. The traditional mold of base-building and micro management can work on touch screens, but needs to be carefully honed so... | Read more »
Using your phone in a protest
I can't write about games today. There is a struggle happening in the streets right now and it needs everyone's attention. Here's some good info on how you can use your iOS device safely amidst a protest. | Read more »
Dungonian is a card-based dungeon crawle...
Dungonian is a card-based dungeon crawler from developer SandFish Games that only recently launched as a free-to-play title. It offers an extensive roster of playable heroes to collect and enemies to take down, and it's available right now for iOS... | Read more »
Steam Link Spotlight - Signs of the Sojo...
Steam Link Spotlight is a feature where we look at PC games that play exceptionally well using the Steam Link app. Our last entry was XCOM: Chimera Squad. Read about how it plays using Steam Link's new mouse and keyboard support over here. | Read more »
Steampunk Tower 2, DreamGate's sequ...
Steampunk Tower 2 is a DreamGate's follow up to their previous tower defence game. It's available now for both iOS and Android as a free-to-play title and will see players defending their lone base by kitting it out with a variety of turrets. [... | Read more »
Clash Royale: The Road to Legendary Aren...
Supercell recently celebrated its 10th anniversary and their best title, Clash Royale, is as good as it's ever been. Even for lapsed players, returning to the game is as easy as can be. If you want to join us in picking the game back up, we've put... | Read more »
Pokemon Go Fest 2020 will be a virtual e...
Niantic has announced that Pokemon Go Fest will still take place this year although understandably it won't be a physical event. Instead, it will become a virtual celebration and is set to be held on 25th and 26th July. [Read more] | Read more »

Price Scanner via MacPrices.net

Amazon has Apple Watch Series 5 models on sal...
Amazon has Apple Watch Series 5 models on sale for $100 off Apple’s MSRP this weekend. Shipping is free. These are the same Apple Watch models sold by Apple in their retail and online stores, and... Read more
Take $200 off the new 2020 13″ 1.4GHz/512GB M...
B&H Photo has the new 2020 13″ 1.4GHz/512GB Space Gray MacBook Pro on sale today for $1299 including free expedited shipping. Their price is $200 off Apple’s MSRP, and it’s the cheapest price... Read more
Apple restocks 27″ iMacs, Certified Refurbish...
Apple has restocked Certified Refurbished 2019 27″ iMacs starting at $1529 and up to $350 off the cost of new models. Apple’s one-year warranty is standard, shipping is free, and each iMac features a... Read more
Apple’s new 2020 13″ 4-Core MacBook Airs on s...
B&H Photo has Apple’s new 2020 13″ 4-Core MacBook Airs on sale today for $100 off Apple’s MSRP, only $1199. Expedited shipping is free to many addresses in the US. The MacBook Airs are the same... Read more
New Verizon promo: $150 off any Apple Watch w...
Verizon is offering $150 off any Apple Watch when purchased alongside an iPhone through June 10, 2020. They’re also offering up to $100 on any Apple Watch trade-in. Here are the details: “Get $150... Read more
Last year’s 13″ 2.4GHz MacBook Pros are avail...
Apple has Certified Refurbished 2019 13″ 2.4GHz/256GB 4-Core Touch Bar MacBook Pros available for $1359, $440 off original MSRP. Apple’s one-year warranty is included, shipping is free, and each... Read more
Apple’s new 2020 13″ MacBook Pros on sale for...
Apple reseller Abt Electronics has new 2020 13″ MacBook Pros on sale today for up to $140 off MSRP, starting at $1208. Shipping is free, and most configurations are in stock today. Note that Abt’s... Read more
Apple CEO Reacts To Nationwide Protests Over...
NEWS: 06.03.20 – With the recent death of a black man in the custody of a white police officer igniting outrage among Americans from all walks of life, which resulted in protests and civil unrest... Read more
At up to $420 off MSRP, these Certified Refur...
Apple has Certified Refurbished 2019 16″ MacBook Pros available for up to $420 off the cost of new models, starting at $2039. Each model features a new outer case, shipping is free, and an Apple 1-... Read more
Apple restocks refurbished 3rd generation 12....
Apple restocked select 3rd generation 12.9″ WiFi iPad Pros starting at only $699 and up to $330 off original MSRP. Each iPad comes with a standard Apple one-year warranty, outer cases are new, and... Read more

Jobs Board

Blue *Apple* Cafe Student Worker - Fall - P...
…to enhance your work experience. Student positions are available at the Blue Apple Cafe. Employee meal discount during working hours is provided. Duties include food Read more
*Apple* Architect - SAIC (United States)
**Description** We are currently seeking a motivated, career and customer oriented Apple Architect to join our team in Washington, DC to begin an exciting and Read more
*Apple* Support Engineer - SAIC (United Stat...
**Description** We are currently seeking a motivated, career and customer oriented Apple Support Engineer to join our team in Washington, DC to begin an exciting and Read more
Perioperative RN - ( *Apple* Hill Surgical C...
Perioperative RN - ( Apple Hill Surgical Center) Tracking Code 60593 Job Description Monday - Friday - Full Time Days Possible Saturdays General Summary: Under the Read more
Senior Practice Manager - *Apple* Hill Eye...
Senior Practice Manager - Apple Hill Eye Center Tracking Code 61713 Job Description Apple Hill Medical Center General Summary: Under general supervision, manages Read more
All contents are Copyright 1984-2011 by Xplain Corporation. All rights reserved. Theme designed by Icreon.