💾 Archived View for mirrors.apple2.org.za › archive › ftp.gno.org › doc › genie › a2pro › genielamp … captured on 2024-12-18 at 06:44:17.
-=-=-=-=-=-=-
|||||| |||||| || || |||||| |||||| || || ||| || || || || ||| |||| |||||| || |||| Your || || || || ||| || || |||||| |||||| || || |||||| |||||| GEnieLamp A2Pro || |||||| || || |||||| RoundTable || || || ||| ||| || || || |||||| |||||||| |||||| RESOURCE! || || || || || || || ||||| || || || || || ~ WELCOME TO THE A2Pro GENIELAMP! ~ ~ORCA/PASCAL V2.0 ~ MD-BASIC V2.0 ~ TWILIGHT II V1.1 ~ ~ NATE C. TROST JOINS GENIELAMP A2PRO ~ LARRY RAMBLES ONCE AGAIN ~ ~ BLUE PLATE SPECIAL CONTEST ~ GNO PROGRAMMING SERIES ~ ~ NEW DEVELOPERS JOIN THE A2PRO FAMILY IN CATEGORY 29 ~ ~ HOT NEWS ~ HOT MESSAGES ~ HOT VIEWS ~ ////////////////////////////////////\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\ GEnie Lamp A2Pro ~ A T/TalkNET OnLine Publication ~ Vol.1, Issue 04 """""""""""""""""""""""""""""""""""""""""""""""""""""""""""""""""""""" Publisher.................................GEnie Information Services Senior Editor..........................................John Peters Editor.................................................Jim Couch ~ GEnieLamp IBM ~ GEnieLamp [PR]/TX2 ~ GEnieLamp ST ~ GEnieLamp A2 ~ ~ GEnieLamp MacPRO ~ GEnieLamp A2Pro ~ GEnieLamp Macintosh ~ ~ Member Of The Disktop Publishing Association ~ ////////////////////////////////////\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\ >>> WHAT'S HAPPENING IN THE APPLE A2Pro ROUNDTABLE? <<< """"""""""""""""""""""""""""""""""""""""""""""""""""""" ~ May 1, 1993 ~ FROM MY DESKTOP ......... [FRM] A2PRO ROUNDTABLE STAFF . [DIR] Notes From The Editor. Staff Directory. HEY MISTER POSTMAN ...... [HEY] DEVELOPER'S CORNER ...... [DEV] Is That A Letter For Me? News from A2Pro Developers. RTC WATCH ............... [RTC] A2U CAMPUS GREEN ........ [A2U] A2Pro RTC News. Your GEnieLamp guide to A2U. LIBRARY BIT BONANZA ..... [LIB] RAMBLINGS................ [RAM] HOT Files You Can Download. Ramblings of a Wannabe Programmer. THE MANAGER TIPS ........ [MAN] TO OUR INTERNET FRIENDS .. [INT] Programing for The Manger. Comp.sys.apple2.programmer. GNO TUTORIAL SERIES ..... [GNO] LOG OFF ................. [LOG] Programming the serial ports. GEnieLamp Information. [IDX]""""""""""""""""""""""""""""""""""""""""""""""""""""""""""""""""""" READING GEnieLamp GEnieLamp has incorporated a unique indexing """"""""""""""""" system to help make reading the magazine easier. To utilize this system, load GEnieLamp into any ASCII word processor or text editor. In the index you will find the following example: HUMOR ONLINE ............ [HUM] [*]GEnie Fun & Games. To read this article, set your find or search command to [HUM]. If you want to scan all of the articles, search for [EOA]. [EOF] will take you to the last page, whereas [IDX] will bring you back to the index. MESSAGE INFO To make it easy for you to respond to messages re-printed """""""""""" here in GEnieLamp, you will find all the information you need immediately following the message. For example: (SMITH, CAT6, TOP1, MSG:58/M530) _____________| _____|__ _|O__ |____ |_____________ |Name of sender CATegory TOPic Msg.# Page number| In this example, to respond to Smith's message, log on to page 475 enter the bulletin board and set CAT 6. Enter your REPly in TOPic 1. A message number that is surrounded by brackets indicates that this message is a "target" message and is referring to a "chain" of two or more messages that are following the same topic. For example: {58}. ABOUT GEnie GEnie costs only $4.95 a month for unlimited evening and """"""""""" weekend access to more than 100 services including electronic mail, online encyclopedia, shopping, news, entertainment, single-player games, multi-player chess and bulletin boards on leisure and professional subjects. With many other services, including the largest collection of files to download and the best online games, for only $6 per hour (non-prime-time/2400 baud). To sign up for GEnie service, call (with modem) 1-800-638-8369. Upon connection type HHH. Wait for the U#= prompt. Type: XTX99368,GENIE and hit RETURN. The system will then prompt you for your information. """""""""""""""""""""""""""""""""""""""""""""""""""""""""""""""""""""""" [EOA] [FRM]////////////////////////////// FROM MY DESKTOP / ///////////////////////////////// Notes From The Editor """"""""""""""""""""" By John Peters [GENIELAMP] CHANGES, CHANGES, CHANGES! Change is good, right? Well, I certainly """""""""""""""""""""""""" hope so, 'cause there is a whole lot of changing going on here at GEnieLamp. I suppose the best place to start is the changes that have taken place on page 515, our home, the GEnieLamp RoundTable. (Keep in mind that many of these changes are happening as I write this - the changes outlined below are subject to change!) First off, the RoundTable is no longer a RoundTable but just a single page. Here's the new menu you will find when on page 515: GEnie GENIELAMP Page 515 Computing on GEnie Newsletter 1.[*]GEnieLamp IBM Magazine 2.[*]GEnieLamp Atari Magazine 3.[*]GEnieLamp Mac Magazine 4.[*]GEnieLamp MacPRO Magazine 5.[*]GEnieLamp Apple II Magazine 6.[*]GEnieLamp A2Pro Magazine 7.[*]FEEDBACK to GEnieLamp 8. Digital Publishing RoundTable As you can see the bulletin board, libraries and information files are gone and all that is available is the GEnieLamp Magazines, Feedback and a gateway to the new DigiPub RoundTable. (More on that later.) On the negative side, this means that Aladdin no longer works on this page. This goes for previous GET THE LAMP scripts as well. On the positive side, our resident script writer, Jim Lubin has come up with a new Aladdin script which will be available in the DigiPub library as well as the Aladdin support RoundTables within the next couple of weeks. But The Big News Is... Now, instead of capturing GEnieLamp, you can """""""""""""""""""""" DOWNLOAD the magazine. No more waiting through a long capture session! Just download GEnieLamp as you would any other file here on GEnie. (We recommend Zmodem for best results.) If you prefer the old method, just turn on your capture buffer and [L]ist the magazine to you computer. (Again, this is in the planning stage and may not be implemented in time for the May 1st issue release. However, the option to _download_ GEnieLamp is coming RSN!) PLUS! Starting with this issue GEnieLamp Online Magazine is going to a """"" twice a month publishing schedule. Now you can get your favorite version of GEnieLamp (GEnieLamp ST, Mac, IBM and A2) on the 1st and the 15th of every month. AND BEST OF ALL... ~ GEnieLamp IS STILL GEnie*Basic! ~ """""""""""""""""" [*][*][*] WHY A NEW ROUNDTABLE? The GEnieLamp RoundTable was originally set up """"""""""""""""""""" primarily for the distribution of GEnieLamp Magazine. Our secondary purpose was to promote and distribute other online newsletters. But electronic publishing goes much deeper then just magazines and newsletters. Therefore, we came to the conclusion that the time has come for electronic publishing and hence, the Digital Publishing RoundTable came online. The Digital RoundTable (or DigiPub for short) is a GEnie*Value RT here on GEnie for people who are interested in pursuing publication of their work electronically whether here on GEnie or via disk-based media. For those looking for online publications, the DigiPub library offers online magazines, newsletters, short-stories, poetry, informational text files and other various text oriented articles for downloading to your computer. Also available are writers' tools and 'Hyper-utilties' for text presentation on most computer systems. In the DigiPub bulletin board you can converse with people in the digital publishing industry, meet editors from some of the top electronic publications and get hints and tips on how to go about publishing your own digital online book. As an added bonus, the DigiPub RoundTable is the official online service for the Digital Publishing Association. (Whew!) Until next month... John Peters [GENIELAMP] [*][*][*] ,_____ ,_____ (__ | (__ | || | | | | ( \ ^| |^^^^^^^^^^| | /X ^^^ \ ( \,,,,,, <_=_________________________________> Title: Never Bite a Computer Mouse Lying in the Sink Medium: Phospor Artist: Rod Martin [EOA] [DIR]////////////////////////////// A2PRO ROUNDTABLE STAFF / ///////////////////////////////// By Jim B. Couch [J.COUCH2] ______________________________________________ APPLE II PROGRAMMERS & DEVELOPERS ROUNDTABLE _____ ______ ______________________________________________ /_____|/______\ /__/|__| ___|__| Head Sysop: Matt Deatherage (M.DEATHERAGE) /__/_|__| /_____/ Assistants: Steve Gunn (A2PRO.STEVE) /________|/__/ __ __ __ Greg Da Costa (A2PRO.GREG) /__/ |__|__/______ /_//_// / Todd P. Whitesel (A2PRO.TODDPW) /__/ |__|________// / \/_/ [EOA] [HEY]////////////////////////////// HEY MISTER POSTMAN / ///////////////////////////////// Is That A Letter For Me? """""""""""""""""""""""" By Jim B Couch [J.COUCH2] o BULLETIN BOARD HOT SPOTS o A2PRO ODDS & ENDS o WHAT'S NEW? o PROGRAMMER'S CORNER o HOT TOPICS o MESSAGE SPOTLIGHT >>>BULLETIN BOARD HOT SPOTS <<< """"""""""""""""""""""""""""""" [*] CAT12, TOP24, MSG{4}..................Dynamic Slot Arbitration [*] CAT29, TOP2, MSG{1}.....About DYA/DigiSoft Innovations Online [*] CAT29, TOP8, MSG{1}..........About Simplexity Software Online [*] CAT29, TOP14, MSG{1}.....About Quality Computers Q-LABS Online [*] CAT29, TOP20, MSG{1}..........About DreamWorld Software Online [*] CAT29, TOP26, MSG{1}............About METAL/FV Software Online [*] CAT32, TOP3, MSG{1}..................................MD-BASIC [*] CAT34, TOP3, MSG{64}........................Ultra Programming [*] CAT36, TOP10, MSG{41}..............................ORCA/Pascal [*] CAT36, TOP32, MSG{1}......................................LOGO >>> A2PRO ODDS & ENDS <<< """"""""""""""""""""""""" WOW! What a busy month! I am sure that you notice this month's A2Pro GEnielamp is the biggest we have ever had. It has been very busy in the A2Pro Roundtable, and the activity is reflected in the size of this month's Lamp. Nate C. Trost (who was introduced last month) officially reports for duty this issue. Look for his fine coverage of Apple II University, the Real Time Conferences, and the A2Pro library. This issue features some tips for making your programs compatible with Seven Hills Software's The Manager, a host of new online developers, the first in a series of lessons on Procyon's GNO environment and another report from Larry Elseman, our own rambling programmer. Of course we also have all the great tips, tricks, and messages we are becoming famous for. There is a lot here, so let's get down to it! WIN A FREE WEEK IN THE BLUE PLATE SPECIAL CONTEST! It's so easy to put a """""""""""""""""""""""""""""""""""""""""""""""""" nifty file for programmers on A2Pro's main menu with our handy dandy "Blue Plate Special File" that we've decided to run a little contest to see who can upload the niftiest file for our next Blue Plate Special. The crack A2Pro staff, especially our crack librarian Todd Whitesel, will look at all the files uploaded since March 1st and pick the one we think is the neatest and niftiest file for all the programmers who hang around here, and on May 15th we'll put it up as the Blue Plate Special File. The person who uploaded that file will get a FREE WEEK in A2Pro. Bulletin board, RTC, Library -- the whole thing is free of charge for an entire week. Note that this person doesn't have to be the _author_ of the file -- just the uploader. If there are duplicates, they'll be resolved in favor of the earlier uploader. Also note that if you've uploaded a really nifty file since March 1st, you're already entered! No penalties for sharing your information soon around here! So if there's something you haven't uploaded yet because you're not sure anyone wants to see it, upload it now! You never can tell. (Of course, being the programming forum, we're after things that help programmers, not normal programs [unless they include source code]. A2 still wants all your regular programs, graphics, sounds and more besides!) --Matt (I speak for myself, not for Apple) (M.DEATHERAGE, CAT1, TOP16, MSG:46/M530) THE POWER OF GEnie's COMMAND LINE EXPOSED! Here in A2Pro, we sometimes """""""""""""""""""""""""""""""""""""""""" discuss how graphical user interfaces are easier to learn and use than command lines, but how people who know how to use the command lines can often accomplish more things easily. In fact, because most of us are programmers, many of us tend to _favor_ the command line (and confuse our users in the process). Well, the A2Pro bulletin board is a great example of how a command line can be intimidating at first but powerful if you know the options. A lot of people simply use the basic bulletin board commands -- BROwse to read all new messages, or RAM (for "Read All Marked") to read all new messages in topics you've marked. However, there are lots of options to each command if you care to type "HELP <command>" to see what GEnie has to say about it (or check your GEnie user manual, if you have one). For example, look at some of the options you can append to READ: NOText -- just show the header, not the message NOReply -- don't stop at the end of each topic for a reply. (GEM uses this) DAT>YYMMDD -- only show messages after YYMMDD. For example, DAT>930228 would only show messages posted in March 1993 or later. You can also use DAT=YYMMDD or DAT<YYMMDD for different qualifications. AUT=GENIEID - Only read messages by a given person, by GEnie mail name. CAT=xx-yy -- Only read messages in category xx through yy, or "ALL" TOP=xx-yy -- Only read messages in topics xx-yy, or "ALL" Say you want to find that great message from Mike Westerfield he posted in his category last week (since March 15), and you want to read all the messages he posted last week to check them out. You can do it in one command, like this: REA CAT=36 DAT>930315 AUT=BYTEWORKS Kinda nifty. There are all kinds of things you can do with the information in our bulletin board if you want to: o BROwse CATegory will show you all new messages in the current category only o INDex will give you a formatted index of _all_ categories and topics on GEnie you can visit. o SEArch lets you search all the topic headers looking for the word of your choice -- great when trying to find answers on things! o NAMe lets you set the nickname that appears at the top of each of your messages. o IGNore lets you tell GEnie "I don't want to see any new messages in this topic again." You can cancel this with UNIgnore -- any IGNored topics will not show up in scans of new messages. o You can do the same thing for entire categories with the "CANcel" command. Be careful, though, because if you CANcel participation in a private category (like one of A2Pro's many running beta-test categories), you'll have to be reinvited before you can change your mind. To rejoin a public category, simply SETcategory to it. In addition to all this, we archive all messages from A2Pro topics into our library when they become old, so they're still available for you to peruse without taking up space and making the bulletin board large and ponderous. You can find them all in the library, some messages going back years. Want to see messages from when System 5.0 was in development? We have some! :) If you have any questions about the bulletin board, please feel free to post a message; we'd be happy to assist you in using it better. Or send GEnie mail to A2PRO.HELP if you're uncomfortable asking a question publicly. --Matt (I speak for myself, not for Apple) (M.DEATHERAGE, CAT1, TOP11, MSG:2/M530) MORE POWER (FROM THE COMMAND LINE) In fact, the IGNore option is more """""""""""""""""""""""""""""""""" robust than I posted -- you use "IGNore PERmanently" to tell GEnie "I don't want to see new messages in this topic again". Without the "PERmanently" option, it simply marks new messages as "read" so they won't show up when reading new messages. GEnie automatically does an "IGNore ALL NEW" command when you first join a roundtable's bulletin board (or when you reenter after having been absent for 30 days) so you don't have tens of thousands of messages to be marked as new. You can also ask it to ignore all messages in the current category, or specific topics (like 3-5), or by using "ALL" ignore in all categories (like in IGNore ALL NEW). Appending "PERmanently" makes GEnie never bother you again with that topic, so be careful. :) --Matt (I speak for myself, not for Apple) (M.DEATHERAGE, CAT1, TOP11, MSG:3/M530) >>> WHAT'S NEW? <<< """"""""""""""""""" TWILIGHT II IS SHIPPING! In case you haven't already heard, Twilight II """""""""""""""""""""""" v1.1 is shipping! Finally! The number of Twilight II modules included is hovering at around forty. But this doesn't take into consideration the loads of YouDrawIt! animation files, or a few other goodies. Anyhow, my point is, now that we're shipping, G2MF and T2 IPC documentation is a step closer! You'll be impressed by the specific powers we offer from a programming standpoint! -Jim Maricondo, DigiSoft Innovations (DYA [DigiSoft:Jim], CAT29, TOP3, MSG:6/M530) ORCA/PASCAL V2.0 DISKS MASTERED I just finished mastering the disks for """"""""""""""""""""""""""""""" Pascal 2.0 yesterday, and we even have a few manuals back. Patty is meeting with a new printer as I type this in hopes of getting manuals faster. The first few flyers for Pascal 2.0 have already been mailed, and we'll continue to mail them for the next several weeks, staggering them a bit in hopes of keeping up with Pascal 2.0 orders better than we did with C 2.0 orders. In short, Pascal 2.0 is here -- but it may be a while before you get your update notice. If you're desperate (I hope! :) here's a brief rundown: o You get the 2.0 development environment, with Shell 2.0.1, PRIZM 2.0.1, Rez, DeRez, and all the other 2.0 level programs. o It's Object Pascal, now! ORCA/Pascal 2.0 implements all of the object extensions used by Macintosh Pascal compilers. As far as I know, this makes ORCA/Pascal the first object oriented language for the GS. o You get the new code generator you've heard about from C people. Here's a few execution times to wet your appetite: ORCA/Pascal 1.4 TML Pascal 2 ORCA/Pascal 2.0 fib 11.70 30.70 11.56 float 39.93 (37.29) 23.27 gamm 18.12 (13.00) 15.83 imath 16.25 50.91 0.28 prime 23.75 68.62 22.75 quick 13.20 28.30 13.20 savage 32.08 () 32.08 sets 14.34 7.84 0.53 All times are in seconds on an accelerated (8MHz) GS. All benchmarks are from the ORCA/Pascal samples disk, and all but sets are originally from Byte magazine. Times shown in parenthesis are for programs that did not run properly, either hanging or giving an incorrect result. o No more 64K limit on arrays! Arrays can now be as large as available memory. o Direct support for HyperCard XCMDs and HyperStudio NBAs. o Support for the FPE floating-point card. o Extern variables. The update is $50 plus shipping, which is $5 in the U.S. There is also a special introductory offer for folks who don't already own ORCA/Pascal, and we have bundle prices if you are ordering the Learn to Program in Pascal course or the Toolbox Programming in Pascal course. If you're interested in more specifics, and either aren't on our mailing list or don't want to wait, let me know. I can either answer questions here or send you a copy of the flyer a little early. -Mike Westerfield (BYTEWORKS, CAT36, TOP10, MSG:41/M530) SYSTEM DISK 4.0.2 RELEASE NOTES It seems (via precedent) that it's now """"""""""""""""""""""""""""""" OK to put the System Disk 4.0.2 release notes online, so here they are: Apple II System Disk 4.0.1 November 3, 1992 Contents of /UTILITIES (3.5" disk) /UTILITIES Blocks PRODOS 35 Updated to version 2.0.2 LAUNCHER.SYSTEM 16 Version changed to 4.0, copyright extended to 1992 SYSUTIL.SYSTEM 3 No change FASTCOPY.SYSTEM 41 Updated to version 1.0.1 to fix bugs copying 1.4 meg disks BASIC.SYSTEM 21 Updated to version 1.5 from System Software 6.0 UTIL.0 87 No change UTIL.1 62 No change UTIL.2 4 No change SETTINGS 1 No change COPY.ME 1 No change CLOCK.PATCH 16 New AppleSoft program. Fixes ProDOS date stamping past 1996. Contents of /UTILITIES (5.25" disk) Same as 3.5" disk, except CLOCK.PATCH is omitted because there's no room. What changed: ProDOS o ProDOS 8 v2.0.2. o KVersion ($BFFF) is $22 for version 2.0.2. o Slot 3, Drive 2 is always reserved for /RAM. The SmartPort remapping code never maps a device into slot 3, drive 2. o The message "RELOCATION/CONFIGURATION ERROR" is uppercase again (like it was in 1.9) so it will be legible on an Apple II+. After displaying the message, it now hangs with a BMI again instead of BRA, for pre-65C02 processors. o Changed the copyright message at $BF40 to start with a $00, to prevent crashes when applications use the code in the ProDOS 8 Technical Reference to remove /RAM. This code assumes there is a $00 after the last device number, which was previously not true if 14 devices were present. o Changed page-3-init table to initialize $3FB (NMI) to $00 $40 $00 instead of JMP $FF59. BASIC.System o Version 1.5 (unchanged from Apple IIgs System Software 6.0). Launcher.System o Version 4.0. The only change is the version number and copyright date. FastCopy.System o Version 1.0.1. o FastCopy now correctly determines the capacity of source and destination disks before copying. Attempting to copy between varying sizes results in the message "Disk must be same type..." and the destination disk being ejected and the user prompted for another disk. o ROM 03 Apple IIgs's using FastCopy 1.0 were forced to have disks in any drives they wished to use for copying at the time they launched version 1.0. Any drives without disks in them were ignored and not available for copying. Now allows any available drive to be used for ROM 01 and ROM 03. o The number of blocks copied from a source disk was not the actual number of blocks on the source disk but the number of blocks on the disk in the drive when version 1.0 was launched. If a 400K disk was in the drive when FastCopy 1.0 was launched, then an 800K disk copied, only 400K of the disk was actually copied. Now it reads the number of blocks on the disk at the actual time of the copy. Clock.Patch o Updated to patch 2.0.2 as well as 1.9 and 2.0.1. The year table in 2.0.2 is in the same place as in 2.0.1. Copy.Me o Unchanged from Apple II System Software 3.2. SysUtil.System Util.0 Util.1 Util.2 Settings o System Utilities version 3.1, unchanged from Apple II System Software 3.2. --Matt (I speak for myself, not for Apple) (M.DEATHERAGE, CAT7, TOP6, MSG:43/M530) >>> PROGRAMMER'S CORNER <<< """"""""""""""""""""""""""" PROCYON LOOKING FOR PROGRAMMER Apple IIGS software publishing and """""""""""""""""""""""""""""" development company is looking for a programmer to write direct-SCC access serial port drivers for the Apple IIGS computer. We will pay REAL $$ for quality work. Please call or write: (303) 781-3273 Programmer c/o Procyon Enterprises, Inc. P.O. Box 620334 Littleton, CO 80162-0334 (Message, CAT13, TOP8, MSG:/M530) NEW XCMND NEEDED Time for a new Xcmd, and a chance for someone to make """""""""""""""" some money! I want a replacement Xfcn for DisplayList. What I need is to be able to use keyboard navigation (like standardFile) to move through the list, and I want to control both the height and width of the dialog. Also Command-Selecting or Shift-Selecting must be supported to select more then one item from the list. The Syntax should be: xDisList prompt, width, height, list, btn1[, btn2[, btn3...]] Prompt: The prompt at the top of the dialog (ex. "Choose a color...") Width: Defines how wide the dialog will be (ex. 190) Height: Defines how tall the dialog will be (ex. 160) List: A RETURN delimted list (ex. "Black" & return & "Blue"...) BtnX: Button[s] to the right of the scrolling list (ex. "OK") The last button named should be the default (ex. --"Cancel","OK"-- The "OK" btn is the default btn) The function should return the buttonName, followed by the user's choice[s] in a RETURN delimited list. Ex. if the user selects "Black" from the list and then clicks "OK", the function would return OK Black If the user had also selected "Blue" it would return OK Black Blue Hmmm, another thing that I don't like about DisplayList is that when it opens up, no item is selected. Just like SFGet, the first item in the list should be selected. Of course if you want extra credit for this assignment, how about a paramter to choose which item in the scrolling list is hilighted when it opens <smile>! So whatcha'll think? Someone want a quick programming project that'll make them some $? It's also a nice thing to have on a resume ("Wrote software that was published worldwide."). -- HangTime [Script-Central] B-)> (A2.HANGTIME, CAT18, TOP5, MSG:29/M530) HOW DO I KEEP MY SLEEPING MACRO ALIVE? I know that a sleeping macro gets """""""""""""""""""""""""""""""""""""" killed by <launch>. It appears that <call> and <link> also zap it. Anyone know of a workaround? Such as a peek to determine if a macro is sleeping and which macro is sleeping and what time it's supposed to wake? That would at least allow one to store the information somewhere, then re-issue the <wake> when you returned from the call or link. ::Dan:: (D.CRUTCHER, CAT34, TOP3, MSG:64/M530) HERE ARE THE SLEEPING MACRO PEEK LOCATIONS The sleeping macro name is at """""""""""""""""""""""""""""""""""""""""" $FF00, minutes at $FF01, hours at $FF02. Have fun. (BRANDT [Randy], CAT34, TOP3, MSG:65/M530) THE INFO IS STILL THERE AFTER A LAUNCH $ff00,$ff01, and $ff02 don't get """""""""""""""""""""""""""""""""""""" overwritten when you launch another task file, the info's still there concerning the macro to wake and the time. The sleep status just gets reset. So what you could do is put a macro to sleep, launch ( and I assume call or link ) another macro set then return to the original macro set and restore the sleep status. $10d6 holds the sleep status. > 127 means a macro is sleeping. < 128 = no sleeping macros. So you could do something like A:<all: wake sa-R at 23:50 : call sa-Z in "NewMacroSet" : poke $10d6, $80 >! restore sleep flag As long as you don't put anything to sleep in the macro you <call>, <launch>, or <link> everything should be OK. (S.BEVILLE [Steve], CAT34, TOP3, MSG:66/M530) THANKS FOR THE HELP, HERE IS A FIX Thanks for the <wake> peeks. I've """""""""""""""""""""""""""""""""" come up with the following, admittedly imperfect "sleeping macro restorer". Add SA-& and BA-& to your default macro set. SA-& would be inserted just before any <call> or <link> or <launch> in which you would want the opportunity to detect and restore the sleeping macro. BA-& would be inserted just after you return from the <call> or <link>. For a <launch> it would need to be in the second macro in your default set. Of course, this assumes that the called macro doesn't do anything to variable J(6) or to memory location $f000-f002. At the least it lets you know that your sleeping macro has been prematurely awakened. <sa-&>:<all: // USE BEFORE CALL, LINK, LAUNCH j(6)=0: // initialize storage variable x=peek $10d6: // check sleep status ifnot x>127: endmacro: // if nothing sleeping, exeunt else: .AskYN "Macro sleeping. Restore it when return from task": if z=1: exit: // if "no", exeunt else: if z=0 or z>2: stop: // if other than "yes", stop else: j(6)=1 // must be "yes", set flag >! <ba-&>:<all: // USE AFTER RETURN FROM CALL ETC. if j(6)=1: poke $10d6,128: // if flag set, reset sleep status >! (D.CRUTCHER, CAT34, TOP3, MSG:67/M530) COOL PROGRAMMING TIP If you want to overcome the annoying limitation """""""""""""""""""" in TEPaintText that causes your text to be drawn in only 4 colors, set bit 2 ($0004) in the fontFlags field of your drawing GrafPort. You can do this with the QuickDraw II call "SetFontFlags". This tells QuickDraw to treat color values as a word, rather than pixel indicies when drawing text. (This isn't documented in a technote yet, so feel privileged! :-) Jim "whatshisname" Murphy (MURPH [Murph'], CAT15, TOP34, MSG:62/M530) IIE DOUBLE WIDTH GRAPHICS ROUTINE To anyone who is interested: """"""""""""""""""""""""""""""""" The following short routine will show a Double-Width Graphics screen on the Apple IIE (W/ an 80 column card ) or later models: LDA #$A0 ;Space character JSR $C300 ;initialize 80-column video BIT $C05E ;Enable 80-column graphics BIT $C057 ;Enable High Resolution graphics (Note 1) BIT $C052 ;Enable Full screen graphics (Note 2) BIT $C050 ;Make Apple show graphics video instead of text Note 1: BIT $C056 will enable Low Resolution graphics. Note 2: BIT $C053 will enable Split screen graphics/Text (T.VAGO [quasicomp], CAT2, TOP6, MSG:84/M530) BASIC SYSTEM HELP NEEDED I need help with BASIC.SYSTEM. How does """""""""""""""""""""""" BASIC.SYSTEM handle memory when it opens/closes files? I use the GETBUFR routine ($BEF5), but I don't like the idea of clearing the entire range of "appropriated" memory just to close a ml generated file. I am also not thrilled about the prospect of having AppleSoft open the file for the ml routine to use. I am writing a spooler program for use with BASIC.SYSTEM, and this is my only (current) pitfall. (T.VAGO [quasicomp], CAT7, TOP4, MSG:79/M530) A LITTLE INFORMATION ON BASIC.SYSTEM AND FILE BUFFERS BASIC.SYSTEM """"""""""""""""""""""""""""""""""""""""""""""""""""" allocates 1K of memory for each file it opens, above HIMEM. This is documented in Appendix A of the ProDOS 8 Technical Reference Manual. Uncle-DOS has a long-standing recommendation not to use FREBUFR because it frees _all_ buffers allocated with GETBUFR, including any programs run in this BASIC.SYSTEM session before yours. This is more important in eight-bit machines than on the IIgs, since on eight-bit machines things like memory- resident utilities have to stay in the lower 128K. That means unless you're sure you're going to quit BASIC.SYSTEM when your program is done, your buffers will probably stick around. You can just use 1K of memory and call the PRODOS 8 MLI to OPEN the files yourself, and manage that memory -- you'll just have to make sure that you put the 1K where no one will step on it. The memory map in Appendix A will help you do that. --Matt (I speak for myself, not for Apple) (M.DEATHERAGE, CAT7, TOP4, MSG:80/M530) COOL FREBUFR TRICK There is a cool trick of setting the ceiling for """""""""""""""""" FREBUFR so that it doesn't release all memory allocated with GETBUFR. All you have to do is adjust the RSHIMEM location in the BI global page. By default, this is $96 (for $9600 = default HIMEM). If you allocate a new buffer with GETBUFR that you don't want any subsequent FREBUFRs removing, just set RSHIMEM to point below your buffer. This is how the Object Module Manager is able to load and unload modules (of course, unloading modules in the middle of others and shifting modules up to fill in the gap is much trickier to do, especially when you have to dynamically relocate code on the fly -- but that's why I wrote the OMM, so nobody else would have to! (MORGAN-DAVIS, CAT7, TOP4, MSG:81/M530) TELL E MORE ABOUT THE OBJECT MODULE MANAGER I am interested in this """"""""""""""""""""""""""""""""""""""""""" Object Module Manager, and how it "is able to load and unload modules". The spool routine I am trying to make is going to have the main portion of its code sit in the auxiliary 64K of RAM, and just have a main memory interface and the file buffer in main memory. It is also going to function as an improved printer port. It will be able to interface with other routines (such as AppleSoft menu and string management, for example) also sitting in the aux memory. I am worried that a ml program may execute that won't install into this main memory interface, and that puts itself below BASIC.SYSTEM in the usual way (calling GETBUFR, and so forth). If I have one (or more) ml created files open while this is happening, it will sit below these files. When I perform an ml OPEN/CLOSE, it will affect the main memory such that the "normal" routine that installed itself would possibly be overwritten, and C- R-A-S-H my system, causing a messy situation. Also, I can't just allocate 1K of memory for dedicated use for ml files, because future routines I may write may also need this file buffer. The very action of OPENing and CLOSEing files takes up a lot of time in of itself. The solution I am considering is a dynamic ml file buffer handling routine, such as must obviously exist in BASIC.SYSTEM. Finally, I can't use the main memory fur much more than the interface and the ml file buffers, because AppleSoft space is already at a premium. Thus, my (real) problem. I want to be able to open/close as many files as I can, but maintain the integrity of any other programs that install below BASIC.SYSTEM without having to close up all of the ml files, de- allocate the memory for those files, and re-allocating memory and opening the files back up after these other programs install themselves. Am I just blowing in the wind here? Or is there a workable solution? (T.VAGO [quasicomp], CAT7, TOP4, MSG:83/M530) HERE IS THE SCOOP! The OMM installs itself below BASIC.System and adds a """""""""""""""""" few management commands to Applesoft via the ampersand feature. The &LOAD GET and &LOAD FRE commands are used to shuffle code modules from disk, into memory, and back out of memory to reclaim space. The modules themselves are standard 6502 programs that have a special 16-byte header at the beginning that simply tells the OMM about the code inside, such as the module's size, program counter origin, address of an ampersand command table, and so on. Each module has three separate parts: code, immediate mode table, and data section. The code part is obvious -- it contains only executable 6502 or 65C02 code (it can contain 65816 code, as long as you don't adjust register sizes and reference immediate values). The immediate mode table is just a list of 16-bit addresses that refer to locations within the code part. The data section includes just that. Because of this format, the OMM is able to relocate modules in memory and they'll keep on running as if nothing happened. So you can load modules A, B, C, D, and E, in that order, and when you remove module B, the OMM is able to shift C, D, and E upwards the fill in B's gap, reclaiming memory. Modules can include a list of ampersand commands that the OMM will parse and then call upon the module to service. This makes it really easy to add a BASIC interface to your modules. Modules can also send messages to other modules, including the OMM itself. This inter-module communication makes it possible to have a multitude of interconnected modules that, together, perform seamless integration. This is how our ModemWorks program is able to provide so much functionality within the limited memory space. > The spool routine I am trying to make is going to have the > main portion of its code sit in the auxiliary 64K of RAM, and > just have a main memory interface and the file buffer in main > memory. Interesting. A print spooler is one of the examples we give as suggested module types. This is because print spooling involves working with various serial or parallel interfaces, yet the main file spooling code is the same. The OMM lends itself well to this kind of situation because you can devise your own printer interface modules and load only the one that is needed to support the attached printer. A second module would hold the interface code to the spooler itself. And the spooler code could reside in auxiliary memory since the OMM doesn't touch it. > I am worried that a ml program may execute that won't install > into this main memory interface, and that puts itself below > BASIC.SYSTEM in the usual way (calling GETBUFR, and so forth). All modules under the OMM follow a standard scheme for memory management, so you'll never have any trouble with this. > If I have one (or more) ml created files open while this is > happening, it will sit below these files. When I perform an ml > OPEN/CLOSE, it will affect the main memory such that the > "normal" routine that installed itself would possibly be > overwritten, and C-R-A-S-H my system, causing a messy > situation. This can't happen under the OMM. > Also, I can't just allocate 1K of memory for dedicated use > for ml files, because future routines I may write may also need > this file buffer. You can allocate a fixed 1K buffer in the data section in an OMM module, and as your code section expands, the only impact is on free memory for BASIC. You wouldn't need to worry about added code spilling into a buffer. > The very action of OPENing and CLOSEing > files takes up a lot of time in of itself. The solution I am > considering is a dynamic ml file buffer handling routine, such > as must obviously exist in BASIC.SYSTEM. Right -- this all depends on how your spooler works. You can use a dynamic file buffer as long as you stay in control while you read and move the spooled data into a larger buffer in the auxiliary memory space. Then you'd close the file and release the buffer. If you put a cap on the size of the file you can spool, then this is a good solution. But if you want to be able to spool unlimited size text files, you'll have to have a fixed open file buffer in your module. This is because a dynamic buffer is valid and usable only while your module has control. If you keep the buffer allocated and return to BASIC operations, there's no way to insure that your buffer remains intact. A BASIC program would only need to &LOAD GET another module or call FREBUFR and you're in trouble. > I want to be able to open/close as many files as I can, but > maintain the integrity of any other programs that install below > BASIC.SYSTEM without having to close up all of the ml files, de > allocate the memory for those files, and re-allocating memory > and opening the files back up after these other programs > install themselves. Since you can only spool one file at a time, why not keep only one file open at a time? Keep a list of files remaining to be processed and open each one as the previous one is closed. I don't see any reason to open up dozens of files at one time -- and under ProDOS 8 I don't think you can open up any more than a few anyway. (What is the limit, 8 FCBs?). Each time you open a file, you have to give it a dedicated File Control Buffer. So, its desirable to keep as few files open as possible -- not the other way around. (MORGAN-DAVIS, CAT7, TOP4, MSG:85/M530) >>> HOT TOPICS <<< """""""""""""""""" IS THERE ANY INTEREST IN SLOT ARBITRATION? How many people are still """""""""""""""""""""""""""""""""""""""""" interested in seeing some form of slot arbitration available, even though Apple believes it can't work with all programs and peripherals due to interrupt concerns? --Matt (I speak for myself, not for Apple) (M.DEATHERAGE, CAT12, TOP24, MSG:4/M530) YES IT COULD BE VERY HANDY I think it would be extremely handy. There """""""""""""""""""""""""" are always going to be programs that it can't work with; the concern is now to implement slot arbitration in a manner that works with old programs in the best manner, not necessarily how to get old programs to use slot arbitration. I wonder, however, if slot arbitration concerns would be better addressed with two drivers: a mouse driver and loaded serial drivers. With these, GS/OS programs could access the built-in mouse and serial hardware without affecting I/O cards in slots 1,2, and 4. -Jawaid (PROCYON.INC, CAT12, TOP24, MSG:5/M530) OR EVEN VERY USEFUL To answer your question, YES, I think slot """"""""""""""""""" arbitration would be VERY useful! -Bryan (SOFTDISK.INC [Zak], CAT12, TOP24, MSG:11/M530) LOADED DRIVERS MIGHT BE A BETTER IDEA In judging how important the Slot """"""""""""""""""""""""""""""""""""" Arbiter is, we need to look at its intended purpose - allowing people to use both built-in ports and slot cards at the same time. My point is that the job could be done (except for Slot 5/SmartPort) with GS/OS drivers as opposed to the Slot Arbiter - IMHO, you're likely to spend much less time writing drivers than trying to get the slot arbiter to work with every conceivable device and situation, especially since so much software ignores existing GS/OS drivers (like the generated serial drivers). So, I'd say that a device-independent mouse driver and loaded serial drivers would beat fixing/finishing the slot arbiter, even if such a task was possible. -Jawaid (PROCYON.INC, CAT12, TOP24, MSG:14/M530) ANY SOLUTION WOULD BE FINE Matt, you've asked whether we want slot """""""""""""""""""""""""" arbitration or smarter drivers that don't need it. I really don't care... I am definitely in favor of any solution that would let me: 1. Put a SCSI card in slot 1, 2, 3, 4, or 5 and still use the printer driver, AppleTalk, and a modem. 2. Put a floppy controller for either 800K, 1.4M, or 140K floppy disks in slot 5 and still use the direct connect for 800K or 1.4M drives. 3. Put a SCSI card in slot 3 and still use the text screen, especially the text tools. I think either method would do these, so I don't care which you use. I simply have a problem that could be solved, and vote wholeheartedly for any solution that works. -Mike Westerfield (BYTEWORKS, CAT12, TOP24, MSG:32/M530) HOW IT WORKS IS UNIMPORTANT Like Mike, I really don't care how it works, """"""""""""""""""""""""""" just as long as it does. When I worked on MouseTalk (seems like eons ago), we made it a point to be able to share IIGS slots with the built-in ports by accessing the slot's device directly -- not using any slot firmware. So you could put a Super Serial Card in slot 1 for a modem, plug a printer into the Printer port, and be able to use both at the same time. Likewise, you could have a device in slot 4 and still use your mouse. This all worked great as long as you stayed in MouseTalk. Of course, not many took advantage of it because so much other software couldn't deal with shared slots and ports. (MORGAN-DAVIS, CAT12, TOP24, MSG:33/M530) >>> MESSAGE SPOTLIGHT <<< """"""""""""""""""""""""" Category 12, Topic 24 Message 34 Wed Apr 14, 1993 M.DEATHERAGE at 16:14 EDT Doing the serial stuff isn't a problem that way, Morgan -- the 8530 softswitches for direct programming are not tied to any slot, so if you stay away from the firmware you're always OK. Using the _mouse_ without having the slot switched in could be problematic, especially during interrupts but not as much so under ProDOS 8 as under GS/OS. These applications that use the slot register ($C02D) cause one of the compatibility problems for implementing slot arbitration -- neither the Slot Arbiter nor GS/OS is spec'ed to say that the slot register will be the same after a GS/OS call as before it. If you fiddle with $C02D, make a GS/OS call and expect it will still be the same way afterwards, you may be incorrect. This probably means GS/OS would have to save and restore $C02D on every call when calling a device that wasn't "swapped in" in the Control Panel settings, and it might still cause problems for interrupt code. --- Let's back up one more time and look at the issue again. The idea of a Slot Arbiter is pretty simple -- GS/OS drivers have a four-bit slot number instead of three bits, and that's enough to describe seven internal and seven external slots. All device drivers for peripherals are supposed to do a fifteen-slot search ($F through $1) as described in GS/OS Device Driver Reference. If a slot arbiter becomes available, GS/OS will start using it and peripherals in slots and ports can co-exist. GS/OS will automatically swap in the appropriate slot/port before dispatching to a device driver, and would probably swap it back out before returning for above compatibility reasons. This means this and only this: Any peripheral you access through a GS/OS driver would not have to be switched in through the Control Panel to be accessed. It has no effect on ProDOS 8 or on things that are _not_ accessed through GS/OS, like the mouse, direct serial access and the text tools (unless redirected through the OS as in ORCA 2.0). The major problem with a slot arbiter is interrupts. If you have code that deals with hardware during interrupts, and that hardware is slot-based, and you do not attempt to use the slot arbiter or make sure that hardware is available before tickling softswitches, you'll cause problems. The Slot Arbiter can't save and restore the slot configuration to "default" around interrupts because it would add too much to the interrupt latency. One possible solution is to provide a way through a CDev to mark some slots as "non-switchable" so they never get changed from their control panel settings. This makes that hardware effectively take two of 14 positions, but that's no worse than it is now. I'm also unsure if slot arbitration would let AppleTalk run without having an "AppleTalk" slot. Not having an "AppleTalk" slot would definitely kill AppleTalk in ProDOS 8. --- The other proposed solution (originally Jawaid's) is to not implement a slot arbiter but implement mouse code and maybe serial port code (in an unspecified way) so that those two particular peripherals have no slot dependencies, arguing that this will solve most people's problems and be less work. I'm not sure it would be less work, since GS/OS already has the Slot Arbiter design built-in, but there's a possibility. Also, GS/OS is in RAM and can easily have stuff like this added as new modules. Mouse code and serial firmware is in ROM and can't easily be patched sometimes. It looks like SSW 6.0.1 will patch _Multiply as a way of fixing a bug in _MenuSelect and _PopUpMenuSelect, as an example of how tricky such things can get. Todd suggested that drivers simply disable interrupts around accesses to hardware-dependent locations and manipulate $C02D themselves. Unfortunately, this isn't suitable for GS/OS drivers, many of which rely on firmware on the peripheral card to do the work. Disabling interrupts around all calls to the firmware a driver might make isn't realistic, especially for the Apple drivers which rely heavily on the ROM in the IIgs to save memory space. --- So if anyone has more comments, we're listening. :) --Matt (I speak for myself, not for Apple) [EOA] [INT]////////////////////////////// INTERNET FRIENDS / ///////////////////////////////// Comp.sys.apple2.programmer needs you! """"""""""""""""""""""""""""""""""""" By Matt Deatherage [M.DEATHERAGE] >>> VOTE FOR COMP.SYS.APPLE2.PROGRAMMER <<< """"""""""""""""""""""""""""""""""""""""""" To all our friends on the Internet: Please feel free to redistribute this message; I'm not going to post it myself. Just don't edit it. Those of you who like to program Apple II computers and regularly read news on the Internet may now that there's a vote currently in progress about reorganizing the comp.sys.apple2 newsgroup into four separate newsgroups. Much discussion has been carried about this vote, but we'll only focus on one part -- the creation of a separate comp.sys.apple2.programmer newsgroup. Being affiliated with a commercial online service, you might think we'd be against this idea because it would create competition. The truth is -- and anyone who's held this job can back it up -- that those of us doing this on commercial online services aren't doing it to get rich. We're here for very little or no pay because we like helping Apple II programmers of all ages, skill levels and interest areas. We've worked hard in A2Pro over the years to create a strong resource for programmers to find help. Our libraries have thousands of files aimed at programmers doing HyperStudio scripts, AppleWorks macros, desktop programming, BASIC programs, Pascal, C and assembly-language programming from the introductory to the extremely obtuse. The libraries are organized by Todd Whitesel in a scheme that allows you to find samples even if you don't know exactly what you seek. Our bulletin boards keep a few thousand programming messages around at any given time, ready for you to browse through because they're also organized into clear, easy-to-navigate topics. We have real-time conferences a few times each week where you can talk to other programmers at a predetermined time (you don't have to spend hours hoping you'll find someone). We produce A2 University, where you can learn anything from introductory Assembly Language programming to intensive data compression -- at no additional cost from normal connect rates. We also bring to our members the companies that work the most with programmers and give them their own areas and libraries here so they can help you better. You'll find information from Procyon, Softdisk, GS+ Magazine, Lunar Productions, Morgan Davis Group and The Byte Works all here, along with DigiSoft, Simplexity, Quality Computers, DreamWorld and now Josh Thompson helping METAL and FutureVision programmers. We feel this is the strongest collection of Apple II programming assistance people assembled anywhere outside of KansasFest, and we're proud to give them a forum to help the programmers. We've managed to produce this area for programmers and keep it very focused, programmer-friendly, full of content and free of noise. This is partly because we have a great sister forum in A2 where those wanting non-programming answers can almost always find them, and partly because we have a fantastic bunch of A2Pro members who give us plenty of programming stuff to talk about and never leave us wondering what to do next. Our colleagues on Delphi, CompuServe and America OnLine also strive to help programmers out for the love of it, and they offer a lot of the same services (though we're obviously biased towards our own great mix). We feel very comfortable that what we do here is important and well-received by Apple II programmers around the world, and we welcome another forum for these topics. To this end, we heartily encourage all members with Internet newsgroup access to read the Call for Votes in comp.sys.apple2 or news.announce.newsgroups and to vote "YES" for the creation of comp.sys.apple2.programmer. We'll continue to do our part by doing what we can to make A2Pro a great place for programmers. We'll continue to produce GEnieLamp A2Pro and we'll post it to the new newsgroup if it passes the vote, and we'll announce our special events for programmers to the new newsgroup as appropriate, using the keyword "A2PRO", so you can choose to read or not read them as you please. We would ask all Internet users to please respect this convention and use the keyword "A2PRO" when posting messages concerning our services to assist those who don't want to see them. Last time this came up for a vote, the required minimum one hundred votes were not cast and the proposal failed due to lack of interest. One new newsgroup will not stop petty bickering, flame wars, jealousy or immaturity that has so often plagued comp.sys.apple2, but it will help those who want to program stay focused on their issues and make better software for everyone. Please support this effort and vote "YES" for comp.sys.apple2.programmer. --Matt Deatherage [*][*][*] [EOA] [RAM]/////////////////////////////// RAMBLINGS / ////////////////////////////////// Ramblings from a 'Wannabe' Programmer """"""""""""""""""""""""""""""""""""" By Larry E. Elseman [L.ELSEMAN1] >>> IKTRFTAANYDT!* <<< """""""""""""""""""""" Remember when you first started to program in BASIC? What did you do when you came across a new statement, something that you just weren't sure what its function was? Did you write code using the new statement, just to see what would happen? Did you just stick to statements that you were already familiar with and feel confident using? Or did you seek the information you were looking for in the programming manual or a reference book? For me, with BASIC anyway, I would look up the new statement to see if it was something that I could use in my code. I've always been curious to see what the technical references had to say about a statement. Of course, many times if I had sample code to look at I could figure out the statement's function on my own. From there I would practice using the new statement by writing a few lines of code to get the syntax down and see the results of using the new statement. Okay, so you're now learning a new language step by step, statement by statement and using the manual and reference material to help you over the rough spots. You have an idea that you would like to program, but you don't know how to implement it into your code because it seems to call for some statement that you have not yet come across. Now what do you do? Aside from asking someone on A2Pro (surely someone there knows a solution :)), you really don't have much of a choice except to seek help from the manual. But how do you look for a statement which may not even exist, and if it does, can you be sure that you'll recognize it when you see it? I bring this up because it has happened to me on more than one occasion. In my pre-GEnie days the only option I had was to spend a lot of time reading the manual. And as you probably know, most language manuals do not exactly keep you on the edge of your seat! What would invariably happen to me is that I would get side-tracked. I would start out searching for something in particular and find something else that would catch my interest. That's not a bad thing of course, because it would still be a learning process, yet it gets frustrating. I think most Apple programmers started programming using the built-in AppleSoft BASIC. If that's true, wouldn't it be neat if other language manuals had an index which cross-referenced BASIC statements to the equivalent or comparable statements in that language? Are there manuals which already do this? If so, I have not seen them. Personally, I tend to think in terms of BASIC when I find myself groping for the correct statement in the language that I am currently learning. I realize that most languages have statements, instructions, mnemonics which have no counterpart to BASIC. In those instances a clear example of what the instruction does and how to implement it in a program would be sufficient, and most manuals that I've seen do at least that much. Perhaps someone on A2Pro (or someone reading this article!) could write a statement cross-reference index of the most popular programming languages for the Apple II line and upload it to A2Pro? Does this have any merit? Would I be the only one interested in such a beast? Is the Apple II too far gone that it would be of little value? Would I be the one to have to write it?... Egads! All right, time for a pop-quiz, no pencil or paper required. What did you do when you read the title of this article? A) I really didn't think much about it. B) I started searching the article for an explanation. C) I started to read the article, but that goofy title kept bugging me. I had to stop and look for an explanation. D) Title? What title? You mean that bunch of letters at the beginning? I thought it was just baud-barf! To see how well you did, load the following program into your BRAM (Biological Random Access Memory) and execute it. 10 If INPUT$ <> "B" and INPUT$ <> "C" then PRINT "Wrong!": Goto 30 20 PRINT "Congratulations! You are a programmer who uses the manual when confronted with the unfamiliar!" 30 PRINT 40 PRINT "* I Know The Reason For This Article And Now You Do Too!" 50 END [EOA] [DEV]////////////////////////////// DEVELOPER'S CORNER / ///////////////////////////////// News from the A2Pro Online Developers """"""""""""""""""""""""""""""""""""" By Jim B.Couch [J.COUCH2] >>> ONLINE SUPPORT IN A2PRO <<< """"""""""""""""""""""""""""""" CAT COMPANY === ======= 29 Independent Developers Online <---- NEW CATEGORY! 30 Procyon, Inc. 31 Softdisk Publishing 32 Morgan Davis Group (MDG) 33 GS+ Magazine 34 JEM Software 35 Lunar Productions 36 The Byte Works Each month this column feature highlights and news from various developers who provide support via A2Pro. This month's big news is that A2Pro has added a whole new category for independent software developers! INDEPENDENT DEVELOPERS PROVIDE ONLINE SUPPORT A2Pro is _very_ proud to """"""""""""""""""""""""""""""""""""""""""""" announce that we now have five developers providing on-line support for programmers (and anyone else) who use or program for their products in Category 29 of the bulletin board (option 1 on the A2Pro main menu)! Now providing support are: Quality Computers - Phantasm Simplexity Software - Desktop Enhancer Digisoft Innovations - Twilight II v 1.0 DreamWorld - 3200's, Dreamgrafix. METAL/FV Software - METAL, METAL/FV Category 29 has a number of topics related to the products these developers provide, stop by and check them out: CATEGORY 29 -- INDEPENDENT DEVELOPERS ONLINE Topic 1 -- About Independent Developers Online Topic 2 -- About DYA/DigiSoft Innovations Online Topic 3 -- Announcements & General Discussion Topic 4 -- Writing Twilight II Modules (G2MF) Topic 5 -- Writing Twilight II Savvy Programs Topic 8 -- About Simplexity Software Online Topic 9 -- Writing Desktop Enhancer Blankers Topic 14 -- About Quality Computers Q-LABS Online Topic 15 -- Writing Phantasm Effects Topic 20 -- About DreamWorld Software Online Topic 21 -- Writing DreamGrafix Externals Topic 26 -- About METAL/FV Software Online Topic 27 -- Programming in METAL >>> NEWS FROM THE INDEPENDENT DEVELOPERS <<< """""""""""""""""""""""""""""""""""""""""""" DIGISOFT PROVIDES TECHNICAL LEVEL SUPPORT ON A2PRO Hello everyone! We're """""""""""""""""""""""""""""""""""""""""""""""""" happy to be finally representing ourselves on the technical level, here in GEnie's A2Pro! If you've never heard of us before, DYA, which stands for Digital Youth Alliance, was formed in January 1990 when a few of us got together to pool our efforts into creating new software and data for the Apple IIgs. In 1990 we started off with several animation demos, such as TextScroll II, Photon, Skull, and Mother Earth. These served as good exercises in learning to program the GS; they also show off some interesting animation and related effects. Later on in 1990, we teamed up with Jonah Stich to produce the original Twilight 1.0 shareware screen saver - the first publicly released modular screen saver for the GS. It was a great hit (for shareware standards) but had several inherent bugs that never were fixed (despite several planned attempts to try.) Anyhow.. in 1991 we brought out two large projects: the DYA SoundSmith ASIF Instrument Disk #1, and Exhibit A. The instrument disk was many months in the making, held up to insure that the instruments included were all in tune with each other and also of the highest quality possible. The instruments were sampled from scratch on an Audio Animator (with the exception of a few done on my old SuperSoniq Digitizer) from a variety of high quality sources such as CD's and a Roland D-70 synthesizer. In the end, we wound up including over 100 new hi-quality instruments. Many of these can also be converted to make great System 6 sounds, using programs slideshow. The disk is selfbooting (using legal methods so it should work just fine with the new FDHD controller card!) and each picture is precompressed to allow us to fit the most possible pictures on one disk. Exhibit A features the best 3200 color fades you'll find anywhere, combined with some impressive 3200 color pictures (converted from GIFs with an early version of Prism), in an elegant selfbooting selfcontained package. Take a look at it; you'll be impressed! Along the way, we've released a handful of other utilities/etc, including an init called MONITOR which replaces the "alternate display mode" CDA on ROM01 GS's with "visit monitor" (this is a temporary change and is reset when you reboot), several different shell utilities, an animation "technote" which tries to explain some beginning to advanced GS animation techniques, as well as a handful of other different things I'm probably forgetting offhand.. Which brings us to 1993! Currently we're working on completing Twilight II v1.1. Twilight II (T2) we feel represents the state of the art in screen savers for the GS. Many ideas were borrowed from After Dark on the M*c, and many features just aren't present anywhere else! Among the features and aspects of Twilight II we will be supporting here are: o an extensive and carefully planned effect module format (the G2MF), which includes support for many powerful features, including some not present in any other screen saver, for any other computer. o the comprehensive Twilight II inter-process communication routines that allow your programs and Twilight II to coordinate efforts and make for the most pleasant computing experience for the user If anyone has any questions or comments on these two current issues, or any other related ones not mentioned here, we'd be happy to entertain them in one of the other DYA folders here in cat 24. Thanks! -- Jim Maricondo, DigiSoft Innovations (Message 1, CAT29, TOP2, MSG:1/M530) TWILIGHT II G2MF VAST STEP FORWARD Twilight II employs an advanced custom """""""""""""""""""""""""""""""""" module format, very similar to CDevs. Twilight II modules can be written in assembly language, C, Pascal, or any combination of the three, and have filetype $BC (generic load file) and auxiliary type $4004. The modules included with Twilight II have been written in assembly and C (Twilight II, the CDev, is in 100% assembly.) Writing Twilight II modules can be a very fun and satisfying task! The Generation 2 Module Format (G2MF), as implemented by Twilight II, represents a vast step forward in performance and power over other conventional module designs for GS screensavers. We have designed it with the present and future needs in mind, and it sports a great deal of flexibility. This is the place to learn all about the G2MF, how you can best work with it, and how it makes many aspects of the task of writing modules much easier!! Jim Maricondo DigiSoft Innovations (Message 1, CAT29, TOP4, MSG:1/M530) MAKING YOUR PROGRAM TW II FRIENDLY Via System 6's new inter-process """""""""""""""""""""""""""""""""" communication (IPC) capabilities, Twilight II and other programs can coordinate efforts by communicating with each other. Twilight II sports a comprehensive set of routines that inform programs when the screen is blanking and unblanking and also allow applications to control certain aspects of Twilight II. By following a few simple guidelines (most of which already recommended by Apple, for good reason), you can insure full compatibility with Twilight II. Many of these suggestions will make your programs much more friendly to the system as a whole, and to other programs as well. This results in a much more pleasant computing experience for the user.. This is the place for more information on T2's IPC routines. We are just waiting to work with you! Also, if you discover any bugs or would like to share features you'd like to see in a future version of Twilight II, please let us know! Jim Maricondo, DigiSoft Innovations (Message 1, CAT29, TOP5, MSG:1/M530) SIMPLEXITY SOFTWARE HISTORY Simplexity Software is about 1.5 years old, """"""""""""""""""""""""""" and is dedicated to the premise that people should NOT work with computers: Computers should work with people! Our name comes from the idea that any application should be simple and easy to use on the outside, with as much of the complexity as possible hidden away on the inside as possible. Thus, Simplexity! Our first product, introduced in August, 1991, was the Desktop Enhancer. It attempted to create a single, cohesive user interface for customizing the desktop environment, and I believe it succeeded fairly well. Unfortunately, it provided only limited features, and was quickly eclipsed in February, 1992 by Signature GS, its major competitor at the time. Massive rewriting ensued, and the Desktop Enhancer v2.0 was released in August, 1992. Packed with more features than were earlier believed possible (due to the benevolent influence of System 6.0) it clearly out- shone its competition in almost every area, but the inevitable early bugs prevented its unqualified acceptance. Having dealt with all known problems, Desktop Enhancer v2.01 is now available for the ridiculous price of $24.95 (U.S.) Our second product, ContactsGS, was introduced in August, 1992, and received rave reviews from every quarter. It is a simple NDA which acts like a Rolodex on the desktop, with the added convenience of automatic phone dialing. Its simple, elegant design not only allows it an amazing degree of versatility, but also allows me to declare it a paragon of simplexity. It is available for a mere $14.95 (U.S.) More products are on the way, (three under development even as you read this!) and each one, like the Desktop Enhancer and ContactsGS, is being written with the utmost attention to three principles: Reliability, useability, and compatibility with current and future system software and applications. We are always interested in new ideas for programs, and occasionally (depending on several factors) are interested in publishing other people's programs. We can be contacted in several ways: GEnie: E-mail to S.McQueen1 America Online: E-mail to SIMPLEXITY Voice phone: (714) 283-3957 U.S. Mail: Simplexity Software 13045 Chapman Ave., Ste. 302 Orange, CA 92668 (S.MCQUEEN1, CAT29, TOP8, MSG:1/M530) WRITING DESKTOP ENHANCER BLANKER MODULES Greetings to one and all! This """""""""""""""""""""""""""""""""""""""" topic will provide a clearinghouse for detailed information about writing screen blanker modules for the Desktop Enhancer. Any questions will be answered in full, and discussions on the subject are welcome. (Discussions off the subject may be accepted, or not, depending on how far off the subject they are! :) A screen blanker program for the Desktop Enhancer is like nothing which has been done on the Apple IIgs before. It can be considered to be similar to a dialog filter procedure, but it is NOT the same! Its freedoms (and responsibilities) are amazing, yet once you understand its limits, it can be one of the easiest types of program to write. Full documentation on how to write blankers is included in the User Guide, and in the demonstration disk. I'll just re-iterate the high points. You may use any tools you need, as long as the application has already started them up. By copying resources into your own handles and closing the resource file, you may have access to your own resources, eliminating the 16-byte limit on the parm field, and allowing easy creation of icons and other standard structures. You must remember to return control to the calling application after each screen update pass, to ensure that the system can continue any processes it may be performing. You must draw only to the current port to prevent problems when the screen blanker is cleared from memory, and you may NOT issue an _AcceptRequests call to install your own request procedure. Even with all that, I cannot imagine any animation that cannot be done using a Desktop Enhancer screen blanker program. It's just that some of the more complex animations may not be as smooth as you might like. Don't worry about that - if you want incredible animations, you should write an animation application: a screen blanker is not the most important process the computer can be running, so it should not hog the whole system all the time for the sake of mere prettiness. Well, those are the barest basics, including a statement of design philosophy. :) If you want to try something Really Different, this is the place to learn how! -Steve (Simplexity Software) (S.MCQUEEN1, CAT29, TOP9, MSG:1/M530) QUALITY COMPUTERS LOOKING FOR NEW PRODUCTS Well, here I am. I'm here to """""""""""""""""""""""""""""""""""""""""" help you if you have an urge to develop new software for Q Labs, Quality Computers' software publishing division. Since this IS A2Pro, we'll limit our discussions to Apple II and IIGS products, although products with multi-platform potential are of particular interest to us right now (we're converting our TestBank program from IBM to Apple II and Mac, for example). We ARE interested in new products! If you have one that's finished, you can pack it up and send it to: Quality Computers, 20200 Nine Mile Rd., St. Clair Shores, MI 48080 USA. Attn: Tom Veselenak. If you're in the process of working on one, I'm here to answer any questions you may have about QC. General questions & answers, I suppose, should go in this topic. (QC [Jerry], CAT29, TOP14, MSG:1/M530) WRITING BLANKER MODULES FOR PHANTASM In this topic we'll discuss writing """""""""""""""""""""""""""""""""""" blanker modules ("effects") for Phantasm, the screen blanker that's part of SIGNATURE GS, published by Q Labs. Since the new Twilight II will also run Phantasm modules, your modules will be available to a wide audience indeed! I'll be uploading the official guidelines for writing modules tomorrow. I've got to warn you, though -- I'm not a IIGS programmer. The A2Pro folks have assured me that they'll help me out with any technical questions. By the way, we're currently trying to put together a disk of blanker modules. If you're into graphics programming, this could be your chance to make a few cool bucks with a weekend's worth of work. We're interested mostly in buying the modules, but if you'd like a royalty arrangement we'll try to work something out. (It depends on how many authors end up being involved in the project. As you can imagine, splitting royalties sixteen different ways could end up being a bit of a nightmare for us...) Use this topic to discuss various aspects of writing Phantasm Effects. (QC [Jerry], CAT29, TOP15, MSG:1/M530) WELCOME TO DREAMWORLD SOFTWARE ONLINE DreamGrafix - (note the spelling :) """"""""""""""""""""""""""""""""""""" Is the only 16/256/3200 color paint program available for the IIGS. If you are a developer, you must have this piece of software, because it will allow you to use 256 color pictures in your software. Also, external commands can be written to create shape tables, font tables, or any number of things. DreamGrafix is commercial, the list price is $99.95, street price will vary. DreamVoir - A combination slideshow w/ background SoundSmith player. It displays 16/256/3200 color pictures while playing SS songs. v1.31 includes 3200 color fades and a lot of new options. DreamVoir is $10 shareware. DuelTris - The last (?) *tris clone you will ever need. :) DuelTris is a two player competitive game, similar to Tetris. It features incredible 256 color pictures and great SS music. DuelTris has a feature called the DuelLINK, which allows you to pass 2-4 lines that you complete to your opponent. DT also has 6 different special pieces which help you lower your puzzle, and/or inverse your opponents controls. You can play two players or 1 player vs. the computer. DuelTris is $15 or $20 shareware. $20 includes the Limited Edition packaging, which features a 3.5" jewel case, a color insert and a printed manual. DreamVoir and DuelTris are available in the A2 libraries, do a file search by my email address: S.CHIANG4 . There are also several DreamGrafix demos available, including an fully working version, minus save print, and view full screen. Topic organization: DreamGrafix externals - This is the area to discuss external commands. We have written several EXTs for DG. Import PrintShop GS graphics, color to greyscale, Area calculator, etc. The rest are reserved. We have some forth coming programs which will also feature drop in modules. -- Steven Chiang (S.CHIANG4, CAT29, TOP20, MSG:1/M530) DREAMGRAFIX TECHNICAL INFORMATION COMING SOON This topic is for """""""""""""""""""""""""""""""""""""""""""""" DreamGrafix technical questions. Any non-technical questions should be directed towards A2 category 18 - "DreamWorld Software Online". The two major topics are DreamGrafix External Commands and DreamGrafix Documents. The external format has not been posted, as it the documentation hasn't been fully completed. I will post it as soon as it is finished. The DreamGrafix document file format is documented, and I will upload it to A2Pro shortly. Again, this topic is for questions related to either aspect of DG. -Steve (Message 1, CAT29, TOP21, MSG:1/M530) USING MULTIPLE PALETTE PICTURES This topic is for using multiple palette """"""""""""""""""""""""""""""" pictures in your software The Apple IIGS SHR hardware is capable of displaying 16 color per line w/ 16 palettes per screen. This means that you can define sections of the screen to correspond to palette 0, another section to palette 1, and so on for up to 16 palettes. This is known as 256 color mode, because 16 palettes of 16 colors is 256 colors. I feel that this mode is one of the best kept secrets on the Apple IIGS. So what, you say? Well, this doesn't sound all that exciting, but there is a lot of potential. For instance, take any game, if your play area is in the center of the screen and you want the score and maybe the title of the game at the top of the screen. For the game play area, you can set it to one palette of 16 colors, use another set of 16 colors for the score, and another 16 or 32 for the title of the game at the top of the screen. Big deal, I don't write games... okay, then take something like SoundSmith, or ModZAP. (soniq doesn't use the effect, I don't think. DreamGrafix Demo 3 would be included in this category though) The pump bars (vu meter) are very colorful. This is also done with palette tricks. Basically, the program always writes to the screen (Sorry, no QD2 here :) in a single color like 1. So if the thing was 4 pixels wide it would be just one lda #$1111 stal $012000,x per line of the bar. The picture is defined in such a way that every 1-2 lines is represented with a different palette. Then to vary the colors of the bar, color 1 is changed on each of the palettes. For you HyperMedia folks, you can combine 320 and 640 modes, to have 640 text with 320 pictures. As soon as I work out a couple of the details, DG will support this. If any of you have seen DuelTris, I use a mixed 320 w/ 640 mode screen wipe. The desktop is 640 mode, and the sliding bar and the picture that is uncovered is in 320 mode. Palette rotation requires very little CPU time, because you are only manipulating a few words of memory. Spy Hunter GS uses palette rotation to move the ground. However, it's not your typical palette rotation, it is more SCB rotation, because he defines two palettes, one with a light g and dark green, and one with a dark grey and a light green. Then by manipulating the SCBs he creates the illusion of movement. Space Harrier Demo from the FTA also used scb rotation for the ground movement. And the California Demo from the GSAllianc used palette rotation to move the checkerboard ground left to right. If you have any questions or ideas, post them here. You don't need even need DreamGrafix to use 256 color pictures. You can simply set the SCBs and palettes up from within the program... The end product is what counts and multiple palette pictures definitely give the artist more freedom. I didn't mention this above, but the 256 color mode is built into the hardware, and thus takes no overhead time. (S.CHIANG4, CAT29, TOP22, MSG:1/M530) METAL/FV SUPPORT COMES TO A2PRO Metal/FV is a full-features electronic """"""""""""""""""""""""""""""" bulletin board system for the enhanced Apple IIe or later with at least 128k of RAM. These topics are for questions and comments regarding the development of Metal/FV as well as questions and comments regarding the Metal language. Question about setting up and using Metal/FV (configuration, etc.) should be directed to the Metal/FV area in A2 -- Category 41, Topic 15. (J.THOMPSON1, CAT29, TOP26, MSG:1/M530) >>> NEWS FROM PROCYON INC. <<< """""""""""""""""""""""""""""" ANOTHER FREEBIE FOR GNO OWNERS I just uploaded the 'copycat' utility. """""""""""""""""""""""""""""" It's going to be file #3260. Copycat basically connects one GNO tty to another, so you can (for example) use a terminal on the printer port to do modem sessions off of the modem port (while the console is free to do IIGS stuff with- this includes desktop programs and what not!). All in all, just another example of the power *real* multitasking gets you. Jawaid (PROCYON.INC, CAT30, TOP3, MSG:76/M530) NOTE: Be sure to check out Jawaid's series on programming for GNO. The series begins in this issue of the A2Pro GEnieLamp! Search for [GNO] -Ed. >>> NEWS FROM SOFTDISK PUBLISHING <<< """"""""""""""""""""""""""""""""""""" CHANGES AT SOFTDISK Recently we had a big re-org here at Softdisk, and """"""""""""""""""" one of the results is that we (Softdisk and Softdisk G-S) are now part of the "Apple Development Group", or ADG as we like to call it. ADG is Softdisk, Softdisk G-S and Diskworld (our Macintosh product). So, something we are looking for are articles that can apply to all platforms. For example, recently Joe Kohn wrote an article about HP printer solutions for Softdisk G-S. In about an hour one of our Mac people "ported" it to Diskworld. As another example, Tim Tobin is writing us an article on removable mass storage options (SyQuest, Floptical, Magneto-Optical, etc) and he's writing for the GS but keeping in mind the Macintosh. So, where does this leave us? Well, we'd like to see some of the following articles: o controlling home electrical stuff with your GS/Mac (X-10??) o solutions for the handicapped o CD-ROM, the ins and outs o ??? If you're interested in writing an article on any of the above, or have ideas of your own, please, contact us...we pay anywhere from $75 to $250 for articles. You can reach us at this address (SOFTDISK.INC) or you can call Lee Golden at 1-318-221-2173. -Bryan (SOFTDISK.INC [Zak], CAT31, TOP3, MSG:25/M530) SOFTDISK STILL LOOKING FOR CD-ROM ARTICLES I just wanted to let everyone """""""""""""""""""""""""""""""""""""""""" know that we've been flooded (well, a couple dozen anyway :) by people wanting to do AppleWorks GS articles and how-tos for us! This is great! (Please, if you are interested, contact us! We have plenty of room!) We've also found someone to write us an article about X-10 stuff, but we are still looking for an article all about CD-ROM options on the IIGS. If you'd like to make $75-$250 -- let us know! - Bryan (SOFTDISK.INC [Bryan Zak], CAT31, TOP3, MSG:26/M530) >>> MORGAN DAVIS GROUP NEWS <<< """"""""""""""""""""""""""""""" MDG Announces BASIC Programmer's Workshop SAN DIEGO, California -- """"""""""""""""""""""""""""""""""""""""" April 1, 1993 -- The Morgan Davis Group announced the BASIC Programmer's Workshop, a software bundle consisting of three popular products: MD-BASIC 2.0, RADE 1.0, and the Object Module Manager 1.3. The $99 collection of high-powered BASIC programming tools offers Apple IIGS users substantial savings, over $80 off the combined suggested retail price. ``The BASIC Programmer's Workshop is a great value. We use these products daily in our own development, so they have to be complementary,'' said company president Morgan Davis, ``Create your programs with MD-BASIC, test them with RADE, and be impressed by the power of the OMM when you run them.'' MD-BASIC is a professional Applesoft BASIC development tool for creating programs using the Apple IIGS desktop interface or any command line shell. The new 2.0 version offers a luxurious desktop mode complete with menus, multiple windows, and integrated text editing features. MD-BASIC translates source code into highly optimized Applesoft programs that are smaller and faster than can be achieved in Applesoft's native ``immediate'' mode, yet they're 100% compatible with every Apple II computer. Beagle Compiler users can compile MD-BASIC-generated programs for additional speed. The MD-BASIC language is based on Applesoft with a number of extensions: free-form layout, named labels (no more line numbers), long and descriptive variable names, modern commands like IF- THEN-ELSE, WHILE-WEND, REPEAT-UNTIL, and DO-LOOP, and features found in C compilers like conditional code processing and #define macros. MD- BASIC catches mistakes like unbalanced parenthesis, undefined and unreferenced labels, misspelled variable names, and other common errors before your programs run. GS+ magazine wrote, ``Applesoft may never get better, but writing programs in Applesoft just did. MD-BASIC changes the way people think about Applesoft.'' The package includes sample source code, interface files, code libraries, and a 100-page manual. RADE (Real-time Applesoft Debugging Environment) is a full- featured diagnostic tool that isolates errors in real-time without disturbing the BASIC environment. You can interrupt the execution of your program at any point to examine or change the contents of variables, set breakpoints, step through code one line at a time, or review the ``history'' buffer that records your entire debugging session. InCider/A+ magazine wrote, ``RADE is fast, powerful, full-featured, and easy to use. It's a breath of fresh air . . . a throwback to the days of tight, efficient programming.'' RADE comes with a 46-page manual and sample software that walks you through a complete debugging session. The Object Module Manager (OMM), an extension manager for Applesoft programmers, makes it possible to add external commands to enhance BASIC programs. Modules are loaded and unloaded as needed, using memory efficiently. They can also communicate with each other, making integration effortless. Developers can easily create their own custom modules. The OMM comes with sample source files in ORCA/M (APW) and Merlin assembler formats, sample programs, a starter set of modules (including AmperWorks: 35 powerful BASIC commands to pick up where Applesoft leaves off), and 67-page manual. The BASIC Programmer's Workshop is available now, directly from the Morgan Davis Group, for $99 plus $7.95 for shipping and handling (overseas S/H is $17.95). CA residents add sales tax. Institutional six-packs are available for $499 each. (MORGAN-DAVIS, CAT32, TOP1, MSG:7/M530) MD-BASIC 2.0 SHIPS WITH DESKTOP/COMMAND LINE INTERFACES SAN DIEGO, CA-- """"""""""""""""""""""""""""""""""""""""""""""""""""""" April 1, 1993-- The Morgan Davis Group today announced the immediate availability of MD-BASIC 2.0, a fully integrated Applesoft BASIC development environment for the Apple IIgs. The new version adds a familiar desktop interface, complete with pull down menus, windows, and mouse support. MD-BASIC can be used as a stand-alone application or as an external tool for command-line shells allowing users to choose the environment they prefer. MD-BASIC translates source code into highly optimized Applesoft programs that are smaller and faster than can be achieved in Applesoft's native ``immediate'' mode, yet they're 100% compatible with every Apple II computer. Beagle Compiler users can compile MD-BASIC-generated programs for additional speed. The MD-BASIC language is based on Applesoft with a number of extensions: free-form layout, named labels (no line numbers), descriptive variable names, modern commands like IF-THEN- ELSE, WHILE-WEND, REPEAT-UNTIL, and DO-LOOP, and features found in C compilers like conditional code processing and #define macros. MD-BASIC catches mistakes like unbalanced parenthesis, undefined and unreferenced labels, misspelled variable names, and other common errors before your programs run. The new desktop interface features multiple windows, cut, copy, and paste editing, choice of font style and tab settings, search and replace, printer support, and Applesoft-to-source conversion built in. Its traditional shell interface includes the processing and conversion capabilities found in the desktop mode. The desktop mode can even be accessed from the shell environment. MD-BASIC requires an Apple IIgs with System 6.0 or newer. A shell such as ORCA or GNO is optional. The package includes sample source code, interface files, code libraries, and a 100-page manual. MD-BASIC retails for $89.95. A $30 upgrade is available directly from the Morgan Davis Group. Include $5 for shipping and handling (overseas S/H is $15). CA residents add sales tax. Institutional six- packs are available for $449 each. (MORGAN-DAVIS, CAT32, TOP1, MSG:8/M530) MDG INSTITUTES MAJOR PROLINE PRICE REDUCTION SAN DIEGO, California-- """""""""""""""""""""""""""""""""""""""""""" April 1, 1993-- The Morgan Davis Group today announced a major price reduction for ProLine, the popular Apple II bulletin board system developed by Morgan Davis and supported since 1984. Prospective BBS buyers can now purchase ProLine for $159.95, down $100 from its former $259.95 suggested retail price. The new price reflects MDG's commitment to Apple II owners by offering the finest product and support available for the best value ever. Recently, ProLine was awarded five out of five stars in the December 1992 issue of inCider/A+. The leading Apple II/Macintosh magazine wrote, ``ProLine is as powerful as many UNIX minicomputer-based systems, yet amazingly, it runs on a standard Apple II. ProLine is top-notch. You can run ProLine as an independent on-line system, but it gains a new world of capabilities if you network it with other systems.'' ProLine can be linked to a global network, known as the Internet, consisting of educational, industrial, and government computers. Many commercial information services are also part of the Internet: America Online, BIX, CompuServe, Delphi, GEnie, MCI Mail, and others. Networked users can exchange electronic mail, bulletins, and software world-wide, with delivery time measured in hours, or even minutes. A leading BBS publication, Boardwatch Magazine (June 1991) noted, ``ProLine is a network of Apple II systems that are not only tied to each other, but routinely carry Internet News Groups . . . something we just didn't expect. The speed and power of this BBS running on an Apple II were quite impressive.'' In addition to Internet networking, ProLine offers terminal emulation compatible with all personal computers, high-speed modem support, and a full complement of file transfer protocols. ProLine does not restrict the types of computers that can access it so it appeals to the entire computing community. Now with a new price, ProLine is the most cost-effective solution for schools, clubs, businesses and user groups. ProLine 2.0 comes with three 800K disks and a 350-page reference manual. An enhanced IIe or Apple IIGS, 64K RAM, and at least 2MB free on a ProDOS-formatted drive is required. ProLine is available immediately, direct from the Morgan Davis Group, for $159.95 plus $8 shipping and handling (overseas air S/H is $25). CA residents add sales tax. Institutional six-packs are available for $799 each. Purchase orders accepted. Morgan Davis Group customers who purchased ProLine after April 1, 1993, for $259.95 will receive a $100 rebate. (MORGAN-DAVIS, CAT32, TOP1, MSG:9/M530) MDG OFFERS LOW-COST INTERNET GATEWAY SAN DIEGO, California-- """""""""""""""""""""""""""""""""""" April 1, 1993-- The Morgan Davis Group today announced uMDSS, a mail distribution subsystem protocol for Unix systems. uMDSS makes possible the exchange of Internet electronic mail and news with microcomputers unable to communicate over traditional UUCP channels, like the venerable Apple II. While available at the university level, Internet access is cost prohibitive for most grade schools still equipped with labs full of aging microcomputers. ``Compared to a direct Internet connection--about $24,000 per year-- and the complexities of special hardware and system administration, it's obvious why K-12 students and the computer-using community have been unable to use the Internet. It's supposed to be available to everyone, but it's too expensive,'' explains MDG president Morgan Davis. ``We're building a network of Internet e-mail access points on inexpensive personal computers. Instead of pouring thousands of dollars into new hardware and monthly access fees, schools can retain their investment in yesterday's hardware and still get today's technology for the cost of a normal telephone bill.'' uMDSS is like UUCP in many ways. uMDSS sites connect to UNIX hosts over serial-based connections. The caller logs in with an account name and password, then identifies itself by its site name and a secondary password. Session information is exchanged, and files begin moving between systems. When all files have been exchanged in both directions the session is complete. uMDSS maintains site lock (LCK) files, session ``.Status'' files, and a detailed log file. It also includes a uustat- like function for reporting job and connection statistics. Integration with local mail services is transparent. At the transfer level, an XMODEM-based 4K-packet protocol provides near 100% or better transfer efficiency, and is compatible with high-speed modems and ports. Client support is currently available for the Apple II through the ProLine BBS developed by Morgan Davis. ``ProLine is a network of Apple II systems that are not only tied to each other, but routinely carry Internet News Groups . . . something we just didn't expect,'' wrote Boardwatch Magazine in a June 1991 review. The uMDSS interface makes this possible. ProLine was recently awarded five out of five stars in an inCider/A+ review. The leading Apple II/Macintosh magazine wrote, ``ProLine is as powerful as many Unix minicomputer-based systems, yet amazingly, it runs on a standard Apple II.'' Support for PC and Macintosh computers is expected later this year. The uMDSS host software is available immediately for $59.95 per site, and can be mailed directly from the Morgan Davis Group to a customer's electronic mailbox. The electronic package contains complete C source code for compilation on most Unix systems. It also includes full documentation on installation and integration with local services such as smail and cnews. A six-host site license is available for $299. (MORGAN-DAVIS, CAT32, TOP1, MSG:10/M530) FOR MORE INFORMATION CONTACT MDG Founded in 1989, the Morgan Davis Group """""""""""""""""""""""""""""""" produces unique, powerful, and innovative software for a variety of computers. For the Apple II, MDG also publishes ProLine, a BBS with Internet access; ModemWorks, a communications toolbox; RADE, a real-time Applesoft debugger; VirusMD, a virus detection and repair utility. Call or write for a free product catalog. Contact: Morgan Davis Group 10079 Nuerto Lane +1 619 670 0563 TEL Rancho San Diego +1 619 670 9643 FAX CA 91977-7132 USA +1 619 670 5379 BBS >>> NEWS FROM THE BYTE WORKS <<< """""""""""""""""""""""""""""""" WHAT IS THE DEAL WITH THE MANUALS? There have been some questions about """""""""""""""""""""""""""""""""" our manuals, so I wanted to explain exactly what is happening, and where the delays are coming from. First, a bit of history. A couple of years ago, we started doing some courses for the Apple IIGS. The first few versions of our first courses were serialized, and were not sent to many people, so we copied them instead of printing them. That worked well, so we kept right on copying when the book form of the courses came out. Looking around, we found we weren't alone. Apple, APDA, and a lot of other companies were using copied pages for short -run products or products that changed frequently. Last year, we ended up reprinting ORCA/M manuals. There were two things that bothered us about this process. The first is that the print quality, while not bad, wasn't as good as we were getting from copiers. True, a good printer can outperform a copier -- but we weren't able to pay for the very best printers. In addition, we had to buy 1000 books to get even a modestly good price break. It ended up costing about $13,000 for the print run -- and we may never sell all of those books. For a company our size, tying up $13,000 per product in inventory cost just doesn't work. (Incidentally, we've checked around. Most printers would charge us $17,000 to $25,000 for the same job. For the quantity and quality, we got a good price.) Well, to make a long story short, by cutting the height of the manual by 1/2 inch, we could copy it. We checked, and found two places that would copy the books for a very good price. We're still using printed covers. We switched back to spiral bindings, since you can do a few of those, where perfect binding (like on a paperback book) is somethign that has to be done to a lot of books at one time. In addition, most of the people we talk to like the new spiral binding better than our old wire binding, and almost everyone liked that better than perfect binding. The printing is better quality. We can even order 10 books and still get a good price. Our inventory price dropped to about $400 for the covers. The price per book dropped to about $9 to $10, depending on the book. And, even better, I can publish programs like Modula-2, which I'm not at all sure will sell 1000 copies, and would not normally be able to risk $13,000 on. The disadvantage is that printing books is tricky. It takes a good operator and a good copier in perfect repair. It also takes time. We're getting a fairly steady stream of books back, but the quantity doesn't keep up with the orders. We've worked out most of the kinks, and have two suppliers, now, but it's going to take some time to get caught up. Since we could no longer afford to produce GS software with 500 page books the old way, though, there wasn't much choice. Still, once the system runs smoothly, we can publish products profitably that couldn't be released at a profit, even on a Mac. You'll see several of those this summer, I'm happy to say. In fact, the changes we've made will allow us to continue producing GS products even if we start creating programs for other computers, too, and I'm pretty happy about that -- I like my GS! Mike Westerfield (BYTEWORKS, CAT36, TOP31, MSG:1/M530) WORK BEGINS ON 'HYPERLOGO' PROJECT We're currently working on a Logo """""""""""""""""""""""""""""""""" interpreter for HyperStudio. This language will eventually be released as a scripting language for HyperStudio GS, and will be built into HyperStudio Mac. We'll probably release stand- alone Logos for the GS and Mac, too, but our plans are not as firm in that area. Specifically, we really haven't decided whether we will publish it ourselves, or pass it on to a company that can reach the K-6 market better than the Byte Works can. Here's a quick run-down on the broad outline for the Logo interpreter, as installed in HyperStudio: o It's called HyperLogo. o Logo has a lot of variants, like BASIC. Ours is Apple Logo with a few commands removed (think "no text screen"). I've also added a few commands from Object Logo (but not objects) and a few commands that are specific to our Logo (mostly for HyperStudio access, plus one other area that will be pretty cool, but I'd like to keep private for now). o In Hyperstudio, you will have up to three windows open when you use Logo. The first, and obvious one, is the script window. You can also open a console window, where you can type Logo commands for immediate execution. Among other things, you can examine and modify your Logo workspace. The last window is the Turtle Window, which you can use to try Logo graphics effects from the Console window. (Normally, of course, Turtle graphics commands draw to the active card.) This is all still in a very fluid state. I'd appreciate any questions or comments you might have. Mike Westerfield (BYTEWORKS, CAT36, TOP32, MSG:1/M530) [EOA] [GNO]/////////////////////////////// GNO TUTORIAL SERIES / ///////////////////////////////// Programming the serial ports. """"""""""""""""""""""""""""" By Jawaid Bazyar [PROCYON.INC] >>> GNO PROGRAMMER'S TUTORIAL <<< """"""""""""""""""""""""""""""""" WELCOME TO THE GNO PROGRAMMING SERIES Hi folks! We've been a little bit """"""""""""""""""""""""""""""""""""" quiet lately because we've been hard at work on the GNO 1.1 upgrade in the little free time we have these days. However, to stir up some excitement (and advertise GNO 1.1 a bit :-) we're going to do a little series on programming GNO's serial communication subsystem. Depending on the response, we'll continue to fill out the following outline of a larger "course": 1. What is GNO, and Why Should I Care? 2. Processes A. Programming processes B. Manipulating processes 3. Inter-process Communication A. Pipes B. Semaphores 4. Communications and the TTY 5. ?-? You'll notice the ? marks; these sections are left open for future additions. Basically, if there are parts of GNO's kernel that anyone has questions on, I'm going to write up a document that hopefully explains it in detail. These sections will appear one by one both in GEnieLamp A2Pro, and in the library with annotated sample source code showing off the techniques described in the section. As the outline fills out, I'll post updated versions to this "Programming GNO" area. Since my writing and free time tend to be somewhat irregular, and since I don't have the time right now to do chats, I've decided not to do this via A2U. I hope the information will still be useful. (PROCYON.INC, CAT30, TOP1, MSG:8/M530) INTRODUCTION TO GNO/UNIX TERMINAL DEVICES UNIX (and GNO) communicate with """"""""""""""""""""""""""""""""""""""""" the outside world almost universally with the TTY interface. TTY is shorthand for "Television Typewriter", and its use is somewhat anachronistic, but TTY is easy to pronounce, so its usage has stuck (along with other anachronistic UNIX terms :-) A more modern term would be 'terminal', and TTY and terminal will be used interchangeably in this section. TTY and terminal will be used to refer to the UNIX interface to terminals, rather than the terminals themselves. The terminal interface is a highly configurable and flexible system. It allows programs to configure all aspect of terminal interface, like baud rate, CR/LF translation, and input mode. GNO TTY Drivers --- --- ------- GNO/ME provides three different TTY (character) devices: the GNO Console driver, and a driver for each of the IIGS' built-in serial ports. Since these disparate devices are all treated the same way by the same interface, programmers get a completely consistent interface to terminals, no matter what the actual device is (this is what we refer to in GNO documentation and advertising). What this means for the programmer is a whole new realm of power - testing a program meant to communicate with other computers over a modem, for example, can be tested with user input on the console. The three drivers all have default names, and the names of the serial devices are user-configurable by editing the etc/ttys file. .ttyco - the GNO console driver .ttya - IIGS modem port .ttyb - IIGS printer port In addition, there is a special file, '.tty', that when opened returns a reference to the terminal the program was executed from. This allows programs to read or write the terminal, even when input/output redirection was used on the program. For example, a debugger could use '.tty' to access the terminal (completely through the OS) even when the program being debugged was executed with "program < foo > bar". If the program was executed from the console, then opening .tty would be like opening .ttyco; using .tty the program doesn't need to know what terminal it was run from. Input Modes ----- ----- There are three basic input modes: cooked, CBREAK, and RAW. Cooked mode is the normal method of operation. It provides some basic input editing by keeping a buffer of input and allowing the user to modify that buffer with backspace (and other editing features, depending on the version of UNIX or GNO in question). Programs reading from a terminal in cooked mode only receive input hen an entire line has been typed (and the return key pressed), even if the program only requested a single character. This is done to help minimize operating system overhead. CBREAK stands for 'character break', and it allows programs to read input a character at a time, houtiting for an entire input line first. Certain high-level features of the tty are still active, like interrupt keys (more on these below) and CR/LF translation. A text editor like Emacs or VI would use CBREAK mode, as would any interactive program that needs to be able to detect single keypresses. The final mode is RAW mode. This provides completely raw access to input data: no character translation or input editing is performed, and the interrupt keys are disabled. You'd use raw mode for a file transfer protocol, for instance. Special Characters ------- ---------- There are a number of special characters that TTYs detect and act on in cooked and CBREAK modes. A table of these follows. The special characters are completely user-configurable, and thus they are named and followed by their default values. Any characters which are only present in GNO 1.1 are marked with an '*'. Char (Def) Description ------ ----- ----------- t_intrc ^C Standard interrupt character. When this is typed, a signal (SIGINT) is sent to the process(es) that are in control of the terminal. Unless the program has installed a handler for this signal, GNO will cause the program to terminate. t_quitc ^\ Similar to t_intrc, except that programs are not allowed to install handlers for this interrupt. The signal SIGQUIT is sent to the process, and GNO will terminate the program. t_stopc ^S When typed, this character will cause GNO to cease output to the terminal. Old Apple II cronies will remember this from AppleSoft BASIC; it's an extremely useful feature. t_startc ^Q This character is used to resume output to the terminal after a t_stopc was used. *t_eofc ^D When a tty receives this character, it is treated as if an end-of-file condition had been received on the terminal file. Any partially entered input lines are returned to the process making the read, along with a GS/OS End Of File error ($4C). t_suspc ^Z Sends the signal SIGTSTP to the process in control of the terminal. Unless the program has installed a handler for this signal, GNO will cause the program to be suspended. That is, the program will stop running, but remains in memory and can be restarted where it left off. *t_dsuspc ^Y Just like t_suspc, except that the suspension happens only when the character is read by the program, not when it is typed. *t_rprntc ^R Reprints the current input line, in the event that it was garbaged by output from a background process or line noise. (PROCYON.INC, CAT30, TOP1, MSG:10/M530) DEVICE CONTROL AND OTHER FUN WITH IOCTL() Mode changes and configuration """"""""""""""""""""""""""""""""""""""""" of the terminal devices is accomplished with the GNO Kernel call ioctl() (I/O Control). ioctl() takes three parameters: ioctl(int fd, unsigned long tioc, void *iod) fd - file descriptor (GS/OS refnum) of the terminal to affect tioc - several bit fields that describe the operation to occur. Simply use the predefined macros in the <sys/ioctl.h> header file iod - pointer to input or output data Now, when we say "file descriptor" we also mean a GS/OS refNum, such as is returned from OpenGS called on one of the terminal devices, or the C statement open(".ttya",O_RDWR) (assuming you have the GNO libraries installed - the standard ORCA/C version of open() will not work correctly in this regard as it does not return a real GS/OS refnum). You can also do terminal I/O through C's stdio (fopen, etc) but you have much less control over the way incoming data is handled due to buffering (and if you turn buffering off you might as well use the low level calls open/read/write/close). There are four data structures that can be accessed with ioctl() that allow programs to set the TTY mode. The first (and most commonly used) is: struct sgttyb { char sg_ispeed; char sg_ospeed; char sg_erase; char sg_kill; short sg_flags; } sg_ispeed and sg_ospeed set the input and output baud rates, respectively. Since no modern computer system transmits at a different baud rate than that which it receives at, sg_ospeed is obsolete and both input and output baud rates are set with sg_ispeed. "So what exactly do I put in sg_ispeed and why is it a char/acter instead of an int?" you ask? there are C macros that equate to predefined baud rates; for instance, the 2400 baud setting is 'B2400'. The interface defines some baud rates that aren't used on the IIGS and also some IIGS-supported baud rates aren't defined in the macros; this was done for full UNIX compatibility. However, The major baud rates (B300, B1200, B2400, B9600, B19200, and B38400) are all defined so communications with any modern devices is no problem. Obviously, the GNO console doesn't have a serial chip in it, so the baud rate settings are ignored. The sg_erase character is the ASCII character that means "backspace" or "delete previous character" when the TTY is in cooked mode (recall that cooked mode supplies user-level input editing). This is configurable so that it can be defined to the key that is most convenient on whatever terminal you're using. The GNO default for sg_erase is 0x7F (the delete key), which corresponds with the fact that most people logged into GNO will be using a IIGS (or even a Mac). sg_kill is not supported; it is meant to delete all input on the current input line. The final field in the sgttyb struct is sg_flags. A fair number of flags that control the TTY's mode of operation are present in this field. The most important of these are (taking the macros that are defined to the bit values) RAW, CBREAK, CRMOD, and ECHO. Note that there is no 'COOKED' flag; COOKED mode is set by making sure RAW and CBREAK are off (set to zero). The CRMOD flag controls how the TTY deals with outgoing and incoming carriage returns and line feeds. With CRMOD turned on, outgoing CR's are converted into a CR/LF sequence; both the GNO console and many terminals (like the DEC VT100) need this. You can tell if a program accidentally left CRMOD turned off before exiting by the appearance of everything on a single line; CR's are left as-is, and since the definition of CR is 'move the cursor to the left of the current line', you get a very disconcerting effect. Using the shell command "stty crmod" will turn the CRMOD bit back on. The final flag that you'll be interested in immediately is ECHO; if ECHO is turned on, everything that is typed at the terminal will be echoed back to the terminal screen. There is a difference here between GNO and UNIX; in GNO, all input processing happens in a process; under UNIX, a good deal of processing occurs in interrupt handlers. Thus, in GNO characters are only echoed back when they are read by the program in question (this ends up being each time you type a key on the keyboard, because when we say "process reads the data" we include the part of the process that is inside the operating system - in this case, the GS/OS ReadGS call on the TTY file). As an example of the use of the ECHO flag, a program that needed to read a password in (invisibly) could turn off the ECHO flag; if you had a program that was communicating through one of the serial port TTYs, you would also want ECHO turned off. For more details on various flags available in sg_flags, see GNO's TTY(4) manpage (GNO 1.1 has a lot more). The second major structure available for inspection via ioctl() (at least in the TTY drivers) is the local mode word. This contains flags that control a number of terminal-support functions. Most of them are there to deal with old terminals that (for example) don't have the tilde key, or don't support lowercase characters (gasp! They do exist!). The particular flags supported by GNO 1.0 or 1.1 are described more fully in the TTY(4) manpage. The third structure is winsize; this structure is designed for use with windowing systems. For example, say a pseudo-tty is active with a text editor. If the user changes the size of the window, the window manager does an ioctl() call to change the window size structure; at that point, the tty driver sends a SIGWINSZ software signal to the process controlling the terminal (more about process groups and control terminals next week). If the program doesn't support the window size record, the signal will be ignored; however, programs like the Stevie text editor that _do_ trap that signal can then update their displays and internal variables to account for the change. Height and width of the content area of the window are stored in both pixel and character units. The final two structures, ltchars and tchars, both allow user (and software) configuration of all of the interrupt characters the TTY recognizes. Recall that interrupt characters are keystrokes like ^C and ^Z. A program can turn off the effect of those keys by setting the value of the appropriate character to -1 (or $FF), in case they don't want the user to interrupt them but also don't need a signal handler for them (or can't install a signal handler, as in the case of SIGQUIT). The user may configure the characters to be anything they like. [ Next, we discuss process groups and actual use of the ioctl system call. We'll also start discussing how to write TTY-savvy software ] (PROCYON.INC, CAT30, TOP1, MSG:15/M530) [EOA] [MAN]/////////////////////////////// THE MANAGER TIPS / ///////////////////////////////// Programing Tips For The Manger """""""""""""""""""""""""""""" By Seven Hills Software [SEVENHILLS] >>> PROGRAMMER INFO CONCERNING THE MANAGER <<< """""""""""""""""""""""""""""""""""""""""""""" USING THE "BACKGROUND" TEST APPLICATION The "Background" application """"""""""""""""""""""""""""""""""""""" demonstrates how an application works in the background. In order for it to operate in the background, the "Can Receive Null Events" option is checked, and to let other applications operate in the background while the test application is in the foreground, the "Can Release Null Events" option is also checked. Background creates a standard menu bar and opens a "Null Event Counts" window that displays how many Null Events are occurring. The Foreground number increments when the application is currently in use (it stops when an NDA or another application is being used). This number increments very quickly because Null Events occur frequently when an application is frontmost. The Background number increments when an NDA or another application is in use. This speed at which this number increments depends upon what the active application is currently doing. The test for being in the background is simple: If the front window is a system window, then the application is in the background. This test is made in Background's main event loop, so each time either number increments you know that the demo has made one pass through its event loop. If you open almost any NDA, the Background number increments whether or not The Manager is set to allow background Null Events. This is because most NDAs allow the main application's event loop to continue executing. To demonstrate the multi-tasking that The Manager provides, launch an application that has been set up to release null events (use TM Application Setup for regular applications; use TM Preferences to control the Mini Launcher). NOTE: If you launch an application that has been set up to Release Null Events but the Background number does not increment, then activate the Finder or Mini Launcher and check the "Allow Background Null Events" option in the TM Preferences dialog box. It is interesting to watch the Background.Demo operate as you use an application: o Position the "Null Event Counts" window in the lower-right corner of the screen. o Activate/Launch an application that is set to release Null Events. o Resize the window(s) so you can still see the values in the Null Event Counts window. o Use the application. Note that the background number increments only during null events, and only when conditions are "friendly" (e.g. a modeless window is open, not when an alert is displayed, etc.). MULTI-TASKING In order for your application to be multi-tasking friendly, """"""""""""" it should call GetNextEvent or TaskMaster as often as possible. This is true whether you are in the foreground or background (if you are in the foreground it's friendly because you're giving background applications a chance to work; if you are in the background it's friendly because you won't hog too much background time). Although we recommend handling update events for the best looking result, for these calls you can even use a NIL mask...the important thing is to make the calls as often as possible. TIP: If you have a big outer loop with several inner sub-loops, one strategy for handling update events is to include TaskMaster(NIL) within the sub-loops and a TaskMaster(Updates) in the big outer loop. HOW MULTI-TASKING WORKS Let's say you have one foreground application and """"""""""""""""""""""" two applications processing in the background. When the foreground application calls GetNextEvent or TaskMaster and there is a Null Event (nothing else happening), The Manager passes control to the first background application, which makes one trip through its current event loop then control is returned to the foreground application. The next time a Null Event occurs in the foreground application, The Manager passes control to the second background application. Because time is shared between foreground and background applications, applications that want to run in the background should be very careful not to stay in control very long (otherwise the foreground application's use will be interrupted). NOTES ABOUT USING WINDOWS Always use non-dialog windows for long """"""""""""""""""""""""" processes. To determine if The Manager can activate another application it does GetWFrame and tests the bit that indicates it's a dialog frame. If a dialog is open, The Manager will not activate another application. If another application cannot be activated, your application can't be put into the background. Another reason for using non-dialog windows is because non-dialog windows will always be opened in the application's layer, whereas alerts/dialog windows will interrupt the user and the current foreground application (annoying and confusing). STANDARD QUICKDRAW As demonstrated by the Background test program, you """""""""""""""""" can use QuickDraw calls to draw into your windows and there will be no ill effects on the foreground application (just follow the standard recommendation to save/set/restore the GrafPort as necessary). DIRECT SCREEN WRITING If your application writes directly to the screen, """"""""""""""""""""" follow two rules to insure compatibility with The Manager (these are also standard Apple rules, but they are rarely followed): RULE #1: Create a dummy window that fills the entire screen. If you draw directly to the screen without creating a window, when the user clicks on what appears to be contents of your window, The Manager will detect a hit in another application's window and will activate that application (or will detect a hit on the desktop and will activate the Finder). By creating a window that fills the screen, when the user clicks The Manager will know the mouse click belongs to your application. RULE #2: Draw ONLY IF your window is frontmost (test _FrontWindow). This should be obvious...if you draw when another window is in front you will overwrite that window's contents. NOTES ABOUT USING ALERTS/DIALOGS If a background application presents an """""""""""""""""""""""""""""""" Alert, that alert is put up in front of the application currently in use. You can see how this works by choosing "AlertWindow every 100 Null Events" from the Background test application's Test menu, then activate another application. Each time the Background Null Event Count is a multiple of 100, an alert will be presented. Start using the other application (e.g. if you're in Teach, start typing a document). Before long an alert from the Background application will interrupt you. If you acknowledge the Alert and keep typing your document, the alert will interrupt you again. Pretty soon you'll know why you do NOT want to interrupt the user with alerts! Not only is it annoying when a background application forces itself upon the user, but it is also very confusing for an "XYZ" application alert appear while you are using application "ABC"! We provided this test option to demonstrate that it is possible to present an alert, but even though it is possible you shouldn't do it. The recommended alternative is to use a modal, but non-dialog, window instead (__DoModalWindow is perfect). As a window it will not interrupt the user, and when the user re-activates your background application, the modal window will be patiently waiting for a response. NOTE: Version 1.0.0 of The Manager has a problem that prevents _DoModalWindow from working properly (in the process of opening the window the application is made active, and the system might crash). If you are developing software to be "Manager-Aware" please contact Seven Hills Software for more information. NOTE: If you insist on using alerts, include the application name within the alert (e.g. "Message from XYZ: File already exists."); otherwise the user won't know where the alert comes from. For example, Apple's Teach application displays an alert when its OOM queue is called. If you launch an application that attempts to allocate a huge memory handle (perhaps to purge memory), Teach's OOM queue routine displays an "out of memory" alert (which has no bearing on the current application, and is very confusing because the alert says nothing about the message coming from Teach). IMPORTANT: Never make Standard File calls while you are in the background! IMPORTANT: Text based applications that can work in the background must not display anything when in the background! Here's the test (which works whether or not The Manager is active): If the Window Manager is started (check _WindStatus), do NOT display text if _FrontWindow returns any window. [*][*][*] SOURCE CODE FOR THE BACKGROUND TEST APPLICATION We have included the """"""""""""""""""""""""""""""""""""""""""""""" source code for the Background test application so you can see how it works. It is also a good place to start if you want to quickly test how some interface component behaves while it the background. The source code and related files are: o Background.c (CC source) o Background.h (CC source) o Background.r (REZ source) o Make.ORCAC (EXEC script): commands to compile with ORCA/C compiler o Make.APWC (EXEC script): commands to compile with APW/C compiler o Background.make (MPWGS text): make file for MPWGS. Notes: o The CC sources are ready for the ORCA/C compiler. To compile with APW/C, execute before Make.APWC: CHANGE Background.c CC <Return> o After compiling you must use TM Application Setup and check the "Can Receive Null Events" option in order for the application to receive any time in the background. If you want other application to work while the Background test application is in the foreground, also check the "Can Release Null Events" option. GETTING INTIMATE WITH THE MANAGER All the guidelines above can be """"""""""""""""""""""""""""""""" implemented in your existing applications without any concern for whether or not The Manager is present on an end-user's machine. In the next version of The Manager, IPC (AcceptRequest/SendRequest) messages will be available to access useful data and utilities. If you are developing an application and want to take advantage of these Manager-specific routines, please contact Seven Hills Software for information. [*][*][*] Ed. Note: The information above was provided by Seven Hills Software. The source code samples and Background application mentioned in the article are available in the A2Pro library. (File #3206 TMPROGINFO.BXY. [EOA] [RTC]/////////////////////////////// RTC WATCH / ///////////////////////////////// A2Pro Real Time Conference News """"""""""""""""""""""""""""""" By Nate C. Trost [N.TROST] >>> WELCOME TO THE RTC WATCH <<< """""""""""""""""""""""""""""""" LOOKING FOR ANSWERS? Looking for answers to your programming questions? """""""""""""""""""" Want to know the latest and greatest Apple II programming news? Have a desire to shoot the breeze with some of the best II people in the business? Try the A2Pro Sunday Night RTC's! 8:30 Eastern every Sunday at page 530, option 2 on the menu! [*][*][*] RTC NEWS FLASH! Starting on May 6, every Thursday night will be Apple """"""""""""""" IIGS Graphics and Sound Night in the A2Pro RTC. Join host Nate Trost for discussing graphics and sound on the GS! 9:30 Eastern every Thursday at page 530, option 2 on the menu. Whether you're a beginner or a master, this is the place to discuss graphics and sound on the GS! [*][*][*] APRIL A2PRO RTC HIGHLIGHTS: Here are some hilights from a April's """"""""""""""""""""""""""" Real Time Conferences, just a taste of what is in store for those who drop by to chat! ON THE ZBASIC LANGUAGE FOR ALL APPLE IIS """""""""""""""""""""""""""""""""""""""" <[Airship] J.GRAHAM29> ----- I've been getting a couple of inquiries about the availability of ZBasic and AC/BASIC. Any idea if either one is still around? <[A2Pro Leader] M.DEATHERAGE> Greg Branche, who _wrote_ ZBasic, says Zedcor will probably be happy to sell you a copy. :) <[Nate] N.TROST> ----------- But will you get any support? <[A2Pro Leader] M.DEATHERAGE> Support? No. Greg says if you're lucky, you might get a manual. :) ON KEYCAREBITS """""""""""""" <[Bill] W.TUDOR> ----------- I want to say something about keyCareBits for keyboard equivs of controls, ok? <[A2Pro Leader] M.DEATHERAGE> It's still a free country, last I checked. <[Bill] W.TUDOR> ----------- Let's say you have a check box and the text begins with "s". Ok, you want an "S" to toggle the check box. No problem. In this case, you may not even care if Apple-S works - BUT- Please SET the keypad and option key care bits so that "keypad-S" and "option-S" do NOT work. In the option case, things may be mapped around and in the keypad case, the user pressed a Function key on the ext keyboard. That's my two cents for the day. :-) ON WINDOW INFO BARS """"""""""""""""""" <P.BENSON1> ---------------- I posted a question in the Window Mgr area & did not get a response I could really work with. I want to set up a color palette in the info bar of a window. My problem is determining which color was picked (i.e. what are my local mouse pts) <[A2Pro Leader] M.DEATHERAGE> Pauley: You have to do it all yourself. The only help the system gives is that the Info bar is just above the local coordinate origin of the window. In other words, the bottom line of your infobar has Y coordinate -1 in local coords. ON 'STRANGE' TOOL CALLS """"""""""""""""""""""" <[Leo] L.PIILONEN> --------- I see in ORCA 2.0 that there are quite a few toolbox calls that don't appear.... ...in Toolbox Reference Vols 1--3 nor in the Technical Notes at ftp.apple.com. <[A2Pro Leader] M.DEATHERAGE> Leo, there's an entirely new book that was published about a year ago called "Programmer's Reference for System 6.0." It's published by the Byte Works and available from them or Resource-Central. This book has what you're looking for in it. (Also note that the 6.0 Golden Master CD from Resource-Central has a complete set of toolbox macros, as well as C header files, for 6.0) ON FINDER RESOURCES """"""""""""""""""" <M.WOLFGRAM2> -- I don't know why Dean would want to move his trash can. That is a good question though. :) Maybe he would rather change the default window sizes to 640 X 200 ? <[Nate] N.TROST> How can I do that with resources, eh Mr. Resource Guy? :) <M.WOLFGRAM2> -- The data that the Finder uses for that, Nate, is kept in a rRectList resource. The resource is referred to as the Geek Preferences. <[Nate] N.TROST> That is a rFib if I ever edited one. :) <M.WOLFGRAM2> -- No, Nate... Honest... The rRectList is referred to as the Geek Preferences resource... because only the Geeks (that's people like Dean) would want to change it :) AND.....OFF THE DEEP END """""""""""""""""""""""" <A2PRO.STEVE> ---------- So who watched 90210 tonight? <[Nate] N.TROST> ------- not I. <[ToddM] T.MYERS4> ----- I just see the commercial 'blurbs' and think ....NOT! (: <[Nate] N.TROST> ------- Debugging is better than 90210. :) <[RESOURCES] M.WOLFGRAM2> 65816 is better than 90210 <[Nate] N.TROST> ------- Hey that gives me an idea... the 90210 instruction set.... <A2PRO.STEVE> ---------- duh #$1234 <[Nate] N.TROST> ------- friend indirect, stranger indirect addressing modes. :) <[RESOURCES] M.WOLFGRAM2> wow >$0000 <A2PRO.STEVE> ---------- stranger indirect indexed protected mode <[Nate] N.TROST> ------- bmw #720,i . :) <A2PRO.STEVE> ---------- We need help. <[Nate] N.TROST> ------- We do. [EOA] [A2U]////////////////////////////// A2U CAMPUS GREEN / ///////////////////////////////// Your GEnieLamp A2Pro guide to A2U """"""""""""""""""""""""""""""""" By Nate C. Trost [N.TROST] >>> WELCOME TO THE CAMPUS GREEN! <<< """""""""""""""""""""""""""""""""""" EXPLORE ONE OF A2PRO'S NEATEST AREAS Here we'll be exploring one of """""""""""""""""""""""""""""""""""" A2Pro's neatest areas, the Apple II University (A2U for short). Over the past several years, A2U has taught many Apple II owners more about their machines. Topics from C programming to data compression have been covered with online classes similar in style to a correspondence course. A class consists of lessons uploaded by an A2U professor, who writes the lessons and provides help via topics in the Bulletin Board and in regular RTCs scheduled for the course. The only cost is the connect time it takes to download the lessons! A2Pro has an entire category devoted to A2U in the Bulletin Board. To find out more about A2U, stop by the A2Pro BB and visit Category 22. Some of the topics you'll want to read/mark are: CAT22, TOP1 What is A2 University? CAT22, TOP2 How to take an A2U Course The two topics above are read-only, discussion and questions concerning A2U should be posted to: CAT22, TOP6 Comments, Questions, Discussion... INTRODUCTION TO RESOURCES COURSE POSTPONED We regret to announce that the """""""""""""""""""""""""""""""""""""""""" A2U "Introduction to Resources" Course has been indefinitely postponed. Marc Wolfgram, the course instructor, is apparently having difficulty keeping up with the lesson schedule along with everything else he tries to tackle. (Lesson 5 hasn't been uploaded), so to make life easier on Marc and you, the course has been postponed, possibly cancelled with lesson 4. We are sorry for any inconvenience this causes anyone. -- the A2Pro Staff NEW IN A2U There isn't too much new in A2U for April, can you say """""""""" Spring Break boys and girls? <grin> Keep watching this space for details of new and exciting A2U courses! We do have something new and exciting to announce though! A2U PRESENTS Apple IIGS Graphics & Sound: The Continuing Saga! """""""""""" There are few aspects of the Apple IIGS as strange and daunting as taking advantage of its audio and visual capabilities. To help beginning GS programmers with their graphics and sound related questions, to promote the exchange of useful techniques, and to provide a fun forum for graphics/sound discussion, A2U will be sponsoring a regular GS Graphics and Sound RTC. These RTCs will be held on Thursday nights at 9:30 Eastern beginning on May 6. The RTCs will be led by Nate Trost, GEnieLamp A2Pro staff writer and longtime GS graphics/sound junkie. If you have questions, new ideas, or just want to shoot the breeze about making the GS look and sound pretty, this RTC is the place to be! PREVIOUS A2U COURSE REFERENCE, PART I A2U has given many courses over the """"""""""""""""""""""""""""""""""""" past several years, and although the courses are over, the lessons remain! These lessons are a valuable source for learning to program, or for honing your skills. This month we present the first half of a two part list of previous A2U courses that are available for downloading in the A2Pro library. All of these great files are available in the A2Pro library, option 3, page 530. And now, the list: HACKING DATA COMPRESSION (ANDY MCFADDEN) This twelve part course covers """""""""""""""""""""""""""""""""""""""" theory and application of data compression. Algorithms are discussed and source code presented in both C and 65816 assembly language. Compression methods discuss include RLE, Huffman, LZ77 and 78, LZW, LZSS, Arithmetic, and more. Source is for the IIGS, concepts apply to all computers. LESSON 1: File #2933 LESSON 7: File #3006 LESSON 2: File #2955 LESSON 8: File #3050 LESSON 3: File #2956 LESSON 9: File #3051 LESSON 4: File #2997 LESSON 10: File #3076 LESSON 5: File #2984 LESSON 11: File #3087 LESSON 6: File #2998 (Note: Lesson 12 will be available following the release of the HardPressed utility from Westcode) Related Files """"""""""""" File #3051 A2U.COMP.8.GIF.TXT (Description of LZW as it applies to GIF images) File #3067 LZWGIF87A.BXY (LZW explanation and GIF 87a specifications) File #3068 GIF89A.BXY (Description of the GIF 89a image format) EIGHT BIT ASSEMBLY LANGUAGE PROGRAMMING (JAY JENNINGS) This ten part """""""""""""""""""""""""""""""""""""""""""""""""""""" course is a starting point for those wishing learn Apple II assembly programming. 10 lessons + archived BB messages Lessons 1-10: Files #2837-2846 Archived BB messages: File #2847 EXPLORING BLOCK WARDEN (BRYAN PIETRZAK) This three part course provides a """"""""""""""""""""""""""""""""""""""" reference for the operation and application of the Block Warden utility included with the ProSEL package. Lessons 1-3: Files #2732-2734 INTRODUCTION TO C PROGRAMMING (WALKER ARCHER AND GARY MORRISON) This ten """"""""""""""""""""""""""""""""""""""""""""""""""""""""""""""" part course serves as an introduction to programming in the C language. Source code compatible with APW and ORCA/C. Lessons 1-10: Files #3214-3223 INTRODUCTION TO PASCAL PROGRAMMING (P. DOTY) This ten part course serves """""""""""""""""""""""""""""""""""""""""""" as an introduction to programming the Pascal language. Source code is suitable for ORCA and TML Pascal. Lessons 1-3: Files #2849-2851 Lessons 4-10: Files #2853-2859 END OF PART I That's the end of Part 1 of the Previous A2U Course """"""""""""" Reference, tune in next month for the rest! [EOA] [LIB]////////////////////////////// ONLINE LIBRARY / ///////////////////////////////// HOT Files You Can Download """""""""""""""""""""""""" By Nate C. Trost [N.TROST] >>> ANNOUNCING THE BIT BONANZA <<< """""""""""""""""""""""""""""""""" YOUR MONTHLY MAP TO A2PRO RICHES GEnieLamp A2Pro proudly introduces Bit """""""""""""""""""""""""""""""" Bonanza, your monthly map to A2Pro library riches! Below you'll find some of the best neat, new, and nifty stuff uploaded to the A2Pro library during March and April. Visit the A2Pro library at page 530, option 3 today! [*][*][*] PROGRAMMING EXAMPLES/SOURCE """"""""""""""""""""""""""" File #3255: MONDRIAN.EF.BXY (GS) Uploaded on 4/14/93 by QC About 6.5K (d/l time approx. 45 seconds @ 2400 baud) This file contains all the information needed to create custom screen blanker modules for the Phantasm screen saver control panel. Programming information and sample source code to the Mondrian blanker is included. (Note: QLabs is looking for new modules to include with a special package of add-on blankers for Phantasm, look in the QLabs A2Pro area: CATegory 29 TOPic 15 for details) File #3254: BULLA.PLUS.BXY (GS) Uploaded on 4/14/93 by A2.LUNATIC About 325K (d/l time approx. 30 minutes @ 2400 baud) This archive contains several previously unreleased FTA/ACS demos. In addition, assembly source code (in Merlin 16+ format) to most of the demos is included on the disk. The demos are: "Bulla," a Mario Bros. style game/demo, "New Parametrix Animation," chaser balls in a figure eight, "New Real-Time Vector Balls," "Diagonal Scroll," you gotta see it to believe it, "Psy Scroll," a funky text scroll, "Coke Animation," a spinning Coke(tm) can!, "Oscillo," music with four separate oscillators/meters, and "Pang," some bouncing balls over a detailed background. File #3250: VCRPLUS.BAS (GENERAL) Uploaded on 4/10/93 by C128.JBEE About 11K (d/l time approx. 1 minute @ 2400 baud) A BASIC program that decodes the VCR+ codes. This is a Commodore BASIC program with the screen/cursor codes commented out. File #3213: METAL.SRC.BXY (8 bit) Uploaded on 3/24/93 by A2.LUNATIC About 95K (d/l time approx. 9 minutes @ 2400 baud) These are the source files part of the METAL telecommunications system for making a really nice BBS (usually used with FutureNet, the current "other half" of the METAL system). These are Merlin source files. This BBS system runs on enhanced Apple IIes and later. Includes direct support for the Apple IIgs ports, memory, etc. File #3202: ADVSRC.BXY Uploaded on 3/14/93 by D.GRANDE2 About 107K (d/l time approx. 10 minutes @ 2400 baud) A minimal port of the original Adventure game to APW C, source and executable are included. A2/A2Pro SPECIAL FILES """""""""""""""""""""" File #3251: A2PROLIB493.BXY (GENERAL) Uploaded on 4/11/93 by J.L.D. About 70K (d/l time approx. 7 minutes @ 2400 baud) This file is an AppleWorks 3.0 database of all files in the A2Pro library as of 4/10/93. An index of the libraries is included for easy reference. Takes 132K on the A2 3.0 desktop, about 70K on disk when unshrunk. There are 1,285 records in the database. File #3248: ORCA.C.01.BXY (GENERAL) Uploaded on 4/7/93 by A2PRO.GREG About 40K (d/l time approx. 4 minutes @ 2400baud) A collection of messages from the 'ORCA/C' topic in Category 36 - The Byte Works Online. File #3247: OR.SHELL.01.BXY (GENERAL) Uploaded on 4/7/93 by A2PRO.GREG About 46K (d/l time approx. 4 minutes 20 seconds @ 2400 baud) A collection of messages from the 'ORCA Shell' topic in Category 36 - The Byte Works Online. File #3196: ULT.PROG.01.BXY (8 bit) Uploaded on 3/4/93 by A2PRO.GREG About 37K (d/l time approx. 3 minutes 45 seconds @ 2400 baud) This file is a collection of messages from the A2Pro RT's bulletin board, Category 34, Topic 3 'Ultra Progamming'. UTILITIES """"""""" File #3246: SHELLPLAY0.5.BXY (GS) Uploaded on 4/5/93 by N.TROST About 13K (d/l time approx. 1 minute 30 seconds @ 2400 baud) ShellPlay 0.5, a freeware MOD music file player for the GS. This player is a shell utility EXE file for use with shell programs such as ORCA and GNO. File #3243: BURGERSPLIT.BXY (GS) Uploaded on 4/5/93 by BURGERBILL About 20K (d/l time approx. 2 minutes @ 2400 baud) This program will split a large file into smaller pieces for whatever purpose you need, such as getting the file to fit on 3.5 or 5 1/4 disks. Written with Orca/C 2.0 Source included. For use with a shell such as ORCA or GNO. File #3242: TODAY.BXY (GS) Uploaded on 4/5/93 by BURGERBILL About 115K (d/l time approx. 11 minutes @ 2400 baud) This program will tell you what happened today. It has about 100K of text for events that happen year round and birthdays of a lot of historical people. Written in Orca/C 2.0 Source code is included. INFORMATION/DOCUMENTATION """"""""""""""""""""""""" File #3239: REL.NOTES.SD401 (GENERAL) Uploaded on 4/5/93 by M.DEATHERAGE About 3K (d/l time approx. 25 seconds @ 2400 baud) This text file contains the release notes from Apple for eight-bit System Disk 4.0.1, available in A2Pro as file #3178. It details the changes made to ProDOS 8 v2.0.2 and FastCopy 1.0.1, the only components on the disk which have changed since Apple IIgs System Software 6.0. (NOTE: This is a text file with no Binary II header so it may be <L>isted into your capture buffer as well as downloaded) File #3238: MODMEDSPECS.BXY (GENERAL) Uploaded on 4/4/93 by A2.DEAN About 40K (d/l time approx. 4 minutes @ 2400 baud) File format descriptions and implementation details for the MOD and MED music formats. Includes descriptions of the ProTracker effects. File #3206: TMPROGINFO.BXY (8 bit) Uploaded on 3/16/93 by SEVENHILLS About 20K (d/l time approx. 2 minutes @ 2400 baud) This upload contains information on writing "Manager-Aware" applications, including information on supporting multi-tasking. [EOA] [LOG]////////////////////////////// LOG OFF / ///////////////////////////////// GEnieLamp Information """"""""""""""""""""" o COMMENTS: Contacting GEnieLamp o GEnieLamp STAFF: Who Are We? o SEARCH-ME! Answers GEnieLamp Information GEnieLamp is published on the 1st and the 15 of """"""""""""""""""""" every month on GEnie on page 515. You can also find GEnieLamp on the main menus in the ST (475), Macintosh (605), IBM (615), Apple II (645), A2Pro (530), Unix (160), Mac Pro (480), Geoworks (1050), BBS (610), CE Software (1005) and the Mini/Mainframe RoundTables. GEnieLamp can is also distributed on CrossNet, Internet, America Online and many public and commercial BBS systems worldwide. We welcome and respond to all GE Mail. To leave comments, suggestions or just to say hi, you can contact us in the DigiPub RoundTable (M1395) or send GE Mail to John Peters at [GENIELAMP] on page 200. GEnieLamp pays for articles submitted and published with online GEnie credit time. Upload submissions in ASCII format to library #42 in the DigiPub RoundTable on page 1395 (M1395;3) or send it to our GE Mail address, GENIELAMP. U.S. MAIL """"""""" GEnieLamp Online Magazine Atten: John Peters 5102 Galley Rd. Suite 115/B Colorado Springs, CO 80915 >>> GEnieLamp STAFF <<< """"""""""""""""""""""" GEnieLamp o John Peters [GENIELAMP] Senior Editor """"""""" ATARI ST o John Gniewkowski [J.GNIEWKOWSK] Editor """""""" o Mel Motogawa [M.MOTOGAWA] ST Staff Writer o Terry Quinn [TQUINN] ST Staff Writer o Sheldon Winick [S.WINICK] ST Staff Writer o Richard Brown [R.BROWN30] ST Staff Writer o John Hoffman [JLHOFFMAN] ST Staff Writer o Al Fasoldt [A.FASOLDT] ST Staff Writer ATARI ST/TX2 o Cliff Allen [C.ALLEN17] Editor/TX2 """""""""""" ATARI [PR] o Fred Koch [F.KOCH] Editor/PD_Q """""""""" IBM o Robert M. Connors [R.CONNORS2] Editor """ o Peter Bogert [P.BOGERT1] IBM Staff Writer o Brad Biondo [B.BIONDO] IBM Staff Writer o Tippy Martinez [TIPPY.ONE] IBM Staff Writer o David Holmes [D.HOLMES14] IBM Staff Writer MACINTOSH o James Flanagan [JFLANAGAN] Editor """"""""" o Richard Vega [R.VEGA] Mac Co-Editor o Dan "Remo" Barter [D.BARTER] Mac Staff Writer o Tom Trinko [T.TRINKO] Mac Staff Writer o Bret Fledderjohn [FLEDDERJOHN] Mac Staff Writer o Bill Garrett [BILL.GARRETT] Mac Staff Writer MacPRO o James Flanagan [JFLANAGAN] Editor """""" o Erik C. Thauvin [MACSPECT] Supervising Editor o Chris Innanen [C.INNANEN] MacPRO Staff Writer o Paul Collins [P.COLLINS] MacPRO Staff Writer APPLE II o Darrel Raines [D.RAINES] Editor """""""" o Phil Shapiro [P.SHAPIRO1] A2 Co-Editor o Mel Fowler [MELSOFT] A2 Staff Writer A2Pro o Jim B. Couch [J.COUCH2] Editor """"" o Nate C. Trost [N.TROST] A2Pro Staff Writer INTERNET o Jim Lubin [JIM.LUBIN] GEnieLamp IBM """""""" ETC. o Jim Lubin [JIM.LUBIN] Add Aladdin """" o Scott Garrigus [S.GARRIGUS] Search-ME! o Bruce Faulkner [R.FAULKNER4] CrossNET Support o Mike White [M.WHITE25] Cowlumnist/Asst. SysOp GEnieLamp CONTRIBUTORS """""""""""""""""""""" o Steven Weyhrich [S.WEYHRICH] o Paul Varn [P.VARN] o Larry E. Elseman [L.ELSEMAN1] o Steve Litwin [S.LITWIN2] \\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\//////////////////////////////////// Material published in this edition may be reprinted under the following terms only. All articles must remain unedited and include the issue number and author at the top of each article reprinted. Reprint permission granted, unless otherwise noted, to registered computer user groups and not for profit publications. Opinions present herein are those of the individual authors and does not necessarily reflect those of the publisher or staff of GEnieLamp. We reserve the right to edit all letters and copy. Include the following at the end or the beginning of every reprint: \\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\//////////////////////////////////// (c) Copyright 1993 T/TalkNET Online Publishing and GEnie. To join GEnie, set your modem to 2400 baud (or less) and half duplex (local echo). Have the modem dial 1-800-638-8369. When you get a CONNECT message, type HHH. At the U#= prompt, type: XTX99014,DIGIPUB and hit the [return] key. The system will then ask you for your information. Call (voice) 1-800-638-9636 for more information. \\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\//////////////////////////////////// [EOF]