From: pottier@clipper.ens.fr (Francois Pottier)
Subject: csmp-digest-v3-023
Date: Wed, 4 May 94 12:25:07 MET DST

C.S.M.P. Digest             Wed, 04 May 94       Volume 3 : Issue 23
 
Today's Topics:
 
        CCollaborator bug
        Embedding PICTS in TextEdit?
        How did YOU learn to program?
        How do I get machine-user name?
        How to: Aladdin-aware ResEdit (was Re: ResEdit + dctb = ID=01?)
        Window -> PICT question



The Comp.Sys.Mac.Programmer Digest is moderated by Francois Pottier
(pottier@clipper.ens.fr).
 
The digest is a collection of article threads from the internet newsgroup
comp.sys.mac.programmer.  It is designed for people who read c.s.m.p. semi-
regularly and want an archive of the discussions.  If you don't know what a
newsgroup is, you probably don't have access to it.  Ask your systems
administrator(s) for details.  If you don't have access to news, you may
still be able to post messages to the group by using a mail server like
anon.penet.fi (mail help@anon.penet.fi for more information).
 
Each issue of the digest contains one or more sets of articles (called
threads), with each set corresponding to a 'discussion' of a particular
subject.  The articles are not edited; all articles included in this digest
are in their original posted form (as received by our news server at
nef.ens.fr).  Article threads are not added to the digest until the last
article added to the thread is at least two weeks old (this is to ensure that
the thread is dead before adding it to the digest).  Article threads that
consist of only one message are generally not included in the digest.

The digest is officially distributed by two means, by email and ftp.

If you want to receive the digest by mail, send email to listserv@ens.fr
with no subject and one of the following commands as body:
    help		                Sends you a summary of commands
    subscribe csmp-digest Your Name	Adds you to the mailing list
    signoff csmp-digest			Removes you from the list
Once you have subscribed, you will automatically receive each new
issue as it is created.

The official ftp info is //ftp.dartmouth.edu/pub/csmp-digest.
Questions related to the ftp site should be directed to
scott.silver@dartmouth.edu. Currently no previous volumes of the CSMP
digest are available there.

Also, the digests are available to WAIS users as comp.sys.mac.programmer.src.


-------------------------------------------------------

>From jafl@cco.caltech.edu (John Lindal)
Subject: CCollaborator bug
Date: 18 Apr 1994 20:50:46 GMT
Organization: California Institute of Technology, Pasadena

I just found a really nasty bug in CCollaborator:

CCollaborator::DependUpon

first line should be:

if (itsProviders && itsProviders->FindIndex(aProvider) > 0) return;

This prevents providers from appearing multiple times in the list!

John Lindal


+++++++++++++++++++++++++++

>From u9119523@sys.uea.ac.uk (Graham Cox)
Date: Tue, 19 Apr 1994 11:09:32 GMT
Organization: School of Information Systems, UEA, Norwich

In article <2ourr6$ane@gap.cco.caltech.edu>, jafl@cco.caltech.edu (John
Lindal) wrote:

> I just found a really nasty bug in CCollaborator:
> 
> CCollaborator::DependUpon
> 
> first line should be:
> 
> if (itsProviders && itsProviders->FindIndex(aProvider) > 0) return;
> 
> This prevents providers from appearing multiple times in the list!
> 
> John Lindal


Ah, that explains it! Thanks- this one was really pissing me off, having to
call CancelDependency before DependUpon every time- just in case.

- ------------------------------------------------------------------------
Love & BSWK, Graham

-Everyone is entitled to their opinion, no matter how wrong they may be...
- ------------------------------------------------------------------------

+++++++++++++++++++++++++++

>From u9119523@sys.uea.ac.uk (Graham Cox)
Date: Tue, 19 Apr 1994 11:10:37 GMT
Organization: School of Information Systems, UEA, Norwich

In article <2ourr6$ane@gap.cco.caltech.edu>, jafl@cco.caltech.edu (John
Lindal) wrote:

> I just found a really nasty bug in CCollaborator:
> 
> CCollaborator::DependUpon
> 
> first line should be:
> 
> if (itsProviders && itsProviders->FindIndex(aProvider) > 0) return;
> 
> This prevents providers from appearing multiple times in the list!
> 
> John Lindal

Another thing I found, though this may have been fixed since v1.1, which I
am using, is that the 'reason' code gets truncated to a short somewhere
between BroadcastChange and ProviderChanged. This doesn't really cause a
problem if you use the numbering scheme that THINK specify for reason
codes, but I use four character strings as reason codes (I think this is
much neater- easier to remember and much easier to keep unique) so it was a
problem for me. The offending bug is caused somewhere in the bowels of the
CCollaborator code, which defines a temporary struct called (I think)
tInfo. Change the type of the reason field from short to long and all is
well.

On a general note, I wonder just how acceptable it is that this stuff is
occasionally a bit sloppy? For example, the CStdPopUpPane object is very
poor- I had to rewrite lots of it to get it to work the way I expected it
to. Another slap on the wrist for Symantec???

- ------------------------------------------------------------------------
Love & BSWK, Graham

-Everyone is entitled to their opinion, no matter how wrong they may be...
- ------------------------------------------------------------------------

---------------------------

>From u9119523@sys.uea.ac.uk (Graham Cox)
Subject: Embedding PICTS in TextEdit?
Date: Tue, 19 Apr 1994 11:20:34 GMT
Organization: School of Information Systems, UEA, Norwich

I want to embed a PICT in TextEdit automatically. The idea I have is to use
an obscure char to indicate that I want a picture, followed maybe by its
resource ID. When I call DrawText or TEUpdate I want to trap this special
char by putting in a stdText bottleneck, load the picture and draw it, then
make sure that the following text goes after the picture. Is this a
feasible approach? Has anyone achieved anything like this using TextEdit-
if so is there any sample code kicking about anywhere?

-Tanx a lot.

- ------------------------------------------------------------------------
Love & BSWK, Graham

-Everyone is entitled to their opinion, no matter how wrong they may be...
- ------------------------------------------------------------------------

+++++++++++++++++++++++++++

>From Philippe.Casgrain@univ-rennes1.fr (Philippe Casgrain)
Date: Tue, 19 Apr 1994 17:29:20 +0100
Organization: Universite de Rennes-1, Fac. de medecine dentaire

In article <u9119523-190494142034@case9.sys.uea.ac.uk>,
u9119523@sys.uea.ac.uk (Graham Cox) wrote:
> I want to embed a PICT in TextEdit automatically. The idea I have is to use
> an obscure char to indicate that I want a picture, followed maybe by its
> resource ID. When I call DrawText or TEUpdate I want to trap this special
> char by putting in a stdText bottleneck, load the picture and draw it, then
> make sure that the following text goes after the picture. Is this a
> feasible approach? Has anyone achieved anything like this using TextEdit-
> if so is there any sample code kicking about anywhere?

 That's almost exactly the way TeachText does it: when it sees an
"option-space" in the text, it takes the first PICT resource it finds in
the resource fork of the document and displays it, then resumes printing
the text. When the next option-space comes along, TeachText displays the
second PICT, and so on...

 So yes, i't been done before (TeachText uses TextEdit, how about
SimpleText?), but I doubt the source to TeachText is available. There might
be a snippet on ftp.apple.com, though.

Philippe
-- 
Philippe.Casgrain@univ-rennes1.fr, Mac Hacker Lite
  Sirius Cybernetics Corporation

+++++++++++++++++++++++++++

>From thundero@news.delphi.com (THUNDERONE@DELPHI.COM)
Date: 20 Apr 1994 04:19:51 -0000
Organization: Delphi Internet Services Corporation

u9119523@sys.uea.ac.uk (Graham Cox) writes:

>I want to embed a PICT in TextEdit automatically. The idea I have is to use
>an obscure char to indicate that I want a picture, followed maybe by its
>resource ID. When I call DrawText or TEUpdate I want to trap this special
>char by putting in a stdText bottleneck, load the picture and draw it, then
>make sure that the following text goes after the picture. Is this a
>feasible approach? Has anyone achieved anything like this using TextEdit-
>if so is there any sample code kicking about anywhere?

Don't use stdText.  That's both overkill and unnecessarily complicating 
things, and would also screw up hit-testing, if you could get it to 
work.  What you want to do is p=TEGetPoint(offsetintotext), create a
rectangle based on p, and draw the picture in that rectangle whenever you 
call TEUpdate().
 
Chris

+++++++++++++++++++++++++++

>From oberst@gov.nt.ca (David Oberst)
Date: Thu, 21 Apr 1994 00:00:40 GMT
Organization: Government of the NWT, Canada

Re: earlier messages about including PICTs in a TextEdit, and "the source
to TeachText" not being available.

True, but there is a shareware text editor out there called TexEdit (now
in version 2.3.1, which now opens up TeachText files, including the pictures.
The author offers to send the Pascal source via snail mail for $5 and a SASE.
BBEdit is available in the Infomac archives (text directory, I think), and
the author gives an email handle of     tombb@aol.com

    David Oberst/GNWT Bureau of Statistics/Yellowknife, NWT, Canada


+++++++++++++++++++++++++++

>From markhanrek@aol.com (MarkHanrek)
Date: 20 Apr 1994 16:59:02 -0400
Organization: America Online, Inc. (1-800-827-6364)

>I want to embed a PICT in TextEdit automatically. The idea I have is to use
>an obscure char to indicate that I want a picture, followed maybe by its
>resource ID. When I call DrawText or TEUpdate I want to trap this special
>char by putting in a stdText bottleneck, load the picture and draw it, then
>make sure that the following text goes after the picture. Is this a
>feasible approach? Has anyone achieved anything like this using TextEdit-
>if so is there any sample code kicking about anywhere?

Locate a copy of "ShowHelp 2.0" which implements teachtext style text and
graphics in a help window. There you will find the source code that does it,
and also learn about a problem that has to do with updating, scrolling, nad the
hilite color ( as I recall ).

I know "ShowHelp 2.0" is on AOL.

Mark Hanrek


+++++++++++++++++++++++++++

>From dowdy@apple.com (Tom Dowdy)
Date: Mon, 25 Apr 1994 19:31:05 GMT
Organization: Apple Computer, Inc.

In article <Philippe.Casgrain-190494172920@193.49.46.4>,
Philippe.Casgrain@univ-rennes1.fr (Philippe Casgrain) wrote:

>  That's almost exactly the way TeachText does it: when it sees an
> "option-space" in the text, it takes the first PICT resource it finds in
> the resource fork of the document and displays it, then resumes printing
> the text. When the next option-space comes along, TeachText displays the
> second PICT, and so on...
> 
>  So yes, i't been done before (TeachText uses TextEdit, how about
> SimpleText?), but I doubt the source to TeachText is available. There might
> be a snippet on ftp.apple.com, though.

SimpleText uses a similar mechanism, although it was slightly modified
due to one basic problem with this approach -- it's not very international
friendly.

TeachText/SimpleText use the non-breaking space character, which works
well for the roman script system, but not for most double byte (and
some other single-byte) script systems.  As a result, SimpleText has
to have localization strings to allow for the use of other characters
in these script systems -- but this means that documents aren't portable
across various localized versions of SimpleText.

A better way is to key off of some other unused attribute (such
as the color of the text) rather than the actual character content.
However, this level of change couldn't be done for this version of
SimpleText due to the need to be backwards compatible with documents
from previous versions of TeachText.

I'd recommend that other folks store the PICT information separatly
and not rely on the *content* of the strings for positioning information.
In that way, you can read in the document on any localized version
of your application and convert into the appropriate text-edit
trick you wish to use -- but not actual store this hacked-up-data
as part of your document format.

-- 
 Tom Dowdy                  Internet: dowdy@apple.COM
 Apple Computer MS:302-3KS  UUCP: {sun,voder,amdahl,decwrl}!apple!dowdy
 1 Infinite Loop            AppleLink: DOWDY1
 Cupertino, CA 95014       
 "The 'Ooh-Ah' Bird is so called because it lays square eggs."

+++++++++++++++++++++++++++

>From walkerj@math.scarolina.edu (Jim Walker)
Date: 19 Apr 1994 16:34:27 GMT
Organization: University of South Carolina - Columbia - Computer Science


The TeachText method is what I used in my Show_help code, available by ftp
from bigbird.csd.scarolina.edu, pub/mac.
--

 -- Jim Walker  USC Dept. of Math.  walkerj@math.scarolina.edu

---------------------------

>From rblaine@tiac.net (Russ Blaine)
Subject: How did YOU learn to program?
Date: 18 Mar 1994 00:03:19 GMT
Organization: The Internet Access Company

How did you learn to program? Did you take a class? Teach yourself 
with a book? Become an apprentice, or what?

Just a general question directed to all members of the programming
community, out of curiosity. I'm teaching myself (well, trying..)
to program C using a book, its not too bad...

- ->Russ
|----------------------------------------------------------------------|
| rblaine@max.tiac.net                                                 |
|----------------------------------------------------------------------|
LAWYER: How did you happen to go to Dr. Cherney?
WITNESS: Well, a gal down the road had had several of her children
        by Dr. Cherney, and said he was really good.


+++++++++++++++++++++++++++

>From greer@utdallas.edu (Dale M. Greer)
Date: 18 Mar 1994 18:05:09 GMT
Organization: The University of Texas at Dallas

Russ Blaine (rblaine@tiac.net) wrote:
> How did you learn to program? Did you take a class? Teach yourself 
> with a book? Become an apprentice, or what?

> Just a general question directed to all members of the programming
> community, out of curiosity. I'm teaching myself (well, trying..)
> to program C using a book, its not too bad...

I took one class in FORTRAN because it was required for physics
majors.  This was just an introductory class, and I didn't really 
learn much about real programming.  After that I just taught myself 
the rest of FORTRAN, then BASIC, Z80 assembler, C, 8086 assembler,
FORTH, 68000 assembler, C++, etc.

With FORTRAN, I learned from books and other people at the university.
After that, learning the rest was fairly easy.  Programming is
programming.

--

Dale Greer, greer@utdallas.edu
"You can't just wake up and kiss the mirror and say 'I'm so purdy,
 I think I'll run for Governor.'" - Texas Gov. Ann Richards



+++++++++++++++++++++++++++

>From markhanrek@aol.com (MarkHanrek)
Date: 18 Mar 1994 13:14:02 -0500
Organization: America Online, Inc. (1-800-827-6364)

It was simple.

I downloaded every cotton-pickin' piece of software that included C source code
(C in my case) and compiled it.

The process of figuring out how that is done, and why these programs fail and
learning to fix them, and why you know YOU don't want to write programs THAT
way, :) is an excellent way to learn.

The important thing here is that you learn by performing an activity that is
engaging, and is never overwhelming, and gives you a more frequent sense of
gratification, because you will only be trying to make little improvements to a
program here and there, and the next thing you know...

When one learns to program, one is usually learning TWO languages, the
traditional language, like C or Pascal, and also the Mac Toolbox (by far more
complex and potentially daunting).

Having fun, and maintaining interest, and SPENDING THE TIME IT TAKES, is
essential to being able to reach a point of being "capable" -- roughly a
man-year after you start ( though you can be instantly productive ).

Other than every piece of source code, get every bit of info, and access to as
many resources as possible, and make friends with other programmers. Saving
time is critical to success.

Have fun.

Mark Hanrek


+++++++++++++++++++++++++++

>From Chuck Simciak <simciac@ccsmtp.ccf.org>
Date: Fri, 18 Mar 1994 22:36:31 GMT
Organization: Cleveland Clinic Foundation

In article <2mar47$78l@sundog.tiac.net> Russ Blaine, rblaine@tiac.net
writes:
>How did you learn to program? Did you take a class? Teach yourself 
>with a book? Become an apprentice, or what?
>
>Just a general question directed to all members of the programming
>community, out of curiosity. I'm teaching myself (well, trying..)
>to program C using a book, its not too bad...

I started out by teaching myself AppleSoft (Basic) on an Apple 2+.  I
tried to move on to Pascal but lost interest after a while.  Then for
college I had to learn Pascal, and as I shifted over to a computer
science major took classes which introduced me to C and Prolog, and a
little bit of object oriented programming and 68000 assembly.  So far the
most important things that I learned did not come from a  book.  "What
makes up good programming Style?".  Such as using a format for naming
variables, strategies for breaking down problems into reusable code
segments, that sort of thing.

later....

    Chuck Simciak      !"The broken image of Man moves in minute by minute
   wxs@po.cwru.edu     ! and cell by cell.... Poverty, hatred, war,
police-
simciac@ccsmtp.ccf.org ! criminals, bureaucracy, insanity, all symptoms of
WRUW 91.1 FM Cleveland ! The Human Virus."           - William S.
Burroughs

+++++++++++++++++++++++++++

>From kaufman@Xenon.Stanford.EDU (Marc T. Kaufman)
Date: 19 Mar 1994 01:20:39 GMT
Organization: Computer Science Department, Stanford University.

In article <2mar47$78l@sundog.tiac.net>, Russ Blaine <rblaine@tiac.net> wrote:
>How did you learn to program? Did you take a class? Teach yourself 
>with a book? Become an apprentice, or what?

I went over to the campus computer center.  The director said: "This is the
manual, and that is the ON switch.  When you turn it off, let the drum cool
down for at least 5 minutes before turning it on again.  Goodby."  That
machine was a Royal-McBee LGP-30.  That's how it was done in those days.
When the center got a new machine, you went out and got a new hardware
manual.  Eventually you graduated to the Burroughs 220, the IBM 1401, the
709...

Marc Kaufman (kaufman@CS.Stanford.edu)


+++++++++++++++++++++++++++

>From bsc@oui.com (Bill Stewart-Cole)
Date: 18 Mar 1994 20:30:05 -0600
Organization: Odyssey Ultraware Inc
St Louis, MO

Russ Blaine asks:

> How did you learn to program? Did you take a class? Teach yourself
> with a book? Become an apprentice, or what?

Here's a oddball story...


In 8th grade Algebra our text included some BASIC. It wasn't covered in
class, and in 1977-78 there was no computer in the school system outside from
some IBM big iron at the central office chugging out grade info... But I read
it and learned a little. 

In HS a few friends had Apples and commies, but my exposure was VERY limited.
There was some oddball mini at school but as a quasi-jock I chose swimming
and water polo over the computer club, and no coach in the USA would consider
allowing one day per fortnight off prractice for some geek club...

In college I had a part-time job in the library, 82-84. My boss had taken a
BASIC course and had written a little database running interpreted for
managing the filling out of incomplete serial volumes. On a Honeywell DPS8. I
read the BASIC docs at the Computer Center, lied about my abilities, compiled
the thing and impressed her with the speed boost. I spent many months
teaching myself BASIC and the timesharing OS (I want to say GCOS.... but my
memory is chancy and imperfect) while refining the program. I proceeded to
carelessly take advantage of sieve-like security so I had room to code and
play in, and got bit by a malicious hacker... I was one of many rogues
briefly blamed for a serious malicious crack.  Lost access, lost any hope of
access there. got some time in as well on a TRS-80 running Xenix (no
kidding...4 10Mb drives each the size of a AT case) 

Changed schools, changed majors, took a basic 'Systems and Data Processing'
course that had some psuedo-assembly and pascal, plus was on a BITNET-linked
machine (WOW!) and was VERY interested. Got a used commie and 300bps modem
for it and worked from home(!) 

I was awed by the Mac. I saw it and my first thought was how silly my coding
was compared to the guys who made this beastie run like this. but in 86 I got
access to the one Plus at my new college, and bought a cheap copy of Turbo
Pascal that I surreptitiously brought in and used. Coded some wierd stuff...
Figured out Mac programming from the TP manual and bookstore sessions with
IM. Taught myself the Pascal I had a taste of earlier along with the Mac
coding paradigm. Hacked an interface to _Launch even though the IM1-4 docs on
it were lousy, and TP ignored it. Coded a starchart plotter as an astronomy
class project and got an A for the course even though the rest of my work was
careless or missing. (lazy I am) 

After a year computerless after college, and 3 years doing unrelated work, I
chucked a job I would never have been fired from mid-recession (91) and
started coding and consulting for the Mac freelance. I took a Unix C course
because I had to get a few hours of college CS anyway, and I haven't touched
Pascal in over 18 months.  Maybe CodeWarrior will get me back to it... 

Basically I taught myself Pascal with a little VERY basic background and some
self-taught BASIC. I picked up C very fast because of the Pascal background
(C is Pascal abbreviated and without a net.... or at least more like Pascal
than either is like the BASIC I learned)  You CAN teach yourself to program.
On the Mac you really should have Inside Mac. Pascal is easier to teach
yourself than C, because it will catch your goofs instead of letting you do
stuff that is a little off (like treating a handle as a pointer... ) C++ (or
and OOP system) is easy to learn if you know the base language and have an
open minhd. It may even be easier to learn from scratch since you won't have
to unlearn anything. 

+++++++++++++++++++++++++++

>From kenlong@netcom.com (Ken Long)
Date: Mon, 21 Mar 1994 03:44:00 GMT
Organization: NETCOM On-line Communication Services (408 241-9760 guest)

Learning how to program, and learning how to learn how = two separate things.

When I got my first computer that was current - a Mac 512 (wasn't even 
all that current, but worked) - I was interested in learning to program 
but had no idea how to start, and no one to ask about it.  I got no 
manual with that Mac and learned the entire Mac interface by trial, error 
and deductive reasoning.

I used to get disks of PD/SW from Best Bits and Bytes, in Van Nuys.  
resEdit 1.2 was my favorite program.  I thought "Inside Mac DA" was some 
sort of DA to tell you stuff about the internal workings of your Mac.

I bought Borland's Turbo Pascal for the Mac, but it assumed you knew how 
to program - just wanted to change to Turbo.  I called Borland and said 
they oughta say so on the box (bought at Egghead) and the "support" 
person gave me a hard time.  I now use that disk for archive storage (not 
S-7 compatible anyway).  I never knew Inside Mac even existed.

The next time I got into it was after 2 years of no Mac, and the purchase 
of an LC.  By then I already had some IM volumes.  But it didn't take 
very long to find out there was no established set of books or anything 
to take a nonprogrammer to the point where he could at least write some 
simple ones.  I don't mean copying code from a book and getting "talked 
through it" - I mean learn enough to be able to create one on his own, 
like you can with carpentry or other industrial arts, etc.

So, I figured the best way to learn to program was to get programs that 
ran and see if I could find out what it was about them that made them 
run.  What did they do, how did they do it, and when.  So I became a 
source code junkie.

I'd trace a simple program in the debugger and if I didn't understand a 
line I would look things up in IM from the line.  If it wasn't in IM, I'd 
change something about the line - usually a value - and see what the 
change did.  Then I'd change it back and try something else.

Also, I could recognise common aspects of various programs, and se 
differences in them.  Recognizing differences, similarities and 
identities, and eveluating relative importances is a key set of factors 
to any learning process.  Comparing, examining, observing in operation, 
commenting out, uncommenting, trying modifications, reading up on parts 
of example source, and being able to locate a working example of any 
routine or fragment of a program are all contibutors to the learning process.

What better source for the answer to a programming question than the 
running output of a succesful programmer?.  What do I mean by successful 
programmer?  One who wrote a program that runs.

Of course, I still have a long way to go to fill in all the gaps in my 
learning.

Here's a tip, which I will not get into a position to implement:  Some 
cracker-jack programmer, or group of programmers could make big bucks by 
producing programming videos.  Sell them for $5.00 and have each one be 
on one small subject - like one on regions, etc.  One on CDEFs, one on 
pointers, one on setting up a menu bar from both code and resources.  Dig?

A guy buys all sorts of books on programming but just can't seem to get 
"pointers."  He orders your tape on pointers, watches in on the TV next 
to his Mac and finally gets them.  Why?  Because somebody SHOWED him, 
intead of told him.  A potential gold mine, especially since the internet 
is on it's way into the living room.

-Ken-

+++++++++++++++++++++++++++

>From rieck@peca.cs.umn.edu (Keith Rieck)
Date: Mon, 21 Mar 1994 19:06:22 GMT
Organization: Whatsamatta U, Mooselvania

In article <2mar47$78l@sundog.tiac.net>, rblaine@tiac.net (Russ Blaine) writes:
|> How did you learn to program? Did you take a class? 

I was about 14 when Radio Shack came out with the TRS-80.  Our local store
had a machine on display with the Basic manual sitting next to it.  I'd
study the manual and play with the machine until the sales clerk threw 
me out.  Then I'd come back later and do it again.

A lot of us are self-taught, but it's alarming how many people I know
who have tried to start with C and have been blown away.  Typically, they 
buy a top-of-the-line compiler and give up after reading the first 50 
pages of their 500 page manual.  There are also plenty of otherwise 
intelligent folks who enroll in introductory language classes, but never
get beyond hello-world.

I haven't used Basic in years, but I still recommend it to anyone who's
trying to learn programming.  It's got a very short learning curve and 
they can start writing functioning programs in one afternoon.  

-- 
/*   Keith Rieck   */int a[200],b=2,c,d=0,e;main(){for(;d<200;b++)for(c=0;;)
{e=a[c++];if(c>d||e*e>b){a[d++]=b;printf("%5d\t",b);break;}if(b%e==0)break;}}

+++++++++++++++++++++++++++

>From chuck@gte.com (Chuck Hoffman)
Date: Tue, 22 Mar 1994 15:00:50 GMT
Organization: GTE Laboratories

In article <2mar47$78l@sundog.tiac.net> Russ Blaine, rblaine@tiac.net
writes:
>How did you learn to program? Did you take a class? Teach yourself 
>with a book? Become an apprentice, or what?
>

I learned FORTRAN in the Summer of 1965 at the U.S. Naval Academy.  Course
name was "Weapons 707."

-- 
Chuck Hoffman
GTE Laboratories, Waltham, MA, USA
617-466-2131
- ------------------------------------------------
I'm not sure why we're here, but I am sure that
while we're here we're supposed to help each other.
- ------------------------------------------------

+++++++++++++++++++++++++++

>From jxd8856@hertz.njit.edu (Jennifer Deats)
Date: 23 Mar 94 17:03:34 GMT
Organization: New Jersey Institute of Technology, Newark, New Jersey

Way back in 1984, my parents got a 128K Mac (and it still works well...as long
as the programs aren't expecting much in terms of hardware). At that point, 
they decided to send me to National Computer Camp (NCC) in Connecticut. They 
taught mostly on Apple IIs and a few TRS-80s. Basic, Pascal, and Assembly were 
the languages they used. I learned an awful lot about some of the abilities of
the Apple II, largely from other campers who did alot of "let's see what 
happens when I do this".

I didn't touch programming too much for the next seven years. Then I went into
computer science here and I'm stunned how fast Pascal came back to me. As for 
other languages, some I learned through class, some I learned on my own, and
alot I learned through experienced programmers who also attend school here.

Just my 2 cents.

-Jennifer
-- 
|   Jennifer Deats  |    This sig is    |
|                   |  currently under  |
|     CIS Major     |    constuction    |

+++++++++++++++++++++++++++

>From fixer@faxcsl.dcrt.nih.gov (Chris Gonna' Find Ray Charles Tate)
Date: Wed, 23 Mar 1994 19:54:36 GMT
Organization: DCRT, NIH, Bethesda, MD

How did I learn to program?

In 1981, my father purchased a *kit* for assembling a Sinclair ZX81 - the
machine that later appeared under the Timex brand, as the Timex-Sinclair
1000.  It originally cost about $100 in kit form.

That little, tiny box had one of the best BASIC implementations I've
ever used, packed into 8K of ROM.  It had a context-sensitive program
editing mode (gave you 'GOTO' when you hit the 'G' key, etc.), and would
syntax-check your program *as you typed it in*.  This was great for
learning the syntax of BASIC (for a 12-year-old kid).

A bit later on, I started fiddling with assembly language on that same
machine - it had a Zilog Z80 processor.  Nice machine, actually....  :-)

When I got to college, I had had enough experience with BASIC that my
father and older brother assured me that I wouldn't have much problem
learning FORTRAN, and so I jumped into the second-semester programming
course, which was supposed to *finish* teaching its students Pascal and
FORTRAN.  It was perfect - my first exposure to real data structures,
challenging (to learn Pascal fast enough to handle the supposition that
I already *knew* the syntax, etc.), and a good choice of projects.

The parts of it I remember were doing a single-source shortest-path
algorithm (taught breadth-first search, basic graph representations, and
queues) in Pascal, and a Choleski symmetric positive-definite matrix
decomposition in FORTRAN, using a compacted matrix representation.  That
one gave us a real feeling for what kinds of programming people who were
serious about it did.

In retrospect, I think Pascal is a better first language than C or FORTRAN,
since you have to deliberately avoid a lot of the 'sloppy' things that other
languages let you get away with.  That makes for better coding style later
on.

Penn State (my alma mater) also required a course in machine language,
in which we studied machine representation of numbers (well, integers,
and a *brief* exposure to some floating-point concepts - I didn't get
any real floating-point exposure until I took a Math-department course
in numerical methods), the basic operating principles of computers, and
various architectures from a programmer's standpoint.  Specifically, we
learned PDP-11 assembly language (the 'standard' stack-based machine, 
with auto-increment and auto-decrement), as well as IBM 370 assembly
language (the IBM mainframes are not stack-based).  No RISC, alas; I
understand that not long after I took that course they started teaching
MIPS assembly language and concepts rather than PDP-11.

The only other real 'learn to program' course wasn't exactly that; it was
a class in abstract data types.  The text was Aho, Hopcroft, & Ullman;
I think it might be taught with Corman, Leiserson, & Rivest these days.
That's an important course - you need the knowledge of programming
technique that comes with studying the art of data structure design and
various programming approaches (dynamic programming, divide-and-conquer,
greedy heuristics - all the standards you *should* know).

My senior year I took a course in OS design, with implementation in teams
of three people.  It was a *ton* of work, but I'm glad I took it.  By
that time I had been programming professionally (summer job at NIST) for
several years, but hadn't don't anything of that scope.  It was a *fantastic*
learning experience for dealing with a very large project, and for learning
the ins and outs of a group project (code management, time management,
et cetera).

I think the basic curriculum I had was quite good.  Penn State's CompSci
department grew out of its Math department, rather than its Engineering
school, and I think it shows (lots of theoretical study, not so much
emphasis on digital engineering).  The course on formal language theory
was ... work.  :-)

- --------------------------------------------------------------------------
Christopher Tate            |  "I hate writing, and I hate statistics, but
MSD, Inc.                   |   most of all I hate writing about statistics.
                            |   I'd rather go to the dentist; at least there
fixer@faxcsl.dcrt.nih.gov   |   you get to spit."     -- Ed Sewell

+++++++++++++++++++++++++++

>From zhfzc@zh014.ubs.ubs.ch (Christian Franz)
Date: Thu, 24 Mar 1994 08:55:44 GMT
Organization: Union Bank Switzerland, CH


Well, in '78 me and my brother saved anough money to buy us an Apple II. 
I began with Basic, then Applesoft Basic and then got the hang of 6502 Assembler.
I remember having discussions with my brother about which programming language
was better since he used the UCSD Pascal while I wrote 6502. I often ridiculed 
him for his choice.

Well, I went on and implemented my own little language (called CFDS, I only know
of a single other person who understands this language - hell, I was only 15 by
then). 

Time went on and I finally went to university (ETH - Swiss Federal Institute
of Technology, you know where Wirth hangs around). I got myself a Mac then and
was immediately overwhelmed by the sheer complexity of the OS and the built-in
routines, the guidelines you had to adhere to etc.

At ETH, I learned Modula-2 at first and then Oberon. Being an Assembly hacker, I
had some difficulties with the concept of procedural, strongly-typed languages. It
seemed all so clumsy while I could code the same problem in a very elegant 15-Byte
tight loop...
After about one year, my view started to shift. Suddenly I recognized the power
of languages like Modula or their ancestor, Pascal. Plus, someone sold me her
copy THINK Pascal. Now *that* was a development system that deserved its name.

After a while, I took a course in compiler design. Suddenly I *knew* why languages
such as C or Assembler could never match the elegance and fitness for servicability
that strongly-typed procedural languages have. And I have come to flushing when I
remember how I laughed into my brother's face when he used the clumsy UCSD when
he could have programmed assembler.

Nowadays I'm a fierce advocat of Pascal and Modula and have a strong dislike of
C or the ultimate insult to cs engineers, C++ (flame bait, do not respond!).
Of course I know there are times when you have to resort to extreme measures 
(if you look at GrafSys, you'll notice that the ultra-fast Triangle routines are
done in 68K assembler). But I like to forget that whenever possible.

Ok, to sum it up, I have learned to program the wrong way all by myself. The
correct way I learned at the university. How to program on the Mac was a matter
of Trial And Error at first. Then, after I had mastered most of the problems,
I found this book 'Macintosh Programming Primer' which is IMHO one of the best
of its kind and would have saved me about a year. Note that it is not intended
for the beginner (in programming) but rather the experienced programmer who
switches to the Mac. 


Cheers,
Christian

--
Christian Franz                        *              Union Bank Of Switzerland
cfranz@home.malg.imp.com         <- at home ->                     +1-261 26 96


+++++++++++++++++++++++++++

>From jburke@UMASSD.EDU
Date: Fri, 25 Mar 1994 16:27:22 GMT
Organization: UMASS DARTMOUTH, NO. DARTMOUTH, MA.

In article <Cn13o9.50w@news.cis.umn.edu>, rieck@peca.cs.umn.edu (Keith Rieck) writes:
>In article <2mar47$78l@sundog.tiac.net>, rblaine@tiac.net (Russ Blaine) writes:
>|> How did you learn to program? Did you take a class? 
>
>I was about 14 when Radio Shack came out with the TRS-80.  Our local store
>had a machine on display with the Basic manual sitting next to it.  I'd
>study the manual and play with the machine until the sales clerk threw 
>me out.  Then I'd come back later and do it again.

You mean someone else learned BASIC this way?  Yow.  They got so used to 
kicking me out that they asked my mom if we were planning to move my
bedroom furniture into the store.

- -----------------------------------------------------------------------------
|James P. Burke       | This is some text that I like to put to the right of my|
|Very Small Animal    | name because it makes this space look less empty.      |
|JBURKE@umassd.edu    | Never put off 'till tomorrow saves nine. He who laughs |
|DRMOMENTUM@aol.com   | last is worth two in the bush. "The foot is a game."   |
- -----------------------------------------------------------------------------

+++++++++++++++++++++++++++

>From peirce@outpost.SF-Bay.org (Michael Peirce)
Date: Sat, 26 Mar 94 14:44:42 PST
Organization: Peirce Software, Inc.

In article <2mar47$78l@sundog.tiac.net>, Russ Blaine <rblaine@tiac.net> wrote:
>How did you learn to program? Did you take a class? Teach yourself 
>with a book? Become an apprentice, or what?

I learned FORTRAN out of a book.  I wrote a bowling scores program
and finagled enough time on a old DEC RSTS system at the University
of Toledo to type it in and debug it.  About the same time I spent some
time at a summer NSF program at Indiana State and got to try my hand
at punching cards for a IBM/360.

The next year my high school got its first Commodore PET and I learned
BASIC (then taught the teachers BASIC).  I learned 6502 assembler
on the machine too, plus 1802 assembler on an ELF that my physics
teacher had bought.

During my freshman year at RPI I learned Pascal (by convincing them
I knew enough FORTRAN to skip that).  It was the first year they tought
Pascal instead of PL/I - thank goodness.  It was fun programming the
big IBM/3033 - I think I was in the last class that really spent much
time on the big mainframe.  By the time I graduated, the computer
geaks (like me) had moved on to Unix workstations and PCs.  Ah IBM
370 assembler, a dying skill (at least I hope so).

I learned the Mac on a 512K with Megamax C (it was cool to see it
use up screen memory when it had exhausted main memory - when the
cool patterns filled up the screen, you knew you were hosed).  I learned
C at the same time and grabbed as much sample code as I could and
spent lots of hours reading the paper back version of Inside Mac.


-- Michael Peirce        -- peirce@outpost.sf-bay.org
-- Peirce Software, Inc. -- 719 Hibiscus Place, Suite 301
--                       -- San Jose, California USA 95117
-- Makers of: Smoothie & -- voice: +1.408.244.6554 fax: +1.408.244.6882
--    Peirce Print Tools -- AppleLink: peirce & America Online: AFC Peirce

+++++++++++++++++++++++++++

>From dspman@aol.com (DSPman)
Date: 27 Mar 1994 19:55:01 -0500
Organization: America Online, Inc. (1-800-827-6364)

Get Marksman 3.0 by IT Makers.  It is a code generation tool.  You 
lay out the user interface and it generates most of the code you 
need that would take you a long time to write.
Learning to program the Mac can be very difficult.  This program 
got me over the hump by generating great skeleton code for a 
program which I can study and ultimately understand.


+++++++++++++++++++++++++++

>From dubois@primate.wisc.edu (Paul DuBois)
Date: 27 Mar 1994 21:14:07 -0600
Organization: Castra Parvulorum


>How did YOU learn to program?

Still haven't.
-- 
Paul DuBois
dubois@primate.wisc.edu

+++++++++++++++++++++++++++

>From me362@lu.erisoft.se (Mats Ekberg)
Date: Wed, 6 Apr 1994 13:49:21 GMT
Organization: Erisoft AB, Sweden


In article b4o@search01.news.aol.com, dspman@aol.com (DSPman) writes:
[]Get Marksman 3.0 by IT Makers.  It is a code generation tool.  You 
[]lay out the user interface and it generates most of the code you 
[]need that would take you a long time to write.
[]Learning to program the Mac can be very difficult.  This program 
[]got me over the hump by generating great skeleton code for a 
[]program which I can study and ultimately understand.
[]

But that results in "regular" procedural programming.
Isn't it better to try to go object-oriented?

What is the experience of all You programmers, what are the major
differences between procedural and OO programming on the Mac?
Tools, code-size, speed, complexity, serviceability and so on...

 
[----------------------------------------------------------------------]
| Addr:  Mats Ekberg @ Erisoft AB  | Voice: +46 920-427 00             |
|        Box 920                   | Email: Mats.Ekberg@lu.erisoft.se  |
|        S-951 28  LULEA           | Memo:  ERI.ECOM.EPLMEK            |
[----------------------------------------------------------------------]



+++++++++++++++++++++++++++

>From deeny3@aol.com (Deeny3)
Date: 9 Apr 1994 23:16:04 -0400
Organization: America Online, Inc. (1-800-827-6364)

Nineteen years ago, I was working for my father, a consulting physicist. He had
a lot of programming he needed done (stuff that you could do in Excel now, of
course), and so he suggested that I take a class. I did -- and it's the only
one I ever took. Most of what I learned I learned at home or on the job. I've
programmed all my adult life and will continue to do so.

_Deirdre

In article <2mar47$78l@sundog.tiac.net>, rblaine@tiac.net (Russ Blaine) writes:

>>How did you learn to program? Did you take a class? Teach yourself 
with a book? Become an apprentice, or what?

Just a general question directed to all members of the programming
community, out of curiosity. I'm teaching myself (well, trying..)
to program C using a book, its not too bad...<<


+++++++++++++++++++++++++++

>From bas2631@silver.sdsmt.edu (Brian Stone)
Date: 11 Apr 1994 20:25:14 GMT
Organization: South Dakota School of Mines and Technology

Deeny3 (deeny3@aol.com) wrote:
: Nineteen years ago, I was working for my father, a consulting physicist. He had
: a lot of programming he needed done (stuff that you could do in Excel now, of
: course), and so he suggested that I take a class. I did -- and it's the only
: one I ever took. Most of what I learned I learned at home or on the job. I've
: programmed all my adult life and will continue to do so.

: _Deirdre

: In article <2mar47$78l@sundog.tiac.net>, rblaine@tiac.net (Russ Blaine) writes:

: >>How did you learn to program? Did you take a class? Teach yourself 
: with a book? Become an apprentice, or what?

: Just a general question directed to all members of the programming
: community, out of curiosity. I'm teaching myself (well, trying..)
: to program C using a book, its not too bad...<<



	Im following up on this just cause Im bored at the moment...
	
	I taught my self Basic on the Commodor 64 when I was 12.  I wrote
a few programs... nothing fancy.  Just messed around with sprites and
little animations.  My father saw that I was interested in this and 
gave me his 64, while he was given a Lisa computer to do some consulting
business.  I was somewhat fasinated by this computer although I never
did any programing on it.  When the Mac Plus came out, my father bought
one.  I imediatly started playing around with it, I must have been 16
at the time.  When he bought Microsoft Q-Basic, that became my buddy
for the years to come.  I taught my self the inner workings of Q-basic
and started writting quite a few small games and other programs.  When
I was a Junior in highschool I took my first Pascal course.  However, 
I never programed much in Pascal outside the class room.  I took two
years of Pascal, both in my Junior and Senior years.  I began college
as a traditional student, just after highschool.  In my first year I 
took a FORTRAN course... probably more usless than Pascal.  In the
first semester of my second year I took an Ansi C course.  After that
course, I taught my self C++.  Since then, however, I havnt used 
C much at all.  Im mainly a Basic programer... but Im slowly trying
to relearn C++.  I got a book on programing 3D graphics in C.  About
six months ago, I translated it into Q-Basic, and it works pretty good.
But, Q-basic is slow... too slow, and I need speed.  In fact, C is also
too slow for what I need, so part of my problem is porting certain
functions to Assembly code.  At the moment I am taking an Assembly
programing class for 386 processors, and I hope to use that knowlege
to help me write Assembly programs for the 6800x0 Motorola processors.
Eventualy I will use my knowlege of 3D graphics, Assembly, and C++
to write my biggest game yet.  Hopfully a 3D Space battle game, not
unlike X-Wing for PC's.  Ive already used 3D graphics in an Artillary
style game that I wrote in Q-Basic... but like I said before... its way
too slow.   I have not yet compleated the program, and the game dosnt
have any sound to it, so I probably will never release this game.  But
I hope to have my 3D space battle game out by the end of the year...
depending on if my sanity holds.  
				

	From the man on a mission from God... and Mars,
		Brian "the man with a head of lettuce" Stone
		bas2631@silver.sdsmt.edu




+++++++++++++++++++++++++++

>From dvorak@extro.ucc.su.OZ.AU (Darko Volaric)
Date: Sat, 9 Apr 1994 03:53:00 GMT
Organization: /etc/organization

In article <Cn8B1o.J8J@umassd.edu> jburke@UMASSD.EDU writes:
>In article <Cn13o9.50w@news.cis.umn.edu>, rieck@peca.cs.umn.edu (Keith Rieck) writes:
>>In article <2mar47$78l@sundog.tiac.net>, rblaine@tiac.net (Russ Blaine) writes:
>>|> How did you learn to program? Did you take a class? 
>>
>>I was about 14 when Radio Shack came out with the TRS-80.  Our local store
>>had a machine on display with the Basic manual sitting next to it.  I'd
>>study the manual and play with the machine until the sales clerk threw 
>>me out.  Then I'd come back later and do it again.
>
>You mean someone else learned BASIC this way?  Yow.  They got so used to 
>kicking me out that they asked my mom if we were planning to move my
>bedroom furniture into the store.
>
I did the same thing (but when I was about 10) but they let me stay since I'd
tell the customers what I was doing and what the computer could do. I probably
was responsible for more sales than the (rather ignorant) salesperson.



+++++++++++++++++++++++++++

>From jjensen@kaiwan.com (John Jensen)
Date: 20 Apr 1994 05:24:46 -0700
Organization: KAIWAN Internet (310/527-4279,818/756-0180,714/741-2920)

Darko Volaric (dvorak@extro.ucc.su.OZ.AU) wrote:
: In article <Cn8B1o.J8J@umassd.edu> jburke@UMASSD.EDU writes:
: >In article <Cn13o9.50w@news.cis.umn.edu>, rieck@peca.cs.umn.edu (Keith Rieck) writes:
: >>In article <2mar47$78l@sundog.tiac.net>, rblaine@tiac.net (Russ Blaine) writes:
: >>|> How did you learn to program? Did you take a class? 
: >>
: >>I was about 14 when Radio Shack came out with the TRS-80.  Our local store
: >>had a machine on display with the Basic manual sitting next to it.  I'd
: >>study the manual and play with the machine until the sales clerk threw 
: >>me out.  Then I'd come back later and do it again.
: >
: >You mean someone else learned BASIC this way?  Yow.  They got so used to 
: >kicking me out that they asked my mom if we were planning to move my
: >bedroom furniture into the store.
: >
: I did the same thing (but when I was about 10) but they let me stay since I'd
: tell the customers what I was doing and what the computer could do. I probably
: was responsible for more sales than the (rather ignorant) salesperson.

Me too.  I had just finished a Fortran course at school (I was studying 
chemistry).  I walked into a Radio Shack and looked at the BASIC manual 
for the TRS-80.  It was a learn-as-you-go thing, so I just started 
typing.  No one ever bothered me, and I walked out a couple hours later 
knowing BASIC.

Thank you Radio Shack.

John

+++++++++++++++++++++++++++

>From gdl@danube.maths (Greg Landweber)
Date: 21 Apr 1994 17:04:58 GMT
Organization: (none)

In article <Cnz44C.527@ucc.su.OZ.AU> dvorak@extro.ucc.su.OZ.AU (Darko Volaric) writes:
   >>I was about 14 when Radio Shack came out with the TRS-80.  Our local store
   >>had a machine on display with the Basic manual sitting next to it.  I'd
   >>study the manual and play with the machine until the sales clerk threw 
   >>me out.  Then I'd come back later and do it again.

My school got a TRS-80 when I was 10, and I used to stay after school
to play on it.  I remember at one point it told me to "type mismatch".
Then, when I typed "mismatch", it said "syntax error".

The following year, my school got an Apple ][+, I learned Logo, and
convinced my parents to get me an Apple //e.  I learned Pascal the
following summer and took a data structures and algorithms class the
summer after that.  In high school, I wrote a grade book (jointly with
Dean Yu) and a class rank program for the teachers and administrators
in AppleSoft basic, and I fiddled a lot with Turbo Pascal (writing
painfully slow interpreters for Lisp and Logo, and a Star Trek battle
simulation based on a board game).

I was declared prophet by my A.P.Computers class, which decided to
start its own religion.  We waited for the second coming of the Timex
Sinclair, while taking our frustrations out on an empty husk of a
Franklin Ace (which came on a cart with boxing gloves).

I got a Mac when I went to college, and the rest is history.

BTW, I learned C somewhere over the Atlantic Ocean.  I brought K&R
with me to read on a flight to England.  I read it again on the way
back, and I started programming in C when I got home.

-- Greg "Buttons" Landweber
   gdl@maths.ox.ac.uk

+++++++++++++++++++++++++++

>From bootstrap1@aol.com (Bootstrap1)
Date: 20 Apr 1994 23:45:07 -0400
Organization: America Online, Inc. (1-800-827-6364)

I had watched a friend write a few little, ten-line BASIC programs making a dot
bounce around on screen on the TRS-80 locked in the back of one of the
classrooms.  The next year, while studying Trig, I asked my teacher if I could
try to program it to draw a circle.  With no manual, and only the experience of
watching my friend, I wrote the following program.

10 X = 0
20 X * X + Y * Y = 100
30 PLOT X,Y
40 X = X + 1
50 GOTO 20

Needless to say, it wouldn't run.  The next week she let me go to the computer
lab, where they had manuals, during class.  Within a couple of days I had the
program running, learned the fundamentals just browsing through the manual,
battled the notorious TRS-80 Mod 1 tape drive, then didn't write another line
of code for three months.  At Christmas my Dad bought an Apple II+ for our
family (this was '81) and I spent 60 hours coding the first three days we had
it.  Six months later I was interning at a startup, writing (not very good)
commercial software for the new IBM PC.

Nathan Tennies
Bootstrap Enterprises Inc

---------------------------

>From jscho@soda.berkeley.edu (John S. Cho)
Subject: How do I get machine-user name?
Date: Sun, 03 Apr 1994 16:23:48 -0800
Organization: University of California, Berkeley

I need some help obtaining the machine and user names from the Shared Setup
control panel. I've played around with the PBxxxx routines and the PPC
toolbox but got no where. Anyhelp would be much appreciated.

John


       ._/                      --=o0o=--    .
      ._/  John Seungwon Cho                ( "If not today, nor yet
 ._/ ._/  University of California, Berkeley `. tomorrow, then some other
._/_/_/  jscho@{soda,uclink,ocf}.berkeley.edu  )  day."    - Dream Theater

+++++++++++++++++++++++++++

>From jumplong@aol.com (Jump Long)
Date: 5 Apr 1994 00:04:01 -0400
Organization: America Online, Inc. (1-800-827-6364)

In article <jscho-030494162348@sultan.hip.berkeley.edu>,
jscho@soda.berkeley.edu (John S. Cho) writes:

> I need some help obtaining the machine and user names from the Shared Setup
> control panel. I've played around with the PBxxxx routines and the PPC
> toolbox but got no where. Anyhelp would be much appreciated.

You can get those names from system resources -16096 (user name) and -16413
(computer name) using the GetString function.  As noted in the Technical Note
"AppleTalk, the Rest of the Story":

"System software version 7.0 allows the user to enter a personalized name by
which her system will be published when connected to an AppleTalk network. The
System 'STR ' resource ID -16413 is used to hold this name. The name (listed as
Macintosh Name) can be up to 31 characters in length and can be set using the
Sharing Setup Control Panel Device (cdev). This resource is different from the
Chooser name, System 'STR ' resource ID -16096. When providing network services
for a workstation, the Flagship name should be used so that the user can
personalize his workstation name while maintaining the use of the Chooser name
for server connection identification. It's important to note that the Flagship
name resource is available only from system software version 7.0. DTS
recommends that applications not change either of these 'STR ' resources."

- Jim Luther


+++++++++++++++++++++++++++

>From jeff31415@aol.com (Jeff 31415)
Date: 19 Apr 1994 18:07:02 -0400
Organization: America Online, Inc. (1-800-827-6364)

In article <jscho-030494162348@sultan.hip.berkeley.edu>,
jscho@soda.berkeley.edu (John S. Cho) writes:

> I need some help obtaining the machine and user names from the Shared Setup
> control panel. I've played around with the PBxxxx routines and the PPC
> toolbox but got no where. Anyhelp would be much appreciated.

I don't know if this is a recommended way to do it, but I find that grabbing
the
appropriate STR# from the active system file works just fine (under System 7).
I haven't seen anything documented by Apple on this one.

Sorry, I can't find the code write now. Email me if you want me to search for
it in a more serious way.

-Jeff Abrahamson



+++++++++++++++++++++++++++

>From jwbaxter@olympus.net (John W. Baxter)
Date: Wed, 20 Apr 1994 08:17:36 -0700
Organization: Internet for the Olympic Peninsula

In article <2p1km6$rve@search01.news.aol.com>, jeff31415@aol.com (Jeff
31415) wrote:

> In article <jscho-030494162348@sultan.hip.berkeley.edu>,
> jscho@soda.berkeley.edu (John S. Cho) writes:
> 
> > I need some help obtaining the machine and user names from the Shared Setup
> > control panel. I've played around with the PBxxxx routines and the PPC
> > toolbox but got no where. Anyhelp would be much appreciated.
> 
> I don't know if this is a recommended way to do it, but I find that grabbing
> the
> appropriate STR# from the active system file works just fine (under System 7).
> I haven't seen anything documented by Apple on this one.

Per Inside Mac: More Mac Toolbox, page 1-127--

User name is 'STR ' -16096
Computer name is 'STR ' -16413

I don't remember how far back into pre-history the above is true [by my
definition, System 6 is pre-history...others--correctly for their
purposes--disagree].

-- 
John Baxter    Port Ludlow, WA, USA  [West shore, Puget Sound]
   jwbaxter@pt.olympus.net

---------------------------

>From egurney@vcd.hp.com (Eddy J. Gurney)
Subject: How to: Aladdin-aware ResEdit (was Re: ResEdit + dctb = ID=01?)
Date: Tue, 19 Apr 1994 20:54:52 GMT
Organization: Hewlett-Packard VCD

Rich Siegel (siegel@netcom.com) wrote:
>In article <sobiloff-180494111601@bsospsyc151.umd.edu> sobiloff@lap.umd.edu writes:
>>This happens when I try to look at StuffIt Expander 3.0.7 or BBEdit
>>2.3.2 (I can open a single resource with BBEdit, but then crash if I
>>try to open another one).

>Out of coincidence, the two applications you tried both contain
>compressed resources. (They're compressed by a scheme that ResEdit
>doesn't know.) Try other examples, such as your copy of THINK C, or
>MPW, or whatever...

Or, make ResEdit aware of the Aladdin resource compression scheme.

Below are my instructions on installing the Aladdin resource
decompressor (found in the FreeWare "BBEdit Lite", which you will
need a copy of) into a fresh ResEdit 2.1.1. NOTE: I take absolutely
no responsibility for this patch; I was bored one weekend and decided
to see if I could get this to work. I feel I was successful; however,
I don't feel comfortable that the Aladdin resource decompressor is
properly "deinstalled" when you quit ResEdit. I'm not sure what effect
this has; everything SEEMS to work fine. The problem with ResEdit 2.1.1
is that it *already* adds a resource decompressor (the Apple one) when
you launch ResEdit. I intercept that patch, add the Aladdin version,
and then continue on and add the Apple version. FYI, they are patching
an undocumented (as far as I know!) trap, _A0FC, to implement resource
decompression. It looked like the Apple scheme does a tail patch on
that trap, so both decompressors work together. But I don't think the
Aladdin de-installer is ever called, since ResEdit probably just calls
_ExitToShell somewhere. SO... after you've used your "special" version
of ResEdit, you may want to restart.

THINK Reference also installs its own resource decompressor (you can
see the code patching _A0FC as well).  However it is different from
the Aladdin or Apple version... 

Patching ResEdit 2.1.1 to use the Aladdin Resource Decompressor
~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~

What you will need:
A fresh (ie, non-patched) copy of ResEdit, version 2.1.1
A fresh (ie, non-patched) copy of the freeware BBEdit Lite, version 2.3.2
Experience using ResEdit to patch stuff. :-)

 1. Make a copy of ResEdit from the Finder. When we're done, this copy will
    have the Aladdin resource decompressor automagically installed when you
    launch this copy.
 2. Open the new copy of ResEdit in ResEdit. Whoa, like weird, man. :-)
 3. Open BBEdit Lite 2.3.2 in ResEdit
 4. (Optional). Double-click on the 'sicn' resource in BBEdit Lite and 
    notice that 'sicn' 911 is "messed up" (because its compressed).  Don't
    open any DLOG's or anything, or ResEdit will CRASH!
 5. Click once on the "DCMP" resource in the BBEdit Lite window and choose
    "Copy".
 6. Select the ResEdit window and choose "Paste".
 7. Double-click on the CODE resource icon in the BBEdit Lite window. Select
    CODE resource 1, and choose "Open Using Hex Editor" from the "Resource"
    menu.
 8. Go to offset 0x005638 (very close to the end, should start with 4E71
    42A7 6100...) and drag select to the end of the resource (offset 0x0058FB,
    should end with A198 4ED1). Make sure you are selecting the hex numbers
    and NOT the ASCII representation on the right.
 9. Choose "Copy".
10. Close all the windows associated with BBEdit Lite, we're done with them.
11. Double-click on the CODE resource icon in the ResEdit window.  Select CODE
    resource 66, and choose "Open Using Hex Editor" from the "Resource"
    menu.
12. Go to the end of the resource (should end with 11C7 0A5E 4E75) and click
    after the 4E75.
13. Choose "Paste".
14. Move to offset 0x0005EC (this is in the newly pasted section, should
    start with FE9C 6100 0114) and select the "FE9C" bytes and change them
    to "FA24".
15. Close the CODE ID=66 hex editor window.
16. Select CODE resource 0 (the jump table) and choose "Open Using Hex Editor"
    from the "Resource" menu.
17. Move to offset 0x000010 (should start with 000C 3F3C 0042...) and select
    the "000C" bytes and change them to "05DA".
18. Select "Save" from the File menu.
18. Select "Get Info for <filename>" from the File menu and change the
    modification date (the "Modified:" field) to something *older* than
    the copy of ResEdit you want to run when you double-click on a
    ResEdit document.  Close the dialog and save the changes.  Why do you
    need to do this?  Since you now have two copies of ResEdit on your
    system, the Finder will launch the latest-modified version (which is
    your newly patched version). Since you will normally want to run the
    "non modified" version, just make the patched version older.
19. Quit out of ResEdit. The patch is complete and ready to go.  I have not
    noticed any side effects from making this patch, but that DOESN'T mean
    there aren't any!  At least you can view/edit/change Aladdin-compressed
    resources now.  NOTE: changing a compressed resource and saving the
    changes will save it in an uncompressed state!  The Aladdin decompressor
    does NOT warn you that the resource you're opening is compressed like
    the Apple decompressor does.
20. (Optional) Launch your newly modified ResEdit.  Open BBEdit Lite again,
    and verify that 'sicn' 911 is no longer "messed up".  Cool. :-)

--
Eddy J. Gurney N8FPW   Hewlett-Packard Company, Vancouver (USA!) Division
egurney@vcd.hp.com                       #include <standard-disclaimer.h>
"Failures are divided into two classes-- those who thought and never did,
      and those who did and never thought."     John Charles Salak

+++++++++++++++++++++++++++

>From leonardr@netcom.com (Leonard Rosenthol)
Date: Wed, 20 Apr 1994 17:26:32 GMT
Organization: Aladdin Systems, Inc.

In article <CoIy3H.JAo@vcd.hp.com>, egurney@vcd.hp.com (Eddy J. Gurney) wrote:

> Or, make ResEdit aware of the Aladdin resource compression scheme.
> 
> Below are my instructions on installing the Aladdin resource
> decompressor 
> [details removed]
>
   Just a reminder to folks that if you must do this, you can NO LONGER
distribute that copy of ResEdit as you have now added "Aladdin
Copyrighted" material that is NOT yours to redistribute.  As our box says
"Our Lawyers are Happy",  please keep them that way ;).

   On a related note, are there REALLY a lot of you who would like to be
able to modify our compressed resources?  Feel free to EMail me and let me
know if there are - maybe we can help...


Leonard
- ------------------------------------------------------------------------
Leonard Rosenthol                      Internet:       leonardr@netcom.com
Director of Advanced Technology        AppleLink:      MACgician
Aladdin Systems, Inc.                  GEnie:          MACgician

---------------------------

>From rrose@CSOS.ORST.EDU (-= Godfather Moof =-)
Subject: Window -> PICT question
Date: 13 Apr 1994 14:29:26 GMT
Organization: CS Outreach Services, Oregon State University, Corvallis, OR, USA

Any people out in the cloud know how to convert a window to a PicHandle?

I've got a 256x256 window that I want to use as a pict...

Thanks.  Please reply to rrose@csos.orst.edu.

+++++++++++++++++++++++++++

>From u9119523@sys.uea.ac.uk (Graham Cox)
Date: Thu, 14 Apr 1994 11:23:31 GMT
Organization: School of Information Systems, UEA, Norwich

In article <2ogvk6$4k4@jadzia.CSOS.ORST.EDU>, rrose@CSOS.ORST.EDU (-=
Godfather Moof =-) wrote:

> Any people out in the cloud know how to convert a window to a PicHandle?
> 
> I've got a 256x256 window that I want to use as a pict...
> 
> Thanks.  Please reply to rrose@csos.orst.edu.


Try this:


PicHandle MakeWindowPict(WindowPtr theWindow)
{

	Rect		r;
	PicHandle	p;



	GetPort(&originalPort);
	SetPort(theWindow);
	r = thePort->portRect;
	p = OpenPicture(&r);
	CopyBits(&thePort->portBits,&thePort->portBits,&r,&r,srcCopy,NULL);
	ClosePicture();
	SetPort(originalPort);
	return(p);
}


Off the top of my head so check the function calls in case I remembered
them wrong.

- ------------------------------------------------------------------------
Love & BSWK, Graham

-Everyone is entitled to their opinion, no matter how wrong they may be...
- ------------------------------------------------------------------------

+++++++++++++++++++++++++++

>From jdm@newton (James D. Meiss)
Date: 17 Apr 1994 17:23:22 GMT
Organization: University of Colorado, Boulder

In article <u9119523-140494112331@case10.sys.uea.ac.uk> u9119523@sys.uea.ac.uk (Graham Cox) writes:
>
>
>PicHandle MakeWindowPict(WindowPtr theWindow)
>{
>
>	Rect		r;
>	PicHandle	p;
>
>
>
>	GetPort(&originalPort);
>	SetPort(theWindow);
>	r = thePort->portRect;
>	p = OpenPicture(&r);
>	CopyBits(&thePort->portBits,&thePort->portBits,&r,&r,srcCopy,NULL);
>	ClosePicture();
>	SetPort(originalPort);
>	return(p);
>}
>
>
>Off the top of my head so check the function calls in case I remembered
>them wrong.
>
	This code works, but mystifies me. Can someone please explain what
copy bits does here? It is reading and writing to the same block of memory?
Does it actually DO the memory writing, or is the instruction just recorded...
in this case how does the picture know how to execute the instruction? Of
course, I guess that the PICT must actually just get the bits in the picture
written to it, but how?

	Sorry for the ignorance, but thanks for you explanations!

	Jim Meiss
	jdm@boulder.colorado.edu

+++++++++++++++++++++++++++

>From u9119523@sys.uea.ac.uk (Graham Cox)
Date: Tue, 19 Apr 1994 10:59:45 GMT
Organization: School of Information Systems, UEA, Norwich

In article <2orraa$6es@lace.Colorado.EDU>, jdm@newton (James D. Meiss)
wrote:

> In article <u9119523-140494112331@case10.sys.uea.ac.uk> u9119523@sys.uea.ac.uk (Graham Cox) writes:
> >
> >
> >PicHandle MakeWindowPict(WindowPtr theWindow)
> >{
> >
> >	Rect		r;
> >	PicHandle	p;
> >
> >
> >
> >	GetPort(&originalPort);
> >	SetPort(theWindow);
> >	r = thePort->portRect;
> >	p = OpenPicture(&r);
> >	CopyBits(&thePort->portBits,&thePort->portBits,&r,&r,srcCopy,NULL);
> >	ClosePicture();
> >	SetPort(originalPort);
> >	return(p);
> >}
> >
> >
> >Off the top of my head so check the function calls in case I remembered
> >them wrong.
> >
> 	This code works, but mystifies me. Can someone please explain what
> copy bits does here? It is reading and writing to the same block of memory?
> Does it actually DO the memory writing, or is the instruction just recorded...
> in this case how does the picture know how to execute the instruction? Of
> course, I guess that the PICT must actually just get the bits in the picture
> written to it, but how?
> 
> 	Sorry for the ignorance, but thanks for you explanations!
> 
> 	Jim Meiss
> 	jdm@boulder.colorado.edu


As you correctly guessed, the copybits call is made just so that it gets
recorded into the picture- I think it does actually write over itself as
well but of course that doesn't matter. When you copybits with an open
picture, the picture records both the copybits opcode AND all of the actual
pixel data (and colour tables too- what a bonus!) When played back
DrawPicture knows that the port in question has changed and does the 'right
thing'. Stuff like this is why I'll never be a Windows programmer...

- ------------------------------------------------------------------------
Love & BSWK, Graham

-Everyone is entitled to their opinion, no matter how wrong they may be...
- ------------------------------------------------------------------------

+++++++++++++++++++++++++++

>From pottier@corvette.ens.fr (Francois Pottier)
Date: 19 Apr 1994 14:52:41 GMT
Organization: Ecole Normale Superieure, PARIS, France

In article <u9119523-190494135945@case9.sys.uea.ac.uk>,
Graham Cox <u9119523@sys.uea.ac.uk> wrote:

>> >	p = OpenPicture(&r);
>> >	CopyBits(&thePort->portBits,&thePort->portBits,&r,&r,srcCopy,NULL);

>
>As you correctly guessed, the copybits call is made just so that it gets
>recorded into the picture- I think it does actually write over itself as
>well but of course that doesn't matter.

No, it doesn't write over itself, it would be a waste. When you call OpenPicture,
all Quickdraw bottlenecks (the standard drawing routines) are replaced with
recording routines. So the CopyBits call above is in fact *not* a call to
the usual CopyBits routine, but to a recording routine. Afterwards, calling
ClosePicture restores the usual bottlenecks.

-- 
Francois Pottier
pottier@dmi.ens.fr

---------------------------

End of C.S.M.P. Digest
**********************