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 cant figure out what the problem is, I could upload a newer version of the PAP Driver interface. The LaserWriter has changed somewhat since Bobs 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 thats 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. Its 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 Capps 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. Its different from plain old math.h. That sounds like its 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 dont get time when your application DOESNT 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 Im not too sure about doing it myself because Im 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, youll 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 doesnt. The code that it calls can be in your application heap. You have to be careful because your application doesnt get switched in when the VBL gets time, so you cant rely on the CurrentA5 low memory variable. You have to stash your applications 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 cant 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 theres 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
Youre right, theres no DblClikEvt... you need to compare the time and location of a mouseUp event with those of the next mouseDown event, and if theyre sufficiently close, the user double-clicked. Read Inside Macintosh Vol. 1, pp 255-56. If youre 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 records 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 wheres are within a specific range.. Hope this helps.
From: rdclark (Richard Clark, Tustin, CA)
Subject: Re: Double Clicks
The mouse isnt supposed to move more than 3 pixels between the 2 clicks, otherwise, its considered a click-and-drag operation. Also, looking at the low memory global DoubleTime isnt 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, dont 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 hes real close to the edge on the first click, and just barely outside on the second click, it shouldnt 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 dont receive a goodBye kiss.
Well, it would seem that applications written in MPW C dont 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, youll see an Assembly-language note which implies that ExitToShell() calls Launch(). (And a quick test with MacsBug seems to confirm this. However, I couldnt 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 doesnt call drivers with the goodBye Kiss that the normal Finder does. So.... if some application has a network session open thru my driver, and doesnt 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 Goldmans 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 cant 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 dont 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 doesnt 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, its 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 dont 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.