Dec 89 Mousehole
Volume Number: | | 5
|
Issue Number: | | 12
|
Column Tag: | | Mousehole Report
|
Mousehole Report
By Rusty Hodge & Larry Nedry, Mousehole BBS
From: Willcox
Re: Print Manager Error
I solved my printing problem, but I do not fully understand why it now works. Maybe someone out their can explain. First, the problem was that sometime when printing (using a Mac IIcx only), the system would sometimes forget that a certain font was a LaserFont, and promptly started creating a bitmap for it. However, the screen font information was also lost, so this process eventually terminated in an error.
I tracked the problem down to a single call to UseResFile from which I had to load a specific private resource. I fixed the problem by modifying the code to:
temp:=CurResFile;
UseResFile(theFileNumber);
theResource:=GetResource(asdfjasldf);
UseResFile(temp);
Now, why does this work??? I have not found a warning in Inside Macintosh, and the error only occurs on my Mac IIcx, not on my Mac Plus.
From: Jmoreno
Re: Print Manager Error
What was happening is the call to UseResFile was removing the System from the list of open files to search for a resource. And that font was no longer found. The system adds each opened resource to the end of a list and then when you try to load a resource it starts at the end and backtracks looking through all of the open resource forks for the requested resource. So when you open a resource it gets a place in line, when you call UseResFile it gets put at the beginning and is set to be the FIRST resource to search (everything else is then gone from the resource list). Hope this helps you understand what is going on. BTW if you havent already I STRONGLY recommend that you buy Inside Mac Vol 1 to 5.
From: Inbox
Re: Var declaration
Sheeshh.... Here I go again..
Awright, Im trying to create an array of the following size after VAR in my globals unit: myarray : array[1..7,1..300] of string[20]; but LSP says that its unable to create blah..blah..blah on this level. Now what is a body to do if using dynamic memory allocation means changing the whole program?? Is there some kind of a call I can make to perhaps increase the size of the applications stack beforehand?! But the globals unit gets compiled first so the instruction wont get executed at that point...
Thanks for listening, _inBox_ (this should read _inTrouble_)
From: Jmoreno
Re: Var declaration
In the run options part of Think Pascal (formerly LSP) there is an option for setting both the stack (which is what you want) and the heap.
From: Tomt
Re: Var declaration
Dumb question but how in Pascal do I access the stuff in a handle. My problem is that I need to make an array of integers of size, say, 500 by 500. Now I tried array type of that size,without making any instances of it, but LSP wouldnt let do that. So if I make a handle to the appropriately sized chunk of memory, how do I access the i,j the element. Im sure its trivial, but I havent been able to figure it out. Thanks in advance for any help
From: Inbox
Re: Var declaration
Awright.. Methinks I got it.. Heres the 500 by 500....
TYPE
myarray = array[1..500,1..500] of integer;
myarrayptr = ^myarray;
myarrayHandle = ^myarrayptr;
VAR
THEarray : myarrayHandle;
BEGIN
THEarray := myarrayHandle(NewHandle(SizeOf(myarray)));
Thats it. To access an element, do
myint := THEarray^^[i,j]; where i and j are integers, etc...
Set an element by THEarray^^[i,j] := myint;
Hope this helps. _inBox_
From: Jimm
Re: Var declaration
On page 447 of LSP 2.0 manual it says that data structures cannot exceed 32766 bytes. Your data structure is 22*7*300 or >42K.
From: Dhands
Re: Var declaration
The previous VAR declaration will work as stated, since the data structure allocated at compile time is only a 4 byte handle, not the >40k array. The array is later allocated dynamically at run-time.
For example:
VAR
good : BigHandle; {4 byte handle to huge, >32k, data}
bad : ARRAY[1..40000] char;{>32k data wont fit here}
The difference is that good has its data on the heap (via NewHandle) and is only limited in size by the available memory. Where as bad is pre-allocated space in global or local areas of the heap which is limited to 32k.
From: Shaper
Re: Printing Samples?
One more question, does anyone have any Pascal (preferably LSP) source code for printing to an ImageWriter - text only, no graphics necessary, I tried to use PrCtlCall() or whatever its called, but I dont know how to set up a ptr to text, and also how do you set the HiWord and LoWord of a longint? I know you can GET it by doing aLongInt:=HiWord(bLongInt) or aLongInt:=LoWord(bLongInt) but you cant do HiWord(bLongInt):=aLongInt...
From: Dhands
Re: Printing Samples?
Heres a quick summary of draft printing using the print managers low level calls. The low level calls should not be used for real printing, but they are great for quick-n-dirty printing.
{1}
PrDrvrOpen; {open print driver}
PrCtlCall(iPrDevCtl,lPrReset,0,0); {reset/init printer}
PrCtlCall(iPrIOCtl,LONGINT(@textBuf),count,0);{send some text}
PrCtlCall(iPrDevCtl,lPrLFSixth,0,0); {advance printer paper}
PrDrvrClose; {close print driver}
VAR
textBuf : PACKED ARRAY [1..256] OF Char;
str : Str255;
Since you must explicitly advance the paper you have to print one line at a time. To print a Str255 for example:
{2}
count := Length(str) {number of bytes to copy}
FOR i := 1 TO count DO
textBuf[i] := str[i];{note: dont copy over str[0] length byte}
PrCtlCall(iPrIOCtl,LONGINT(@textBuf),count,0);
PrCtlCall(iPrDevCtl,lPrLFSixth,0,0);
From: Jmoreno
Re: Printing Samples?
1a) Why dont you try using the regular printing process, its no big deal to open the port then open a page print a page, close the page then open another page if needed....
1b) To get a pointer to the text in a Str255 use
TextPtr:=@YourString[1]; { really need to make sure you have 1+ chars}
2a) to set the Hi&LoWord of a longInt use:
bLongInt:LongInt;
theInt:^Integer;
BEGIN
theInt:=@bLongInt;
theInt^:= 12; { set the HiWord}
theInt:=Ptr(LongInt(theInt) + 2);
theInt^:= 60; { set the LowWord}
END;
or Use a variable RECORD
From: Inbox
Re: Holy #$%^!!
What just happened is too weird to be true. Ive had a folder with one of the LSP projects I was working on, and I made 2 copies of it by ctl-D (Duplicate). I put the two copies in different folders in other places of the tree. Over a period of a few months, I made changes to the original file, and replaced the old copies with new ones once in a while. But today I discovered that whenever I change a file (LSP project and its files) in one of the folders, they get changed in all of them. So, when I make some changes to the copy, save, and quit, the changes appear in the original source file as soon as I open it. However, when I changed the names of the files in one of the copy folders, removed the object code, and recompiled, the changes were gone and the old stuff was there unaltered. So one can assume that whenever the copy was opened, LSP really opened the original, and, when I saved the changes, they were saved to the original, and the copy was never altered. Is this a major access path screw-up on the LSP part or what? Ive never noticed anything like that before. I rebuilt the Desktop file a sec ago and hope that this wont happen to all my LSC projects as well. Any comments or ideas or similar experiences???
From: Siegel
Re: Holy #$%^!!
Remember that Pascal remembers files in a project by absolute pathname, and not relatively, as THINK C does. Therefore, all of your duplicate projects are pointing to the same set of source files, until you explicitly change the references with option double-click.
From: Rguerra
Re: Resource Question
How does one read resources into memory at INIT time and have them stay in the System Heap after the INIT has executed and STILL HAVE THEM RECOGNIZABLE AS RESOURCES? DetachResource will make them ordinary handled blocks. Since they would probably have to remain as part of an open resource map, how do you keep your INIT files resource fork open, ie. prevent the Systems INIT31 mechanism from closing it after execution? Id like to leave certain resources in the fork open AS RESOURCES, and Ill leave the whole file open if I must. Alternatively, is there a way to graft a resource onto the System file (or ROM resource map in memory) without actually explicitly AddResource - ing to the System? Id really rather not modify peoples System files. Any suggestions would be appreciated.
From: Bob Beason
Re: Scrolling Window
I am trying to write an application that takes data from an A/D board (in a Mac II) and plots it in a window as a horizontal graph. I would like for the graph to be about 4 screens wide and as the data are plotted, for the window automatically to shift to the right so that the most recent point is at the right edge of the screen. In some cases there will be only a few msecs between values from the I/O board, so I cant spend a lot of time redrawing the window. Does anyone have or know of any C routines to handle automatic scrolling along the horizontal axis?
From: Noisy
Re: Desktop Bashing
Ok...so Apple says that directly drawing into the Desktop is a BAD THING, probably because it will abuse and confuse MultiFinder. No bets. Anyone have any brilliant (or at least moderately bright) ideas on how to display icons in the Desktop (like the Trashcan) without violating wMgrPort? The infamous make a window bigger than the desktop and never let the User select it is great under the Finder, but fails miserably under MultiFinder, cause it hides all the other application windows. Displaying icons inside 32x32 windows is a cheap solution, but then you get ugly frames around them (a custom WDEF maybe?). If youve got the idea...Ive got the beer.
From: Dhands
Re: Edittext items & MacApp
I noticed something odd about putting controls (i.e., Radio buttons, Check boxes, Edittext etc...) into windows. MacApp will accept most of the standard controls in a TWindow or TView except for Edittext items. Edittext items require a superview of type TDialogView, where as the other controls will work with superviews of just TWindow or TView. The problem appears to be the fTEView field of TEditText remains nil if there is no TDialogView superview. It would be nice to be able to put an Edittext into a TWindow or TView, is this possible? and what might be the reason for not allowing it?
From: Rastamon
Re: Edittext items & MacApp
TEditText depends upon TDialogView to handle things like tabbing and dismissing modal dialogs. You can use TTEView objects in TViews and TWindows, but youll have to handle the tabbing between fields yourself.
From: Jaff
Re: Need Partitioning SW
Help, anyone! I want to do a partition on a Rodime 100MB drive we have. The drive was purchased from TallGrass as a raw device; weve formatted it with their utility which does not support partitions. Weve also been able to format it with CMS Utility v4.0 which does not support partitions either. We would like to be able to run A/UX and Mac OS on this drive. Both utilities which can create the partitioning we desire do not recognize the device; Apple HD SC Setup wants a SONY, and Jasmines DriveWare, although the Rodime RO3000T 1.26 string appears within their resources, does not work either.
Can anyone help?
From: Gwdavis
Re: Need Partitioning SW
Rodime formatting software is available on CIS or Genie, I think. I used it to format my CMS Pro102, and its the same drive I think.
From: Andgroup
Re: Flushing the cache
Does anyone out there know how to flush the read disk cache? I am not referring to the file system write cache, but the caching mechanism described in tech note #81. I need to flush cache of all blocks as specified, flushing the whole cache would be a bit gauche, but I would settle with that if that is all I had..
From: Malam
Re: LocalTalk xones
Liaison can create two zones on a non-dedicated Macintosh. Its pretty cheap, compared to the Apple Internet Router, which costs $399. As far as hardware is concerned, the AST ICP for the MacII does implement extra AppleTalk ports, especially useful under A/UX. Something to that effect...
From: Jaff
Re: Scrolling INIT
Does anyone know of an INIT that will slow up scrolling (through lists or menus) on fast machines? We have SE/30s, IIx & IIcx (soon to have IIci) and find it hard to maneuver a menu when it scrolls real fast! Please upload!
From: Mrteague
Re: Scrolling INIT
I will upload the INIT someone else mentioned - call Scroll/Limit. On standard machines (SE, II), I found the top speed to be TOO slow - it seems to add a lot of processing overhead as an INIT. Good luck with it.