TweetFollow Us on Twitter

Nov 89 Mousehole
Volume Number:5
Issue Number:11
Column Tag:Mousehole Report

Mousehole Report

By Rusty Hodge & Larry Nedry, Mousehole BBS

From: Tomt

Re: global variables

This is probably a dumb question but is there a way in LSP 2.0 to create global variables that are accessible by multiple units? As an old Fortran person I’d really like the equivalent of a common statement to give global scope to a variable, I’d even settle for something likes C’s extern statement. Thanks for any help. By the way I’d like this to work independently of the build order.

From: Siegel

Re: global variables

Declare any public globals in the interface-part of a UNIT, and any other UNITs that want that global should USE the UNIT where the global is declared.

From: Jmoreno

Re: global variables

The best way to create global variable that are accessible by multiple units AND independent of the build order is to create a unit with just global declarations and have it first in the build and have all of your units use it. Something like this

Unit MyGlobals;
INTERFACE
CONST
MyConst = 32;
TYPE
MYTPE = INTEGER;
VAR
MyGlobalVar: INTEGER;
SecndGlob:Str255;
IMPLEMENTATION
{ I don’t need no stinkin implementation}
END.

From: Macww

Re: global variables

Someone else has probably replied by now, but here goes. It is very common for a Pascal program to have a separate unit, consisting of an interface section only, declaring all global constants, variables, types, etc. Put it first in the build order, but the order of subsequent units will not matter vis a vis the Globals unit.

From: Jmoreno

Re: Dispatch Table

I’m trying to gain some experience with C by translating a program I have from Pascal to C. I don’t want to do a line by line translation, and I noticed that I could handle menu events using a dispatch table to functions instead of a bunch of switch statements. My problem is that I can not get the dispatch table to compile under Think C 3.0. Could somebody please post an example of one?

From: Noisy

Re: Dispatch Table

One way to code a dispatch table in C is to create an array of pointers to functions. That way you can provide your own indexing techniques and bypass multiple depths of switch() statements. This does have some limitations though: since all the calls are made through a single statement, ensuring that each function gets the correct type/number of parameters can be a headache (typecasting unsigned longs is probably your best bet). Secondly, heaven help you if you try to jump with an invalid index value...you’ll discover the delights of the BRND (Branch to random address) opcode! Anyway...here’s a little source to help you on your way:

typedef void (*FuncPtr)();
FuncPtr func_list[] = { my_func1, my_func2, my_func3 };
...
index_val = 2; /* whichever value you want to jump to
(*func_list[index_val])(parameters...);
...

Eh voila! Instant jump table.

From: Gurglekat

From: Dhands

Re: MacApp & Dialog Items

I just started using MacApp 2.0b9 and I have a simple question... What’s the best way to validate a dialog item’s data before dismissing the dialog? I currently override the “CanDismiss” function and check the items there, this seems awkward as I go about checking each field for valid data. The checks are very simple, for example, verify that all EditText items have text. Any suggestions?

From: MacDTS

Re: MacApp & Dialog Items

Override this taken from UMacApp.TControls

FUNCTION TControl.Validate: LONGINT;
BEGIN
Validate := noErr;
END;

Write the routine that validates the control’s data. Also look at how the numbered text controls work.

From: Chuckb

Re: Cross-Compilers

I’m looking for a cross-compiler that runs on a mac and compiles at least z80 code. I’d prefer to have one that does a variety of different processors. Does anyone have any experience with such a beast?

From: Apage

Re: Cross-Compilers

Check out MicroAsm’s in MacTutor’s ads, they have a wide variety of cross assemblers for the Mac.

From: Gpoole

Re: INITs

This is a fairly open-ended question but we would appreciate any help we can get on this matter. The subject is INIT’s, or more specifically, how to get along with them. We are developing a program for commercial release and all seems to work fine as long as we are using just Finder or MultiFinder, no bombs, errors, weird happenings, quitting unexpectedly, etc. As soon as we have some INITs in the system though, all kinds of weird things start happening. With that said, are there any general guidelines we as developers should follow in coding to peacefully co-exist with INITs? Are there any known defensive programming techniques? In case it helps, some the INITs we have are: DialogKeys (CE Software), SuperLaserSpool, PowerMenus, Capture, CanOpener, and Suitcase. Thanks for any help you can give.

From: Gurglekat

Re: INITs

The only thing I can think of for general defensive programming against INITs is to assume that ALL traps move memory. Patched traps can, of course, move memory, and INITs patch traps... I don’t remember where I heard this; maybe from one of Knaster’s books.

From: Rguerra

Re: INITs

It’s probably SAFEST to assume that ANY trap can move memory. While a patched trap’s code in and of itself doesn’t absolutely HAVE to move memory, there are no guarantees. If you’re going to patch traps, one should avoid appending code that moves memory in a trap that is NOT supposed to do so. But who knows what goes on so ... Let’s all be careful out there!

From: Gpoole

Re: INITs

Thanks for the replies to my INIT question, especially the one from DTS. I also asked them this same question and the reply was that there is nothing that can be done for defense. The trenches seem to know best.

From: Brad

Re: INITs

If your program doesn’t get along with the INIT’s you mentioned in your message, then either you have a knack for finding bugs in other people’s code, or your program is doing something very wrong. I work on a very large commercial product, and I run with dozens of INITs, MultiFinder, EtherTalk, etc, and darned near all of the crashes I see are either bugs in my code or bugs (occasionally) in the system. Some INITs out there are downright dangerous and shouldn’t be distributed, but many of those you mentioned could be considered standard equipment on many machines.

From: Brad

Re: INITs

It’s ridiculous to program as if any trap can move memory. If someone patches a trap that is documented as NOT moving memory, and, as a result of something in the patch, memory may be moved, then the patch has a bug and shouldn’t be used. Defensive programming is important; check your error codes, preflight, don’t assume, etc - but there’s no need to get carried away. Relocatable blocks don’t relocate unless provoked, and they only get purged if they’re purgeable and memory is tight. (But come System 7, and who knows...)

From: Gurglekat

Re: INITs

It’s not the tough to program as if any trap can move memory. All you really have to be careful of are WITH statements, keeping handles half-dereferenced across traps, and passing dereferenced elements of records in handles as VAR parameters. HLock and HUnlock aren’t that hard to use.

From: Coretech

Re: TEHilite, ColorWindows, & Mac II

I am making reference to the color that TextEdit uses for marking highlighted text for selection purposes. When the COLOR cdev changes this, does TE then ignore the color specified for highlighting in the window auxiliary record? Is there anyway to avoid this change from occurring? (I would like to be sure that highlighted text is always visible by controlling the colors myself). I don’t know much about color as I don’t have a color machine, but I do have an SE/30 which has the color QD roms. The only problem is that I don’t encounter the problem on the SE/30 machine, only on a true color machine. I fear that the problem stems from something that I am doing in my code. If the text that is highlighted is left highlighted and a different selection is highlighted, the second selection is highlighted without any problems. The problem only appears after I do a mouse down in content and then move the cursor location to the location of the mouse down, deselecting any highlighted text. If text is again highlighted, the problem of the “invisible highlighting” occurs once again. Please help me. I am new to the color world and would like to support it in my program.

From: Essam

Re: Simple INIT

There was a beautiful example of an INIT that stays around (by patching GetResource and ExitToShell to beep when an application is launched or quit, found in MacTutor June 1989. Unfortunately, this INIT was in Forth. Does anyone have a LSP Pascal version of this code?

From: Inbox

Re: LSP I/O procs

It seems that LSP’s built-in I/O procs don’t work properly with HFS. My app uses info passed by SFGetFile in the Open(myFileVar,name) call but I can’t access files that are in a directory other than the one the app is in. What should I do? Do I need to use PBGetCatInfo or something of this sort?!

From: Siegel

Re: LSP I/O procs

IF you’re getting back from a standard file call, do a SetVol(NIL, reply.vRefNum) before calling the library routines.

From: Unclejim

Re: Disk Based Scrolling

Help! I am still struggling with getting some disk based scrolling to work. I need to scroll around in 200-300K files and only keep 40-50K in memory at one time. (Scroll Up & down etc). I can’t seem to keep my scroll bars moving smoothly as I swap buffers and use TESetText etc. If anyone has even the simplest example of this disk based scroll in any language it would be a terrific help. Editing is not an issue at this stage just scroll up and down and keep track of the buffers. I thought it would be easy; it probably is, but I’m not having much luck so far. Thanks Jim

From: Inbox

Re: Ah, yes...

Yet another wall stands before me... Can an Apple IIGS connect to a Mac via the AppleTalk cable? It seems that I’ll have to pump data back and 4th between the Mac and the GS, and I wonder whether AppleTalk can do it. Also, what special knowledge will I have to obtain to use the thing?

From: Mrteague

Re: Ah, yes...

I have often transferred data between Apple IIGS & Mac, using a DIN-8 to DIN-8 serial cable, and comms software on each end - I have 19.2K out of it no problem. As for using AppleTalk - you would need to have appropriate software on both ends, and the only product that I know would fit your ends, is AppleShare. Can’t help you on the other question.

From: Jmoreno

Re: arrays as files

Here is some pascal source for finding you were launched with a file

CountAppFiles(AppMessage, NumAppFiles);

IF NumAppFiles <> 0 THEN { the user has opened documents from the finder }

that would be something like

CountAppFiles(AppMessage,&NumAppFiles);

if NumAppFile != 0 /* open the file */

From: Cforden

Re: Converting to TC 4.0 docs?

I have just started trying to get our project converted from THINK C 3.0x to version 4.0. There have been a few things I’ve had to change to do to accomplish the conversion. Not one of them has really stumped me for more than a hour, but I wonder: isn’t there any documentation addressed specifically to 3.0x users who are trying to convert their existing projects? We ordered our version 4.0 in response to Symantec’s upgrade brochure, but when I opened the package I saw no documentation directed towards those of us who already had 3.0 projects. I already like some of the little improvements in 4.0-- like allowing duplicate function prototypes-- but wish there was some hand holding by THINK for us as we convert. I also would like to see a complete list of differences between the two versions so I could take full advantage of all the improvements.

From: Siegel

Re: Converting to TC 4.0 docs?

The differences between earlier versions and 4.0 are described starting at the bottom of Page 8 in the 4.0 User’s Manual: “Notes For Experienced Users”.

From: Nedry

Re: Converting to TC 4.0 docs?

The Think 4.0 User’s Manual does not describe any differences between 3.0 and 4.0. It only describe the additions. I have had to modify every one of my projects dues to changes in Think C 4.0. Most changes are minor but they take time. A list of the changes would be nice to have!

From: Cforden

Re: Converting to TC 4.0

Some hints for converting your projects from THINK C 3.0 to 4.0. There is a serious bug-- atof(“.03”) returns a value of .3. (The new routine wrongly strips leading zeros between the decimal point and the first significant digit.) You will encounter “unknown error -192” when compiling files with previously precompiled headers. Re-precompile them. You will have to change ‘#include “strings.h” ‘ to: ‘#include “string.h”’. You will be allowed to have multiple identical function prototypes. The new version of ResEdit supplied (1.2) now allows you to open a Project.rsrc file and launch ResEdit by double clicking on the .rsrc file.

From: Brad

Re: Dialogs

Don’t over-complicate things. There is no restriction that all of the code for your XCMD needs to be local to your Main function. As long as the entry point is Main, you’re all set. If your filter function needs to access variables, just allocate them somewhere and stuff a reference to them (either a pointer or a handle, if you prefer) in the RefCon field of the dialog. Since your filter gets the dialogPtr passed to it, you can use GetWRefCon (dialogPtr) to access the reference to your variables.

From: Alamac

Re: LocalTalk xones

I’ve read the threads on this subject and I understand your need to provide a solution without adding a lot of expensive hardware. Check out a software solution called Liaison from Infosphere at 800 445 7085. It looks like it will accomplish what you want. Plug an Appletalk line into the printer port of a Mac and plug the other Appletalk line into the modem port of the same Mac, run Liaison in the background and voila, you have just created two Appletalk zones. Sorry for the late supply but my machine has been away for about 6 weeks. Hope this helps.

From: Gurglekat

Re: LocalTalk xones

Well, it looks like we got some little beastie from Shiva to do the zone divisions. It turned about to be close to $500, but what’s $500 when you NEED the thing?... Thanks for the reply anyway. The software solution sounds like a nice alternative.

From: Rguerra

Re: APPLICON

Has any seen or heard of an INIT called “Applicon”? It apparently was written by someone at Apple and implements a Set-Aside feature such that the switched out layer’s windows are zoomed down to a single icon placed on one side of the screen. I was told by another Apple employee that it has been discussed on AppleLink and the internal Usenet areas at Apple quite a bit and that the author wrote it as Freeware. If anyone has it, I’d really appreciate it if you’d upload it here. Thanks!

From: Gurglekat

Re: APPLICON

There’s a thing running around on CompuServe called AltWDEF (and another similar one called AWinDef, I believe) that does the window-shrink-to-icon business. It’s an evolving thing, so I’d need to check on it if you’re interested. Odds are that someone who calls here has it. I suggest you repost under a different header that long distance people (most of the users?) might not skip over.

From: Walrus

Re: Programming Environments

Is it my imagination or are many of the programming environments available on the MS-DOS machines slicker and simpler than on the Mac? I am most familiar with the Borland products for the IBM and the Symantec packages. For instance, you are writing a program, you try to run it and it bombs. Turbo whatever will blow you back into your source code, right where the problem happened. Turbo Pascal 3.0 was doing this years ago. Is there some inherent problem with the Mac that prevents some of these labor saving things (like moving necessary files into projects, can’t it do it on the fly?). Of course, I work on a mainframe so I still have to submit batch jobs to compile and run programs, but, the Mac is supposed to be slicker than the IBM!!

From: Siegel

Re: Programming Environments

The Symantec environments do all of this; if an error happens, the source debugger will show you where it was detected; also, both THINK C and THINK Pascal have commands to add the current window to a project, and THINK C will add a file as soon as you save it and compile it.

From: Gurglekat

Re: Programming Environments

As a matter of fact, I did a project a while back that run under Turbo/PC and Lightspeed/Mac both. At the time, Turbo/PC had just come out with a new version that looked suspiciously like it had taken a LOT of cues from Lightspeed. I’ve heard the new debugger in Turbo/PC looks a little bit too much like Lightspeed, too...

From: Arlen

Re: Programming Environments

Yes the “integrated” environments are slicker on the IBM. Why is a good question, but I suspect that it’s more difficult to do some of the cute hacks the IBM-ers do without breaking the programming rules for the Mac (at least I’m finding that a problem in the projects I work on). You can still break the rules if you want to, but be prepared for a customer service headache bigger than the Grand Canyon.

 

Community Search:
MacTech Search:

Software Updates via MacUpdate

Airmail 3.3.2 - Powerful, minimal email...
Airmail is an mail client with fast performance and intuitive interaction. Support for iCloud, MS Exchange, Gmail, Google Apps, IMAP, POP3, Yahoo!, AOL, Outlook.com, Live.com. Airmail was designed... Read more
Numi 3.15.1 - Menu-bar calculator suppor...
Numi is a calculator that magically combines calculations with text, and allows you to freely share your computations. Numi combines text editor and calculator Support plain English. For example, '5... Read more
Airmail 3.3.2 - Powerful, minimal email...
Airmail is an mail client with fast performance and intuitive interaction. Support for iCloud, MS Exchange, Gmail, Google Apps, IMAP, POP3, Yahoo!, AOL, Outlook.com, Live.com. Airmail was designed... Read more
Numi 3.15.1 - Menu-bar calculator suppor...
Numi is a calculator that magically combines calculations with text, and allows you to freely share your computations. Numi combines text editor and calculator Support plain English. For example, '5... Read more
TextSoap 8.4.1 - Automate tedious text d...
TextSoap can automatically remove unwanted characters, fix up messed up carriage returns, and do pretty much anything else that we can think of to text. Save time and effort. Be more productive. Stop... Read more
TextSoap 8.4.1 - Automate tedious text d...
TextSoap can automatically remove unwanted characters, fix up messed up carriage returns, and do pretty much anything else that we can think of to text. Save time and effort. Be more productive. Stop... Read more
Backblaze 4.3.0.44 - Online backup servi...
Backblaze is an online backup service designed from the ground-up for the Mac. With unlimited storage available for $5 per month, as well as a free 15-day trial, peace of mind is within reach with... Read more
Numi 3.15 - Menu-bar calculator supports...
Numi is a calculator that magically combines calculations with text, and allows you to freely share your computations. Numi combines text editor and calculator Support plain English. For example, '5... Read more
EtreCheck 3.3.3 - For troubleshooting yo...
EtreCheck is an app that displays the important details of your system configuration and allow you to copy that information to the Clipboard. It is meant to be used with Apple Support Communities to... Read more
BusyContacts 1.1.8 - Fast, efficient con...
BusyContacts is a contact manager for OS X that makes creating, finding, and managing contacts faster and more efficient. It brings to contact management the same power, flexibility, and sharing... Read more

Latest Forum Discussions

See All

The best new games we played this week
We were quite busy this week. A bunch of big mobile games launched over the past few days, alongside a few teeny surprises. There're lots of quality games to load your phone with. We've gone and picked out five of our favorites for the week. [... | Read more »
Magikarp Jump beginner's guide
Magikarp Jump is a mystifying little game. Part Tamagotchi, part idle clicker, there's not a whole lot of video game there, per se, but for some reason we can't help coming back to it again and again. Your goal is to train up a little Magikarp to... | Read more »
Goat Simulator PAYDAY (Games)
Goat Simulator PAYDAY 1.0 Device: iOS Universal Category: Games Price: $4.99, Version: 1.0 (iTunes) Description: ** IMPORTANT - SUPPORTED DEVICES **iPhone 4S, iPad 2, iPod Touch 5 or better Goat Simulator: Payday is the most... | Read more »
GRID Autosport delayed until autumn
Sorry mobile racing fans -- GRID Autosport has been delayed a few months. The game is now expected to launch this fall on iOS. Feral Interactive announced that they wanted more time to work on the game's UI and overall performance before launching... | Read more »
Zombie Gunship Survival Beginner's...
The much anticipated Zombie Gunship Survival is here. In this latest entry in the Zombie Gunship franchise, you're tasked with supporting ground troops and protecting your base from the zombie horde. There's a lot of rich base building fun, and... | Read more »
Mordheim: Warband Skirmish (Games)
Mordheim: Warband Skirmish 1.2.2 Device: iOS Universal Category: Games Price: $3.99, Version: 1.2.2 (iTunes) Description: Explore the ruins of the City of Mordheim, clash with other scavenging warbands and collect Wyrdstone -... | Read more »
Mordheim: Warband Skirmish brings tablet...
Legendary Games has just launched Mordheim: Warband Skirmish, a new turn-based action game for iOS and Android. | Read more »
Magikarp Jump splashes onto Android worl...
If you're tired ofPokémon GObut still want something to satisfy your mobilePokémon fix,Magikarp Jumpmay just do the trick. It's out now on Android devices the world over. While it looks like a simple arcade jumper, there's quite a bit more to it... | Read more »
Purrfectly charming open-world RPG Cat Q...
Cat Quest, an expansive open-world RPG from former Koei-Tecmo developers, got a new gameplay trailer today. The video showcases the combat and exploration features of this feline-themed RPG. Cat puns abound as you travel across a large map in a... | Read more »
Jaipur: A Card Game of Duels (Games)
Jaipur: A Card Game of Duels 1.0 Device: iOS Universal Category: Games Price: $1.99, Version: 1.0 (iTunes) Description: ** WARNING: iPad 2, iPad Mini 1 & iPhone 4S are NOT compatible. ** *** Special Launch Price for a limited... | Read more »

Price Scanner via MacPrices.net

Memorial Day savings: 13-inch Touch Bar MacBo...
B&H Photo has the 2016 Apple 13″ Touch Bar MacBook Pros in stock today and on sale for up to $150 off MSRP. Shipping is free, and B&H charges NY & NJ sales tax only: - 13″ 2.9GHz/512GB... Read more
Apple refurbished 13-inch MacBook Airs availa...
Apple has Certified Refurbished 2016 13″ MacBook Airs available starting at $849. An Apple one-year warranty is included with each MacBook, and shipping is free: - 13″ 1.6GHz/8GB/128GB MacBook Air: $... Read more
Apple restocks refurbished 11-inch MacBook Ai...
Apple has Certified Refurbished 11″ MacBook Airs (the latest models recently discontinued by Apple), available for up to $170 off original MSRP. An Apple one-year warranty is included with each... Read more
12-inch 1.2GHz Retina MacBooks on sale for up...
B&H has 12″ 1.2GHz Retina MacBooks on sale for up to $150 off MSRP. Shipping is free, and B&H charges NY & NJ sales tax only: - 12″ 1.2GHz Space Gray Retina MacBook: $1449.99 $150 off... Read more
15-inch 2.7GHz Silver Touch Bar MacBook Pro o...
MacMall has the 15-inch 2.7GHz Silver Touch Bar MacBook Pro (MLW82LL/A) on sale for $2569 as part of their Memorial Day sale. Shipping is free. Their price is $230 off MSRP. Read more
Free Tread Wisely Mobile App Endorsed By Fath...
Just in time for the summer driving season, Cooper Tire & Rubber Company has announced the launch of a new Tread Wisely mobile app. Designed to promote tire and vehicle safety among teens and... Read more
Commercial Notebooks And Detachable Tablets W...
Worldwide shipments of personal computing devices (PCDs), comprised of traditional PCs (a combination of desktop, notebook, and workstations) and tablets (slates and detachables), are forecast to... Read more
Best value this Memorial Day weekend: Touch B...
Apple has Certified Refurbished 2016 15″ and 13″ MacBook Pros available for $230 to $420 off original MSRP. An Apple one-year warranty is included with each model, and shipping is free: - 15″ 2.6GHz... Read more
13-inch MacBook Airs on sale for up to $130 o...
Overstock.com has 13″ MacBook Airs on sale for up to $130 off MSRP including free shipping: - 13″ 1.6GHz/128GB MacBook Air (sku MMGF2LL/A): $869.99 $130 off MSRP - 13″ 1.6GHz/256GB MacBook Air (sku... Read more
2.8GHz Mac mini available for $973 with free...
Adorama has the 2.8GHz Mac mini available for $973, $16 off MSRP, including a free copy of Apple’s 3-Year AppleCare Protection Plan. Shipping is free, and Adorama charges sales tax in NY & NJ... Read more

Jobs Board

*Apple* Retail - Multiple Positions - Apple,...
Job Description: Sales Specialist - Retail Customer Service and Sales Transform Apple Store visitors into loyal Apple customers. When customers enter the store, Read more
*Apple* Media Products - Commerce Engineerin...
Apple Media Products - Commerce Engineering Manager Job Number: 57037480 Santa Clara Valley, California, United States Posted: Apr. 18, 2017 Weekly Hours: 40.00 Job Read more
*Apple* Retail - Multiple Positions - Apple,...
Job Description: Sales Specialist - Retail Customer Service and Sales Transform Apple Store visitors into loyal Apple customers. When customers enter the store, Read more
*Apple* Media Products - Commerce Engineerin...
Apple Media Products - Commerce Engineering Manager Job Number: 57037480 Santa Clara Valley, California, United States Posted: Apr. 18, 2017 Weekly Hours: 40.00 Job Read more
*Apple* Media Products - Commerce Engineerin...
Apple Media Products - Commerce Engineering Manager Job Number: 57037480 Santa Clara Valley, California, United States Posted: Apr. 18, 2017 Weekly Hours: 40.00 Job Read more
All contents are Copyright 1984-2011 by Xplain Corporation. All rights reserved. Theme designed by Icreon.