|||||| |||||| || || |||||| ||||||
|| || ||| || || ||
|| ||| |||| |||||| || |||| Your
|| || || || ||| || ||
|||||| |||||| || || |||||| |||||| GenieLamp Computing
|| |||||| || || |||||| RoundTable
|| || || ||| ||| || ||
|| |||||| |||||||| |||||| RESOURCE!
|| || || || || || ||
||||| || || || || ||
~ WELCOME TO GENIELAMP APPLE II! ~
""""""""""""""""""""""""""""""
~ FILE BANDWAGON: Top 10 Files for February
~ PD_QUICKVIEW: Change-A-File
~ BEHIND THE SCENES: With _Juiced.GS_ and the SIS Team
~ HOT NEWS, HOT FILES, HOT MESSAGES ~
\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\////////////////////////////////////
GenieLamp Apple II ~ A T/TalkNET Publication ~ Vol.6, Issue 62
""""""""""""""""""""""""""""""""""""""""""""""""""""""""""""""""""""""""
""""""""""""""""""""""""""""""""""""""""""""""""""""""""""""""""""""""""
Editor...................................................Ryan M. Suenaga
\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\////////////////////////////////////
~ GenieLamp IBM ~ GenieLamp ST ~ GenieLamp PowerPC ~
~ GenieLamp A2Pro ~ GenieLamp Macintosh ~ GenieLamp TX2 ~
~ GenieLamp Windows ~ GenieLamp A2 ~ LiveWire (ASCII) ~
~ Member Of The Digital Publishing Association ~
GE Mail: GENIELAMP Internet: genielamp@genie.com
////////////////////////////////////\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\
>>> WHAT'S HAPPENING IN THE APPLE II ROUNDTABLE? <<<
""""""""""""""""""""""""""""""""""""""""""""""""""""
~ April 1, 1997 ~
FROM MY DESKTOP ......... [FRM] HEY MISTER POSTMAN ...... [HEY]
Notes From The Editor. Is That A Letter For Me?
A2/PRO_ductivity ........ [A2P] FILE BANDWAGON .......... [BAN]
A2Pro Bits & Bytes. Top 10 files for February 1997.
PD_QUICKVIEW ............ [PDQ] BEHIND THE SCENES ....... [BTS]
Change-A-File. With the SIS team and _Juiced.GS_
REAL WORLD APPLE .........[RWA] LOG OFF ................. [LOG]
A Temperature Sensor 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 reprinted
"""""""""""" here in GenieLamp, you will find all the information you
need immediately following the message. For example:
(SMITH, CAT6, TOP1, MSG:58/M475)
_____________| _____|__ _|___ |____ |_____________
|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 has pricing plans to fit almost any budget. Genie's
""""""""""" services include email, software downloads, bulletin boards,
chat lines, and an Internet gateway included at a non-prime time connect
rate of $2.75. Some pricing plans include uncharged online connect time.
As always, prices are subject to change without notice. To sign up for
Genie, call (with modem) 1-800-638-8369 in the USA or 1-800-387-8330 in
Canada. Upon connection wait for the U#= prompt. Type: JOINGENIE and hit
RETURN. The system will then prompt you for your information. Need more
information? Call Genie's customer service line (voice) at 1-800-638-9636.
GET GENIELAMP ON THE NET! Now you can get your GenieLamp issues from
""""""""""""""""""""""""" the Internet. If you use a web browser,
connect to "gopher://gopher.genie.com/11/magazines". When using a gopher
program, connect to "gopher.genie.com" and then choose item 7 (Magazines
and Newsletters from Genie's RoundTables).
*** GET INTO THE LAMP! ***
"""""""""""""""""""""""""""""""""""""""""""""""""""""""""""""""""""""""""""
///////////////////////////////////////// Genie_QWIK_QUOTE /////
/ "I typo, therefore I am." /
////////////////////////////////////////////////// A2.TONY /////
[EOA]
[FRM]//////////////////////////////
FROM MY DESKTOP /
/////////////////////////////////
Notes From The Editor
"""""""""""""""""""""
by Ryan M. Suenaga, M.S.W., L.S.W.
[A2LAMP]
>>> EVERYBODY GO SURF!!! <<<
""""""""""""""""""""""""""""
"Surfing the Internet" was a catchphrase, and now it's a cliche, but I
still don't understand it. Not the Internet; that I have a grasp on. It's
the surfing part.
Being someone who spent many a weekend (and a good amount of
schooldays) jumping on a board and catching waves in the middle of the
Pacific Ocean, I just can't make the connection. Real surfing doesn't
require a computer, a modem, or a phone line; just some decent weather, a
fiberglass board, and some rolling waves. Having spent a lot of hours in
front of a computer display, I realize jumping from site to site on the
World Wide Web requires a certain amount of knowledge, but I can't imagine
practicing web surfing for years and years. On the positive side, I also
can't imagine drowning because I got caught by a bigger wave of HyperText
Markup Language than I was prepared to deal with.
Right now, it doesn't look like the accuracy of the analogy matters,
because the news for Apple IIgs users wishing to browse the World Wide Web
is the best it's ever been. The Spectrum Internet Suite, aka SIS, from
Seven Hills Software is the first Apple II Web browser available, coming
from one of the most reputable developers of Apple II software. The
software that people had been waiting years for is finally here (or should
be by the time you read this). And it doesn't require a fancy Internet
connnection; a simple Unix shell account or your plain old Genie account
will do just fine.
Apple II users who have waited for years to check out the Internet
finally have their chance. And while we may not have all of the bells and
whistles of the hulking Web browsers that frequent other platforms, it's
clear that an elegant, simple Apple II solution has again been found. Once
more, we find out when someone says, "You can't do that on an Apple II,"
they really mean, "You can do something better on an Apple II."
In the meantime, I wait for SIS to show up in my mailbox, still trying
to figure out how surfing and Web browsing relate.
[*][*][*]
If you've decided to become a SIS-sy and cruise the 'net, or you
already have some form of Web access, here's a hot new URL to add to your
collection:
http://www.syndicomm.com/a2web
That's where to find The Mother Of All Apple II Web Sites, A2-Web.
Hosted by Syndicomm, managers of the A2 and A2Pro areas on Genie and
Delphi, and webmeistered by A2's own Dangerous David Kerwood, A2-Web has
been months in the making. You can find links to virtually every Apple
II-related company on the Web at A2-Web, as well as links to Apple II user
home pages, Apple II user groups, Internet resources, and virtually
everything you can imagine on the World Wide Web. A2-Web is optimized for
use on Apple II-usable Web browsers (SIS and Lynx) as well as looking great
with graphical Web browsers on other computer platforms (like Netscape
Navigator). If you have your own contribution to make to A2-Web, be sure
to let David know by sur. . . uh, browsing A2-Web and dropping a note in
his emailbox.
[*][*][*]
My good buddy Tim Kellers told me at the 1996 Kansasfest that, "KFest
is better than real life." I've expanded that to, "The Apple II is better
than real life," and as such I try not to get too serious about writing
about it. Unfortunately, some of my lapses have been too serious to joke
about.
Currently, I'm running close to on schedule with the actual content of
_GenieLamp A2_ usually showing up right around the first of the month.
Unfortunately, there's more to life than just the content. There's also
the hype; in this case, the HyperStudio and Hypercard versions of
_GenieLamp A2_.
On a monthly basis, I've been trying to get these done so I can learn
how to do them and I've simply been running out of time. Editor Emeritus
Doug Cuff has come to the rescue each time by putting out both of the
HyperLamps, and I owe him a great debt for this.
Now to see if I can find a few hours to figure out how to do these on
my own. . .
[*][*][*]
As I've said before, it's common for _GenieLamp A2_ to have uncommonly
good writers, and this issue is no exception. We are again joined by the
editor and publisher of the world famous Apple II periodical _Juiced.GS_,
Max Jones, as well as our own Editor Emeritus, Doug Cuff. And Peter
Brickell is back as well, making this not only the largest issue of
_GenieLamp A2_ under my tenure, but also the current issue of all Apple II
periodicals with the most diverse set of writers. Max brings us up to
speed on how three of the SIS-sies got involved in the development of the
Spectrum Internet Suite, Peter continues his real world escapades, and Doug
has a pair of articles to share with us.
_GenieLamp A2_'s more than five years old now, and like any five year
old, there are new plans in place. I'm hoping to get a home for the 'Lamp
up on the World Wide Web in the next month or so. In fact, I already have
a site picked out; it's just a matter of finding the time. And of course,
that's the limiting element.
Still, I'm hoping to have a URL for you in the coming issue, and a
preliminary site up, just so when you go and sur. . . uh, cruise the Web,
_GenieLamp_ will be right there with you.
-- Ryan
Genie Mail: A2LAMP Internet: a2lamp@genie.com
__________________________________________________________
| |
| REPRINTING GENIELAMP |
| |
| If you want to reprint any part of GenieLamp, or |
| post it to a bulletin board, please see the very end |
| of this file for instructions and limitations. |
|__________________________________________________________|
ASCII ART BEGINS
_____ _ _ ___ ___
/ ____| (_) | | / _ \|__ \
| | __ ___ _ __ _ ___| | __ _ _ __ ___ _ __ | |_| | ) |
| | |_ |/ _ \ '_ \| |/ _ \ | / _` | '_ ` _ \| '_ \ | _ | / /
| |__| | __/ | | | | __/ |___| (_| | | | | | | |_) | | | | |/ /_
\_____|\___|_| |_|_|\___|______\__,_|_| |_| |_| .__/ |_| |_|____|
| |
|_|
ASCII ART ENDS
[EOA]
[HEY]//////////////////////////////
HEY MISTER POSTMAN /
/////////////////////////////////
Is That A Letter For Me?
""""""""""""""""""""""""
by Ryan Suenaga
[A2LAMP]
o BULLETIN BOARD HOT SPOTS
o A2 POT-POURRI
o HOT TOPICS
o WHAT'S NEW
o THROUGH THE GRAPEVINE
o MESSAGE SPOTLIGHT
>>> BULLETIN BOARD HOT SPOTS <<<
""""""""""""""""""""""""""""""""
[*] CAT 5, TOP 14 ....... A Few Words about Gus
[*] CAT 8, TOP 18 ....... Even More Postscript and PublishIt!
[*] CAT 13, TOP 5 ....... Sheppy Speaks, People Listen
[*] CAT 17, TOP 25 ....... Appleworks 5 vs. Appleworks 3
[*] CAT 42, TOP 17 ....... Everyone wants to be a SIS-sy
>>> A2 POT-POURRI <<<
"""""""""""""""""""""
GUS, MEET EDDI. . . UH, BERNIE Hi Kids -
""""""""""""""""""""""""""""""
The following is a message I've recieved from Andy Nicholas at Apple
Computer, one of the creators of Gus, the Apple IIgs emulator for the Power
Macintosh. Andy is looking for more people to be involved in the testing
and evaluation of Gus, specifically in education, and is soliciting
volunteers to help test the emulator. Read on for the details...
Forwarded Message:
To: All users of Apple Computers
From: Andy Nicholas, Apple Computer
"Gus" is the name of an Apple IIGS emulator for Power Macs developed by
some engineers at Apple in their spare time. Gus is not and will not be an
official Apple product. Gus runs Apple II and IIGS software from "disk
images" created from original Apple II and IIGS disks. Creating the disk
images is relatively straightforward; however, Gus does not run copy
protected software at this time (this may change depending on your
responses).
Aside from the obvious benefit of using Apple II and IIgs software on Power
Macintosh computers, Gus can also serve a very useful purpose in helping
schools transition to using (and buying) Power Macs from their Apple II and
IIGS's.
If you know of a school district whose "computer coordinator" or
"technology czar" wouldn't mind signing a non-disclosure agreement and
would be interested in having their school district evaluate Gus please
have them contact us at gus-feedback@apple.com. We appear to already have
some interest in this direction.
We need the following information from a school's computer coordinator in
order to non-disclose them:
(1) Name
(2) School district & school affiliation
(3) USMail address where we can send a non-disclosure form
(4) Email address where notifications of new versions can be sent
(5) Do you have web access?
If you don't have web access, do you have FTP access?
Please do not contact Apple's support lines with questions regarding Gus.
The only way right now to receive information is to subscribe to
gus-news@apple.com and send questions regarding Gus to
gus-feedback@apple.com.
Thanks,
Andy Nicholas
Apple Computer
(A2.DAD, CAT5, TOP14, MSG:274/M645;1)
>>>>> Gus, and Fast Ed. . . er, Bernie II the Rescue also made the
""""" Macintouch site on the World Wide Web today. Check out
http://www.macintouch.com.
Ryan
http://www.keystroke.net/~rsuenaga
"There's no shortage of windmills to tilt at."--Logan
ANSITerm and CoPilot v2.55
(A2LAMP, CAT5, TOP14, MSG:275/M645;1)
MORE PUBLISHIT!4 PATCHES PublishIt!4 Patch Update:
""""""""""""""""""""""""
Two improvements:
First, please disregard the prior method I posted about modifying the
Laserprep file so that PI4 PostScript print-to-disk files could be made to
print correctly from outside of PI without any prior printer
initialization.
Yea, this method worked, but, there is a much better way. The better way
involves removing some of the unnecessary lines from the Laserprep file
Yea, this method worked, but, there is a much better way. The better way
deleted with no apparent problem. One line inside the 'md' area must be
modified though. These changes make the whole process work much better.
When this is done, there is no need to add the persistant download lines of
Serverdict Begin Exitserver to the beginning of the Laserprep file and no
need to imbed the CTRL-D at the end of the file. This is important because
it will no longer change the permanent 'state' of whatever printer you may
wish to send the file to, whether it is hooked up to a PC, Mac, or other
computer. In other words, the PublishIt job will be a completely self
contained, encapsulated (and portable) file.
I'll post the mods and would like some of you with PostScript printers to
try printing some PI PostScript print-to-disk files from _outside_ of
PublishIt (preferably on Mac's or PC's) and let me know if you run across
any problems.
Second, I've finally shade tree hacked a way to patch PI4 so that we can
install and use the ZapfDingbats font and then have it use the internal
PostScript ZapfDingbats font when printing.
The patch is to the DTP.MAIN file in PI4, and works by replacing the built-
in Avantgard-for-Northbrook swap with a ZapfDingbats-for-Northbrook swap.
Also, the patch disables the Laserprep font re-encoding that keeps the
Dingbat character names (eg A4, A5, etc...) from being encoded.
Most of you probably aren't Dingbat fans. I have wanted, though, for a long
time, to use the shadowed check box, the scissors, the telephone and the
pencil symbols on some of the forms I construct. This will allow that. You
will need to download (from A2 is fine) the bit-mapped Dingbats fonts.
Note, you won't be printing bit-mapped fonts; you will use the full-formed
built- in PostScript fonts. The bit-mapped fonts are necessary only for
'place holding' and for PI's print preview mode. I did find, however, that
using (and renaming) the bit-mapped 14 point font as either a 10 or 12
point font gave the best results.
Finally, I think a patch to allow PostScript printing via the parallel card
is very doable. This could speed printing up as well as allow use of some
PostScript printers that don't have a serial port.
Hugh...
(H.HOOD, CAT8, TOP18, MSG:166/M645;1)
A2-WEB OPENS Possibly lost in the aura of the SIS release was the
"""""""""""" announcement of the opening of The Mother of All Apple II
Web Sites, A2 web. The webmeister is our own David Kerwood, and the url
is:
http://www.syndicomm.com/a2web
Ryan
http://www.keystroke.net/~rsuenaga
"There's no shortage of windmills to tilt at."--Logan
ANSITerm and CoPilot v2.55
(A2LAMP, CAT13, TOP17, MSG:53/M645;1)
>>>>> I didn't miss it. It was right there on page 18. Not to mention the
""""" screen shot on page 5. ;)
--
Carl Knoblock - Telephone Tech
cknoblo@delphi.com
cknoblo@novia.net
(C.KNOBLOCK, CAT35, TOP8, MSG:31/M645;1)
>>>>> Great! I just saw it for the first time today (in Juiced.GS, I
""""" mean). A2-Web is, in fact, SIS-enhanced - you will see things
there on the page that you will ONLY see if you view the pages with SIS.
Of course, all the pages of A2-Web are fully functional with the more
primitive browsers as well. :)
Use the feedback button and tell me how to make it better!
David K. - A2-Web! Get tangled at http://www.syndicomm.com/a2web/
(A2.DAD, CAT35, TOP8, MSG:32/M645;1)
>>> HOT TOPICS <<<
""""""""""""""""""
A WOLF UPDATE It's still in the works... but the going is slow. I'm
""""""""""""" working on putting in all the new art I just got. :)
Sound-wise, things have kinda stalled for the time being. I still am
working on getting access to the equipment and people I need to get the
voices rerecorded.
Sheppy
(SHEPPY, CAT13, TOP5, MSG:93/M645;1)
>>>>> Sheppy,
"""""
I was wondering if you were losing interest in this project, or just busy
with other things. Appreciate the update.
And I should add that the W3D beta is just flat-out awesome!
Ed Staib / Bugman
Delivered via Warped 8 meg GS Rom-01 Tower
Proterm 3.1 till Spectrum/SIS bundle arrives :)
(E.STAIB, CAT13, TOP5, MSG:94/M645;1)
<<<<< I'm just busy with other things, I assure you. Wolf 3D is
""""" basically acharity project for Logicware, and is therefore the
absolute lowest priorityon my schedule. As such, I can only spend personal
time on it, and I don'thave a lot of that left after working 12-16 hours a
day on the money-making stuff at work.
And to be honest, now that I'm married I like to spend as much of my free
time with my wife as I can. :)
I've gotten the new art, and am working gradually on getting it all in. :)
Sheppy
(SHEPPY, CAT13, TOP5, MSG:95/M645;1)
SHIFTY LIST 2.0: AN UPDATE I've been extremely busy lately. But I assure
"""""""""""""""""""""""""" you, I'm still here. I admit I haven't read
the BB other than this topic for several months though. :)
At any rate, I'm looking at the best way to get Shifty List 2.0 done in the
shortest possible time.
Sheppy
(SHEPPY, CAT13, TOP18, MSG:63/M645;1)
<<<<< BTW... I'm putting reasonable effort into Shifty List 2.0, and
""""" expect to be finished with it this spring (possibly within a month
or so). I don't know for sure yet how it will be distributed, but it will
be vastly superior to the original. :)
Sheppy
(SHEPPY, CAT13, TOP18, MSG:64/M645;1)
>>>>> Sheppy, is it too late to ask for something on that? Is it
""""" possible to make it so that it could be launched by PROSel? ie. an
application, in addition to a Finder Extra? Or I guess you could assure
me that PROsel's init manager within the Utilities is fully compatible with
ShiftyList. Someone somewhere told me that mixing init managers
(ShiftyList, Initmaster, PROSel) was dangerous.
Thanks!
_________
| homas
(T.COMPTER, CAT13, TOP18, MSG:65/M645;1)
<<<<< Shifty List isn't an init manager; it's a totally different tool
""""" for allowing you to shift-boot and still get some items loaded up.
There won't be an application version of the Shifty List Finder Extension
for Shifty List 2.0 (the features list for Shifty List 2.0 is final), but
I'm already working on a Shifty List 3.0 features list, and I'll consider
it for that version.
Sheppy
(SHEPPY, CAT13, TOP18, MSG:66/M645;1)
KEYBOARD KAOS Somebody (I forget who) pleaded for assistance:
"""""""""""""
>I fell into a Rom 3 //gs, now I need a //gs keyboard. Can anyone help?
The absolute best keyboards for the IIgs are the genuine Apple Extended
Keyboard, also known as the Mac SE keyboard, family number M0115, or the
Apple Extended Keyboard II, family number M3501. Either one of these in
combination with Bill Tudor's free Extended Keyboard Init (in the A2
Library) really makes heavy duty typing on the IIgs a whole lot nicer. Call
Sun Remarketing and see if they have any of these. They ain't cheap, but if
you spend a lot of time actually _doing_ stuff with your IIgs, they are one
of the best investments you can make. These keyboards will work on all Macs
as well, even PowerBooks and Duos, and are still the best keyboards
available.
David K. - A2-Web! Get tangled at http://www.syndicomm.com/a2web/
(A2.DAD, CAT12, TOP28, MSG:54/M645;1)
>>>>> David -
"""""
>...the genuine Apple Extended Keyboard,
I've grown so accustomed to the placement of keys on the GS keyboard, I'm
wondering how the AEK compares - such as the Esc, Tab, control, Option and
Open apple keys?
- Joachim
(J.NELSON56, CAT12, TOP28, MSG:56/M645;1)
>>>>> Extended keyboards usually have all their keys in the same places.
""""" The GS keyboard is the one that's different because it's so small.
Here are the differences between the GS keybaord and the AppleDesign (which
I think is layed out the same as the Apple Extended II):
GS Keyboard
===========
[RESET]
[ESC] 1 2 3 4 5 6 7 8 9 0 - = [DEL]
[TAB] Q W E R T Y U I O P [ ] [RET] Numeric
[CTL] A S D F G H J K L ; ' [RETRN] <-- "L" shaped Return key Keypad
[SHIFT] Z X C V B N M , . / [SHIFT]
[CAP][OPT][CMD] ` [SPACE] \ [ARROWS]
AppleDesign
===========
[ESC] [Function Keys F1-F15] [RESET]
` 1 2 3 4 5 6 7 8 9 0 - = [DEL] [HELP][HOME][PGUP]
[TAB] Q W E R T Y U I O P [ ] \ [DEL][END][PGDN] Numeric
[CAP] A S D F G H J K L ; ' [RETRN] Keypad
[SHIFT] Z X C V B N M , . / [SHIFT] Inverted-T
[CTL][OPT][CMD] [SPACE] [CMD][OPT][CTL] Arrow Keys
The numeric keypads are the same except the "+" and "-" keys are reversed.
I hope my ASCII art is legible.
- Tony
(A2.TONY, CAT12, TOP28, MSG:57/M645;1)
<<<<< Tony - in a terrific display of hard work and expended effort
""""" (which made everyone sit up and take notice - not something that
happens every day) did this for the Genie A2 subscribers:
>Here are the differences between the GS keybaord and the AppleDesign
>(which I think is layed out the same as the Apple Extended II):
It is. Super effort, Tony.
Just a clarification. The AppleDesign keyboards are not at all the same as
the Apple Extended keyboards, apart from the fact that they are, uh,
keyboards. The Apple Extended and Extended II keyboards are big, heavy,
solid keyboards with great tactile feedback on the keys. No rubbery typing
with these. The AppleDesign keyboards are good enough for most people,
lightweight but not flimsy, though the keys are more squishy than I
personnally prefer.
David K. - A2-Web! Get tangled at http://www.syndicomm.com/a2web/
(A2.DAD, CAT12 ,TOP28, MSG:58/M645;1)
>>> WHAT'S NEW <<<
""""""""""""""""""
SEVEN HILLS ANNOUNCES SIS Seven Hills Software is proud to announce
""""""""""""""""""""""""" Spectrum Internet Suite:
Now you can access the World Wide Web directly from your Apple IIGS!
Using Spectrum 2.1 and its expandable XCMD/XDisplay technology, Seven Hills
Software has developed the Spectrum Internet Suite - a combination of
XCMDs, XDisplays and scripts designed to put you on the World Wide Web,
right from your Apple IIGS - all without the need for GNO/ME, TCP/IP, or
other programs.
All you need is Spectrum 2.1, Spectrum Internet Suite, and a UNIX shell
account or a Genie account!
Building on the power and strength of Spectrum and its associated plug-in
XCMDs and Displays, Spectrum Internet Suite combines an XDisplay with a new
XCMD and powerful Spectrum scripting to provide a one-stop solution to the
Internet.
Features include:
===== NAVIGATION =====
- Optional Toolbar for quick access for frequently used commands
- Proxy server support
- Progress bar reports download status
- Bookmark facility for visting favorite sites
- Perform Basic Authentication security
- History list maintained to return to a visited page
in the same session
- Browse files on local/network disks as well as the web
- Type in URLs without the need of http://
- Automatic URL completion (for standard www. and .com addresses):
type "apple" and it will load "http://www.apple.com/"
===== WEB PAGE GENERATION =====
- Supports the HTML 3.2 standards
- "Netscape Navigator Client Pull" Dynamic Updating
- Frame cells are accessed by links (like Lynx 2.6)
- Exclusive Spectrum specific HTML tags: play Apple IIGS sound
effects and speech from a web page! (the computer viewing
the page must be running Spectrum Internet Suite and have
appropriate sounds/speech software installed for these tags to work)
- Color text
- Multiple fonts and styles
- Emedded IMG tag translation
- Anchors and >> THROUGH THE GRAPEVINE <<<
"""""""""""""""""""""""""""""
EVEN MORE SPECTRUM TRICKS I also am working on a Master Command Center
""""""""""""""""""""""""" for Spectrum 2.1 users.
It will access Delphi, Genie, CIS, the Delphi Messenger, Genie Copilot, and
a mini CIS BB Reader all from one convenient Hitzone Menu.
It's nowhere ready yet, but give me time. ;-)
(K.GRAHAM16, CAT3, TOP36, MSG:61/M645;2)
THE NEW SSII The next issue of Shareware Solutions II is finally nearing
"""""""""""" completion.
Unlike the last issue, where there were many short (1-2 page) articles,
this upcoming issue has two very long feature length articles. My feature
length article is all about Spectrum Internet Suite, and Steve Disbrow's
feature length article is all about networking.
Of course, there's also the usual Grapevine news column (with some
interesting Easter Egg discoveries), some "killer" Such A Deal offerings,
the usual mix of freeware/shareware coverage in the Shareware Solutions II
columns, and a second look at the the IIGS Emulator from our good friends
in Switzerland.
Soon....real soon now...
Joe
(JOE.KOHN, CAT28, TOP4, MSG:46/M645;1)
SSII'S NEW HARMONIE I have zero details to offer at the moment, but there
""""""""""""""""""" will soon be an updated version of Harmonie available
from Burger Bill and Shareware Solutions II.
In addition to fixing bugs in the current versions (AWGS colors, full
justification), there will be direct support for a number of newer HP ink
jet printers, and on those printers that offer 600 x 300 dpi, you'll
finally be able to take full advantage of that increased resolution.
Joe Kohn
(JOE.KOHN, CAT28, TOP4, MSG:78/M645;1)
>>>>> If the Burger-meister is taking Harmonie suggestions, I'd like to
""""" make a couple:
1) Make the Deskwriter drivers work via Appletalk.
2) Do a conventional (non-networked) driver for the Laserwriter, that
converts TrueType fonts on the fly :)
3) Do some for the newer Canon and Epson printers.
Okay, I know I ask for a lot :)
Ryan
http://www.keystroke.net/~rsuenaga
"There's no shortage of windmills to tilt at."--Logan
ANSITerm and CoPilot v2.55
(A2LAMP, CAT28, TOP4, MSG:90/645;1)
SSII BRINGS BACK A2-CENTRAL Coming Soon...to an Apple II screen near
""""""""""""""""""""""""""" you...
For the first time ever, every word that appeared in every issue of
Open-Apple, A2-Central, and A2-Central-On-Disk will be available in a
special 12 disk (3.5" only) collection that will be soon be available from
Tom Weishaar and Joe Kohn. That's 8.8 megabytes of Apple II information,
hints, tips, and humor from some of the sharpest minds to ever write about
the Apple II.
In addition, all 73 back issues of A2-Central-On-Disk will also be
available.
(JOE.KOHN, CAT28, TOP4, MSG:79/M645;1)
>>> MESSAGE SPOTLIGHT <<<
"""""""""""""""""""""""""
Category 13, Topic 43
Message 36 Sat Mar 08, 1997
M.JONES145 [MaxJ] at 12:49 EST
Oh, what a night ....
For those of you who missed it, the Apple II Saloon hosted a "New PRODUCT"
celebration Friday night in the A2 RTC, and the turnout was fabulous! When
Dave Hecker made the announcement about Spectrum Internet Suite, the first
and only IIGS Web browser, there were no fewer than 32 poeple in the room.
As the night went on, some folks left, others joined in, and there was
still about a dozen people in the Saloon when I finally signed off a little
after 2 a.m.
There were even Genie users in the RTC Friday night who said they had NEVER
been in an RTC before.
Oh, what a night ...
We'll be working on a transcript of the session in the next day or so. Look
for it to be uploaded later this weekend.
I want to express my appreciation to the SIS development team -- Ewen
Wannop, Geoff Weiss and Dave Hecker -- for being our guests for the RTC
celebration. Ewen had to get out of bed at 4 a.m. to attend, and Geoff came
in on a guest account and was still in the RTC when I left. What a trooper!
Thanks also to Cindy for helping get the guest account arranged for Geoff.
Thanks also to Dave Miller for setting up the Simulbot so our friends on
Delphi could participate.
And, of course, thanks to all those who attended and made this celebration
a memorable one.
Apple II forever,
Max
[*][*][*]
While on Genie, do you spend most of your time downloading files?
If so, you may be missing out some excellent information in the Bulletin
Board area. The messages listed above only scratch the surface of
what's available and waiting for you in the bulletin board area.
If you are serious about your Apple II, the GenieLamp staff strongly
urge you to give the bulletin board area a try. There are literally
thousands of messages posted from people like you from all over the
world.
[EOA]
[A2P]//////////////////////////////
A2/PRO_ductivity /
/////////////////////////////////
By Ryan M. Suenaga, M.S.W.
[A2LAMP]
>>> A2PRO BITS & BYTES <<<
""""""""""""""""""""""""""
UUENCODING IN C MINOR I need some help deciphering the following C code.
""""""""""""""""""""" It is supposed to be code to decode UUencoded
files. Anyone who feels led to comment this code and/or point out problems
with it will receive my undying gratitude (well, at least a big thank you
;).
Charlie
--**--
if (msgtype == 'U')
{
FILE *f;
char c1, c2, c3;
int cnt, csum;
f = fopen (buf2, (i== 1) ? "w" : "a");
if (f)
{
if (i != 1)
{
cnt = *buf - ' ';
csum = 0;
for (c = buf+1; cnt>0; c += 4)
{
c1 = ((c[0] - ' ') & 0x3f) << 2 | ((c[1] - ' ') & 0x3f) >> 4;
c2 = ((c[1] - ' ') & 0x3f) << 4 | ((c[2] - ' ') & 0x3f) >> 2;
c3 = ((c[2] - ' ') & 0x3f) << 6 | ((c[3] - ' ') & 0x3f);
if (cnt-- > 0)
fputc (c1,f);
if (cnt-- > 0)
fputc (c2,f);
if (cnt-- > 0)
fputc(c3, f);
}
}
while (prevline = ourbuf,
sgets (buf, 1024, &ourbuf) &&
(i = check_uue (buf)))
{
cnt = *buf - ' ';
csum = 0;
for (c = buf+1; i>0 && cnt> 0; c += 4)
{
c1 = ((c[0] - ' ') & 0x3f) << 2 | ((c[1] - ' ') & 0x3f) >> 4;
c2 = ((c[1] - ' ') & 0x3f) << 4 | ((c[2] - ' ') & 0x3f) >> 2;
c3 = ((c[2] - ' ') & 0x3f) << 6 | ((c[3] - ' ') & 0x3f);
if (cnt-- > 0)
fputc (c1,f);
if (cnt-- > 0)
fputc (c2,f);
if (cnt-- > 0)
fputc(c3, f);
}
}
fclose (f);
p += sprintf (p, " Got %s to %s\n",bu
f1, download_path);
}
}
(A2.CHARLIE, CAT4, TOP2, MSG:83/M530;1)
>>>>> Roughly translating the c code, first a file "f" is opened for
""""" writing. I'm not sure what "i" is used for but assuming it's not 1
you go into a loop to decode a line of uucode.
Evidently, the line of uucode has previously been stored in in a buffer
pointed to by "buf".
cnt = *buf - ' ';
takes the first character in the buffer (the line count) and subtracts an
ascii space (32) from it. Thus cnt now holds the length of the line (in
bytes when decoded). Assuming the line starts with "M" that is 45.
csum = 0;
"csum", the checksum is set to zero.
for (c = buf+1; cnt>0; c += 4)
next comes a loop that decodes the line od uucode. c is probably declared
somewhere previously as a pointer of type char (char *c). It is initially
set to point to the second character in "buf" (c = buf+1;). The loop is set
up so that it will continue to loop while the "cnt" is greater than zero
(cnt>0;), and each time thru the loop c is incremented by 4 (c += 4). Each
time thru the loop four uucode characters are translated.
Remember that four uucode characters translate to three real bytes. c1, c2
and c3 are variables that hold the three resulting bytes. They are not
related to the variable c which is a pointer and c[n] which is the nth
character past where c is currently pointing. Remember, at the start of the
loop c is pointing to the second character in the buffer, the one past the
line length character.
c1 = ((c[0] - ' ') & 0x3f) << 2 | ((c[1] - ' ') & 0x3f) >> 4;
This line decodes the first byte. c[0] is the second ascii character in the
uucode line, and c[1] is the third. The part ((c[n] - ' ') & 0x3f) takes
an uucoded character and subtracts 32 (an ascii space) from it and ANDs it
with $3F to mask off the two high bits that aren't used. the << 2 shifts
the first result two BITS to the left and the >> 4 shifts the second result
four bits to the right. The | operator ORs the results together. Let's say
the line starts off M3F.... "M" is the line length, c[0] = '3' and c[1] =
'F' in ascii code '3' = $33 and 'F' = $46. Following the equation above:
Left half Right half
$33 - $20 (a space) = $13 $4F - $20 (a space) = $2F
ANDing with $3F = $13 ANDing with $3F = $2F
2 bit left shift = $4C 4 bit right shift = $02
OR the two halfs and c1 = $4E
c2 and c3 are derived the same way, except the shifts are different to
extract the three bytes.
if (cnt-- > 0)
fputc (c1,f);
if (cnt-- > 0)
fputc (c2,f);
if (cnt-- > 0)
fputc(c3, f);
} <== brace that ends loop
This code writes c1, c2 and c3 to the output file. as long as there are
still bytes to be output (ie. cnt-- > 0) the -- after the "cnt" decrements
"cnt" by one AFTER the comparison test is made.
Then the loop is tested, and if cnt>0 is still true, the loop starts again,
this time with c pointing to the 6th uucode character in the line. The
looping continues until the last byte is decoded and "cnt" becomes zero.
This completes one line of the code.
I'm not sure how the remaining code and the "check_uue (buf)" function work
as parts of that code are missing. It is safe to bet that it gets the next
line into buffer and checks the checksum of the processed line, so I'll
stop here. The remaining code is repetitive to what I listed above.
Charlie, I did this in a hurry, I think it is accurate, but typos may have
slipped in. I hope this gives you some help.
Where did you get this code? Is in the library or can it be posted in its
entirety?
\ ___\ ___\
\ !\ \
A Bob,
H AF6C
(R.ECKWEILER, CAT4, TOP2, MSG:84/M530;1)
<<<<< The code was posted to me on Delphi. I retyped it here and may have
""""" made some typos. Here is the original text...
--**--
if (msgtype == 'U')
// want UUE file?
{
FILE *f;
// UU decoded output file
char c1, c2, c3;
int cnt,
csum;
f = fopen (buf2, (i == 1) ? "w" : "a");
if (f)
{
if (i != 1)
// a body line?
{
cnt = *buf - ' ';
csum = 0;
for (c = buf+1; cnt > 0; c += 4)
{
c1 = ((c[0] - ' ') & 0x3f) << 2
| ((c[1] - ' ') & 0x3f) >> 4;
c2 = ((c[1] - ' ') & 0x3f) << 4
| ((c[2] - ' ') & 0x3f) >> 2;
c3 = ((c[2] - ' ') & 0x3f) << 6
| ((c[3] - ' ') & 0x3f);
if (cnt-- > 0)
fputc (c1, f);
if (cnt-- > 0)
fputc (c2, f);
if (cnt-- > 0)
fputc (c3, f);
}
}
while (prevline = ourbuf,
sgets (buf, 1024, &ourbuf) && (i = check_uue (buf)))
{
cnt = *buf - ' ';
csum = 0;
for (c = buf+1; i > 0 && cnt > 0; c += 4)
{
c1 = ((c[0] - ' ') & 0x3f) << 2
| ((c[1] - ' ') & 0x3f) >> 4;
c2 = ((c[1] - ' ') & 0x3f) << 4
| ((c[2] - ' ') & 0x3f) >> 2;
c3 = ((c[2] - ' ') & 0x3f) << 6
| ((c[3] - ' ') & 0x3f);
if (cnt-- > 0)
fputc (c1, f);
if (cnt-- > 0)
fputc (c2, f);
if (cnt-- > 0)
fputc (c3, f);
}
}
fclose (f);
p += sprintf (p, " Got %s to %s\n", buf1, download_path);
}
}
--**--
Charlie
(A2.CHARLIE, CAT4, TOP2, MSG:85/M530;1)
>>>>> Thanks Charlie, the added code didn't help much, there's still a
""""" lot missing. I hope the translation I gave you is enough to get
you started. Be sure not to write the decode part in AppleSoft. Bit
shifting can be a challenge in basic unless there is an integer divide. In
either case it is a lot slower than "C" or assembly.
If you ever come across a better example of how the checksum is calculated
please pass it along.
Happy St. Patty's Day to you Mr. O'Charlie,
Bob O'Eckweiler
(R.ECKWEILER, CAT4, TOP2, MSG:86/M530;1)
MORE UUENCODING I'm interested in learning how encoding and decoding in
""""""""""""""" UU is done.
I've read a bit of stuff on the Internet, but I haven't found any
information on exactly how the algorithm works that changes the 3 eight-bit
characters into 4 six-bit characters.
Anyone around here able to explain it to me?
Charlie
(A2.CHARLIE, CAT23, TOP19, MSG:1/M530/1)
>>>>> Hmmm... I'm not real familiar with the inner workings of UUencode
""""" or Binscii, but I do know Base64 inside and out. :) Base64 is
actually a pretty simple encoding scheme when you look at it.
Dave
(JUST.DAVE, CAT23, TOP19, MSG:2/M530;1)
>>>>> I have source code around here somewhere for sciibin, a UNIX
""""" program that handles Binscii decoding. If you're interested, I
could upload it here. It's C source code, BTW.
I'm sure I could dig up similar UU source code, if I had some time...
- Tony
(A2.TONY, CAT23, TOP19, MSG:4/M530;1)
>>>>> Base64 is really very simple in concept, but it's a bear to
""""" actually implement. :)
Imagine you have two trays that are 24 bits long. One is divided in 3
pieces, each slot is 8 bits wide. Your second tray is divided into 4
pieces, each 6 bits wide. You just line the bits up in the 8 bit tray,
hold it over the six bit tray, and drop the bits straight down. (see the
diagram)
_______________________ _______________________ ______________________
|7 6 5 4 3 2 1 0 |7 6 5 4 3 2 1 0 |7 6 5 4 3 2 1 0|
| | | | | | | | | | | | | | | | | | | | | | | |
v v v v v v v v v v v v v v v v v v v v v v v v
|5 4 3 2 1 0 |5 4 3 2 1 0 |5 4 3 2 1 0 |5 4 3 2 1 0|
~~~~~~~~~~~~~~~~~ ~~~~~~~~~~~~~~~~~ ~~~~~~~~~~~~~~~~~ ~~~~~~~~~~~~~~~~
The resulting 6 bit values are used as a simple table lookup to the valid
characters we can use for base64.
Table 1: The Base64 Alphabet (graciously swiped from RFC 2045)
Value Encoding Value Encoding Value Encoding Value Encoding
0 A 17 R 34 i 51 z
1 B 18 S 35 j 52 0
2 C 19 T 36 k 53 1
3 D 20 U 37 l 54 2
4 E 21 V 38 m 55 3
5 F 22 W 39 n 56 4
6 G 23 X 40 o 57 5
7 H 24 Y 41 p 58 6
8 I 25 Z 42 q 59 7
9 J 26 a 43 r 60 8
10 K 27 b 44 s 61 9
11 L 28 c 45 t 62 +
12 M 29 d 46 u 63 /
13 N 30 e 47 v
14 O 31 f 48 w (pad) =
15 P 32 g 49 x
16 Q 33 h 50 y
When you hit the end of the data, if you don't have exactly 3 bytes to
convert, then just drop what you have into the six-bit "tray" from the left
side, and fill with 0-bits on the right to fill the current six-bit slot.
Any empty slots on the right hand side can be filled with '=' characters.
You can use a maximum of 76 characters per line.
The "official" documentation on this encoding scheme begins on page 24 of
RFC 2045, which can be found at
You can also request a copy of it in email by sending mail to
"mailserv@ds.internic.net". The subject can be whatever you want. In the
BODY of the message, put "document-by-name rfc2045" (without the quotes
obviously :)
I'm not REAL familiar with UUencode, but I think it's pretty similar,
except instead of using a table lookup, it just adds 32 to the 6-bit value
(and some implementations replace spaces with back-apostrophes (`)). The
problem with this (and why base64 was created) is that some mailservers
choke on certain characters that are legal in UUencode. The alphabet used
in the lookup table for base64 was carefully chosen so that every character
in it would safely pass through all known mail server software.
Dave
(JUST.DAVE, CAT23, TOP19, MSG:5/M530;1)
<<<<< Thanks! If I understand the concept then the following is true:
"""""
Hi-Bit A = 193 Hi-Bit B = 194 Hi-Bit C = 195
_______________________ _______________________ ______________________
|7 6 5 4 3 2 1 0 |7 6 5 4 3 2 1 0 |7 6 5 4 3 2 1 0|
1 1 0 0 0 0 0 1 1 1 0 0 0 0 1 0 1 1 0 0 0 0 1 1
|5 4 3 2 1 0 |5 4 3 2 1 0 |5 4 3 2 1 0 |5 4 3 2 1 0|
~~~~~~~~~~~~~~~~~ ~~~~~~~~~~~~~~~~~ ~~~~~~~~~~~~~~~~~ ~~~~~~~~~~~~~~~~
48 28 11 3
w c L D
Is that right?
Charlie
(A2.CHARLIE, CAT23, TOP19, MSG:6/530;1)
<<<<< Tony,
"""""
Thanks. :) It never hurts to have sample code available.
BTW, Alan [STARFALL] gave me the following information in the INTERNET RT
BB:
"You can get C source code for UUencode/decode from the GNU project.
Go to ftp://gatekeeper.dec.com/pub/GNU/sharutils-4.2.tar.gz to get it.
You'll need gunzip to uncompress it, and a tar utility to extract the
files."
Any chance that you could grab that and put it here in a form that I can
read?
Charlie
(A2.CHARLIE, CAT23, TOP19, MSG:7/M530;1)
>>>>> If I understand Dave's explanation, it means that for every four
""""" character string in BASE64, there is a corresponding 3 character
string in REAL (i.e., the original document). Is this a correct
interpretation?
A brute force method would be to simply encode the possible combination of
6- bit characters (4 each) and use a translation table to the 3x8-bit sets.
It would be horrendous, but it would work. Or, one would have to use a
64-entry table, convert the characters to the bits, concatenate them, and
then break into 8-bit groups, and reconvert to ASCII.
Is the above correct?
It also sounds like UUENCODE can't use the control characters. If it adds
32 to the value, it means that values less than 32 to start, when
subtracted from, would give an encoded value less than zero.
Joat
(A2.TIM, CAT23, TOP19, MSG:8/M530;1)
>>>>> Charlie:
"""""
> Is that right?
Yes. :)
>>> Joat
> If I understand Dave's explanation, it means that for every four
> character string in BASE64, there is a corresponding 3 character
> string in REAL (i.e., the original document). Is this a correct
> interpretation?
Almost. If the 4-character string in base64 ends in = signs, then there
are less than 3 characters in the that spot in the original document. This
can only ocurr at the end of the data though.
> A brute force method would be to simply encode the possible
> combination of 6- bit characters (4 each) and use a translation table
> to the 3x8-bit sets. It would be horrendous, but it would work. Or,
> one would have to use a 64-entry table, convert the characters to the
> bits, concatenate them, and then break into 8-bit groups, and
> reconvert to ASCII.
Well, yeah, except that brute force translation table would take
approximately 64 megabytes of RAM to store, which makes it a little painful
to use. :) So unless you're working on a machine that actually has that
much memory available, you're pretty much stuck with splitting apart and
reconcatenating the bits and using the 64-entry table.
> It also sounds like UUENCODE can't use the control characters. If it
> adds 32 to the value, it means that values less than 32 to start, when
> subtracted from, would give an encoded value less than zero.
No, you missed part of it. I think you still split the bits apart using
that "tray example" method I showed you. The resulting 6-bit values have
32 added to them. Which makes it pretty identical to base64 except that 64
entry table being used is actually a subset of the standard ASCII table
starting at ASCII 32. I think the first character of the line is also a
count of how many characters are on that line in UUencode.
Hmmm... waitasec... if you mean in the encoded data, then no, neither
base64 nor uuencode uses control characters in the encoding. UUencode
depends on the end-of-line characters for a crosscheck, since it has a
length byte on each line. base64 just ignores any whitespace.
Dave
(JUST.DAVE, CAT23, TOP19, MSG:9/M530;1)
>>>>> A2.CHARLIE
"""""
If you're just looking for theory, it's simple enough. (Note: Some of the
details may not be completely accurate.) You process the file to be
converted in chunks of three characters (padding with zeroes at EOF?). Say
you have the following three values in a particular chunk of data (shown
here in binary):
10110101 11010010 01101101
To convert them, you take the top two bits off of each number, concatenate
them together to make a fourth six-bit byte:
10110101 11010010 01101101
|| || ||
------>----------->------------> 00101101
So you end up with:
00110101 00010010 00101101 00101101
Then you add 32 ($20) to each resulting value to get a number in the range
of 32 to 96 (ASCII value of printable characters). For each line of
output, put the line length (normally 77 characters? - an uppercase 'M')
followed by the encoded characters. A zero length line terminates (?).
Hope it helps.
...Chris
(K.FLYNN, CAT23, TOP19, MSG:11/M530;1)
<<<<< Chris,
"""""
I've just become interested in this subject, and I'm wondering about
creating a utility for the Apple II (8 bit) that will encode/decode UU
and/or Base64.
From what I've seen of Base64 (Dave's explanation), this shouldn't be a
major problem. However, I've gotten at least two different takes on how UU
does it's coding, so I'm not sure how to proceed there.
Andy, over in the Internet RT, said that UU is done this way (which is
similar to Dave's description of Base64):
| 7 6 5 4 3 2 1 0| 7 6 5 4 3 2 1 0| 7 6 5 4 3 2 1 0|
| | | | | | | | | | | | | | | | | | | | | | | |
v v v v v v v v v v v v v v v v v v v v v v v v
| 5 4 3 2 1 0| 5 4 3 2 1 0| 5 4 3 2 1 0| 5 4 3 2 1 0|
While you say...
1 1 0 0 1 0 0 1 0 1 0 0 0 1 1 0 0 0 1 1 1 1 0 1
--- --- ---
0 0 0 0 1 0 0 1 0 0 0 0 0 1 1 0 0 0 1 1 1 1 0 1 0 0 1 1 0 1 0 0
--- --- ---
Is there more than one way to do UU?
Charlie
(A2.CHARLIE, CAT23, TOP19, MSG:12/M530;1)
>>>>> Charlie,
"""""
For some years now, I have been receiving earthquake reports off of
packet radio that are uuencoded. I use a standard decoder that I think I
got off of AOL back when Apple //s were legal there.
Being an inquisitive fellow, I also remember downloading a file or two that
included the format for uuencoding and some source code (in C). If you
like, and if I can find it - which I think I can, I'd be glad to upload it
for all to see.
Bob, AF6C
(R.ECKWEILER, CAT23, TOP19, MSG:16/M530;1)
>>>>> UUENCODE was developed to allow sending binary files over digital
""""" communication links. Many of these links allowed only the
transmission of the standard printable ascii characters. Control codes
were used for other functions. Also, many of these links truncated spaces
and blank lines.
UUENCODE expands the file to be transmitted by 33% (plus overhead) by
converting the binary file into one of 64 printable ascii characters
thru . Also, since the space can be truncated on some
systems, later versions of UUENCODE further translate the space into the
back apostrophe (`) ascii 96.
Three 8 bit bytes are encoded at a time. The 24 bits are separated into
four six-bit 'bytes' and 32 is added to each of these 'bytes' to make it a
printable ascii character.
Let's convert $AB CD EF:
10101011 11001101 11101111 <= $AB CD EF in binary (3 bytes)
101010 111100 110111 101111 <= group into 6-bit "bytes"
00101010 00111100 00110111 00101111 <= put it in 8 bit byte form
by adding two leading 0
bits. ($2A 3C 37 2F)
01001010 01011100 01010111 01001111 <= add 32 ($20) to each byte
($4A 5C 57 4F)
J \ W O <= equivalent ascii
Before going any farther, here is a two line text file and how it appears
after UUENCODING. Of course UUENCODING a text file is kind of a waste, but
it makes a good example.
Here's the test file (each line ends with a ):
Now is the time for all good men to come to the aid of their party!
The quick brown fox jumps over the lazy dog.
And here's that file UUENCODed:
begin 644 testfile.txt
M3F]W(&ES('1H92!T:6UE(&9OGD@9&]G+@U46
``
end
size 113
The "begin 664" tells the decoder that uuencoded data follows and the
"testfile.txt" is the filename that the file will be given.
The encoded data then follows. Each line starts with a line length
character and optionally ends with a checksum character.
Notice that each of the first two lines start with a capital "M". This is
a line-length character. "M" = ascii 77 minus the 32 offset = 45. But if
you count the characters on one of those lines there are 62 characters. (61
characters if there is no checksum.) The 45 refers to the number of 8-bit
bytes in that line prior to encoding. Forty-five bytes corresponds with 60
characters + one length and one checksum character adds to 62.
Likewise the 7 line length character on the third encoded line refers to 23
bytes. If the number of bytes on the list line is not divisable by three
the last group of four characters may only partially used. Some programs
seem to pad zeros and others leave garbage. Since the number of bytes on
the line is known this is not a problem. In the example above the last four
ascii characters (+@U4) decode to $2E 0D 54 which is the ending period for
byte 112 and a carriage return for byte 113 (the last byte) followed by "T"
which is ignored garbage.
The next line just contains two back apostrophe characters, which marks the
end of file (Line length of zero). The "end" is a marker to tell the
decoder that it is finished. Sometimes more than one file is encoded and
another "begin" is encountered instead of the "end". UUENCODE allows for
more than one file to be transmitted.
The "size 113" is generated by the program I use and is not used by the
decoder. It is just ascii information and in usually not present when sent.
The checksum presents a problem across different versions of UUENCODE.
Most programs have a feature to allow ignoring the line checksum. Richard
Marks in his program uses the sum of all the encoded characters, before
adding the mapping, modulo 64 as the checksum. This appears to be the
correct method (according to information I've read - but I'm no expert).
The version written by Mark Horton and ported to the IIgs by Jeff Noxon
uses a different scheme; he uses the sum of the original, not the encoded
characters. The version I used to encode the short text message above is
the Horton/Noxon version.
The Norton/Moxon version of UUENCODE and UUDECODE is available in the A2PRO
library as file 4926.
Hope this helps some,
\ ___\ ___\
\ !\ \
A Bob,
H AF6C
(R.ECKWEILER, CAT23, TOP19, MSG:17/M530;1)
>>>>> A2.CHARLIE
"""""
|| Andy, over in the Internet RT, said that UU is done this way...:
||
|| While you say...
Don't listen to me. :) I just pulled that off the top of my head from
some point in time from the ancient past. That means more than a couple of
weeks ago. :)
I double-checked and you're correct. Three eight-bit bytes at a time are
packed into a bit stream and chopped back up into four six-bit bytes. The
order of the bits does not change.
The actual format appears to be:
begin end
Each encoded line consists of a length byte followed by up to 60 encoded
(45 unencoded) characters. The length byte is the ASCII value represented
by 32 plus the number of unencoded characters in the line. Any encoded
value that would be a space character (including the length byte) is
replaced by the back tick character (`).
...Chris
(K.FLYNN, CAT23, TOP19, MSG:19/M530;1)
<<<<< Hmmm...
"""""
Somewhere in the last few days I've seen that mentioned as the backslash
(\). I did see that you put two back ticks (``) on the line following the
last encoded line, and then on the next line you put the word "end".
Am I confused (probably)?
Charlie
(A2.CHARLIE, CAT23, TOP19, MSG:20/M530;1)
>>>>> A2.CHARLIE
"""""
|| Somewhere in the last few days I've seen [`] mentioned as the backslash
|| (\).
Nope, it's definitely a backtick according to the source code I saw.
|| I did see that you put two back ticks (``) on the line following the
|| last encoded line, and then on the next line you put the word "end".
||
|| Am I confused (probably)?
Yep, but only about me showing two backticks. I didn't say that, though it
looks fine to me.
...Chris
(K.FLYNN, CAT23, TOP19, MSG:21/M530;1)
>>>>> Yes, the last line (before the END, which is optional - it could be
""""" another BEGIN for another file) has one or two back ticks (could I
have said backslash by mistake?). The back tick is SPACE which is 32 which
decodes to zero. Thus the line length of the last line is zero. The second
back tick is the checksum, also zero.
\ ___\ ___\
\ !\ \
A Bob,
H AF6C
(R.ECKWEILER, CAT23, TOP19, MSG:24/M530;1)
[EOA]
[BAN]//////////////////////////////
FILE BANDWAGON /
/////////////////////////////////
Top 10 Files for February
"""""""""""""""""""""""""
by Douglas Cuff
[D.CUFF]
This feature lists the ten most popular files for the month. To give
files a chance to seek their own levels, no files will be added to the list
until they've been in place at least a month. This month, we look at the
files uploaded 1-28 February 1997.
This isn't the Academy Awards ceremony, folks; it's more like the
People's Choice Awards (both of which are trademarked, by the way). The
Top 10 doesn't necessarily tell you what's new and interesting--what files
_you_ might find interesting--it simply tells you what files have been
downloaded a lot--what other people found interesting!
This month, GenieLamp A2 occupies four spots on the list, but we're
just counting that one file. We hope this explains why there are 13 files
on the Top 10 list.
File # Filename Bytes DLs Short description
------ --------------- ------ --- -------------------------------------
28342 A2.DOM.9702.BXY 416640 82 A2 Disk of the Month, Jan/Feb 1997
28307 MEGABOX201.BXY 19840 61 MegaBox 2.0.1 - NDA Music Player
28302 ALMP9702TXT.BXY 64896 53 GenieLamp A2 February 1997 Text
28301 ALMP9702AWP.BXY 72192 51 GenieLamp A2 February 1997 AWP
28313 PATCH.INFO.BXY 10368 36 AppleWorks 5.1 Patcher Information
28336 ALMP9702.HS.BXY 95360 25 GenieLamp A2, Feb. 1997 (HyprStudio)
28309 BESTMODS.01.BXY 1272704 25 Best MODs Collection Number 1
28304 A2.JAN.ADB.BXY 3228 24 ADB Update of A2 Library Index - JAN
28334 BESTMODS.06.BXY 1064448 21 Best MODs Collection Number 6
28305 FEB97DESK.BXY 467484 21 Desktop background INIs for Feb. 97.
28300 ALMP9702.ASC 119992 20 GenieLamp A2 February 1997 ASCII
28321 BESTMODS.04.BXY 1086592 18 Best MODs Collection Number 4
28339 BESTMODS.08.BXY 908544 16 Best MODs Collection Number 8
A2.DOM.9702.BXY Genie's A2 Disk of the Month has moved to a bi-monthly
""""""""""""""" schedule. This edition begins with the Dean's List and
two issues of GenieLamp A2 (January and February 1997). In the directory
for all Apple II's, there's AutoMenu, a BASIC program selector to run only
the executable files on your drive, and Fresh.It.Patch, instructions to
patch AppleWorks v5.1 so that the desktop does not shrink each time you
re-run it. In the Apple IIgs folder, there's FontViewer, v2.0 of the
genealogy program Pedigree, and two picture-viewing utilities, Eye (a
Finder extra that needs to be placed in System:FinderExtras) and GIFview, a
quick 'n' dirty program for GIF graphics. Freeware and shareware.
MEGABOX201.BXY MegaBox v2.0.1 by Rolf Braun is a music-player in an NDA
"""""""""""""" that can handle SoundSmith, Midi Synth, and NoiseTracker
GS music files. The program hasn't changed since v2.0; only the
documentation and some supplementary files, which are now included. Either
public domain or freeware; the documentation isn't clear.
ALMP9702TXT.BXY Four editions of the February issue of GenieLamp A2 grace
""""""""""""""" our Top 10 list this month--in order of popularity, the
standard text file edition, the AppleWorks word processor edition, the
HyperStudio edition, and the "linefeeds added" unshrunk text file edition.
All four editions feature the same great articles--the reinstatement of
A2Pro RoundTable coverage, a review of Quick Click Morph, and a profile of
software author Bret "Slixter" Victor. Freeware.
PATCH.INFO.BXY Here are two files detailing the AppleWorks patches made
"""""""""""""" available in Bev's Free Patcher v6.5, available from
Beverly Cadieux of Kingwood Micro Software / TEXAS II. The lion's share of
the approximately 130 patches are for the most recent version of
AppleWorks, v5.1. These two files are freeware.
BESTMODS.01.BXY Part 1 of a series of "Best MODs" (music modules)
""""""""""""""" uploaded by Russell Nielson. These 9 Amiga music modules
may be played using favorite MODule player--Nielson suggests Deskplay:
Captive 2, Dirty Mary 2, FunkySong, Kingdom of Pleasure, Leave Me Alone,
Living Proof, LK (Lizard King), Pelforth Blues, Spacedweeb, Taproot, The
Code of Pulse, and Walking in the Space. Freeware.
A2.JAN.ADB.BXY An AppleWorks data base file of all the uploads to Genie's
"""""""""""""" A2 library during the month of January 1997--42 files in
all. Freeware.
BESTMODS.06.BXY These 9 Amiga music modules may be played using favorite
""""""""""""""" MODule player: Acid Jazz, Clairvoyance, Decibel
Overload, Fury Forest, Glutturale, Love Anarchy, Nitabrowski, Odyssey Part
1, and Street Jungle. Freeware.
FEB97DESK.BXY A collection of 61 pictures in .INI format, to allow the
""""""""""""" graphics to be used as the background for desktop programs
(replacing the standard periwinkle blue). Almost all of these pictures
focus on Valentine's Day--cupids, hearts, flowers, and the like--and as
usual, there are many variations on some of the graphics (larger and
smaller versions, mirror images, different backgrounds). Of the Valentine
graphics, the best in my opinion are HEART3.INI (showing candy hearts with
messages on them, or "conversation candies") and HEARTS2.INI, a nice
pattern of large and small red hearts on a white background. There are a
few graphics not on the Valentine theme: GRHOGDAY.INI, concerning
Groundhog Day (February 2); PRESDAY.INI, concerning the American holiday
President's Day (February 17); and RED.DRAGONa.INI, concerning a holiday I
confess I am in ignorance of. (Readers?) Two graphics which may appear to
be exceptions are the series CHRSTY3A.INI, CHRSTY3b.INI, CHRSTY3c.INI,
which are very abstract representations of a heart pattern (and therefore
not limited to use at Valentime) and the series VAL1.INI, VAL2.INI,
VAL3.INI, which are sirds, or hidden three-dimensional pictures. (Avoid
the last one, VAL3.INI, which has been imperfectly translated.) Freeware.
BESTMODS.04.BXY These 9 Amiga music modules may be played using favorite
""""""""""""""" MODule player: CPLX TaiPan Preview, Hmmmmma, Let there
be Funk 2, M0rk Sone 2, Rubicon, So What, Tan, Technomania, and
Tranzeseven. Freeware.
BESTMODS.08.BXY These 9 Amiga music modules may be played using favorite
""""""""""""""" MODule player: Enigma, Entity, Gratitude, Herald, It's
Phenomenal, Klisje Paa Klisje, Macnormalia, Mandelforce, and Marek
Bilinski. Freeware.
[EOA]
[PDQ]//////////////////////////////
PD_QUICKVIEW /
/////////////////////////////////
Yours For The Asking
""""""""""""""""""""
by Douglas Cuff
[D.CUFF]
Program Name: Change-A-File
Filename: CF.4.22.BXY
Program Number: 24287
File Size: 27392
Program Type: utility
Author: Harold D. Portnoy
Version Reviewed: v4.22
File Type: freeware & shareware
Requirements: Apple IIe, IIc, IIgs
FROM THE AUTHOR CHANGE-A-FILE is a batch file utility that reads
""""""""""""""" AppleWorks Word Processor (AWP) and text (TXT) files;
converts AWP files to TXT files, TXT files to AWP files, and AWP 3.0 (AWP
4) files to AWP 2.x files; restores damaged AWP and ADB (data base) files
(including AW4); change file or auxiliary type codes, and strip or insert
line feeds. Up to 88 files in a directory or subdirectory can be altered.
This program uses the ProSel format. CHANGE-A-FILE is particularly useful
to the AppleWorks (AWKS) user and to prepare files for uploading or alter
files after downloading.
[*][*][*]
. __
(^) <^> /~ ~\
\-=======_/"\_======-/ \)
PD_Q RATING "\. 1 ./"
""""""""""" "\._ _ _./"
. __ (_____) . __
(^) <^> /~ ~\ (^) <^> /~ ~\
\-=======_/"\_======-/ \) \-=======_/"\_======-/ \)
"\. 2 ./" "\. 3 ./"
"\._ _ _./" "\._ _ _./"
(_____) (_____)
. __ . __
(^) <^> /~ ~\ (^) <^> /~ ~\
\-=======_/"\_======-/ \) \-=======_/"\_======-/ \)
"\. 4 ./" "\. 5 ./"
"\._ _ _./" "\._ _ _./"
(_____) (_____)
FIVE LAMPS (1-5)
PD_Q COMMENTS Change-A-File is a utility that comes in two parts. The
""""""""""""" first part is free--three commands for manipulating text
files, one command for typing text and AppleWorks word processor files (to
the screen or printer), and one command for altering file types--five
commands in all.
The three commands for manipulating text files--
L- Strip Linefeed
C- Strip Control Character
I- Insert Linefeed
--are not unique to this utility, but I like the batch implementation here.
You can choose to strip or insert linefeeds, which is value to those who
know that Apple, IBM, and UNIX all use different "newline" (or "end of
line") sequences. Apple uses the carriage return online. IBM uses the
carriage return plus linefeed. UNIX uses the linefeed only. You begin to
see why inserting and removing linefeeds are important. If you the World
Wide Web a lot, you'll probably find yourself with a lot of UNIX text
files. Change-A-File not only lets you strip the linefeeds, but optionally
lets you change the linefeeds to carriage returns--very useful indeed.
To be sure, there are other utilities to handle the insertion and
stripping of linefeeds--AppleWorks can now handle this internally with a
simple macro, for instance--but I've found none so handy as Change-A-File.
The ability to strip _any_ control character is also handy, even if the
interface is slightly counter-intuitive--it sends me diving for the
documentation file every time. To strip Control-Z, for example, press Z
(not Control-Z) and then Return.
The utility to view TXT and AWP files is nice, too, but it can only
scroll forward, not back, as File-A-Trix does. On the bright side, it
handles AppleWorks centering and indenting commands properly, which is more
can do. To be honest, I keep forgetting about the ability to change the
file type, auxiliary type, and the eight bits of the access code--so many
other utilities offer similar capacity with a similar interface.
All five commands I've described so far are absolutely free, and make
the program well worth having because of its handy interface. If you pay
author Harold Portnoy a mingy $10, you'll get a password to unlock
Change-A-File and will get six more commands. When unlocked, Change-A-File
really comes into its own.
W- AWP File to TXT File
T- TXT File to AWP File
X- AWP 3-5 to 2.x File
E- Exhume AWP File
D- AWP File Doctor (AW 2-5)
R- Repair ADB File (AW 2-5)
The ability to change AppleWorks files into text files is nothing
new--AppleWorks now handles the matter perfectly adequately--but again,
this program makes it even easier. It's actually worth the hassle of
quitting AppleWorks and launching the Change-A-File program--praise doesn't
get any richer than that. For starters, you can be sure that your centered
and indented text will be treated properly. You can translate a slew of
files at one time, and you can easily choose to have each line end with or
without a hard return.
The routine to change TXT files into AWP files isn't quite as good--it
doesn't always update the screen display properly when you first load the
file--but it's still an appreciable time-saver. You can start working with
a large pre-converted file more quickly than you can a text file. The
latter has to be loaded onto the desktop and then converted for the word
processor module once you enter the file. The second stage takes time.
The file recovery and repair utilities are life-savers. I don't
suppose I've had to use them more than half a dozen times in the last three
years, but each time they've come through for me. "Exhume AWP" is the
first command to try on word processor files that won't load, and if that
doesn't work, you move onto the "AWP File Doctor". (You can sometimes
benefit from trying both commands.) "Repair ADB File" does much the same
thing, except--obviously--for data base files, and for that reason is even
more valuable. With a word processor file, there are always alternatives,
but a data base file is much trickier to resurrect, making the final of the
six commands useful indeed.
SUMMING UP If I had to list the two utilities I use most on a daily
"""""""""" basis, Change-A-File would come third, after the File-A-Trix
Classic Desk Accessory (Apple IIgs only) and Cat Doctor (part of the
commercial ProSel package, available in separate Apple IIe/IIc and IIgs
versions). It keeps growing with me as I want to send out text or collect
it, and I wouldn't want to be without it.
RATING SYSTEM
"""""""""""""
5 LAMPS.........What? You haven't downloaded this program YET?
4 LAMPS.........Innovative or feature rich, take a look!
3 LAMPS.........Good execution, stable program.
2 LAMPS.........Gets the job done.
1 LAMP..........A marginal download.
0 ..............GenieLamp Turkey Award!
[EOA]
[BTS]//////////////////////////////
BEHIND THE SCENES /
/////////////////////////////////
With _Juiced.GS_ and the Spectrum Internet Suite development team
"""""""""""""""""""""""""""""""""""""""""""""""""""""""""""""""""
by Max Jones
[M.JONES145]
(C) 1997, Max Jones, Juiced.GS
All rights reserved
The Apple II world has been buzzing since early March when it was
greeted with the news that Spectrum Internet Suite, a full-featured World
Wide Web browser, had been developed for the IIgs.
Final production details are being worked out by SIS publisher Seven
Hills Software. If all goes well, SIS could begin shipping during the first
week of April.
The product announcement, first made in the Winter '97 issue of
Juiced.GS and a day later in a Genie Apple II Roundtable Real-Time
Conference, may go down as one of the most stunning project developments in
Apple II history. While common wisdom dictated that TCP/IP, the complex set
of protocols that drive telecommunications on the Internet, would be needed
for the IIGS before a Web browser could be developed, Spectrum Internet
Suite was designed so that it did not need it.
In fact, the basic requirements for running SIS include only Spectrum
v2.1, either a Unix shell or Genie account, and a fairly robust hardware
configuration with extra RAM, hard drive and high-speed modem. An
accelerator is highly recommended.
The development of SIS represents an intensive, seven-month project
begun last July during Kfest '96 in Kansas City, Missouri. It was then that
Spectrum author Ewen Wannop, Seven Hills partner Dave Hecker, and Apple II
programmers Richard Bennett and Tim Buchheim, met up with Geoff Weiss, a
systems administrator for an East Coast Internet service provider.
Discussions among this small group planted the seeds that have now
blossomed into a product many thought would never be possible on an Apple
IIgs. Wannop wrote the Spectrum add-ons, Weiss wrote the powerful scripts,
Hecker guided the development team, and Bennett and Buchheim served as
consultants. Also joining the team within weeks of its formation was Ken
Lucke, a master Spectrum scripter in his own right who has been involved
with Spectrum development since its early days.
I had the pleasure of being asked in mid-January by the SIS team and
Seven Hills to become a beta tester for the final phase of development. I
used what I learned to prepare my article for the Winter issue of
Juiced.GS. As it turned out, that article was the first to be published
about the project.
While doing exhaustive testing on SIS, I also had the opportunity to
interview Wannop, Weiss and Hecker about the project. I have compiled major
portions of those interviews and am pleased to share them with _GenieLamp
A2_ readers this month.
[*][*][*]
Following are portions of an interview conducted in early February
with Spectrum author Ewen Wannop.
Juiced.GS> How did Spectrum Internet Suite come to be?
"""""""""
Ewen> When I got to Kfest last year, the one thing I was hoping to see was
"""" Derek Taubert's Internet Tools and TCP/IP in action. Accessing the
Internet in my opinion was the last big frontier for the IIgs to break
through. If it was not able to join the Net revolution soon, then I felt
the IIgs was unlikely to survive into the next millenium.
Unfortunately, Derek was unable to get to Kfest, and nobody had been
authorized to show his work in progress.
This left me very frustrated. I had not even started to do anything
along Net lines, as I had made assumptions that it would be necessary to
have TCP/IP in order to do anything with the Net. Also, I had been very
busy right up to the day before I flew to Kfest, getting Spectrum v2.1
ready.
During Kfest I met face to face with those who had only been names up
to that time. I had been introduced to Geoff Weiss quite early on, as I had
borrowed his IIgs and enormous screen for my Spectrum demonstration. It was
not until the last night of the fest, after we had got back from Jess and
Jim's steak extravaganza, that a small group of us got together in Geoff's
dorm room and SIS was born.
Juiced.GS> Could you share with us some of what happened that night?
"""""""""
Ewen> Geoff had his Mac connected to the Net, and many of us had been
"""" browsing with it over the three days of the fest. That fateful
night, Richard Bennett, Tim Buchheim, Dave Hecker, Geoff and myself started
talking. We all lamented the fact that Derek Taubert had not finished his
TCP/IP, and that this was really holding us all up in getting connected to
the Net with the IIgs.
Geoff then dropped a bombshell. He said that you did not TCP/IP to
access the Net, and that there was another route that anybody with an ISP
provider could use. Geoff asked us to give him a Web URL, and then he then
proceeded to type a few commands into his Mac. Lo and behold, HTML poured
onto his screen!
I think all our mouths just dropped in unison as the implications of
this struck home. Richard and myself were aghast. If we had known about
this sooner, I am sure we would have been showing working browsers and
other Internet goodies at Kfest last year!
We quickly realized we now had some very important information, and so
a working group was instantly set up with those who were grouped in that
dorm room. Seven Hills was to mastermind the project, and they agreed to
publish it. The moment I got back home to England, I started working on the
browser. Within a month or so, I had the first Beta version available for
testing.
Juiced.GS> But wasn't SIS a combined effort?
"""""""""
Ewen> Until I had a working browser, or at least one that could interpret
"""" HTML and display it meaningfully, nothing much else could happen
with the project. I had decided quite early on that the quickest way to get
anything working was to use the existing power of Spectrum. There was no
point in reinventing wheels.
For this reason the browser was built as a drop-in Spectrum Online
Display. In order to control the special display, I made it also conform to
XCMD structure. This meant it was a new kind of hybrid display and XCMD, so
I simply called it an XDisplay.
With the first test version, I had prepared a very simple script that
could at least tell me that it was working, and could load in HTML text
files to test the display. I uploaded this to the testers, and concentrated
from there on on the actual display itself. Geoff Weiss and Dave Hecker
started working on the scripts straightaway, but very soon Geoff, with his
amazing knowledge of how the Net works, took the scripts on, and has worked
on them ever since.
The scripts are really the core of SIS. The browser actually
interprets the HTML and displays it, but apart from a few functions that
were better done in assembler, the main part of SIS is achieved by the
controlling scripts. It only goes to show that we really do have a very
powerful scripting language in Spectrum!
The beta testing team grew over time, and their contributions were
invaluable, not only in reporting bugs, but in helping us decide what
should and should not be included in the browser. The title 'Spectrum
Internet Suite' or SIS, was coined quite early on.
Juiced.GS> What has your life been like over the last seven months since
""""""""" SIS was born?
Ewen> Well, that is an easy one. It has really been no different from the
"""" previous five years or so during Spectrum develop. Oh, and I suppose
my e-mail count has risen somewhat. One day, I think I counted over a
hundred messages whizzing around the testers.
Apart from the unfortunate need to go to work every so often, my days
are filled from morning till late at night, debugging, testing and
developing. The one thing that has changed though, is that work on the
browser, and its various parts, has taken precedent over Spectrum itself. I
have an increasing list of things that need to be done for any future
versions of Spectrum, but have just not had the time to tackle them.
Juiced.GS> Where do you see SIS going from here?
"""""""""
Ewen> We are very pleased and excited to have made the IIgs access the Web
"""" through SIS. There are some limitations with the access method we
currently use, and if Derek Taubert ever gets his TCP/IP finished, then I
would hope that we could link into that, and give SIS more flexible access
to the Net.
The scripts can be further developed to provide even more of the
features that are normally expected from Net access. Geoff had not done
much Spectrum scripting till he tackled this project, and I think he was
suprised how powerful and flexible Spectrum scripting was. If we can keep
him at it, I am sure we might see even more SIS features in the future.
We were not able to provide onscreen graphics as part of the display.
Fast as the IIgs may be, it was just not up to the speed required, or the
screen resolution needed, to show pictures. Perhaps we could do something
with showing graphics on demand, but this will depend on some other key
features being resolved first.
Juiced.GS> What are your plans for the future?
"""""""""
Ewen> I shall have much more time on my hands after the beginning of
"""" April. I plan to spend a great deal of it in front of the keyboard.
There are still many projects that I would like to tackle, which I have
just not had time to even start until now. The IIgs is definitely not dead
as we have just proved. It has a great deal of life left in it yet!
[*][*][*]
Following is an edited transcript of an interview conducted in early
February by Juiced.GS with SIS scripter Geoff Weiss.
Juiced.GS> How did you come to be involved with the birth of Spectrum
""""""""" Internet Suite at Kfest '96?
Geoff> Dave Hecker and Ewen Wannop tended to hang out in the area near my
""""" room. I stumbled into a conversation with two other people and
learned that Seven Hills was given a suggestion of how to possibly design a
Web browser for the IIgs without using TCP/IP. I was in disbelief how easy
the network connection worked and wanted to test it out immediately. We
used my roommate's local (Kansas City based) ISP to connect to my work.
The commands we initially tried did not work. All of a sudden, I
recognized the commands as something I had seen in operating our Web
server.
After a few minutes in getting to the right file, I figured out what
we were doing wrong. We went through the set of commands and lo and
behold, the entire contents of my company's home page was displayed in its
pure HTML form. I remember being stunned thinking that was incredibly
simple and couldn't believe a Web browser couldn't have been developed for
any Apple II in four years. After a little more work, I figured out how to
access pages besides the home page of a site.
I remember this being an incredible day and saw that my IIgs could
last a few more years as my sole computer. It was decided that since
Spectrum is a WYSIWYG IIgs telecommunication program, a Web Browser could
be easily developed using much of the built-in macro functions. The
display that generates the Web page would be written in assembly langauge
by Ewen. Just about every other Web Browser in existance is based on a set
of C library routines, but this GS Web browser would use assembly for the
quickest page generation possible.
Juiced.GS> At what point did you become part of the development team?
"""""""""
Geoff> Roughly six weeks after KansasFest, Dave (Hecker) gave me the
""""" option to be a beta tester for the browser. Of course I accepted
since I wanted to be one of the first people to browse the Web on a IIgs.
The script I received was written to work only on Genie. I rewrote the
network connection so it worked with my ISP. In less than an hour, I could
load my Web page on my IIgs. This was very exciting.
But, the user interface was very, very simplistic. After the browser
started, one had to select a menu item to bring up a window to enter a Web
server on one line and the Web page on another line. I found this
interface to be very, very clunky since I use Lynx and Netscape
Navigator all the time. I spent a bit of time modifying the interface to
make it "feel" more like the Netscape Navigator. The winow to select a
Web server and page was changed to follow the normal URL syntax. More
modifications included support for relative URLs and a complete redesign of
the menus so it was more intuitive. It wasn't until Thanksgiving when the
browser actually started to look like Netscape Navigator with buttons and
an URL entry line on a toolbar. A common Netscape Navigator feature like
going forward and backward in the History List wasn't added until
mid-December.
Juiced.GS> What has your life been like the past seven as SIS development
""""""""" intensified?
Geoff> Since I have a full time job as a system administrator for a small
""""" ISP in Washington, D.C., IIgs development is done on a part time
basis. I mostly considred writing the browser as "fun." I have to
consider this as fun since I'm not going to make any money on the browser
(well, I will get some financial compensation based on sales, but any money
I make will not cover the time I actually spent on development I put in).
There was a time at the first two weeks of November when our system
had a major server crash and I couldn't do any work on the browser. It was
understood by Dave and Ewen that my priorities were at work and browser
development had to wait.
At the beginning of January, I was getting frustrated since our
network connection started having problems accessing certain Web sites. I
was at a point where I thought we had to give up the entire project. There
were only a few of us who knew about the browser. I was thinking we could
keep it a secret and be the only ones who had Web access on a IIgs. I
don't remember when my pessimism wore off, but a few development specs were
changed to get around the problems I was facing.
Juiced.GS> Now that SIS has been completed and is such an excellent piece
""""""""" of software, you must be happy you stuck with it in tough
times.
Geoff> Over the course of seven months, there were some weekend mornings
""""" that I didn't get to sleep until 6 a.m. working on the browser.
There were weeks when I got nothing done just trying to resolve a stupid
bug. But looking back at it all, it is incredible that a fully functional
Web browser could be developed for the IIgs in the spare time of a few
dedicated individuals in only seven months.
[*][*][*]
Following is an edited transcript of an interview conducted with Seven
Hills Software partner Dave Hecker in early February.
Juiced.GS> Please trace for us the steps leading up to the discovery of
""""""""" the Web access method used by SIS and the decision to develop a
browser.
Dave> Shortly before Kfest I had some exposure to servers, ports, and
"""" other networking issues that got me wondering if there wasn't a way
to retrieve web pages without requiring TCP/IP.
At the Kfest roast I sat between Richard [Bennett] and Ewen, and by a
stroke of luck Tim Buchheim was sitting across from me. I was asking
Richard and Ewen, "How does this work" and "How does that work", and
eventually I put it all together. "So if I did X and Y (without a TCP/IP
connection), could I retrieve the HTML code for a web page?"
Here's where the luck comes in: While Richard was pondering, Tim pipes
in, "Sure! You just do X and Y, then A and B, and you'll get the HTML
code."
Back in the dorm that night, we were talking again and really wanting
to do a little testing of our newly-assembled knowledge. Luck visits again,
and Richard asked Geoff Weiss if we could borrow his Unix account.
"Sure!"
Geoff pounds out some commands. Close. A few more. Closer. A few more.
Bingo! There's the full text of a Web page! Disbelieving what he just
saw, Geoff tries another site. Bam! Then another.
I asked Richard a few more questions, and Geoff offered some answers.
Turns out he administers a Web server and knows a LOT about a missing piece
of the puzzle!
From there the idea just took off. Within a few short weeks after
Kfest we were actually cruising the web! On a IIGS! Without the "required"
TCP/IP! AMAZING!
Juiced.GS> Amazing, indeed. But the method of getting to that point turned
""""""""" out to really be quite simple?
Dave> For what it's worth, the solution to not needing TCP/IP had existed
"""" all along ... it just took some luck to ask the right questions of
the right people at the right time! In hindsight, the solution was so
obvious we could not believe no one had thought of it before.
[*][*][*]
>>> ABOUT JUICED.GS <<<
"""""""""""""""""""""""
_Juiced.GS_ is a quarterly printed magazine dedicated to the people
and products that keep the Apple IIgs going strong. In 1996, the
magazine's inaugural year, _Juiced.GS_ went out to 295 paid subscribers in
42 states and 11 foreign countries.
SUBSCRIPTION INFORMATION:
A 1997 subscription is available for $14 in the U.S., Canada and
Mexico; $20 elsewhere in the world.
A set of the four 1996 issues is also available for $14 in the U.S.,
Canada and Mexico; $20 elsewhere.
Renewals: If you were a 1996 subscriber, your subscription expired
with Volume 1, Issue 4, Fall '96. If you have not yet renewed your
subscription, or did not also subscribe for 1997 when you purchased your
1996 subscription, now is the time to renew. The Winter '97 issue (Volume
2, Issue 1) was published the first week of March.
New subscriptions and renewals should be addressed to:
Max Jones
Juiced.GS
2217 Lakeview drive
Sullivan, Indiana 47882
Send checks or money orders in U.S. funds payable to Max Jones. Sorry,
no credit cards or purchase orders can be accepted.
_Juiced.GS_ has a home page on the World Wide Web. Pay us a visit the
next time you're cruising the web. The URL is:
http://users.ids.net/~kerwood/juiced.gs
E-mail to _Juiced.GS_ should be directed to:
Genie: M.JONES145
Delphi: JuicedGS
Internet: m.jones145@genie.com -or- juicedgs@delphi.com
[EOA]
[RWA]//////////////////////////////
THE REAL WORLD APPLE /
/////////////////////////////////
Connecting to the World Outside
"""""""""""""""""""""""""""""""
by Peter C. Brickell
[P.BRICKELL]
>>> PART 3B: BUILDING AN APPLE II TEMPERATURE SENSOR<<<
""""""""""""""""""""""""""""""""""""""""""""""""""""""""
In this installment I will be carrying on from my previous discussion
of the theory of using thermistors as temperature sensors for the Apple II.
I'll give some specific information on building a practical thermistor
circuit for the Apple game port.
First though, I'll review the last two installments. In Part 2 I
talked about how timing delays can be programmed into the Apple to do
elapsed time measurements. I gave some simple examples in Applesoft.
Machine language can also be used for greater accuracy of timing.
In Part 3a I described how the Apple's paddle input lines are used to
indirectly measure resistance using a built in timing routine. The usual
type of resistance which is measured by these lines is the variable
resistors in a set of paddles or a joystick. In these cases, the value of
the resistance is directly related to the position of the paddle or
joystick.
I discussed how a temperature sensitive resistor (thermistor) can be
substituted for the paddle or joystick resistor to allow the Apple to
crudely measure temperature with the PDL() command from Applesoft. I also
stated that for better accuracy of measurements with a thermistor that a
machine language routine, a larger capacitor in the circuit, and some form
of calibration program are needed. Now, on with the show!
>>>SOFTWARE<<<
""""""""""""""
To measure temperatures accurately you will need a machine language
program which can accurately time the charging of the larger external
capacitor used in this design. The project is taken from the book "Chaos
in the Laboratory" by Vernier Software, and a program disk is included with
the book. The book (which contains many other Apple II interfacing
projects) is priced at $25.95 according to their 1997 catalogue. It has a
suitable temperature measuring routine on the disk and an Applesoft output
program which can be easily modified to suit the user.
You will also require a calibrating program. This is also included on
the disk that I mentioned above. Enterprising programmers who feel up to
writing their own routines will not need these. The general idea is that
three variable values must be established to accurately describe the
thermistor temperature response. This means setting up and solving three
simultaneous equations (which is more programming than I was prepared to
take on) Using the Vernier software I have been able to read temperatures
accurately to about 0.2 degrees Fahrenheit.
I will describe some project modifications at the end of this article
to allow crude use of a thermistor probe without the software I mentioned
above, but for accurate temperature measurements, you will need these
programs and the following design.
>>>HARDWARE<<<
""""""""""""""
You will need only three parts to build the thermistor sensor for the
Apple, other than some wire and your soldering equipment and skills.
You will need:
1) A thermistor with a negative temperature coefficient (i.e. resistance
goes down as temperature goes up). The room temperature resistance
should be about 10 k ohms. These are available at Radio Shack and
electronics shops. They should cost less than a dollar a piece.
To start with, a plain bead type is satisfactory. I will get into some
of the variations later.
2) A 4.7 microfarad capacitor rated at 10 volts or more. Some are much
better than others at keeping their capacitance constant over a range of
temperatures. The best are the metalized plastic caps (polyester,
polypropylene, polycarbonate). The least stable (but cheapest) are
electrolytic and tantalum types. Note: these last two types are
polarized. You must install them with the correct polarity.
3) A 16 pin DIP (Dual Inline Package) plug to fit into your Apple's game
I/O port. If you are using a //c for this, you will need a DB-9 "D"
style male connector to plug into your game port. Again, Radio Shack or
an electronics supplier should have these.
The only other materials are some thin, insulated wire and some
insulating tape. For those who may not wish to hunt around for components,
Vernier Software at one time sold a parts kit for this project. I don't
know if it is still available, but it may be worth asking.
>>>ASSEMBLY<<<
""""""""""""""
Once again I am assuming that you know how to use a soldering iron and
have some familiarity with electronics assembly. Even though you are not
working directly on your computer, a mistake in assembly could damage your
Apple once you connect the sensor to the computer. If you aren't sure
about how any of this is done, have a friend who is familiar with
electrical work give you a hand or check your work over before plugging it
into your computer.
1) Decide how long a lead you want for your temperature sensor and cut two
wires this length. Solder one to each lead of your thermistor. At this
point you should insulate the bare leads of the thermistor. If you
don't, they may touch and short out during use. This won't cause any
damage, but will give erroneous temperature readings.
2) Connect one thermistor wire to the +5 volt line on your game port plug.
On the 16 pin DIP plug, this is pin #1. If the pins are not numbered,
the end of the plug with the #1 pin will be indicated with a notch or
some other marking (see the following ASCII schematic). Looking at the
top of the plug, the #1 pin will be at the top left. On the DB-9 plug
for //c users, the +5 volt line is pin #2. These pins will usually be
marked.
3) Connect the other wire from the thermistor to the PDL 0 line. On the 16
pin connector it is pin #6. On the DB-9 connector, PDL 0 is pin #5.
4) Solder a shorter wire to each lead of your capacitor. Mark the positive
wire if you are using a tantalum or electrolytic capacitor. Otherwise
the two leads are interchangeable. You may want to mount the capacitor
on a small circuit board or in a plastic box to protect it and keep it
out of the way.
5) Solder one capacitor wire to the PDL 0 line as you did in (3) above with
the thermistor wire. If you are using a polarized capacitor, this MUST
be the positive (+) wire from the capacitor.
6) Solder the remaining capacitor wire to the ground (GND) pin of the game
port plug. On the 16 pin connector this is pin #8. On the DB-9
connector, the GND line is pin #3.
ASCII ART BEGINS
16 PIN I/O CONNECTOR (from above):
_________ __________
| \____/ |
+5 V | 1 X 16 |
| |
| 2 15 |
| |
| 3 14 |
| |
| 4 13 |
| |
| 5 12 |
| |
PDL 0 | 6 X 11 |
| |
| 7 10 |
| |
GND | 8 X 9 |
|_________________________|
THERMISTOR CIRCUIT SCHEMATIC:
+5 V ________________
|
|
/ \
( T ) Thermistor
\ /
|
PDL 0 _______________|
|
| +
____|____
_____ Capacitor
/ | \ (+/- apply if polarized)
/ | \
| -
GND ________________|
ASCII ART ENDS
That's it! You now have a thermistor temperature sensor for your
Apple. Before you plug it in, check your work carefully to be sure that
nothing is incorrectly wired, shorted, or incompletely soldered.
This project can even be built without soldering if you use a small
breadboard for assembly and a crimp-type 16 pin plug. I don't recommend
this approach for any type of permanent installation, and the accuracy may
be slightly affected by the built in capacitance of the breadboard itself.
However, for experimentation it is a very easy and quick way to work.
To test out your work, check the resistance between pin #1 and pin #6
(pins 2 and 5 on the DB-9). It should read approximately 10 k ohms (the
same as your thermistor). The resistance should also decrease as you warm
up the thermistor with your fingers. Pins #1 and #8 (2 and 3 on the DB-9)
should have an infinite resistance, as should pins #6 and #8 (3 and 5 on
DB-9), although you may get a momentary low resistance reading as the
capacitor charges up. If all this checks out, you are ready to proceed.
To use the sensor is very simple. Turn off your computer and plug in
the Game Port plug into the appropriate socket (16 pin socket inside a ][
Plus, //e, or //GS, or the external DB-9 socket for a joystick on the //c).
With the 16 pin connector, make absolutely sure that you plug the pin 1 end
of the plug into the pin 1 end of the socket. Very bad things can happen
if you do this backwards! Both the plug and the socket will have some type
of marking or notch to indicate which is the pin 1 end. Also, be careful
not to mis-align any pins when putting in the plug.
Start up the computer and run the temperature measuring software. It
will allow you to continuously display timing counts to start with. These
should vary as you touch the thermistor and warm it up. Once everything
appears to be working properly, you can calibrate the thermistor using the
calibration routine that is part of the program for making temperature
measurements.
The calibration routine requires you to put the thermistor in three
different regions of known temperature and input the actual temperature. I
put my thermistors inside a plastic bag and immerse them in 3 beakers of
water at different temperatures. From then on the program can calculate an
unknown temperature by itself and you're in business!
>>>MODIFICATIONS FOR SIMPLE APPLESOFT USE<<<
""""""""""""""""""""""""""""""""""""""""""""
If you don't want to bother with getting special software to try out
the thermistor sensor, you can use it in a simplified form with only the
PDL command to read a crude temperature. As I described in an earlier
installment, you are limited to one of 256 values (0-255) with this
command, so it is not really suitable for much more than experimenting.
To use a thermistor in this mode, you do not use the 4.7 microfarad
capacitor or the connection to the GND line. You also must use a
thermistor which has a resistance of approximately 150 k ohms at the
minimum temperature that you will want to use it at. This may take a
little hunting to find, but most large electronics houses have a fair
selection of thermistors.
To use such a thermistor, connect the leads to the PDL 0 and + 5 volt
lines of your computer directly (see above discussion for pin numbers). In
this way it will mimic the action of a game paddle resistor, and you should
be able to make readings using the Applesoft PDL(0) command. A simple
routine is:
10 HOME
20 VTAB 10: HTAB 15
30 X = PDL(0)
40 PRINT X
50 GOTO 10
This will give you a continuous display of the PDL value on your
screen. You will have to make up your own calibration table for the
thermistor, and as I mentioned before, it won't be a straight line.
Nevertheless an enterprising Apple user can probably make good use of this
simple temperature measurement system.
>>>MODIFICATIONS<<<
"""""""""""""""""""
Some substitution of components can be done in the thermistor sensor
circuit and still achieve the same results. I found a very cheap supply of
thermistors with a room temperature resistance of about 30 k ohms (about
three times the recommended resistance). So I substituted a smaller
capacitor (1.5 microfarads - 1/3 of the recommended value) and the system
works perfectly. What is important is that the value of capacitance times
resistance remains roughly the same as that given by the components listed
above.
You can also substitute different physical types of thermistors,
depending on where you plan to use them. There are some which come encased
in glass or resin for submerged use, or use in corrosive chemicals.
Remember that if the leads get wet, you will short out the thermistor and
it will not read properly.
I use one of mine to measure the temperature of aquarium water. To
avoid having to hunt around for the right resistance of thermistor in a
coated design, I just slipped mine inside a small glass tube and sealed one
end. This is partially submerged in the water and thus the probe is
protected from moisture. The response time of the probe is slower than
with a naked thermistor, but aquarium water temperature changes gradually,
so it is not important.
Thermistor size will affect how quickly it correctly reads the
temperature surrounding it (its equilibration time). The smaller the
thermistor bead, the faster it will come to equilibrium and read the
correct temperature. I use a small bead thermistor (about 2-3 mm in
diameter) for measuring room temperature. It responds so fast that I have
enclosed it in a sandwich bag to avoid having draughts adversely affect the
reading.
It should be apparent that you can connect more than one temperature
sensor to an Apple, as there are four PDL lines. With modification of the
temperature reading program, machine language counting routine, and
calibration program this is possible. I have built a system which can read
temperatures from thermistors connected to all four PDL lines. It wasn't a
trivial programming exercise, but it can be done.
So this concludes the section on temperature measurement. The ability
to measure resistance via the PDL lines is a great tool for interfacing the
Apple. You can get resistors which vary their resistance in response to
light, moisture, and other parameters. With suitable design and
programming it is possible to use that old ][ Plus to do all these things!
Next installment: Reading buttons and switches.
>>>APOLOGIES AND EXCUSES<<<
"""""""""""""""""""""""""""
I must offer my sincere apologies to any readers who have been
patiently waiting for this installment of the Real World Apple to appear.
Such a long gap will not happen again.
As the gracious editors of _GenieLamp_ pointed out I was indeed
exploring the real world. Although, after returning to the snows of March
at home in Toronto, I'm not sure just how "real" the South Pacific actually
was!
I would have written this article during the four months that I was
away, but I was informed by my new bride (who apparently has known me for
far too long) that if she spotted a computer in my possession on the
islands of Rarotonga (Cook Islands) or New Zealand, that I would be single
again so fast it would make my head spin. Ahhh, the joys of marital bliss!
(I think the only reason that I am allowed to keep a computer around is so
that I can send her email while she is teaching overseas!)
See you next month (promise!).
//////////////////////////////////////// Genie_QWIK_QUOTE ////
/ Indiana's a good place to be FROM. /
///////////////////////////////////////////// J.DWYER8 /////
[EOA]
[LOG]//////////////////////////////
LOG OFF /
/////////////////////////////////
GenieLamp Information
"""""""""""""""""""""
o COMMENTS: Contacting GenieLamp
o GenieLamp STAFF: Who Are We?
GenieLamp Information GenieLamp A2 is published on the first of every
""""""""""""""""""""" month in library 55 of Genie's A2 RoundTable (page
645;3). GenieLamp is also distributed on CrossNet and many public and
commercial BBS systems worldwide.
o To reach GenieLamp on Internet send mail to genielamp@genie.com or to
reach GenieLamp _A2_, send mail to a2lamp@genie.com
o Back issues of GenieLamp A2 are available in the A2 RoundTable
Library #55 on page 645 (m645;3).
o We welcome and respond to all E-mail. To leave comments, suggestions
or just to say hi, you can contact me in the A2 RoundTable (Category
3, Topic 3) or send GenieMail to Ryan Suenaga at [A2LAMP] on page
200.
>>> GENIELAMP STAFF <<<
"""""""""""""""""""""""
GenieLamp o John Peters [GENIELAMP] Publisher
""""""""" o Mike White [MWHITE] Managing Editor
APPLE II o Ryan M. Suenaga [A2LAMP] Editor
"""""""" o Doug Cuff [D.CUFF] Editor Emeritus
A2Pro o Tim Buchheim [A2PRO.GELAMP] Editor
"""""
ATARI o Sheldon H. Winick [GELAMP.ST] Editor
"""""
IBM o Sharon Molnar [SHARON.LAMP] Editor
"""
MACINTOSH o Richard Vega [GELAMP.MAC] Editor
"""""""""
POWER PC o Ben Soulon [BEN.GELAMP] Editor
""""""""
\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\////////////////////////////////////
Opinions expressed herein are those of the individual authors, and do
not necessarily represent the opinions of Genie Online Services,
Yovelle Renaissance Corp., GenieLamp Online Magazines, or T/TalkNet
Online Publishing. Bulletin board messages are reprinted verbatim and
are included in this publication with permission from Genie Online
Services and the source RoundTable. Genie Online Services, GenieLamp
Online Magazines, and T/TalkNet Publishing do not guarantee the
accuracy or suitability of any information included herein. We reserve
the right to edit all letters and copy.
Material published in this edition may be reprinted under the fol-
lowing terms only. Reprint permission granted, unless otherwise noted,
to registered computer user groups and not for profit publications.
All articles must remain unedited and include the issue number and
author at the top of each article reprinted. Please include the fol-
lowing at the end of all reprints:
\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\///////////////////////////////////
The preceding article is reprinted courtesy of GenieLamp Online
Magazine. (c) Copyright 1996 T/TalkNET Publishing and Genie Online
Services. To join Genie, set your modem to half duplex (local echo).
Have your modem dial 1-800-638-8369 in the United States or
1-800-387-8330 in Canada. When you get a CONNECT message, wait for
the U#= prompt, type: JOINGENIE and hit the RETURN key. Genie will
then prompt you for your signup information. If the signup server
is unavailable, call (voice) 1-800-638-9636 for more information.
////////////////////////////////////\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\
[EOF]
ÿÿ