From: pottier@clipper.ens.fr (Francois Pottier)
Subject: csmp-digest-v3-030
Date: Wed, 25 May 94 10:42:16 MET DST

C.S.M.P. Digest             Wed, 25 May 94       Volume 3 : Issue 30
 
Today's Topics:
 
        Apple's blatant disregard for User Interface Guidelines
        List Manager clikLoop problem... but whose it?
        Opening a file with C standard i-o routines
        Sym CDK vs CodeWarrior PPC: first impressions
        Where is the inheritance in AE objects?
        [Q] How to prevent _DragWindow from selecting the window?
        [Q] casting Str255 <--> (char*)



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 jjvbl@lhdsy1.lahabra.chevron.com (John V. Blzka)
Subject: Apple's blatant disregard for User Interface Guidelines
Date: 2 May 94 15:26:59 GMT
Organization: Chevron, La Habra, CA

Hello,
I've been working on a presentation on Human Factors Engineering.
I am using Apple's User Interface Guidelines as an example.  
What I would like to know is:
  Does Apple violate it's own Guidelines in any of it's System 7  
  software?
  If so, can I easily demonstrate it?

Thanks in advance,
John
jjvbl@chevron.com

-- 
===================================================================
John Blyzka                      | jjvbl@chevron.com
"the BLITZ"                      | "only the good die young"
 

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

>From cwiltgen@mcs.com (Charles Wiltgen)
Date: Tue, 03 May 1994 19:54:07 -0600
Organization: Lederhosen 'R' Us - Worldwide Leaders in Lederhosen

In article <16674@lhdsy1.lahabra.chevron.com>,
jjvbl@lhdsy1.lahabra.chevron.com (John V. Blzka) wrote:

> Hello,
> I've been working on a presentation on Human Factors Engineering.
> I am using Apple's User Interface Guidelines as an example.  
> What I would like to know is:
>   Does Apple violate it's own Guidelines in any of it's System 7  
>   software?
>   If so, can I easily demonstrate it?

How 'bout dragging a disk to the trash to eject it?

-- 
Charles Wiltgen    "Love is a snowmobile racing across the tundra and
cwiltgen@mcs.com    then suddenly it flips over, pinning you underneath.
(INTP)              At night, the ice weasels come." - Nietzsche (Groening)
World Wide Web      http://venus.mcs.net/~cwiltgen/home.html

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

>From rmah@panix.com (Robert S. Mah)
Date: Tue, 03 May 1994 21:57:11 -0500
Organization: One Step Beyond

cwiltgen@mcs.com (Charles Wiltgen) wrote:

> jjvbl@lhdsy1.lahabra.chevron.com (John V. Blzka) wrote:
> 
> > I've been working on a presentation on Human Factors Engineering.
> > I am using Apple's User Interface Guidelines as an example.  
> > What I would like to know is:
> >   Does Apple violate it's own Guidelines in any of it's System 7  
> >   software?  If so, can I easily demonstrate it?
> 
> How 'bout dragging a disk to the trash to eject it?

That is, in fact, a wonderful example of the _process_ of iterative
user interface design.  Complete with pragmatic compromises and soul
searching about paradigm stability and all that.

There was a thread over in comp.human-factors about this where one of
Apple's Human Interface people stopped by and asked for suggestions.
The winner got a T-shirt.  Suffice it to say that no one could come up
with anything better, given the constraints at hand.  It's a pretty
damn tough problem.

Cheers,
Rob
___________________________________________________________________________
Robert S. Mah  -=-  One Step Beyond  -=-  212-947-6507  -=-  rmah@panix.com

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

>From pcastine@jake.prz.tu-berlin.de (Peter Castine)
Date: Wed, 4 May 1994 11:13:39 GMT
Organization: PRZ TU-Berlin

jjvbl@lhdsy1.lahabra.chevron.com (John V. Blzka) asked:
>>   Does Apple violate it's own Guidelines in any of it's System 7  
>>   software?
>>   If so, can I easily demonstrate it?

cwiltgen@mcs.com (Charles Wiltgen) replied:
>How 'bout dragging a disk to the trash to eject it?

Although the semantics and history of this gesture have been
much debated, I find myself asking "What Human Interface
Principle does this violate?" It certainly supports the
principles Direct Manipulation, See-and-Point, and User
Control. Admittedly, it weakens the metaphor of trashcan-
as-device-of-destruction, but since that's not what the
trash can is (it's more a metaphor of device-to-get-things
-off-my-desktop) and metaphors are meant to be *extensible*
("Metaphors in the computer interface suggest a use for
something, but that use doesn't define or limit the 
implementation of the metaphor", _Macintosh Human Interface
Guidelines_ p. 5), that's not really the problem. 

In short, although dragging a disk to the trash (as an
alternative to the Put Away command) may seem to be
a strange gesture, it's not a violation.

As far was the original question is concerned, you
can find a number of violations if you want to nit-pick.
For instance, ResEdit 2.1.1 does not use the new,
canonical layout for its "Maybe you want to save
before closing/quitting?" dialog. Also, some of
the recommendations regarding movabale modal
dialogs and modeless dialogs were slow in percolating
through to the entire system software. 

I think, however, you will be hard-pressed to find
a violation in the Finder.

Hope this helps,

-- 
Peter Castine                      | Da sprach Jesus zu ihm: Stecke dein
pcastine@prz.tu-berlin.de          | Schwerdt an seinen Ort; denn wer das
- ---------------------------------| Schwerdt nimmt, der soll durchs
     ``Have Mac, will travel''     | Schwerdt umkommen. (Matthai 26:52)

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

>From u9119523@sys.uea.ac.uk (Graham Cox)
Date: Wed, 4 May 1994 20:24:52 GMT
Organization: School of Information Systems, UEA, Norwich

In article <cwiltgen-030594195407@cwiltgen.pr.mcs.net>, cwiltgen@mcs.com
(Charles Wiltgen) wrote:

> In article <16674@lhdsy1.lahabra.chevron.com>,
> jjvbl@lhdsy1.lahabra.chevron.com (John V. Blzka) wrote:
> 
> > Hello,
> > I've been working on a presentation on Human Factors Engineering.
> > I am using Apple's User Interface Guidelines as an example.  
> > What I would like to know is:
> >   Does Apple violate it's own Guidelines in any of it's System 7  
> >   software?
> >   If so, can I easily demonstrate it?
> 
> How 'bout dragging a disk to the trash to eject it?


Oh, THAT old chestnut! Be honest- could YOU live without it?

Here's a trivial example- not in the system but in most graphics programs,
including MacDraw and ClarisWorks- the guidelines say that the cursor keys
should never be used to position graphic elements, but most programs do
this. However, in my opinion, it is the guideline that's stupid- WHY NOT!!!



> 
> -- 
> Charles Wiltgen    "Love is a snowmobile racing across the tundra and
> cwiltgen@mcs.com    then suddenly it flips over, pinning you underneath.
> (INTP)              At night, the ice weasels come." - Nietzsche (Groening)
> World Wide Web      http://venus.mcs.net/~cwiltgen/home.html

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

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

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

>From zz1bb@impending.ucsd.edu (Barry Brown)
Date: 4 May 94 17:17:18 GMT
Organization: (none)

In <1994May4.111339.29072@prz.tu-berlin.de> pcastine@jake.prz.tu-berlin.de (Peter Castine) writes:

>jjvbl@lhdsy1.lahabra.chevron.com (John V. Blzka) asked:
>>>   Does Apple violate it's own Guidelines in any of it's System 7  
>>>   software?
>>>   If so, can I easily demonstrate it?

>cwiltgen@mcs.com (Charles Wiltgen) replied:
>>How 'bout dragging a disk to the trash to eject it?

>Although the semantics and history of this gesture have been
>much debated, I find myself asking "What Human Interface
>Principle does this violate?" It certainly supports the
>principles Direct Manipulation, See-and-Point, and User
>Control.

I believe it violates the (perhaps unwritten) "no surprises" and the "one
object, one action" rules.

A novice user is surprised to find out that trashing a disk doesn't erase
it, but ejects it instead.  S/he also discovers that selecting Eject from
the Special menu doesn't remove the disk image from the desktop and may even
ask him/her for the disk again in the future!

Second, the Trash can is used for two purposes: removing files and ejecting
disks -- two very different actions.  The Trash is just a folder (albeit a
special one); trashed files show up in its window before you empty it.  Why
don't trashed disks show up in it, either?

-- 
Barry E. Brown                          Internet: bbrown@ucsd.edu
UCSD Academic Computing Services        AOL:      BarryBrown
Student Consultant
<a href="http://www-cse.ucsd.edu/users/bbrown">My WWW Home Page</a>

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

>From sjb8502@ucs.usl.edu (Bienvenu Jay )
Date: Wed, 4 May 1994 18:06:50 GMT
Organization: Univ. of Southwestern La., Lafayette


Does Claris count as part of Apple?  If so, I've got one:
MacWrite does not display a watch cursor while saving a file.

Jay Bienvenu
sjb8502@usl.edu

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

>From Paul Ferguson <pferguson@kaleida.com>
Date: 4 May 1994 23:48:17 GMT
Organization: Kaleida Labs, Inc.

In article <16674@lhdsy1.lahabra.chevron.com> John V. Blzka,
jjvbl@lhdsy1.lahabra.chevron.com writes:
> Does Apple violate it's own Guidelines in any of it's System 7  
> software?

One classic example that comes to mind is the Alarm Clock, which
suffers from a bunch of violations:  non-standard controls,
non-standard title bar (not to mention using the title bar to
display the time), non-standard close box, a cross-hair cursor to
select a field, the big-small display modes, flashing the Apple
menu forever when the alarm goes off (how many people at some
point in their life were mystified to see a flashing alarm clock
where the Apple menu is?)  It's hard to find anything about the
alarm clock that doesn't violate the HIG.

Rumor has it that this DA was originally developed by Microsoft,
which might explain some of it.  It has not evolved at all from
it's earliest incarnation, which is pretty lame on Apple's part.
How hard is it to write an alarm clock?
 
--fergy

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

>From Brad Koehn <koehn@macc.wisc.edu>
Date: 5 May 1994 01:35:32 GMT
Organization: University of Wisconsin

In article <1994May4.111339.29072@prz.tu-berlin.de> Peter Castine,
pcastine@jake.prz.tu-berlin.de writes:
>I think, however, you will be hard-pressed to find
>a violation in the Finder.

Oh, let's see, where to start:
If you get info on a file on a server, or on a local volume with file
sharing turned on, clicking on the name changes it to it's DOS equivilant.

It doesn't give background applications any time (hardly). I know this
probably isn't spelled out in the HIG, but it should be.

When copying files, the menus don't dim. If you click in the menu bar
during a copy, the dim all of a sudden.

With the sharing box open, there's now way to save changes. You have to
hit the close box, and dismiss the (up to three) annoying dialogs.

Dragging items onto a system folder that's not the one you booted with
doesn't put them in the right place, even if the icons in the folder
(e.g. apple menu items folder) show correctly.

You may call these bugs, but I say bugs are the most obvious form of HIG
violation.
_________________________________________________________________________
Brad Koehn          Data Transformations, Inc.        koehn@macc.wisc.edu

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

>From quinn@cs.uwa.edu.au (Quinn "The Eskimo!")
Date: Thu, 05 May 1994 10:03:13 +0800
Organization: Department of Computer Science, The University of Western Australia

In article <1994May4.111339.29072@prz.tu-berlin.de>,
pcastine@jake.prz.tu-berlin.de (Peter Castine) wrote:

>I think, however, you will be hard-pressed to find
>a violation in the Finder.

OK, I've got a good one!  Why, when you drag a file into a folder where
there already exists a file of the same name, do you have the option of
replacing the original.  Why doesn't the Finder move it to the Trash??? 
OK, so maybe it's not a *real* HIG violation but it's really inconsistent
and consistency is one of the central precepts of the HIG.

Other (more obvious) problems become apparent when you install PowerTalk. 
Try the following...

1) Open your catalogue.
2) Drag a file into the catalogue window.
3) See Finder highlight catalogue window.
4) Let go.
5) See file zoom back to its original position.

Or try this...

1) Open your catalogue.
2) Find a user record (either in your Personal Catalogue or in a
PowerShare catalogue) and drag it to the catalogue window.
3) See Finder highlight catalogue window.
4) Let go.
5) Read dialog telling you that you can't do it because you don't have
privileges.

Question #1 Why does it highlight the window (in both cases)?
Question #2 Why does it have different behaviour when it finally realises
            that it's failed?

Basically AOCE's HI is severely broken in a lot of places.  Unfortunately
it's a Finder extension, which means that these problems appear to be
Finder problems.
-- 
Quinn "The Eskimo!"      <quinn@cs.uwa.edu.au>     "Support HAVOC!"
Department of Computer Science, The University of Western Australia

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

>From alister@netcom.com (Rick Reynolds aka GreenGoo)
Date: Thu, 5 May 1994 06:32:08 GMT
Organization: NETCOM On-line Communication Services (408 241-9760 guest)

>How 'bout dragging a disk to the trash to eject it?


I never really thought much about this issue but I think there should
have been a disk drive icon on the desktop, always visable but somehow
conveying to the user that a disk is inserted. When the user wants
to change disks they can press an "eject" button on the icon. But alas
that brings up the problem of having a control (which woule have to be
smaller then other controls) on a Finder icon.

Hmmm...
-- 
Richard Reynolds
alister@netcom.com

 "Most dreams are made of glass. You throw just one stone and then there
goes your last window" -RJD


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

>From deguzman@binkley.math.uiuc.edu (Alan DeGuzman)
Date: 5 May 1994 13:17:32 GMT
Organization: Calculus&Mathematica at UIUC

alister@netcom.com (Rick Reynolds aka GreenGoo) writes:

>>How 'bout dragging a disk to the trash to eject it?


>I never really thought much about this issue but I think there should
>have been a disk drive icon on the desktop, always visable but somehow
>conveying to the user that a disk is inserted.

Uh, what about the disk's icon? Granted, it can be hidden behind windows,
but I'd rather have what *I* want to stay on top of the desktop layer
rather than some floating icons or whatever.

>When the user wants
>to change disks they can press an "eject" button on the icon. But alas
>that brings up the problem of having a control (which woule have to be
>smaller then other controls) on a Finder icon.

Now you're on to something. How about letting every icon that is a volume
have a 'switch' or 'button' drawn on (or near) the icon that let's you
eject the volume (eject in the sense of "Put Away"). It could even be dimmed
out for volumes that can't be "Put Away", like the startup volume.
--
Alan A. DeGuzman          "The problem with people is that they're only human."
Calculus&Mathematica
DISCLAIMER: "The University         - Hobbes to Calvin from
can't afford my opinions."           'The Indispensible Calvin and Hobbes'

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

>From tzs@u.washington.edu (Tim Smith)
Date: 5 May 1994 13:52:44 GMT
Organization: University of Washington School of Law, Class of '95

> I've been working on a presentation on Human Factors Engineering.
> I am using Apple's User Interface Guidelines as an example.  
> What I would like to know is:
>   Does Apple violate it's own Guidelines in any of it's System 7  
>   software?
>   If so, can I easily demonstrate it?

In the thingy that is used to select a color (get it by selecting "other..."
for your highlight color in the Colors control panel, or double clicking
on a palette entry in the pattern editor in the General control panel),
they use a scroll bar to set brightness.  I think this violates something
in the User Interface Guidelines.

--Tim Smith

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

>From Thomas Reed <reed@medicine.wustl.edu>
Date: 5 May 1994 15:00:06 GMT
Organization: Washington University

In article <2q9ih4$nhs@news.doit.wisc.edu> Brad Koehn,
koehn@macc.wisc.edu writes:
>It doesn't give background applications any time (hardly). I know this
>probably isn't spelled out in the HIG, but it should be.

I don't think that this kind of stuff is in the interface guidelines,
though I can't say that for sure.  Actually, the amount of time
background applications get depends on the background application.  Any
application can grab as much or as little of the CPU time as it needs. 
That's how the Mac's cooperative multitasking works.

>When copying files, the menus don't dim. If you click in the menu bar
>during a copy, the dim all of a sudden.

I think my menus dim, all except the Apple, Balloon Help, and Application
(you know, the one on the far right) menus.  If they don't dim, it's
probably for one of two reasons:  1)  you can use them even during a
copy, or 2)  you have an extension or control panel installed that does
something with your menus.

>With the sharing box open, there's now way to save changes. You have to
>hit the close box, and dismiss the (up to three) annoying dialogs.

Agreed on this one.  It'd be nice if there was a friendlier way to do
sharing stuff.  Though I'm not going to complain too much -- I don't mind
the way it's done now.

>Dragging items onto a system folder that's not the one you booted with
>doesn't put them in the right place, even if the icons in the folder
>(e.g. apple menu items folder) show correctly.

Yes, I've often done this.  However, there's really only one way for the
computer to know that a folder is the system folder without doing more
stuff than it should have to do -- if it has the active system in it.  If
every time you dropped something in a folder, the system had to search
that folder for a copy of the Finder, then all your moves would take a
little longer.  Not only that, but it wouldn't be reliable -- sometimes I
keep copies of the Finder around in different places to play with them.

-Thomas
=====================================================
Thomas Reed                    Washington University
Reed@telesphere.wustl.edu          Medical School
(also:  Reed@medicine.wustl.edu)
- ---------------------------------------------------
Clothes make the man.  Naked people have little or no
influence on society.  -- Mark Twain
=====================================================

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

>From Paul Ferguson <pferguson@kaleida.com>
Date: 5 May 1994 15:30:12 GMT
Organization: Kaleida Labs, Inc.

In article <2qatnc$bon@news.u.washington.edu> Tim Smith, tzs@u.washington.edu
writes:
> In the thingy that is used to select a color (get it by
> selecting "other..." for your highlight color in the Colors
> control panel, or double clicking on a palette entry in the
> pattern editor in the General control panel), they use a scroll
> bar to set brightness.  I think this violates something in the
> User Interface Guidelines.

HIG page 215: "Use scroll bars only for representing the relative
position of the visible portion of a document and in scrolling
lists."  I suppose one could argue that in the color picker, the
"document" is the entire color space and that you are scrolling
through it to see different views.  On the other hand, what the
slider is doing is changing the brightness from 0-65535, which
is exactly what the example shown on that page says is an incorrect
use of a scroll bar.

This does raise the issue of why Apple explicitly talks about
sliders (in a section entitled "Controls Not Supported by the
Macintosh Toolbox") and gives guidelines as to their use, but have
never provided any sort of standard slider controls for programmers
to use.  Other environments like Motif provide slider widgets with
the same look and feel as their scroll bars, check boxes, etc.  I
think Apple's OS and UI groups have failed by not providing the
same.  Hence the scroll bar often does get misused because it is
much easier to use what's there than write it from scratch (and
writing a smooth slider is not a trivial task).

--fergy

- ------------------------------------------------------------------
  Paul Ferguson         | "It's a sick world, I'm a happy guy..."
  pferguson@kaleida.com |  
- ------------------------------------------------------------------

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

>From hades@coos.dartmouth.edu (Brian V. Hughes)
Date: 5 May 1994 17:33:26 GMT
Organization: Dartmouth College, Hanover, NH, USA

Thomas Reed <reed@medicine.wustl.edu> writes:

>Brad Koehn, koehn@macc.wisc.edu writes:
>>It doesn't give background applications any time (hardly). I know this
>>probably isn't spelled out in the HIG, but it should be.

>I don't think that this kind of stuff is in the interface guidelines,
>though I can't say that for sure.

    No it's not in the HIG, but that's because there is no human
interface involved with background applications getting CPU time.

>Actually, the amount of time background applications get depends on the
>background application.  Any application can grab as much or as little
>of the CPU time as it needs.  That's how the Mac's cooperative
>multitasking works.

    Nope, sorry. There's this little routine called WaitNextEvent() that
must be called, at a decent interval, by the forgroung application so
that when the background application calls GetNextEvent() there's
something there to be gotten. Applications have to be written to perform
as both foreground and background apps, nicely, so that the Mac
cooporative scheme works the way it's supposed to.

-Hades

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

>From Chuck Simciak <simciac@ccsmtp.ccf.org>
Date: Thu, 5 May 1994 17:28:00 GMT
Organization: Cleveland Clinic Foundation

In article <2qatnc$bon@news.u.washington.edu> Tim Smith,
tzs@u.washington.edu writes:
>> I've been working on a presentation on Human Factors Engineering.
>> I am using Apple's User Interface Guidelines as an example.  
>> What I would like to know is:
>>   Does Apple violate it's own Guidelines in any of it's System 7  
>>   software?
>>   If so, can I easily demonstrate it?

I'm not sure if this counts as breaking an interface guideline but it is
very annonying.  Say I go to save a file, the StandardPutFile dialog
emerges and I have to navigate several folders to get to my desitination.
 The file name field has already been filled with a defualt.  Here's the
catch.  Upon having navigated the multiple folders to place the file, the
SAVE button is now an OPEN button.  I then have to click in the filename
text field to cause the button to CHANGE to SAVE.  This "feature" was
introduced in System 7 and has been a source of nuisance ever since.

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 dn_crow@bean.open.ac.uk (dn_crow)
Date: Thu, 5 May 1994 18:43:00 GMT
Organization: (none)

An example that has always rather amused me is the one about switching
between applications. The guidlines state that if I click outside any
window belonging to my application, this action should switch me to the
application whose window I have clicked over (e.g. the Finder). The
only action of this click, or indeed double-click, should be to switch
applications. In particular, the guidelines state that the clicks
should *not* be sent to the application being clicked upon.

However, the Finder disregards this: try loading an application and
bringing it to the front, while still being able to see a finder window
behind it. If you now click over a visible finder icon, the appropriate
Finder window is brought to the front (correct) but the icon is
selected (incorrect).

This, along with most of the other problems mentioned in this thread,
is pretty minor, so if, as your rather biased title suggests, you're
trolling for Apple-bashing material, I think you'll have a pretty weak
case...

Dan

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

>From pcastine@jake.prz.tu-berlin.de (Peter Castine)
Date: Thu, 5 May 1994 19:48:30 GMT
Organization: PRZ TU-Berlin

quinn@cs.uwa.edu.au (Quinn "The Eskimo!") writes:
>pcastine@jake.prz.tu-berlin.de (that's me) wrote:
>
>>I think, however, you will be hard-pressed to find
>>a violation in the Finder.
>
>OK, I've got a good one!  Why, when you drag a file into a folder where
>there already exists a file of the same name, do you have the option of
>replacing the original.  Why doesn't the Finder move it to the Trash??? 
>OK, so maybe it's not a *real* HIG violation but it's really inconsistent

Inconsistent with what?

>and consistency is one of the central precepts of the HIG.

Consistency is, IMHO, a secondary concern. Smith et.al. discuss the
practical issues of maintaining consistency in real world applications
in their 1982 article "Designing the Star user interface." (Originally
printed in Byte 7(4), reprinted in Baecker & Buxton's _Readings in 
Human-Computer Interaction_, the paper is a must-read). Short
precis: consistency is the hobgoblin of small minds.

>Other (more obvious) problems become apparent when you install PowerTalk. 

This is cheating--PowerTalk extensions aren't the Finder. I suppose
they look that way, though.

>Try the following...
>
>1) Open your catalogue.
>2) Drag a file into the catalogue window.
>3) See Finder highlight catalogue window.
>4) Let go.
>5) See file zoom back to its original position.
>

This example comes practically straight from the discussion in
the above-mentioned article. Geez--maybe I should just violate
copyright and type in the entire paper.

:-)

>Or try this...
>
>1) Open your catalogue.
>2) Find a user record (either in your Personal Catalogue or in a
>PowerShare catalogue) and drag it to the catalogue window.
>3) See Finder highlight catalogue window.
>4) Let go.
>5) Read dialog telling you that you can't do it because you don't have
>privileges.
>
>Question #1 Why does it highlight the window (in both cases)?

For performance reasons? (Checking privileges might slow down
feedback, direct manipulation. I'm obviously guessing on this one).

>Question #2 Why does it have different behaviour when it finally realises
>            that it's failed?

What's it supposed to do? Not tell you that it failed? Disregard
privileges?

>Basically AOCE's HI is severely broken in a lot of places.  

Severely? Well, I'll let that pass before a flame war breaks out.

> Unfortunately
>it's a Finder extension, 

Like I said, cheating.

>which means that these problems appear to be
>Finder problems.

Well, touche.

-- 
Peter Castine                      | Da sprach Jesus zu ihm: Stecke dein
pcastine@prz.tu-berlin.de          | Schwerdt an seinen Ort; denn wer das
- ---------------------------------| Schwerdt nimmt, der soll durchs
     ``Have Mac, will travel''     | Schwerdt umkommen. (Matthai 26:52)

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

>From Thomas Reed <reed@medicine.wustl.edu>
Date: 5 May 1994 20:31:38 GMT
Organization: Washington University

In article <1994May5.172800.22102@bme.ri.ccf.org> Chuck Simciak,
simciac@ccsmtp.ccf.org writes:
> The file name field has already been filled with a defualt.  Here's the
>catch.  Upon having navigated the multiple folders to place the file, the
>SAVE button is now an OPEN button.  I then have to click in the filename
>text field to cause the button to CHANGE to SAVE.  This "feature" was
>introduced in System 7 and has been a source of nuisance ever since.

I believe this problem is caused not by the system, but by Directory
Assistance II.  (Or a similar program.)  My System 7.x machine never did
this until I installed Directory Assistance II, so...

-Thomas
=====================================================
Thomas Reed                    Washington University
Reed@telesphere.wustl.edu          Medical School
(also:  Reed@medicine.wustl.edu)
- ---------------------------------------------------
Clothes make the man.  Naked people have little or no
influence on society.  -- Mark Twain
=====================================================

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

>From Thomas Reed <reed@medicine.wustl.edu>
Date: 5 May 1994 20:48:08 GMT
Organization: Washington University

In article <2qbal6$3tu@dartvax.dartmouth.edu> Brian V. Hughes,
hades@coos.dartmouth.edu writes:
>>Actually, the amount of time background applications get depends on the
>>background application.  Any application can grab as much or as little
>>of the CPU time as it needs.  That's how the Mac's cooperative
>>multitasking works.
>
>    Nope, sorry. There's this little routine called WaitNextEvent() that
>must be called, at a decent interval, by the forgroung application so
>that when the background application calls GetNextEvent() there's
>something there to be gotten.

Yes, it's true that there has to be "something to be gotten", but I think
most applications these days, background or not, call WaitNextEvent, so
they can control directly how much time they get by giving different
numbers for the sleep value.  A low value causes the app to be given time
more often, a high value causes the app to be given time less often. 
Plus, if the background app doesn't call WaitNextEvent AT ALL for a
while, they get ALL of that processing time.  WaitNextEvent is the key
behind applications getting CPU time.

-Thomas
=====================================================
Thomas Reed                    Washington University
Reed@telesphere.wustl.edu          Medical School
(also:  Reed@medicine.wustl.edu)
- ---------------------------------------------------
Clothes make the man.  Naked people have little or no
influence on society.  -- Mark Twain
=====================================================

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

>From pcastine@jake.prz.tu-berlin.de (Peter Castine)
Date: Thu, 5 May 1994 20:39:17 GMT
Organization: PRZ TU-Berlin

Chuck Simciak <simciac@ccsmtp.ccf.org> writes:
>
>I'm not sure if this counts as breaking an interface guideline but it is
>very annonying.  Say I go to save a file, the StandardPutFile dialog
>emerges and I have to navigate several folders to get to my desitination.
> The file name field has already been filled with a defualt.  Here's the
>catch.  Upon having navigated the multiple folders to place the file, the
>SAVE button is now an OPEN button.  I then have to click in the filename
>text field to cause the button to CHANGE to SAVE.  This "feature" was
>introduced in System 7 and has been a source of nuisance ever since.

I like this one, because the Standard Save File dialog is being
*consistent* (that's right, folks!).

The Save button only changes to Open when you've selected a folder
in the directory list. When this is the case, the EditText field
with the document name is no longer the active item in the dialog,
the directory list is the active item (highlighted with an extra
two-pixel thick box surrounding it). So, the Save button is being
context-sensitive, changes to 'Open' and behaves the same way
a double-click on the currently selected item would behave.

BTW, you don't need to click on the document name, you only have
to deselect any folder, for the button to change back to Open.

I'm just waiting for someone to say "Why don't they add another
button, so you've got one for Save and one for Open?" Before you
ask that question, read Tognazzini's article on Consistency in
_The Art of Human-Computer Interface Design_ ;-q

-- 
Peter Castine                      | Da sprach Jesus zu ihm: Stecke dein
pcastine@prz.tu-berlin.de          | Schwerdt an seinen Ort; denn wer das
- ---------------------------------| Schwerdt nimmt, der soll durchs
     ``Have Mac, will travel''     | Schwerdt umkommen. (Matthai 26:52)

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

>From quinn@cs.uwa.edu.au (Quinn "The Eskimo!")
Date: Fri, 06 May 1994 10:41:44 +0800
Organization: Department of Computer Science, The University of Western Australia

In article <2qatnc$bon@news.u.washington.edu>, tzs@u.washington.edu (Tim
Smith) wrote:

>In the thingy that is used to select a color (get it by selecting "other..."
>for your highlight color in the Colors control panel, or double clicking
>on a palette entry in the pattern editor in the General control panel),
>they use a scroll bar to set brightness.  I think this violates something
>in the User Interface Guidelines.

Actually it violates the letter, *but not IMHO the spirit*, of the
guideline that states that you should only put settings, as opposed to
commands, in a popup menu.
-- 
Quinn "The Eskimo!"      <quinn@cs.uwa.edu.au>     "Support HAVOC!"
Department of Computer Science, The University of Western Australia

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

>From jfinete@cats.ucsc.edu (Joseph Manuel Finete)
Date: 6 May 1994 03:04:26 GMT
Organization: University of California; Santa Cruz


In article <1994May5.203917.29612@prz.tu-berlin.de> pcastine@jake.prz.tu-berlin.de (Peter Castine) writes:
>
>I like this one, because the Standard Save File dialog is being
>*consistent* (that's right, folks!).
>
>The Save button only changes to Open when you've selected a folder
>in the directory list. When this is the case, the EditText field
>with the document name is no longer the active item in the dialog,
>the directory list is the active item (highlighted with an extra
>two-pixel thick box surrounding it). So, the Save button is being
>context-sensitive, changes to 'Open' and behaves the same way
>a double-click on the currently selected item would behave.
>
>BTW, you don't need to click on the document name, you only have
>to deselect any folder, for the button to change back to Open.

Also, hitting the TAB key will let you cycle through the dialog items.
So if the file list is selected, hit TAB and then the EditText field
will be selected. My problem is that its not obvious enough that the
file list is selected or that the Edit Text field is not selected,
although, I really don't have a good idea on how to alleviate this.

-- 
Joe Finete
jfinete@cats.ucsc.edu

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

>From d88-jwa@dront.nada.kth.se (Jon Wätte)
Date: 6 May 1994 08:34:14 GMT
Organization: The Royal Institute of Technology

In <1994May5.172800.22102@bme.ri.ccf.org> Chuck Simciak <simciac@ccsmtp.ccf.org> writes:

>catch.  Upon having navigated the multiple folders to place the file, the
>SAVE button is now an OPEN button.  I then have to click in the filename
>text field to cause the button to CHANGE to SAVE.  This "feature" was

Or you can press TAB. This is so you can actually type-select
folder names in the list, instead of having to use arrow keys.

Cheers,

					/ h+
-- 
 -- Jon W{tte, h+@nada.kth.se, Mac Hacker Deluxe (on a Swedish scale) --

   What we need is a good GNU [...] licence manager implementation.
                     -- Raphael Manfredi

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

>From d88-jwa@dront.nada.kth.se (Jon Wätte)
Date: 6 May 1994 08:36:21 GMT
Organization: The Royal Institute of Technology

In <1994May5.184300.25982@leeds.ac.uk> dn_crow@bean.open.ac.uk (dn_crow) writes:

>only action of this click, or indeed double-click, should be to switch
>applications. In particular, the guidelines state that the clicks
>should *not* be sent to the application being clicked upon.

This recommendation is going away with the new, direct manipulation,
Drag Manager, and AOCE which uses it (or its cousin) and it will DEFINATELY
not be the case when you run OpenDoc.

Cheers,

					/ h+
-- 
 -- Jon W{tte, h+@nada.kth.se, Mac Hacker Deluxe (on a Swedish scale) --

   What we need is a good GNU [...] licence manager implementation.
                     -- Raphael Manfredi

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

>From sw@network-analysis-ltd.co.uk (Sak Wathanasin)
Date: Fri, 6 May 94 09:47:25 GMT
Organization: Network Analysis Ltd


In article <1994May5.184300.25982@leeds.ac.uk> (comp.sys.mac.advocacy,comp.sys.mac.programmer), dn_crow@bean.open.ac.uk (dn_crow) writes:

> applications. In particular, the guidelines state that the clicks
> should *not* be sent to the application being clicked upon.

As with all guidelines, this is not meant to be slavishly adhered to.
It's up to the appl whether to accept the first click, and in the case
of the Finder what it does makes a lot of sense. Although the desktop
is a window in some sense, in a way it isn't. You have to select a piece
of paper (window) to write in it, but surely you don't expect to
"select" your desk to pick something up or put it down. (I'd also argue
that you should be able to "click through" to most appls, just like I can
scribble a note in the margin of a sheet of paper without having to move it
to the front, but that's another story.)

The Finder also does the same with folder windows. Does anyone remember
what it used to be like? When you wanted to drag a file from one folder
to another, you clicked on the src icon which would bring its window to
the front. This would sometimes cover up the window you wanted to drag
to, so you'd have to go back and move it out from underneath (then move
it back after the drag if you're obsessively tidy like me :-). The way
it does it now is MUCH better, and I'm pleased to see that the Drag Mgr
supports this way of working. If the guidelines say that you can't do
this, then the guidelines should be changed.


Sak Wathanasin
Network Analysis Limited
178 Wainbody Ave South, Coventry CV3 6BX, UK

Internet: sw@network-analysis-ltd.co.uk 
uucp:     ...!uknet!nan!sw                       AppleLink: NAN.LTD
Phone: (+44) 203 419996 Mobile:(+44) 850 587411  Fax: (+44) 203 690690

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

>From Willie Abrams <willie-abrams@uokhsc.edu>
Date: 5 May 1994 15:02:28 GMT
Organization: OU Health Sciences Center

In article <quinn-050594100313@eriodon.cs.uwa.oz.au> Quinn,
quinn@cs.uwa.edu.au writes:
>Basically AOCE's HI is severely broken in a lot of places.  Unfortunately

AOCE is real screwed up as far as HIG goes. If we are going to
flame its flaws, here are my complaints:

The standard mailer is a specific size, which means if you
make the window smaller, it cuts off the damn mailer, and
if you make the window bigger, you can't take advantage
of the extra space to the right of the mailer.

The way the mailer is shaped, You can only see about three
enclosures...

AppleMail has a real sluggish event loop. I know this isn't
necessarily a HIG flaw, but it is a real UI flaw. I end up
reading mail in ClarisWorks, since it responds to my stimulus
faster.

PowerShare admin stuff is just plain ugly. Chicago and Geneva
are the System and Application typefaces for a reason - they
are readable on screen. This Palatino stuff, with fixed sixed
panes are a real pain. At least with AppleShare, you had nice
resizeable and movable lists that allowed you to manage it.
(although it didn't remember window positions...ugh!)

I can move the keys off the desktop, but I can't move the
catalogs (I guess I can sort of see that) - QuickDraw GX
suffers there too, with all of those desktop printers...a
real pain in the butt for those of use who move frequently
from enviroment to enviroment with the same system.

Another UI problem - Symantec/Think C - I can't open a source
file without opening a project. Great! Modal Functionality...
Probably why I like Metrowerks...

Is there a forum where people can talk and discuss about
UI issues? Would that be a thread that should be here in csmp?

I think we have a real opportunity to jolt some people back
into thinking about how software is used. There are real
usability issues that are not related to functionality that
need to be addressed.

We as programmers need to address these head on, as we implement
the great (or horrid) user interfaces.

I will stop now. I am getting incensed.

Willie Abrams         	   
Telemedicine Software Guy  Internet:  willie-abrams@uokhsc.edu
OU Health Sciences Center  AppleLink: Willie

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

>From John Hamilton Slye <jsbr+@andrew.cmu.edu>
Date: Fri,  6 May 1994 12:55:38 -0400
Organization: Junior, Electrical and Computer Engineering, Carnegie Mellon, Pittsburgh, PA

On 06-May-94 in Re: Apple's blatant disrega..
user Joseph Manuel Finete@cat writes:
>Also, hitting the TAB key will let you cycle through the dialog items.
>So if the file list is selected, hit TAB and then the EditText field
>will be selected. My problem is that its not obvious enough that the
>file list is selected or that the Edit Text field is not selected,
>although, I really don't have a good idea on how to alleviate this.

When the test field is not selected, the caret isn't in it anymore...and
when the file list is selected, there is an outline box around it...


O------------------O---------------------O----------------------------------O
|                  | jsbr@andrew.cmu.edu | "I know that there are people in |
| J. Hamilton Slye |                     | the world who do not love their  |
|                  |   ham@ece.cmu.edu   | fellow human beings...and I HATE |
O------------------O---------------------O people like that!"               |
|          1071 Morewood Ave.            |              - Tom Lehrer        |
|         Pittsburgh, Pa. 15213          O----------------------------------O
|            (412) 862-3739              |       THIS SPACE FOR RENT!       |
O----------------------------------------O----------------------------------O

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

>From Robert Hess <robert_hess@macweek.ziff.com>
Date: Fri, 6 May 1994 18:44:40 GMT
Organization: MacWEEK

In article <quinn-050594100313@eriodon.cs.uwa.oz.au> Quinn, quinn@cs.uwa.edu.au writes:
>Other (more obvious) problems become apparent when you install PowerTalk. 

Oh, I have an even better one...

A letter sits in the In Tray. I drag it out of the In Tray into a folder. Have I
moved the letter? No, I've copied it.

The copied letter and the letter remaining in the In Tray, appear to be identical
(same icon, same name). In one window I can see the sender date sent, etc. In
another window I see size, date modified, etc. Can I modify the name of something
in the In Tray? No. How about in a folder? Yes. Can I move something from a
folder back into the In Tray? No.

I love PowerTalk but it imposes a whole set of new (i.e. inconsistent) rules on
new users and, like you said, makes the Finder seem awkward.

========================================================================
Robert Hess, WEEKgeek                      robert_hess@macweek.ziff.com
MacWEEK                                    AppleLink: WNDZSX
301 Howard                                 CompuServe: 72511,333
San Francisco, Calif. 94105                America Online: MacWEEK
(415) 243-3576 days                        MCI: RHESS
(415) 243-3651 fax
(415) 647-5549 nights                      I speak for myself.
now doesn't that make you feel better?     And sometimes not even that.
========================================================================

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

>From Robert Hess <robert_hess@macweek.ziff.com>
Date: Fri, 6 May 1994 18:46:25 GMT
Organization: MacWEEK

In article <quinn-050594100313@eriodon.cs.uwa.oz.au> Quinn, quinn@cs.uwa.edu.au writes:
>1) Open your catalogue.
>2) Find a user record (either in your Personal Catalogue or in a
>PowerShare catalogue) and drag it to the catalogue window.
>3) See Finder highlight catalogue window.
>4) Let go.
>5) Read dialog telling you that you can't do it because you don't have
>privileges.

Or, better yet, drag a user record into the "mount points" list of the File
Sharing Monitor. It hightlights, indicating it is willing to accept a drag. Why
on Earth would it do that? (Or, for that matter, why would someone try to do
this? But that's not the point. ;)

========================================================================
Robert Hess, WEEKgeek                      robert_hess@macweek.ziff.com
MacWEEK                                    AppleLink: WNDZSX
301 Howard                                 CompuServe: 72511,333
San Francisco, Calif. 94105                America Online: MacWEEK
(415) 243-3576 days                        MCI: RHESS
(415) 243-3651 fax
(415) 647-5549 nights                      I speak for myself.
now doesn't that make you feel better?     And sometimes not even that.
========================================================================

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

>From pcastine@jake.prz.tu-berlin.de (Peter Castine)
Date: Fri, 6 May 1994 19:43:02 GMT
Organization: PRZ TU-Berlin

Willie Abrams <willie-abrams@uokhsc.edu> writes:
>
>Is there a forum where people can talk and discuss about
>UI issues? Would that be a thread that should be here in csmp?
>

How about comp.human-factors? That might have been a more appropriate
place to follow-up.

-- 
Peter Castine                      | Da sprach Jesus zu ihm: Stecke dein
pcastine@prz.tu-berlin.de          | Schwerdt an seinen Ort; denn wer das
- ---------------------------------| Schwerdt nimmt, der soll durchs
     ``Have Mac, will travel''     | Schwerdt umkommen. (Matthai 26:52)

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

>From pcastine@jake.prz.tu-berlin.de (Peter Castine)
Date: Fri, 6 May 1994 20:03:56 GMT
Organization: PRZ TU-Berlin

Joseph Manuel Finete@cat writes:
>>Also, hitting the TAB key will let you cycle through the dialog items.
>>So if the file list is selected, hit TAB and then the EditText field
>>will be selected. My problem is that its not obvious enough that the
>>file list is selected or that the Edit Text field is not selected,
>>although, I really don't have a good idea on how to alleviate this.

John Hamilton Slye <jsbr+@andrew.cmu.edu> responded:
>
>When the test field is not selected, the caret isn't in it anymore...and
>when the file list is selected, there is an outline box around it...

I think Joseph may have been aware of this behavior. It is, however, a
bit on the subtle side. It becomes more obvious when the EditText
field is entirely selected, because it highlights/unhighlights when
you tab in and out of it.
-- 
Peter Castine                      | Da sprach Jesus zu ihm: Stecke dein
pcastine@prz.tu-berlin.de          | Schwerdt an seinen Ort; denn wer das
- ---------------------------------| Schwerdt nimmt, der soll durchs
     ``Have Mac, will travel''     | Schwerdt umkommen. (Matthai 26:52)

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

>From jaeger@kunikpok.icus.com (Jaeger)
Date: Fri, 06 May 94 13:20:30 CDT
Organization: Kunikpok Kennels and Komputers (Pet Project)

Here's a blatantly diregarded interface guidline.  When formatting 
floppies there is no progress indicator.  Anything that takes as long as 
formatting a floppy should have a progress bar.

Brian  Stern  :-{)}
Jaeger@fquest.com

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

>From mikec@mv.mv.com (Mike Callaghan)
Date: Fri, 6 May 1994 21:51:04 GMT
Organization: MV Communications, Inc.

In article <1994May5.184300.25982@leeds.ac.uk>,
dn_crow <dn_crow@bean.open.ac.uk> wrote:
>However, the Finder disregards this: try loading an application and
>bringing it to the front, while still being able to see a finder window
>behind it. If you now click over a visible finder icon, the appropriate
>Finder window is brought to the front (correct) but the icon is
>selected (incorrect).

If I'm not mistaken, this is simple to correct with ResEdit by changing
the Finder's SIZE resource (Get Front Clicks, I believe). Personally, I
like it, and wish more programs did it.

MikeC
-- 
Michael D. Callaghan                             Nashua, New Hampshire
- --------------------------------------------------------------------
RULE: "(sqrt(-1)) before (2.71828), except after (186,000 miles/sec)."
            [THE DANGERS OF MIXING GRAMMAR AND SCIENCE]

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

>From scgkr@mucc.mahidol.ac.th (Graham Keith Rogers - SCLG)
Date: 7 May 1994 02:06:49 GMT
Organization: Mahidol University, Thailand.

Paul Ferguson (pferguson@kaleida.com) wrote:
: select a field, the big-small display modes, flashing the Apple
: menu forever when the alarm goes off (how many people at some
: point in their life were mystified to see a flashing alarm clock
: where the Apple menu is?)  It's hard to find anything about the

Is *that* what that is.  Jeez, how do I turn it off?  Please....

Graham

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

>From d88-jwa@dront.nada.kth.se (Jon Wätte)
Date: 7 May 1994 09:03:08 GMT
Organization: The Royal Institute of Technology

In <CpE9EG.5Ep@zcias2.ziff.com> Robert Hess <robert_hess@macweek.ziff.com> writes:

>A letter sits in the In Tray. I drag it out of the In Tray into a folder. Have I
>moved the letter? No, I've copied it.

Of course! It's the same thing as "a file is sitting on a floppy
disk, and I drag it to a folder on my hard disk."

However, QuickDraw GX desktop printers are another thing:

A file sits in the printer queue, and I drag it to the desktop.
It is MOVED there.
I then drag it to the printer again, and it is COPIED into the
printer.
It makes sense, of course, since moving it to the printer would
delete it once it was printed, but it's still eerie.

-- 
 -- Jon W{tte, h+@nada.kth.se, Mac Hacker Deluxe (on a Swedish scale) --
  "Anyone who tries to make a distinction between education and
   entertainment doesn't know the first thing about either"
                     -- Trip Hawkins

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

>From tzs@u.washington.edu (Tim Smith)
Date: 7 May 1994 09:46:06 GMT
Organization: University of Washington School of Law, Class of '95

Quinn "The Eskimo!" <quinn@cs.uwa.edu.au> wrote:
>>In the thingy that is used to select a color (get it by selecting "other..."
>>for your highlight color in the Colors control panel, or double clicking
>>on a palette entry in the pattern editor in the General control panel),
>>they use a scroll bar to set brightness.  I think this violates something
>>in the User Interface Guidelines.
>
>Actually it violates the letter, *but not IMHO the spirit*, of the
>guideline that states that you should only put settings, as opposed to
>commands, in a popup menu.

I was thinking of page 215, where it says that scroll bars are *only* to
be used to manipulate the relative position in a document or list.  They
explicitly say that scroll bars are not to be used where sliders should
be used.  Thus, the color selector is a blatant violation.

--Tim Smith

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

>From hall_j@sat.mot.com (Joseph Hall)
Date: Fri, 6 May 1994 17:11:28 GMT
Organization: Motorola Inc., Satellite Communications

Seems it was dn_crow@bean.open.ac.uk (dn_crow) who said:
>An example that has always rather amused me is the one about switching
>between applications. The guidlines state that if I click outside any
>window belonging to my application, this action should switch me to the
>application whose window I have clicked over (e.g. the Finder). The
>only action of this click, or indeed double-click, should be to switch
>applications. In particular, the guidelines state that the clicks
>should *not* be sent to the application being clicked upon.

Is this correct?  There is one of the finder flags (the application
bits you can change with ResEdit) that can be set so that the click 
will be delivered to the application after it is brought to the front.  
I have found this a very appropriate behavior in the case of apps like 
THINK Reference.  You click on the "thinker" icon in the background, and
wham, there's THINK Reference for you.

-- 
Joseph Nathan Hall | Joseph's Law of Interface Design: Never give your users
Software Architect | a choice between the easy way and the right way.
Gorca Systems Inc. |                 joseph@joebloe.maple-shade.nj.us (home)
(on assignment)    | (602) 732-2549 (work)  Joseph_Hall-SC052C@email.mot.com

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

>From derek@netcom.com (Derek LeLash)
Date: Sat, 7 May 1994 18:07:00 GMT
Organization: Corner of Walk & Don't Walk

In article <johan.solve-060594152443@js_mac.hh.se> johan.solve@itn.hh.se (Johan Solve) writes:
>
>Metaphors that needs to be explained (as the trashcan in the remove-disk
>case) are not good metaphors. Picture a new user who has never seen a Mac
>before. He inserts a disk and wants to get it out again. I don't think he
>even dare to think of dragging it to the trash. There has to be a Mac guru
>around to explain to him that "in this special case, nothing gets deleted.
>But the disk will disappear from the desktop (and reappear on the real life
>desktop...)"
>
>Not good. 

No.  The user selects the disk icon and chooses "Put Away" from the File menu.
Anything else is an optional short cut.  Does the fact that *everyone* drags
disks to the Trash *regardless* of how "pure" the metaphor is tell you anything
about how the Finder was designed to give users multiple ways to perform an
action, so that they can pick the one they want?  I guarantee you that five
minutes after someone learns that you *can* (not *must*) eject a disk by
throwing it in the trash, that will be the only method they ever use.  Who
cares if the metaphor is perfect?

Derek
-- 
Derek LeLash, SrTechWriter/INFP | "Everyone lays off their Prozac for a week
BASYS Automation Systems, Inc.  |  before I come to town.  Nothing serious,
home: derek@netcom.com          |  just enough to get a little dip going."
work: derek@scooter.amc.dec.com |                            -- Shawn Colvin

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

>From de19@umail.umd.edu (Dana S Emery)
Date: Sat, 07 May 1994 15:54:44 -0500
Organization: Botany, UMCP

In article <2qb1lmINNh21@medicine.wustl.edu>, Thomas Reed
<reed@medicine.wustl.edu> wrote:

> >Dragging items onto a system folder that's not the one you booted with
> >doesn't put them in the right place, even if the icons in the folder
> >(e.g. apple menu items folder) show correctly.
> 
> Yes, I've often done this.  However, there's really only one way for the
> computer to know that a folder is the system folder without doing more
> stuff than it should have to do -- if it has the active system in it.

disagree, the Finder already knows if a viable system is inside, it has to 
in order to show the proper icon for a system folder. 

The rest is simply a matter of searching for tagged folders and directing 
the files, and I, as a user would expect that behaviour to be consistant 
for any folder showing the blessed system icon, no matter if it was in fact

the booted system.
--

Dana S Emery <de19@umail.umd.edu>

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

>From d88-jwa@dront.nada.kth.se (Jon Wätte)
Date: 8 May 1994 10:09:08 GMT
Organization: The Royal Institute of Technology

In <de19-070594155445@hjpatt-91.umd.edu> de19@umail.umd.edu (Dana S Emery) writes:

>disagree, the Finder already knows if a viable system is inside, it has to 
>in order to show the proper icon for a system folder. 

So far so good.

>The rest is simply a matter of searching for tagged folders and directing 
>the files, and I, as a user would expect that behaviour to be consistant 
>for any folder showing the blessed system icon, no matter if it was in fact
>the booted system.

Exactly how would the Swedish Finder know about the names of the
Hindu special folders?

Cheers,

					/ h+
-- 
 -- Jon W{tte, h+@nada.kth.se, Mac Hacker Deluxe (on a Swedish scale) --

   There's no sex act that can't be made better with Jell-O.

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

>From quinn@cs.uwa.edu.au (Quinn "The Eskimo!")
Date: Mon, 09 May 1994 10:34:31 +0800
Organization: Department of Computer Science, The University of Western Australia

In article <2qfo0u$7kn@news.u.washington.edu>, tzs@u.washington.edu (Tim
Smith) wrote:

>Quinn "The Eskimo!" <quinn@cs.uwa.edu.au> wrote:
>>Someone else wrote:
>>>In the thingy that is used to select a color (get it by selecting "other..."
>>>for your highlight color in the Colors control panel, or double clicking
>>>on a palette entry in the pattern editor in the General control panel),
>>>they use a scroll bar to set brightness.  I think this violates something
>>>in the User Interface Guidelines.
>>
>>Actually it violates the letter, *but not IMHO the spirit*, of the
>>guideline that states that you should only put settings, as opposed to
>>commands, in a popup menu.
>
>I was thinking of page 215, where it says that scroll bars are *only* to
>be used to manipulate the relative position in a document or list.

True enough.  [Whoops, forgot to *read* the post!]  I was talking about
the "Other..." on the popup menu, not the scroll bars for selecting
values.  The scroll bars are obviouly broken.

btw This "thingy" is called the Colour Picker.
-- 
Quinn "The Eskimo!"      <quinn@cs.uwa.edu.au>     "Support HAVOC!"
Department of Computer Science, The University of Western Australia
  Repeat 100 times... I will read the post before replying.

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

>From quinn@cs.uwa.edu.au (Quinn "The Eskimo!")
Date: Mon, 09 May 1994 10:56:32 +0800
Organization: Department of Computer Science, The University of Western Australia

In article <1994May5.194830.28693@prz.tu-berlin.de>,
pcastine@jake.prz.tu-berlin.de (Peter Castine) wrote:

>quinn@cs.uwa.edu.au (Quinn "The Eskimo!") writes:
>>pcastine@jake.prz.tu-berlin.de (that's me) wrote:
>>
>>>I think, however, you will be hard-pressed to find
>>>a violation in the Finder.
>>
>>OK, I've got a good one!  Why, when you drag a file into a folder where
>>there already exists a file of the same name, do you have the option of
>>replacing the original.  Why doesn't the Finder move it to the Trash??? 
>>OK, so maybe it's not a *real* HIG violation but it's really inconsistent
>
>Inconsistent with what?

Inconsistent with the fact that every other time you try to delete a file
in the Finder you have a chance to undo that action by dragging it out of
the Trash.

>>and consistency is one of the central precepts of the HIG.
>
>Consistency is, IMHO, a secondary concern. Smith et.al. discuss the
>practical issues of maintaining consistency in real world applications
>in their 1982 article "Designing the Star user interface." (Originally
>printed in Byte 7(4), reprinted in Baecker & Buxton's _Readings in 
>Human-Computer Interaction_, the paper is a must-read). Short
>precis: consistency is the hobgoblin of small minds.

No, *mindless* adherence to consistency is the hobgoblin of small minds.

Actually I'd like to know where you precis comes from because my copy of
Smitch et al says...

%Everyone agrees that consistency is an admirable goal.  However, it
%is perhaps the single hardest characterist of all to achieve in a
%a computer system.  In fact, in systems of even moderate complexity,
%consistency may not be well defined.

The fact that seemingly inconsistent behaviour may be good for the user
(eg their classic drog document on printer example, also dragging floppies
to the Trash) doesn't imply that you shouldn't evaluate your behaviour in
terms of the consistent environment you're creating.  Besides the
behaviour I advocate (moving replaced files to the Trash) is simply better
than the alternative (deleting them).  Are you arguing otherwise?

If so then you're arguing directly with the HIG, which advocate
"Forgiveness" (p10) and says...

#You can encourage people to explore your application by building in
#forgiveness.  Forgiveness means that actions on the computer are
#generally reversible.  People need to feel that they can try things
#without damaging the system; /create safety nets/ for people so that
#they feel comfortable learning and using your product. [my italics]

>>Question #1 Why does it highlight the window (in both cases)?
>
>For performance reasons? (Checking privileges might slow down
>feedback, direct manipulation. I'm obviously guessing on this one).

Personally I think that's crap -- but I don't know enough about AOCE
programming to prove it (:

>>Question #2 Why does it have different behaviour when it finally realises
>>            that it's failed?
>
>What's it supposed to do? Not tell you that it failed? Disregard
>privileges?

Yeah, but why *2* different behaviours?

>>Basically AOCE's HI is severely broken in a lot of places.  
>
>Severely? Well, I'll let that pass before a flame war breaks out.

Well I've got some support out there; see the comments by Willie Abrams
<willie-abrams@uokhsc.edu>.
-- 
Quinn "The Eskimo!"      <quinn@cs.uwa.edu.au>     "Support HAVOC!"
Department of Computer Science, The University of Western Australia

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

>From howden@munta.cs.mu.OZ.AU (Nicholas James HOWDEN)
Date: Mon, 9 May 1994 04:16:44 GMT
Organization: Computer Science, University of Melbourne, Australia

Paul Ferguson <pferguson@kaleida.com> writes:

>In article <16674@lhdsy1.lahabra.chevron.com> John V. Blzka,
>jjvbl@lhdsy1.lahabra.chevron.com writes:
>> Does Apple violate it's own Guidelines in any of it's System 7  
>> software?

>One classic example that comes to mind is the Alarm Clock, which
>suffers from a bunch of violations:  non-standard controls,
	...
>point in their life were mystified to see a flashing alarm clock
>where the Apple menu is?)  It's hard to find anything about the
>alarm clock that doesn't violate the HIG.

Another good one is when someone sets the alarm clock, but then removes the
item from the apple menu after it goes off. You then have a flashing alarm
clock in the apple menu with no way to turn it off (this certainly sounds
like a Micro$oft 'feature' to me ;-)

Nick.
-- 

- -----------------------------------------------------------------------------
********   I F   Y O U   Q U I T ,   Y O U ' L L   N E V E R   W I N   ********
- -----------------------------------------------------------------------------

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

>From tzs@u.washington.edu (Tim Smith)
Date: 9 May 1994 07:49:53 GMT
Organization: University of Washington School of Law, Class of '95

Thomas Reed  <reed@medicine.wustl.edu> wrote:
>>Dragging items onto a system folder that's not the one you booted with
>>doesn't put them in the right place, even if the icons in the folder
>>(e.g. apple menu items folder) show correctly.
>
>Yes, I've often done this.  However, there's really only one way for the
>computer to know that a folder is the system folder without doing more
>stuff than it should have to do -- if it has the active system in it.  If
>every time you dropped something in a folder, the system had to search
>that folder for a copy of the Finder, then all your moves would take a
>little longer.  Not only that, but it wouldn't be reliable -- sometimes I

It would only have to do this when you dropped an extension, control panel,
or other magic file into a folder.  For most dropping, it doesn't matter
if the destination is a System Folder, so it would not have to do more
work in the vast majority of cases.

--Tim Smith

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

>From dn_crow@bean.open.ac.uk (dn_crow)
Date: Mon, 9 May 1994 08:43:17 GMT
Organization: (none)

In article <jmiller-080594123607@fastlane.com>
jmiller@connected.com (James Miller) writes:

> In article <1994May5.184300.25982@leeds.ac.uk>, dn_crow@bean.open.ac.uk
> (dn_crow) wrote:
> 
> > However, the Finder disregards this: try loading an application and
> > bringing it to the front, while still being able to see a finder window
> > behind it. If you now click over a visible finder icon, the appropriate
> > Finder window is brought to the front (correct) but the icon is
> > selected (incorrect).
> 
> The Finder is not really an application in Apple's eyes, it is the user
> interface to the system.  The reason an icon will stay selected when
> another window is brought to the front, is to allow it to more easily copy
> files from one window to another.

I'm not arguing that Apple is *wrong* to make the Finder work this way:
personally, I would like all applications to work like this as I find
it very useful. OTOH, I can also see why you don't want to do this:
there are some applications where I need to see the whole window before
deciding where I click on it, and having to click on the window border
to bring it to the front would be a pain. Sigh. An insoluable problem,
probably.

However right Apple may be in their decision, they are still
inconsitent with their own HIGs (which apply to the User Interface of
the whole system: Finder and applications alike).

Dan


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

>From leblonk@netcom.com (Marcel Blonk)
Date: Mon, 9 May 1994 09:51:40 GMT
Organization: NETCOM On-line Communication Services (408 241-9760 guest)

Maybe this should come under the header of "Apple's blatant disregard for 
User Opinions"

In this thread there have been many complaints about the AOCE UI. Not at 
all unwaranted IMO. My $.02 on this: before AOCE was released, it was 
shown a couple of times on the WWDC. I, and many others that I've talked 
to, always found that the interface needed *major* changes (desktop 
clutter/finderlookalikebutnotthesameafterall type things). These concerns 
were often voiced, in the different AOCE forums and workgroups. To apple 
in general and to the development team in particular. Yet, it was released 
with all the same UI problems that people (in this case, developers 
mostly) complained about.

What up with that????

To me it seems that Apple has entered a stage, in which the big company 
mentality is slowly creeping in, in which each little department has it's 
own little territory to defend and defend it they shall, against every one 
who'd dare challenge them on their terrain (just one example: how come 
something like AppendDITL is part of the comm toolbox! It's a generic 
routine, that has NOTHING to do with communications. If the CTB group 
wanted this routine to be added, it should have been added in a generic 
place, NOT the CTB toolbox. What if the already poorly supported CTB 
becomes extinct or replaced by something better? Would the system still 
have to support CTB just for the xxxDITL routines (which probably are 
being used by programs that have nothing to do with the CTB, since they 
are documented as dialog manager extensions)). We see it all the time, 
different systems extensions are released, and each uses its own ( 
different) interface philosophy. There is no consistancy between them 
anymore.

In several workgroup discussions at the WWDC, I found that the teams 
showed a certain resistance to remarks coming from the developers like: 
"wouldn't it be better to combine/make consistant/integrate x with y" 
where x was developed by a different group than y (again, the AOCE group 
showed this quite distinctively).

Is this the end of the Apple we once knew and loved? Is Apple after all, 
just another company grown big, rigid and more guided by internal politics 
than by the drive for a better product? I don't know, but that is what I 
fear is happening.

Oops, guess I dropped a few cents more then I was planning to.

mb

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

>From resnick@cogsci.uiuc.edu (Pete Resnick)
Date: Mon, 09 May 1994 11:15:33 -0500
Organization: University of Illinois at Urbana-Champaign

In article <u9119523-040594132452@case4.sys.uea.ac.uk>,
u9119523@sys.uea.ac.uk (Graham Cox) wrote:

>Here's a trivial example- not in the system but in most graphics programs,
>including MacDraw and ClarisWorks- the guidelines say that the cursor keys
>should never be used to position graphic elements, but most programs do
>this.

That's simply false. From the Macintosh Human Interface Guidlines, chapter 10:

    In a graphics application, the arrow keys can be used for fine movement of
    selected objects, particularly since graphics applications typically have
    no insertion point. If a graphics application uses arrow keys, it should
    be only to move the selected object by the smallest possible increment
    (one pixel or one grid unit). For example, the user could select an object
    and use the arrow keys to move one pixel per keystroke in the direction of
    the arrow key pressed.

pr
-- 
Pete Resnick    	(...so what is a mojo, and why would one be rising?)
Graduate assistant - Philosophy Department, Gregory Hall, UIUC
System manager - Cognitive Science Group, Beckman Institute, UIUC
Internet: resnick@cogsci.uiuc.edu

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

>From resnick@cogsci.uiuc.edu (Pete Resnick)
Date: Mon, 09 May 1994 11:23:16 -0500
Organization: University of Illinois at Urbana-Champaign

In article <2qido4$8c4@news.kth.se>, d88-jwa@dront.nada.kth.se (Jon Wätte)
wrote:

>In <de19-070594155445@hjpatt-91.umd.edu> de19@umail.umd.edu (Dana S
Emery) writes:
>
>>disagree, the Finder already knows if a viable system is inside, it has to 
>>in order to show the proper icon for a system folder. 
>
>So far so good.
>
>>The rest is simply a matter of searching for tagged folders and directing 
>>the files, and I, as a user would expect that behaviour to be consistant 
>>for any folder showing the blessed system icon, no matter if it was in fact
>>the booted system.
>
>Exactly how would the Swedish Finder know about the names of the
>Hindu special folders?

The same way it knows what the names of the Swedish special folders are:

    GetResource('fld#', 0);

pr
-- 
Pete Resnick    	(...so what is a mojo, and why would one be rising?)
Graduate assistant - Philosophy Department, Gregory Hall, UIUC
System manager - Cognitive Science Group, Beckman Institute, UIUC
Internet: resnick@cogsci.uiuc.edu

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

>From jfw@ksr.com (John F. Woods)
Date: 9 May 1994 20:36:43 GMT
Organization: Kendall Square Research

johan.solve@itn.hh.se (Johan Solve) writes:
>etaphors that needs to be explained (as the trashcan in the remove-disk
<case) are not good metaphors. Picture a new user who has never seen a Mac
>before. He inserts a disk and wants to get it out again. I don't think he
<even dare to think of dragging it to the trash. There has to be a Mac guru
>around to explain to him that "in this special case, nothing gets deleted.
<But the disk will disappear from the desktop (and reappear on the real life
>desktop...)"

Let's remember how this came about.  Originally you ejected disks by selecting
Eject from the menu (or typing command-E); this left a ghost image that had
to be thrown away.  A lot of people asked for a short cut, and the obvious one
was the one chosen.  Of course, if you don't KNOW what it's a shortcut for,
it does seem to mean something else.

On the other hand, if you had an Ejector on the desktop, what would it mean to
drag an ordinary file onto it?

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

>From maynard@elwing.otago.ac.nz (Maynard James Handley)
Date: Mon, 9 May 1994 22:49:13 GMT
Organization: University of Otago

Tim Smith (tzs@u.washington.edu) wrote:
> Quinn "The Eskimo!" <quinn@cs.uwa.edu.au> wrote:
> >>In the thingy that is used to select a color (get it by selecting "other..."
> >>for your highlight color in the Colors control panel, or double clicking
> >>on a palette entry in the pattern editor in the General control panel),
> >>they use a scroll bar to set brightness.  I think this violates something
> >>in the User Interface Guidelines.
> >
> >Actually it violates the letter, *but not IMHO the spirit*, of the
> >guideline that states that you should only put settings, as opposed to
> >commands, in a popup menu.

> I was thinking of page 215, where it says that scroll bars are *only* to
> be used to manipulate the relative position in a document or list.  They
> explicitly say that scroll bars are not to be used where sliders should
> be used.  Thus, the color selector is a blatant violation.

> --Tim Smith

I just want to add two point.
Firstly, this use of a scroll bar to select the color may seem a minor matter,
but I have found it really irritating over and over. It should be fixed by 
Apple even if it seems silly.
Secondly, Apple have been really dumb by not releasing the slider CDEF inti
the system, like they did with the PopupMenu CDEF. If they added this to the
system so that programmers could trivially access and use it, problems like 
this would go away.

Maynard Handley

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

>From quinn@cs.uwa.edu.au (Quinn "The Eskimo!")
Date: Tue, 10 May 1994 11:23:03 +0800
Organization: Department of Computer Science, The University of Western Australia

In article <leblonkCpJ4q4.Dou@netcom.com>, leblonk@netcom.com (Marcel
Blonk) wrote:

>Is this the end of the Apple we once knew and loved? Is Apple after all, 
>just another company grown big, rigid and more guided by internal politics 
>than by the drive for a better product?

I thought "guided by internal politics" *was* the Apple we once knew and
loved (:
-- 
Quinn "The Eskimo!"      <quinn@cs.uwa.edu.au>     "Support HAVOC!"
Department of Computer Science, The University of Western Australia

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

>From rmah@panix.com (Robert S. Mah)
Date: Tue, 10 May 1994 01:48:31 -0500
Organization: One Step Beyond

maynard@elwing.otago.ac.nz (Maynard James Handley) wrote:

> Secondly, Apple have been really dumb by not releasing the slider CDEF 
> into the system, like they did with the PopupMenu CDEF. If they added
> this to the system so that programmers could trivially access and use
> it, problems like this would go away.

Agreed.  Also why were the little up/down arrow thingies never rolled into
the system?  I guess we'll never know...

Also, I never did quite understand why both push buttons, radio buttons,
check boxes and scroll bars were all rolled into one CDEF.  If _I_ were 
designing things, I would have put buttons into 1, radio buttons and check
boxes in another and scroll bars in a third.  Good thing they didn't let
me do this :-).

Cheers,
Rob
___________________________________________________________________________
Robert S. Mah  -=-  One Step Beyond  -=-  212-947-6507  -=-  rmah@panix.com

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

>From deguzman@binkley.math.uiuc.edu (Alan DeGuzman)
Date: 10 May 1994 07:21:34 GMT
Organization: Calculus&Mathematica at UIUC

jfw@ksr.com (John F. Woods) writes:

[snip]

>On the other hand, if you had an Ejector on the desktop, what would it mean to
>drag an ordinary file onto it?

Nothing. If this Ejector was written only to eject volumes, the Ejector's
icon would not darken if a file was dragged onto it.
--
Alan A. DeGuzman                  "The problem with the future is that it
Calculus&Mathematica               keeps turning into the present."
DISCLAIMER: "The University 
can't afford my opinions."                     - Calvin to Hobbes

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

>From Greg_Marriott@genmagic.com (Greg Marriott)
Date: Tue, 10 May 1994 09:09:44 -0800
Organization: General Magic, Inc.

rmah@panix.com (Robert S. Mah) wrote:

> Also, I never did quite understand why both push buttons, radio buttons,
> check boxes and scroll bars were all rolled into one CDEF.

They weren't.  Buttons are in one CDEF and the scrollbar is in another.

> I would have put buttons into 1, radio buttons and check
> boxes in another and scroll bars in a third.

Separating the buttons would have been a good idea, but it's not so bad the
way it is since there's a bunch of common code that is shared.

-- 
Greg Marriott
Just Some Guy
General Magic, Inc.

Disclaimer: My opinions are not necessarily the same as General Magic's.
            (can a company even HAVE an opinion?)

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

>From Jens Alfke <jens_alfke@powertalk.apple.com>
Date: Tue, 10 May 1994 17:47:24 GMT
Organization: Apple Computer

Thomas Reed, reed@medicine.wustl.edu writes:
> Yes, it's true that there has to be "something to be gotten", but I think
> most applications these days, background or not, call WaitNextEvent, so
> they can control directly how much time they get by giving different
> numbers for the sleep value.

Yes, but if the front app is calling WNE with a very small sleep time -- like
zero -- then there will be much less time for bg apps to run unless they do
something evil like running for several seconds at a time without calling WNE.
  The foreground app should always use a sleep time of infinity unless it
needs to be doing something periodically like blink an i-beam or check for
modifier key changes, and even then it should sleep at least 15 ticks or so
at a time (depending on GetCaretTime, of course.)

That said, does the Finder really call WNE with a zero sleep time? I'd be
surprised if it did.

--Jens Alfke
  jens_alfke@powertalk              Rebel girl, rebel girl,
            .apple.com              Rebel girl you are the queen of my world

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

>From Jens Alfke <jens_alfke@powertalk.apple.com>
Date: Tue, 10 May 1994 18:17:22 GMT
Organization: Apple Computer

Paul Ferguson, pferguson@kaleida.com writes:
> On the other hand, what the
> slider is doing is changing the brightness from 0-65535, which
> is exactly what the example shown on that page says is an incorrect
> use of a scroll bar.

That's the old color picker. If you install ColorSync you get the New &
Improved, All Singing All Dancing color picker, which is much, much nicer and
features sliders instead of scrollbars.

--Jens Alfke
  jens_alfke@powertalk              Rebel girl, rebel girl,
            .apple.com              Rebel girl you are the queen of my world

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

>From platypus@cirrus.som.cwru.edu (Gary Kacmarcik)
Date: 10 May 1994 22:11:36 GMT
Organization: Case Western Reserve University, Cleveland, Ohio (USA)


In article <rmah-100594014831@rmah.dialup.access.net> rmah@panix.com (Robert S. Mah) writes:
> Also, I never did quite understand why both push buttons, radio buttons,
> check boxes and scroll bars were all rolled into one CDEF.  If _I_ were 
> designing things, I would have put buttons into 1, radio buttons and check
> boxes in another and scroll bars in a third.  Good thing they didn't let
> me do this :-).

push buttons, check boxes and radio buttons are in one CDEF (CDEF 0, with
variation codes of 0, 1 and 2, respectively)

scrollbars are in a separate CDEF (CDEF 1)

-gary j kacmarcik
platypus@cirrus.som.cwru.edu


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

>From rmah@panix.com (Robert S. Mah)
Date: Tue, 10 May 1994 19:10:18 -0500
Organization: One Step Beyond

Greg_Marriott@genmagic.com (Greg Marriott) wrote:

> rmah@panix.com (Robert S. Mah) wrote:
> 
> > Also, I never did quite understand why both push buttons, radio buttons,
> > check boxes and scroll bars were all rolled into one CDEF.
> 
> They weren't.  Buttons are in one CDEF and the scrollbar is in another.

Woops!  You are quite right.  I don't know why I thought that until you
pointed out the error of my ways...


> > I would have put buttons into 1, radio buttons and check
> > boxes in another and scroll bars in a third.
> 
> Separating the buttons would have been a good idea, but it's not so bad 
> the way it is since there's a bunch of common code that is shared.

Yes, I understand that many compromises had to be made to fit the original 
Mac OS into a scant 64K of ROM and 128K of RAM.  That they did it was a 
marvel.

Cheers,
Rob
___________________________________________________________________________
Robert S. Mah  -=-  One Step Beyond  -=-  212-947-6507  -=-  rmah@panix.com

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

>From DACRXL01.OURX124@tcp30.dx.deere.com (Juan Ingles)
Date: Wed, 11 May 1994 15:28:57 GMT
Organization: Proteus Ventures, Inc.

In article <2qkpv1$e9o@news.u.washington.edu>
tzs@u.washington.edu (Tim Smith) writes:

> It would only have to do this when you dropped an extension, control panel,
> or other magic file into a folder.  For most dropping, it doesn't matter
> if the destination is a System Folder, so it would not have to do more
> work in the vast majority of cases.
> 
> --Tim Smith

Yes it would: It would have to check every single file to see if it was
an extension, control panel, or other magic file.

Juan Ingles
<DACRXL01.OURX124@tcp30.dx.deere.com>
--
Proteus Ventures, Inc. - Computer Software Consulting and Development
    1514 Oriole Ave * Waterloo, IA 50701 * (319) 232-0985

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

>From mbishop@pliny.ccs.itd.umich.edu (Michael J. Bishop)
Date: 11 May 1994 18:00:02 GMT
Organization: University of Michigan

John F. Woods (jfw@ksr.com) wrote:

: johan.solve@itn.hh.se (Johan Solve) writes:
: >etaphors that needs to be explained (as the trashcan in the remove-disk
: <case) are not good metaphors. Picture a new user who has never seen a Mac
: >before. He inserts a disk and wants to get it out again. I don't think he
: <even dare to think of dragging it to the trash. There has to be a Mac guru
: >around to explain to him that "in this special case, nothing gets deleted.
: <But the disk will disappear from the desktop (and reappear on the real life
: >desktop...)"

: Let's remember how this came about.  Originally you ejected disks by selecting
: Eject from the menu (or typing command-E); this left a ghost image that had
: to be thrown away.  A lot of people asked for a short cut, and the obvious one
: was the one chosen.  Of course, if you don't KNOW what it's a shortcut for,
: it does seem to mean something else.

: On the other hand, if you had an Ejector on the desktop, what would it mean to
: drag an ordinary file onto it?


Here's what I think Apple should do. Let me know if you think it is good 
or bad.

-- after I installed the Hardware system update on my powerbook, when I
hit the power button, it performed the same command as if I had selected
"Shut Down". It's the old "hardware/software integration" genius that
Apple is famous for. 

Why don't they do this for the disk drive? Why don't they make a button 
that when pushed performs the same command as if the user selected "Put 
Away" from the File menu?

People expect there to be an eject button like on a PC. Putting a button 
which triggers the software is the best compromise, I believe because it 
still allows Apple to do that cool hardware integration stuff but is 
still intuitive to the user.

I personally *hate* having to select Shut Down to turn of my mac so the 
Hardware update was genius and much needed IMO.

--
_____________________________________________________________________________
 Michael Bishop 	"The best way to predict the future is to invent it."
 mbishop@umich.edu						- Alan Kay

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

>From Ron_Hunsinger@bmug.org (Ron Hunsinger)
Date: Wed, 11 May 94 06:26:41 PST
Organization: Berkeley Macintosh Users Group

To: resnick@cogsci.uiuc.edu (Pete Resnick),UUCP

>In article <2qido4$8c4@news.kth.se>, d88-jwa@dront.nada.kth.se (Jon Wdtte)
>wrote:
>
>>Exactly how would the Swedish Finder know about the names of the
>>Hindu special folders?
>
>The same way it knows what the names of the Swedish special folders are:
>
>    GetResource('fld#', 0);
>

Wouldn't work.  This would only tell the Swedish Finder the names of the 
*Swedish* special folders.  Although...

If Apple was hard-pressed, I suppose the active Finder could look in
the boot blocks of the other System Folder's volume to get the name of
the other Finder, then open the other Finder's resource fork and get the 
folder names from it.  And do all this only if the destination folder 
matches the id of the blessed folder (available from vcbFndrInfo).  Might 
actually be doable in reasonable time, because you would only have to open 
the other Finder if you actually had files to disburse into special folders.

>pr
>-- 
>Pete Resnick    (...so what is a mojo, and why would one be rising?)

According to "The Official Scrabble Players Dictionary (Second Edition)":

    MOJO   n,  pl. -JOS or -JOES,  a magic charm.

I believe this is New Orleans slang, possibly of Cajun origin.

In any event, "Mr. Mojo Risin" is an anagram for "Jim Morrison".

Just so you'll know...
-Ron Hunsinger

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

>From ruhl@du.edu (ROBERT A. UHL )
Date: Wed, 11 May 1994 22:04:07 GMT
Organization: University of Denver

In article <2qarlc$e1n@vixen.cso.uiuc.edu> aad@uiuc.edu writes:
>alister@netcom.com (Rick Reynolds aka GreenGoo) writes:
>
>>>How 'bout dragging a disk to the trash to eject it?
>
>
>>I never really thought much about this issue but I think there should
>>have been a disk drive icon on the desktop, always visable but somehow
>>conveying to the user that a disk is inserted.
>
>Uh, what about the disk's icon? Granted, it can be hidden behind windows,
>but I'd rather have what *I* want to stay on top of the desktop layer
>rather than some floating icons or whatever.
>
>>When the user wants
>>to change disks they can press an "eject" button on the icon. But alas
>>that brings up the problem of having a control (which woule have to be
>>smaller then other controls) on a Finder icon.
>
>Now you're on to something. How about letting every icon that is a volume
>have a 'switch' or 'button' drawn on (or near) the icon that let's you
>eject the volume (eject in the sense of "Put Away"). It could even be dimmed
>out for volumes that can't be "Put Away", like the startup volume.
>--
>Alan A. DeGuzman

Here's another idea:
I've always thought that ejecting the disk should get rid of it; you
know, if it's out, I can put it in the box and forget about it. Also,
the 'Eject' button in the SF dialogs is not a true (IMO) eject;
nothing is more annoying to be flipping through floppies on the SF
dialog (which I do a lot) and, when you quit, finding a whole mess of
grey floppy icons.
So... I propose that 'Eject' take the place of the current 'Put Away',
and that the 'spit-out-the-disk-but-keep-it-mounted' action be
renamed. Not only would this be helpful in the above mentioned ways,
but command-E would truly eject the ?!*% disk.

-- 
- -------------------------------------------------------
| Bob Uhl | Spectre                  | Christos Anesti! |
| U of D  | Baron Robert von Raetzin | Alithos Anesti!  |
- -------------------------------------------------------

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

>From ldo@waikato.ac.nz (Lawrence D'Oliveiro, Waikato University)
Date: 12 May 94 17:14:12 +1200
Organization: University of Waikato, Hamilton, New Zealand

In article <2qido4$8c4@news.kth.se>, d88-jwa@dront.nada.kth.se (Jon Wätte) writes:
>
> Exactly how would the Swedish Finder know about the names of the
> Hindu special folders?

I guess the same way it would know about the Muslim special folders, or
the Christian special folders, or the Jewish ones, or the atheist ones. :-)

Lawrence
(born in a place long influenced by Indian culture)

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

>From pcastine@tubprz.prz.tu-berlin.de (Peter Castine)
Date: Thu, 12 May 1994 11:10:49 GMT
Organization: PRZ TU-Berlin

In article <Cpnryv.CsE@du.edu> ruhl@du.edu (ROBERT A. UHL ) writes:
>
>So... I propose that 'Eject' take the place of the current 'Put Away',
>and that the 'spit-out-the-disk-but-keep-it-mounted' action be
>renamed. Not only would this be helpful in the above mentioned ways,
>but command-E would truly eject the ?!*% disk.

No, no, no, no.

You need the 'spit-out-the-disk-but-keep-it-mounted' feature in order
to copy disks on Macs with only one floppy drive (which is surely
the vast majority of machines out there). 

There is NOTHING to be gained by renaming menu commands in 1994. There
are people out there who have been happily dragging disks to the
trash for over ten years. To quote Tog: "An imporant aspect of
consistency was defined by Smith et al. [1983] in this way: 'Consistency
asserts that mechanisms should be used in the same way wherever they
occur.' I would add, by inference, 'and _when_ever they occur':
first release or fifth release." (from "Consistency", in The Art
of Human-Computer Interface Design, Addison-Wesley 1990, Tog's emphasis.)

We now have in the current system:

1) A menu command (w/ command-key equivalent) for ejecting a disk.
2) A menu command (w/ command-key equivalent) for ejecting AND unmounting
   a disk.
3) A simple mouse gesture for ejecting AND unmounting a disk.

I honestly can *NOT* understand all this bitching about (3) above. If
you don't want to drag the disk to the trash, then DON'T DO IT. Hit
Command-Y and shut up. 

(BTW, despite my current .sig, this is one point where there is simply
nothing to be gained by negating the principle of consistency.)


-- 
Peter Castine                  | Con'sis'ten'cy (n., pl. -cies)
pcastine@prz.tu-berlin.de      | 1a) last refuge of the unimaginative
- -----------------------------| b) hobgoblin of little minds
   ``Have Mac, will travel''   | (Apologies to Webster, Emerson, & Wilde)

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

>From gjw2824@hertz.njit.edu (Greg Weston)
Date: 12 May 94 05:04:11 GMT
Organization: New Jersey Institute of Technology, Newark, New Jersey

In article <1994May5.172800.22102@bme.ri.ccf.org>,
Chuck Simciak <simciac@ccsmtp.ccf.org> wrote:
>I'm not sure if this counts as breaking an interface guideline but it is
>very annonying.  Say I go to save a file, the StandardPutFile dialog
>emerges and I have to navigate several folders to get to my desitination.
> The file name field has already been filled with a defualt.  Here's the
>catch.  Upon having navigated the multiple folders to place the file, the
>SAVE button is now an OPEN button.  I then have to click in the filename
>text field to cause the button to CHANGE to SAVE.  This "feature" was
>introduced in System 7 and has been a source of nuisance ever since.

I find it tedious, too. But it is a little easier (I find) to press
tab, which toggles between manipulating the list and the field, than
to grab the mouse and click. (Since in that situation, I've usually
had my hands on the keyboard up til then anyway.)
	Greg

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

>From gt7344b@prism.gatech.edu (MMMMM MMMMM)
Date: 12 May 1994 11:57:20 -0400
Organization: Georgia Institute of Technology

In article <1994May12.111049.29637@prz.tu-berlin.de> pcastine@tubprz.prz.tu-berlin.de (Peter Castine) writes:
>In article <Cpnryv.CsE@du.edu> ruhl@du.edu (ROBERT A. UHL ) writes:
>I honestly can *NOT* understand all this bitching about (3) above. If
>you don't want to drag the disk to the trash, then DON'T DO IT. Hit
>Command-Y and shut up. 
>

I think you're forgetting the original point of this thread.  Yes,
dragging a disk to the trash is quick, easy, and we all do it.  But it
does violate the Mac HIG.  

It's unintuitive.  And I'm willing to admit that I was terrified the first
time I tried dragging a floppy to the trash. 



-- 
  /////////\    /////////\    /////////\    /////////\    /////////\    
  \_____// /   //\____// /   //\____// /   //\____// /   //\____// /   
       ///////// /   ///////// /   ///////// /   ///////// /   /////////\
       \_______\/    \_______\/    \_______\/    \_______\/    \_______\/ 

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

>From mxmora@unix.sri.com (Matt Mora)
Date: 12 May 1994 08:54:10 -0700
Organization: SRI International, Menlo Park, CA

In article <1994May12.111049.29637@prz.tu-berlin.de> pcastine@tubprz.prz.tu-berlin.de (Peter Castine) writes:

>No, no, no, no.
>
>You need the 'spit-out-the-disk-but-keep-it-mounted' feature in order
>to copy disks on Macs with only one floppy drive (which is surely
>the vast majority of machines out there). 

nah, what we need to implement is Andy Herzfeld (sp?) velocity
feature. Pick up a disk icon with the mouse and throw it off the desktop
to eject it. :-) The disk icon would then glide across the desktop and when it
the icon was completly off the desktop, it would eject. Kind of like when
a disk falls off your desk. 

If you didn't throw it hard enough it would glide to a halt some where on 
your desktop.

Ejecting a disk should be fun!


Xavier

-- 
___________________________________________________________
Matthew Xavier Mora                       Matt_Mora@sri.com
SRI International                       mxmora@unix.sri.com
333 Ravenswood Ave                    Menlo Park, CA. 94025

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

>From sbb@panix.com (Steve Baumgarten)
Date: 12 May 94 12:51:39
Organization: PANIX Public Access Unix, NYC

In article <2qtjl0$ob9@acme.gatech.edu> gt7344b@prism.gatech.edu (MMMMM MMMMM) writes:

   I think you're forgetting the original point of this thread.  Yes,
   dragging a disk to the trash is quick, easy, and we all do it.  But
   it does violate the Mac HIG.

No it doesn't.  It's a shortcut you don't have to use.  Try selecting
"Put Away" from the menu; or select "Eject", and then with the disk in
your hand you should have no fear of dragging the dimmed icon to the
trash.

   It's unintuitive.  And I'm willing to admit that I was terrified
   the first time I tried dragging a floppy to the trash.

Should have tried using the menus first; that's what they're there
for. 

If it were the Mac's sole means of ejecting a floppy, then yes, I'd
agree that it's not intuitive.  But a menu choice labeled "Eject" is
pretty intuitive, you have to admit...

--
    Steve Baumgarten       |  "New York... when civilization falls apart,
    PANIX, New York, NY    |   remember, we were way ahead of you."
                           |  
    Email: sbb@panix.com   |                            - David Letterman

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

>From pcastine@tubprz.prz.tu-berlin.de (Peter Castine)
Date: Thu, 12 May 1994 17:11:36 GMT
Organization: PRZ TU-Berlin

gt7344b@prism.gatech.edu (MMMMM MMMMM) writes:
>
>pcastine@tubprz.prz.tu-berlin.de (Peter Castine) writes:
>>I honestly can *NOT* understand all this bitching about (3) above. If
>>you don't want to drag the disk to the trash, then DON'T DO IT. Hit
>>Command-Y and shut up. 
>>
>
>I think you're forgetting the original point of this thread.  Yes,
>dragging a disk to the trash is quick, easy, and we all do it.  But it
>does violate the Mac HIG.  

No it doesn't. It's an extension of the Finder's interface.

Take a look at HIG p. 38 ('When to go beyond the guidelines'):

	There are times when the standard user interface doesn't cover the
	needs of your application. This is true in the following situations:

	o Your are creating a new feature for which no element or behavior
	  exists. In this case, you can extend the Macintosh user interface
	  in a prescribed way.

	o  An existing element does almost everything you need it to, but
	   a little modification that improves its functions makes the 
	   difference to your application.

The drag-disk-to-trash convention is *built on an existing interface
convention.* (Cf. HIG p. 39) To repeat: the original method was to Eject 
(or Command-E) the disk and drag the off-line icon to the trash. 

>It's unintuitive.  And I'm willing to admit that I was terrified the first
>time I tried dragging a floppy to the trash. 

Gee, I dunno. I seem to remember way back in spring of '84 wondering
"how do I get rid of this disk?", checking out the menus and finding
Eject. Sure, I was a little surprised when the shadow of the disk
stayed on the desk, but since there didn't seem to be any other
appropriate menu items, I dragged the outline to the trash. A day
or two later, I thought "Why not combine the two steps and drag the
disk straight to the trash? This is a Mac, before something aweful
happens, one of these funny message window thingies is sure to pop
up and let me back out." (How many people remember the funny alert
icons Apple used back then? Now, *those* were worth changing.)

Nowadays, I think a lot of beginners click on that funny question
mark thingie at the top right of the screen. Guess what Balloon
Help says about the trash?

BTW, the adjective should be 'unintuitable'. See _Tog on Interface_.
Sorry, I'm getting pedantic.

Admittedly, naive Mac users sometimes get nervous when they see me
dragging a disk to the trash. When this happens, I also go into
teacher mode, do the two-step Eject/Trash Outline procedure,
demonstrate the Put Away command, and then show the one-step
Trash shortcut. But I'd bet they hit on the idea in a couple
of weeks on their own.

Wonder which people work out faster--dragging a disk to the trash
or the 'xp' trick in vi?


-- 
Peter Castine                  | Con'sis'ten'cy (n., pl. -cies)
pcastine@prz.tu-berlin.de      | 1a) last refuge of the unimaginative
- -----------------------------| b) hobgoblin of little minds
   ``Have Mac, will travel''   | (Apologies to Webster, Emerson, & Wilde)

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

>From Antoine Paul Brusseau <ab2y+@andrew.cmu.edu>
Date: Thu, 12 May 1994 16:34:49 -0400
Organization: Carnegie Mellon, Pittsburgh, PA

Excerpts from netnews.comp.sys.mac.programmer: 12-May-94 Re: Apple's
blatant disrega.. by Peter Castine@tubprz.prz 
> Take a look at HIG p. 38 ('When to go beyond the guidelines'):
> 
>         There are times when the standard user interface doesn't cover the
>         needs of your application. This is true in the following situations:
> 
>         o Your are creating a new feature for which no element or behavior
>           exists. In this case, you can extend the Macintosh user interface
>           in a prescribed way.
> 
>         o  An existing element does almost everything you need it to, but
>            a little modification that improves its functions makes the 
>            difference to your application.
>
>The drag-disk-to-trash convention is *built on an existing interface
>convention.* (Cf. HIG p. 39) To repeat: the original method was to Eject 
>(or Command-E) the disk and drag the off-line icon to the trash.


    If Apple had added a close box to disk icons, people wouldn't be
declaring this a violation of HIG. The problem is, the trash icons most
common analogy is that of a place one puts items in order to
*PERMANENTLY DESTROY THEM*. Putting a disk in the trash, does not do
this. This violates peoples expectations. Thus, it is a poor UI design
decision. Whereas, a close box is used to remove an item from the
desktop. Putting a close box on disk icons would have built on an
existing interface convention without violating any preexisting ones (I
think:).

Tony

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

>From Stephen Jonke <jonke@gsfc.nasa.gov>
Date: 12 May 1994 22:09:24 GMT
Organization: NASA GSFC

Sorry if this is a repeat, but you can use "Put Away" (Command-Y) in the
"File" menu to unmount a disk.  I can't remember when this capabilit was
added to Put Away - some version of System 7 in any case.  This concept
is somewhat intuitive, except that "Eject Disk" seems like it should do
this and it draws the users attention.  My sister has been using Eject
Disk when she wants to just get the disk out and I can understand why as
this seems the intuitive thing to do.  Does anyone every use "Eject Disk"
in its current form intentionally any more?  Seems like the simple
solution is to change it's functionality so that it unmounts the disk
without leaving the ghost icon on the desktop, as one would expect.  Keep
the drag to trash alternative since lots of Mac users are use to that. 
And then have it so that if you select a floppy disk and pick "Duplicate"
it does the floppy copying shennanigans.  Doesn't this make a heck of a
lot more sense?

Steve

- -------------------
 jonke@gsfc.nasa.gov
- -------------------

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

>From pcastine@tubprz.prz.tu-berlin.de (Peter Castine)
Date: Fri, 13 May 1994 08:38:56 GMT
Organization: PRZ TU-Berlin

mbishop@pliny.ccs.itd.umich.edu (Michael J. Bishop) writes:
>
>Here's what I think Apple should do. Let me know if you think it is good 
>or bad.
>
>-- after I installed the Hardware system update on my powerbook, when I
>hit the power button, it performed the same command as if I had selected
>"Shut Down". It's the old "hardware/software integration" genius that
>Apple is famous for. 
>
>Why don't they do this for the disk drive? Why don't they make a button 
>that when pushed performs the same command as if the user selected "Put 
>Away" from the File menu?
>
>People expect there to be an eject button like on a PC. Putting a button 
>which triggers the software is the best compromise, I believe because it 
>still allows Apple to do that cool hardware integration stuff but is 
>still intuitive to the user.

There is a question of cost. 

Anyone care to estimate what that would add to the price of a Mac?
A simple mechanical switch isn't going to do the trick, you need
something that will send a signal to the logic board, etc.

And don't forget that adding, say $5, to manufacturing costs means
a three digit price increse for the consumer.

Still, it's not a bad idea. But see my next comment.

>I personally *hate* having to select Shut Down to turn of my mac so the 
>Hardware update was genius and much needed IMO.

Using the power switch as a shortcut for Shut Down makes sense on a
PowerBook for two reasons: 1) the switch already has the necessary
connections to the logic board (you couldn't do this on an SE, where
the power switch simply cuts of the power supply) and 2) you can
normally reach the switch on a PB without any inconvenience. Many
Quadra and Mac II boxes are stuck under a desk (and with them the
diskette drives)--in this configuration, menu commands are considerably
more convenient. And, although I use the PowerKey extension so I
can drop into MacsBugs from the keyboard, I don't really want to
have the Shut Down command anywhere on my keyboard--too easy
to hit by accident (of course, some people *do* map some key
combinations to the Shut Down command... and one of them wrote
an extension so that Shut Down produces an Alert "Do you really
want to shut down now?" because he hit the key combination by
accident too often. This is progress :-? )

I'm not sure if it's possible for an extension to catch the signal
sent by the power switch on the Mac II family and cause it to 
initiate the Shut Down sequence. Now that the subject has been on 
the net, I expect somebody will try. ;-)

-- 
Peter Castine                  | Con'sis'ten'cy (n., pl. -cies)
pcastine@prz.tu-berlin.de      | 1a) last refuge of the unimaginative
- -----------------------------| b) hobgoblin of little minds
   ``Have Mac, will travel''   | (Apologies to Webster, Emerson, & Wilde)

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

>From pcastine@tubprz.prz.tu-berlin.de (Peter Castine)
Date: Fri, 13 May 1994 09:07:26 GMT
Organization: PRZ TU-Berlin

Antoine Paul Brusseau <ab2y+@andrew.cmu.edu> writes:
>
>    If Apple had added a close box to disk icons, people wouldn't be
>declaring this a violation of HIG. The problem is, the trash icons most
>common analogy is that of a place one puts items in order to
>*PERMANENTLY DESTROY THEM*. 

*NO IT DOES NOT*. Drag some files to the trash. See the trash can
get fat. Open the trash. There are your files. Select a file. Use
the Put Away command. Hey, presto-the file is back where it came
from. Drag another file onto the desktop. There it is--this is
not permanent destruction.

This is a Mac, not an Atari.

Selecting "Empty Trash" permanently destroys the file (well, for
most users it's close enough to destruction). You also get
an alert warning you of this (just like HIG advises).

> Putting a disk in the trash, does not do
>this. This violates peoples expectations. Thus, it is a poor UI design
>decision. Whereas, a close box is used to remove an item from the
>desktop. Putting a close box on disk icons would have built on an
>existing interface convention without violating any preexisting ones (I
>think:).

A disk icon is a fairly small object. 32x32 pixels. A close box is also
a small object. 10x10 pixels. That's 10% of a disk icon. 10% is actually
a lot (particularly nowadays, with custom disk icons that have rockets
shooting out of them). 

[As a footnote, Fitt's law would indicate that it takes about three
times as long to move the mouse to a close box as it does to move
the mouse to grab a disk icon for dragging. Someone want to do
a comparison of these two alternatives for un-mounting a disk
a la Card et.al.'s _The Psychology of Human-Computer Interaction_?]

I'm not saying that the suggestion to add a close box is a bad one.
However, I think it needs to be thought through more thoroughly.

-- 
Peter Castine                  | Con'sis'ten'cy (n., pl. -cies)
pcastine@prz.tu-berlin.de      | 1a) last refuge of the unimaginative
- -----------------------------| b) hobgoblin of little minds
   ``Have Mac, will travel''   | (Apologies to Webster, Emerson, & Wilde)

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

>From pcastine@tubprz.prz.tu-berlin.de (Peter Castine)
Date: Fri, 13 May 1994 09:28:02 GMT
Organization: PRZ TU-Berlin

Stephen Jonke <jonke@gsfc.nasa.gov> writes:
>Sorry if this is a repeat, but you can use "Put Away" (Command-Y) in the
>"File" menu to unmount a disk.  I can't remember when this capabilit was
>added to Put Away - some version of System 7 in any case.  

7.0d1, if I'm not mistaken. As far as users are concerned, since day
1 A.S. (anno septimum, or whatever the Latin would be :)

> This concept
>is somewhat intuitive, except that "Eject Disk" seems like it should do
>this and it draws the users attention.  My sister has been using Eject
>Disk when she wants to just get the disk out and I can understand why as
>this seems the intuitive thing to do.  Does anyone every use "Eject Disk"
>in its current form intentionally any more?  

Yes!!!!!!!!!!!!!!!!!!!!!!!!!!!!!
Constantly.

> Seems like the simple
>solution is to change it's functionality 

No. 

Changing functionality of commands between software versions
is one of the worst possible violations of human interface design
concievable. Think about it--what would happen if Ford swapped the
position of the emergency brake and the gear shift. Or, if you're
using automatic transmission, how about swapping the gas pedal
and the brake. Think about it--do you really want to have to check
the system software version every time you sit down at a new Mac
so that you know which command configuration you've got?

>so that it unmounts the disk
>without leaving the ghost icon on the desktop, as one would expect.  Keep
>the drag to trash alternative since lots of Mac users are use to that. 
>And then have it so that if you select a floppy disk and pick "Duplicate"
>it does the floppy copying shennanigans.  Doesn't this make a heck of a
>lot more sense?a

System 8 might extend Duplicate to copying disks. I rather expect not,
since the current trend in the interface is towards enhanced use of
mouse gestures (there will be less Cut/COpy/Paste as drag-and-drop
is implemented in more and more applications). In fact, the mouse
gesture for copying disks was one of the earliest implementations
of drag-and-drop on Macintosh.

-- 
Peter Castine                  | Con'sis'ten'cy (n., pl. -cies)
pcastine@prz.tu-berlin.de      | 1a) last refuge of the unimaginative
- -----------------------------| b) hobgoblin of little minds
   ``Have Mac, will travel''   | (Apologies to Webster, Emerson, & Wilde)

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

>From D.A.G.Gillies@bradford.ac.uk (David Gillies)
Date: Fri, 13 May 1994 12:25:46 GMT
Organization: Unseen University, Ankh-Morpork

In article <Cpnryv.CsE@du.edu> ruhl@du.edu (ROBERT A. UHL ) writes:
>Here's another idea:
>I've always thought that ejecting the disk should get rid of it; you
>know, if it's out, I can put it in the box and forget about it. Also,
>the 'Eject' button in the SF dialogs is not a true (IMO) eject;
>nothing is more annoying to be flipping through floppies on the SF
>dialog (which I do a lot) and, when you quit, finding a whole mess of
>grey floppy icons.
>So... I propose that 'Eject' take the place of the current 'Put Away',
>and that the 'spit-out-the-disk-but-keep-it-mounted' action be
>renamed. Not only would this be helpful in the above mentioned ways,
>but command-E would truly eject the ?!*% disk.
>
Of course 'Eject' ejects the disk. It enables you to remove it from the disk
drive, doesn't it? That fits any reasonable definiton of eject in my book.
It takes most people with an IQ higher than that of a potato to realise
the difference between 'Eject', and 'Put Away'. For those amongst us who are
not completely illiterate, the distinction is also pointed out in *the manual*
(you know, that big thick ring-bound thing that is put on one side by MacBozos
and never read, thereby generating 98% of tech support traffic, and giving
rise to those 'Tricks'n'Tips' columns in magazines, full of things like "did
you know that if you hold down the option key when opening a folder, the
parent folder will disappear?")

Changing the way this works now would only serve to confuse the people who
extracted their heads from their arses long enough to actually understand
how to use a Mac.

Keeping volumes mounted is a time-saving feature. If you had to wait the
twenty seconds or so it takes to mount a floppy every time you popped one out
of the slot in the Standard File dialog, you'd go mad. It's not perfect, but
until someone comes up with abetter solution we're stuck with it. 

______________________________________________________________________
David A. G. Gillies                     (D.A.G.Gillies@bradford.ac.uk)
      University of Bradford, Bradford, West Yorkshire, England
(c) 1994 Wittgenstein and The Furniture Depository of The Living Dead

A little learning is a dangerous thing - but not half as dangerous as a
lot of ignorance.
- ---------------------REPLIES VIA EMAIL PLEASE-----------------------
_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/

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

>From D.A.G.Gillies@bradford.ac.uk (David Gillies)
Date: Fri, 13 May 1994 12:30:48 GMT
Organization: Unseen University, Ankh-Morpork

In article <2qtjf2$4us@unix.sri.com> mxmora@unix.sri.com (Matt Mora) writes:
>In article <1994May12.111049.29637@prz.tu-berlin.de> pcastine@tubprz.prz.tu-berlin.de (Peter Castine) writes:
>
>>No, no, no, no.
>>
>>You need the 'spit-out-the-disk-but-keep-it-mounted' feature in order
>>to copy disks on Macs with only one floppy drive (which is surely
>>the vast majority of machines out there). 
>
>nah, what we need to implement is Andy Herzfeld (sp?) velocity
>feature. Pick up a disk icon with the mouse and throw it off the desktop
>to eject it. :-) The disk icon would then glide across the desktop and when it
>the icon was completly off the desktop, it would eject. Kind of like when
>a disk falls off your desk. 
>
>If you didn't throw it hard enough it would glide to a halt some where on 
>your desktop.
>
>Ejecting a disk should be fun!
>
Great idea! Anyone want to write this? It could be a bit tricky...

______________________________________________________
David A. G. Gillies     (D.A.G.Gillies@bradford.ac.uk)
(c) 1994 Wittgenstein's Amazing Underwater Supermarket
_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/

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

>From Antoine Paul Brusseau <ab2y+@andrew.cmu.edu>
Date: Fri, 13 May 1994 09:30:06 -0400
Organization: Carnegie Mellon, Pittsburgh, PA

Excerpts from netnews.comp.sys.mac.programmer: 13-May-94 Re: Apple's
blatant disrega.. by Peter Castine@tubprz.prz 
> >    If Apple had added a close box to disk icons, people wouldn't be
> >declaring this a violation of HIG. The problem is, the trash icons most
> >common analogy is that of a place one puts items in order to
> >*PERMANENTLY DESTROY THEM*. 
> 
> *NO IT DOES NOT*. Drag some files to the trash. See the trash can
> get fat. Open the trash. There are your files. Select a file. Use
> the Put Away command. Hey, presto-the file is back where it came
> from. Drag another file onto the desktop. There it is--this is
> not permanent destruction.

I think you misread my post. I said "in order to *PERMANENTLY DESTOY
THEM*", not "so that they are *IMMEDIATELY DESTROYED*". To further the
analogy, if I put an object from my desk into the rubish bin, it is not
immediately destroyed. If I choose, I can take the object out any time
before the cleaning staff comes. This is the correct analogy, and it is
followed consistently with file icons. Putting a floppy disk into the
trash in order to eject it does not follow this analogy. This is the
point of my previous post.

Tony

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

>From dowdy@apple.com (Tom Dowdy)
Date: Fri, 13 May 1994 15:40:32 GMT
Organization: Apple Computer, Inc.

In article <cwiltgen-030594195407@cwiltgen.pr.mcs.net>, cwiltgen@mcs.com
(Charles Wiltgen) wrote:
> In article <16674@lhdsy1.lahabra.chevron.com>,
> jjvbl@lhdsy1.lahabra.chevron.com (John V. Blzka) wrote:
> 
> > Hello,
> > I've been working on a presentation on Human Factors Engineering.
> > I am using Apple's User Interface Guidelines as an example.  
> > What I would like to know is:
> >   Does Apple violate it's own Guidelines in any of it's System 7  
> >   software?
> >   If so, can I easily demonstrate it?
> 
> How 'bout dragging a disk to the trash to eject it?

I'm not sure how this is a direct violation of the UI guidelines
(and maybe it is)...It *is* probably a non-intuative feature,
that wasn't well thought out for first implementation.

However, I'd like to ask you if you now use the "Put Away" menu
item in System 7, which performs the same function.  Or, do
you continue to drag the disk to the trash.  If you continue
to drag the disk to the trash -- why?  If we took away
that feature, would you complain?

-- 
 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 mbishop@ovid.ccs.itd.umich.edu (Michael J. Bishop)
Date: 13 May 1994 16:28:51 GMT
Organization: University of Michigan

Peter Castine (pcastine@tubprz.prz.tu-berlin.de) wrote:
: mbishop@pliny.ccs.itd.umich.edu (Michael J. Bishop) writes:

: Anyone care to estimate what that would add to the price of a Mac?
: A simple mechanical switch isn't going to do the trick, you need
: something that will send a signal to the logic board, etc.

: And don't forget that adding, say $5, to manufacturing costs means
: a three digit price increse for the consumer.

: Still, it's not a bad idea. But see my next comment.

: >I personally *hate* having to select Shut Down to turn of my mac so the 
: >Hardware update was genius and much needed IMO.

: Using the power switch as a shortcut for Shut Down makes sense on a
: PowerBook for two reasons: 1) the switch already has the necessary
: connections to the logic board (you couldn't do this on an SE, where
: the power switch simply cuts of the power supply) and 2) you can
: normally reach the switch on a PB without any inconvenience. Many
: Quadra and Mac II boxes are stuck under a desk (and with them the
: diskette drives)--in this configuration, menu commands are considerably
: more convenient. And, although I use the PowerKey extension so I
: can drop into MacsBugs from the keyboard, I don't really want to
: have the Shut Down command anywhere on my keyboard--too easy
: to hit by accident (of course, some people *do* map some key
: combinations to the Shut Down command... and one of them wrote
: an extension so that Shut Down produces an Alert "Do you really
: want to shut down now?" because he hit the key combination by
: accident too often. This is progress :-? )

Ah ha! I can build on that. The ergonomic keyboard comes with an 
extension which allows the keyboard to switch the volume up and down. How 
hard would it be to use one of those "new" keys to eject the disk? Then 
both the power key and the "put away" key are both accessible from the 
keyboard. Apple adds new keys all the time that do cool new things. I 
think they could have added a "put away" key.

: -- 
: Peter Castine                  | Con'sis'ten'cy (n., pl. -cies)
: pcastine@prz.tu-berlin.de      | 1a) last refuge of the unimaginative
: -------------------------------| b) hobgoblin of little minds
:    ``Have Mac, will travel''   | (Apologies to Webster, Emerson, & Wilde)

--
_____________________________________________________________________________
 Michael Bishop 	"The best way to predict the future is to invent it."
 mbishop@umich.edu						- Alan Kay

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

>From mwalker@netcom.com (Mel Walker)
Date: Fri, 13 May 1994 16:37:17 GMT
Organization: Committee to Elect Dan Quayle Lord of the Cosmos

Antoine Paul Brusseau (ab2y+@andrew.cmu.edu) wrote:
:     If Apple had added a close box to disk icons, people wouldn't be
: declaring this a violation of HIG. The problem is, the trash icons most
: common analogy is that of a place one puts items in order to
: *PERMANENTLY DESTROY THEM*.

No, the common analogy is that one puts items into a trash can in order 
to *GET RID OF THEM*. Thus, when I want to get rid of a disk, I throw it 
in the trash. I does not violate my expectations in the slightest.

: Putting a disk in the trash, does not do
: this. This violates peoples expectations. Thus, it is a poor UI design
: decision. Whereas, a close box is used to remove an item from the
: desktop. Putting a close box on disk icons would have built on an
: existing interface convention without violating any preexisting ones (I
: think:).

What happens when you double-click on the disk to open it, and hit the 
close box? Since the close box would take a sizeable amount of the disk 
icon, I figure that it would happen quite a bit. In addition, the close 
box would interfere with my cool custom icons. :-)

Just out of curiousity, are there any GUIs that put close boxes on a disk 
icon?
-- 
Mel Walker                                     mwalker@netcom.com

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

>From Stephen Jonke <jonke@gsfc.nasa.gov>
Date: 13 May 1994 17:47:43 GMT
Organization: NASA GSFC

In article <1994May13.092802.16931@prz.tu-berlin.de> Peter Castine,
pcastine@tubprz.prz.tu-berlin.de writes:
>Changing functionality of commands between software versions
>is one of the worst possible violations of human interface design
>concievable. Think about it--what would happen if Ford swapped the
>position of the emergency brake and the gear shift. Or, if you're
>using automatic transmission, how about swapping the gas pedal
>and the brake.

I disagree with this opinion.  You can't compare these two things,
because the consequences are quite drastically different.  If you do what
you suggest with cars, people can be killed.  If you do what I suggest
with Empty Trash and duplicate, you risk people being annoyed once or
twice, then seeing that it's better and being happy with it.  That's not
much of risk and there is great reward.  If lots of people use the
current Eject Disk functionality for things other then copying, then they
could throw in a new command that does this (offhand I can't think of a
name) that is NOT "Eject Disk".

You can go overboard with consistency and this is a perfect example.  You
are being consistent with something that was wrong to start with.  That
is a greater mistake, IMHO.  Plus, Apple's goal these days is to attract
NEW Mac users and if there are quirks like the Eject Disk "feature", they
are going to pick these out and say "boy, this is stupid, I'm going back
to my PC which is just as good" (not that this is true, but we are
talking about PC users who are confinced their PCs are just as good!  :)

Actually, here's another alternative that would be a better, but not as
good as my first suggestion.  Keep Eject Disk and have it appear to do
the same as usual, but make it so that it no longer asks you to put the
disk in if you shutdown (or whatever.)  Also, you should be able to drag
the greyed disk icon to the trash similarly.  This is actually the way it
use to work anyway, right?

Steve

- -------------------
 jonke@gsfc.nasa.gov
- -------------------

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

>From David Casseres <casseres@apple.com>
Date: Fri, 13 May 1994 17:46:08 GMT
Organization: Apple Computer, Inc.

In article <dowdy-130594083624@17.202.72.12> Tom Dowdy, dowdy@apple.com writes:
> I'm not sure how this is a direct violation of the UI guidelines
> (and maybe it is)...It *is* probably a non-intuative feature,
> that wasn't well thought out for first implementation.
> 
> However, I'd like to ask you if you now use the "Put Away" menu
> item in System 7, which performs the same function.  Or, do
> you continue to drag the disk to the trash.  If you continue
> to drag the disk to the trash -- why?  If we took away
> that feature, would you complain?

I bet anything that if we took away that feature there would be howls of rage
from so many people that we'd put it right back in as quickly as possible.

I was around when this was invented, and I guarantee that everyone knew it was
unintuitive, and thought hard about it.  But everyone also knew that there
really had to be a way to eject a diskette with just a simple mouse gesture,
and no one could come up with a better way to do it.

There are lots of things about GUI design that simply can't be accounted for
in guidelines.  For example, when you drag a file from one folder to another,
it disappears from its original location and appears in the new location.

*Except*... if you are dragging it from one disk to another then it doesn't
disappear from the original location.  It's completely inconsistent and not
even intuitive, but it's *right*.

We know this because on the Lisa it worked the other way, and the file was
erased from its original disk after being copied to the new one.  And this
turned out to be *wrong*, even though it was consistent and intuitive.

Sometimes even the best guidelines need to be blatantly disregarded.

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

David Casseres
Exclaimer: Hey!

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

>From resnick@cogsci.uiuc.edu (Pete Resnick)
Date: 13 May 1994 18:44:39 GMT
Organization: University of Illinois at Urbana

Ron_Hunsinger@bmug.org (Ron Hunsinger) writes:

>resnick@cogsci.uiuc.edu (Pete Resnick) writes:

>>In article <2qido4$8c4@news.kth.se>, d88-jwa@dront.nada.kth.se (Jon Wdtte)
>>wrote:
>>
>>>Exactly how would the Swedish Finder know about the names of the
>>>Hindu special folders?
>>
>>The same way it knows what the names of the Swedish special folders are:
>>
>>    GetResource('fld#', 0);
>>

>Wouldn't work.  This would only tell the Swedish Finder the names of the 
>*Swedish* special folders.  Although...

>If Apple was hard-pressed, I suppose the active Finder could look in
>the boot blocks of the other System Folder's volume to get the name of
>the other Finder, then open the other Finder's resource fork and get the 
>folder names from it.  And do all this only if the destination folder 
>matches the id of the blessed folder (available from vcbFndrInfo).

I think you are getting confused here. The question is, if I drag to a
non-blessed system folder, why can't the Finder figure out where to
put the files? To realize it's a legitamate (albeit unblessed) system
folder in the first place, you must *already* notice that there is a
System and a Finder in that folder. You don't need to go looking in
boot blocks to figure that out; you simply need to look at file types.
Once you discover that there are appropriate System and Finder files
using the file types, you can then open the appropriate one (I forget
whether the fld# is in the System or the Finder; I believe it's the
former) and do the GetResource from that file (I guess using
Get1Resource instead of GetResource actually). You won't get the ones
from the Swedish system since the Hindu (or whatever) system is the
current resource file. It doesn't have to be the blessed folder since
any system folder will be reasonable to put things into appropriate
places.

Right?

pr
-- 
Pete Resnick             (...so what is a mojo, and why would one be rising?)
Graduate assistant - Philosophy Department, Gregory Hall, UIUC
System manager - Cognitive Science Group, Beckman Institute, UIUC
Internet: resnick@cogsci.uiuc.edu

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

>From peirce@outpost.SF-Bay.org (Michael Peirce)
Date: 13 May 94 00:44:48 GMT
Organization: Peirce Software, Inc.


In article <zig.768162596@wc.novell.com> (comp.sys.mac.advocacy,comp.sys.mac.programmer), zig@wc.novell.com (Zig Zichterman) writes:
> One place Apple violates its suggested guidelines in in the Finder's
> "About This Macintosh..." menu item. The Mac HI Guidelines book (pages 67-70)
> suggests that the ellipsis (...) should appear only on menu items that 
> require *additional* information before they can complete (such as
> choosing a file from an Open... dialog, or setting up options in a
> Preferences... dialog, and so on). For menu items that execute without
> further information from the user, such as Cut, Copy, showing an About
> box, and so on, the ellipsis should not appear.
> 
> After 10 years of tradition, who's going to really remove the ellipsis
> from their "About..." menu?

I've always interpretted the presence of an ellipsis to mean a dialog
will be called up, i.e. something will interupt you focus on the current
window.  Or more specifically, you'll have to do something to get
back to where you were.

With this interpretation, the About... is correct.

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

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

>From Antoine Paul Brusseau <ab2y+@andrew.cmu.edu>
Date: Fri, 13 May 1994 15:42:40 -0400
Organization: Carnegie Mellon, Pittsburgh, PA

Excerpts from netnews.comp.sys.mac.programmer: 13-May-94 Re: Apple's
blatant disrega.. by Mel Walker@netcom.com 
> No, the common analogy is that one puts items into a trash can in order 
> to *GET RID OF THEM*. Thus, when I want to get rid of a disk, I throw it 
> in the trash. I does not violate my expectations in the slightest.

Unfortunately, the most common consequence of getting rid of something
is that it is permanently destroyed (i.e., the trash icon is most often
used to destroy files). Thus, the association in many peoples' minds is
a place where one puts an item in order to permanently destroy it. The
reason I bring this up, is that more than a few people that I've taught
to use Apple computers have been shocked that putting a disk in the
trash can is the easiest way of ejecting a disk. Several non-technically
oriented people I know actively balk at using this feature because they
are afraid their data is going to be erased (no matter how many times I
reassure them it isn't). Philosophically and empirically, the evidence
indicates that this feature is more than a little dubious as a UI
shortcut.

Since many people including myself make extended use of this feature, it
is obviously desirible to have a UI shortcut for ejecting a disk (menus
are just too incovenient and command-y is too arcane). That's why I
think some other method (that doesn't violate common expectations), such
as having a close button on ejectable media volumes or dragging
ejectable media icons off the desktop, as a way of ejecting them is
preferable.

Tony

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

>From Antoine Paul Brusseau <ab2y+@andrew.cmu.edu>
Date: Fri, 13 May 1994 15:55:08 -0400
Organization: Carnegie Mellon, Pittsburgh, PA

Excerpts from netnews.comp.sys.mac.programmer: 13-May-94 Re: Apple's
blatant disrega.. by David Casseres@apple.com 
> Sometimes even the best guidelines need to be blatantly disregarded.

That's by far the best argument I've heard in support of dragging icons
into the trash. But what about putting a close box on (or near) floppy
icons, or dragging them off the desktop in order to eject them? Both of
these methods sound intuitive and consistent (at least superficially).

Tony

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

>From 103t_english@west.cscwc.pima.edu
Date: 14 May 94 04:04:01 MST
Organization: (none)

In article <Uhod=du00UzxE3WloB@andrew.cmu.edu>, Antoine Paul Brusseau <ab2y+@andrew.cmu.edu> writes:
>     If Apple had added a close box to disk icons, people wouldn't be
> declaring this a violation of HIG. The problem is, the trash icons most
> common analogy is that of a place one puts items in order to
> *PERMANENTLY DESTROY THEM*. Putting a disk in the trash, does not do
> this. This violates peoples expectations. Thus, it is a poor UI design
> decision. Whereas, a close box is used to remove an item from the
> desktop. Putting a close box on disk icons would have built on an
> existing interface convention without violating any preexisting ones (I
> think:).
> 
> Tony


Now figger out how to make sure that the close box was clicked on and the user
wasn't trying to either select or open the file...


Lawson

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

>From pcastine@jake.prz.tu-berlin.de (Peter Castine)
Date: Sat, 14 May 1994 10:31:04 GMT
Organization: PRZ TU-Berlin

Antoine Paul Brusseau <ab2y+@andrew.cmu.edu> writes:
>...more than a few people that I've taught
>to use Apple computers have been shocked that putting a disk in the
>trash can is the easiest way of ejecting a disk. Several non-technically
>oriented people I know actively balk at using this feature because they
>are afraid their data is going to be erased (no matter how many times I
>reassure them it isn't). 

So, what do the people do instaed of dragging the disk to the trash?
Before System 7.0, the alternative was to Eject and then trash the
shadow. Did users back then (or the 40% of machines still running
System <7) keep on doing this? Or did they get used to the idea of
the shortcut? (Anybody have any data on this? Experience? Anecdotes?)

Do new users running System 7.x still keep to the Put Away command 
(or the keyboard equivalent)? Or do they find the mouse gesture more
convenient?

When I've done Mac training (this is, admittedly, a while ago), I always
demonstrated the two-step method first, which seemed not to bother
people (except that it took two steps). *THEN* I showed the disk-to-trash
shortcut. SOme people like it. Some people get used to it. Others don't.

HIG lists no less than five different flavors of consistency. Only
one of these is consistency with people's expectations. Meeting the
expectations of ALL users is impossible (HIG is coy on this one, and
just says "it's difficult to meet the expectations of everyone."
It ain't difficult. It's 'mpossible.)

Take the following example:

I've trained people who expected the backspace key to work
like the left arrow (move the I-beam cursor to the left
in text editing without deleting characters). Why? Because that's
the way most typewriters work. 

How about this: Teach people who've never worked with a computer
before how to use a spreadsheet. They will invariably
type 'x' instead of '*' for multiplication.

Sorry for the continuing sermon. I really just wanted to know
how long it takes people to become comfortable with the disk-
to-trash shortcut. I suspect that (with the exception of
those who have been forced to work with a Mac and are determined
to hate any aspect of it they can), the time is resonably short.
-- 
Peter Castine                  | Con'sis'ten'cy (n., pl. -cies)
pcastine@prz.tu-berlin.de      | 1a) last refuge of the unimaginative
- -----------------------------| b) hobgoblin of little minds
   ``Have Mac, will travel''   | (Apologies to Webster, Emerson, & Wilde)

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

>From pcastine@jake.prz.tu-berlin.de (Peter Castine)
Date: Sat, 14 May 1994 10:39:02 GMT
Organization: PRZ TU-Berlin

>Excerpts from netnews.comp.sys.mac.programmer: 13-May-94 Re: Apple's
>blatant disrega.. by David Casseres@apple.com 
>> Sometimes even the best guidelines need to be blatantly disregarded.
                                                 ~~~~~~~~~

No. The guidelines (all eleven of 'em, as well as a few other unstated
concerns such as efficiency and convenience for the user, as well as cost
and time for the developers) have to be balanced with one another.


-- 
Peter Castine                  | Con'sis'ten'cy (n., pl. -cies)
pcastine@prz.tu-berlin.de      | 1a) last refuge of the unimaginative
- -----------------------------| b) hobgoblin of little minds
   ``Have Mac, will travel''   | (Apologies to Webster, Emerson, & Wilde)

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

>From bizarre@leland.stanford.edu (Bruce Templeton)
Date: Sat, 14 May 1994 13:51:42 -0800
Organization: Stanford University

In article <1994May14.103104.5587@prz.tu-berlin.de>,
pcastine@jake.prz.tu-berlin.de (Peter Castine) wrote:
> So, what do the people do instaed of dragging the disk to the trash?
> Before System 7.0, the alternative was to Eject and then trash the
> shadow. Did users back then (or the 40% of machines still running
> System <7) keep on doing this? Or did they get used to the idea of
> the shortcut? (Anybody have any data on this? Experience? Anecdotes?)
<deleted>
> Sorry for the continuing sermon. I really just wanted to know
> how long it takes people to become comfortable with the disk-
> to-trash shortcut. I suspect that (with the exception of
> those who have been forced to work with a Mac and are determined
> to hate any aspect of it they can), the time is resonably short.

I'm embarassed to admit, I had my Mac Plus for *two years* before I
realized that you could get rid of the ghost disk by dragging it to 
the trash.  I just sat there and swapped disks until it let me go.
When I got too many ghost disks on my desktop, I restarted my computer.
Note that I was a very novice user, and did not know anyone else who 
had a Macintosh.  I was very jealous of my friends who had eject 
buttons on their PC's.

When I got to college, someone dragged my disk with a paper on it to 
the trash and I almost had a heart attack.

As far as shortcuts go, Apple actually removed the one I really liked
with the introduction of System 7.  You could type Command-Option-E
and hold the option key down until the disk ejected and the ghost 
would disappear.  With the Put Away command, you have to select the 
disk with the mouse before it works.

Yup, Apple screwed up ejecting pretty bad.

-Bruce

-- 
|*Bruce Templeton                                      ______________ *|
|*bizarre@leland.stanford.edu                 DFOTB  /______________/|*|
|*Disclaimer:  The statements above reflect the      |  o   o   o  | |*|
|*opinions of virtually everyone I have ever met.    |_____________|/ *|

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

>From oster@netcom.com (David Phillip Oster)
Date: Sat, 14 May 1994 23:02:06 GMT
Organization: Netcom Online Communications Services (408-241-9760 login: guest)


After all these years, surely the finder could have a little more Undo for

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

>From tzs@u.washington.edu (Tim Smith)
Date: 14 May 1994 05:39:07 GMT
Organization: University of Washington School of Law, Class of '95

Speaking of how manipulating things on the screen should be fun, surely I'm
not the only one who wants to be able to move the cursor by having commands
for "rotate left", "rotate right", and "thrust", am I?

--Tim Smith

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

>From shimpei@leland.Stanford.EDU (Shimpei Yamashita)
Date: 15 May 1994 09:32:28 GMT
Organization: Stanford University, CA 94305, USA

In article <1994May13.122546.950@bradford.ac.uk>,
David Gillies <D.A.G.Gillies@bradford.ac.uk> wrote:
:Of course 'Eject' ejects the disk. It enables you to remove it from the disk
:drive, doesn't it? That fits any reasonable definiton of eject in my book.
:It takes most people with an IQ higher than that of a potato to realise
:the difference between 'Eject', and 'Put Away'. For those amongst us who are
:not completely illiterate, the distinction is also pointed out in *the manual*

I've been using System 6 on a Plus since 1988. I saw System 7 for the first
time when I came to college, and I freely admit that it took me about
six months to realize that "Put Away" is the menu equivalent of dragging
the disk to the trash. It *is* counterintuitive that "ejecting the disk"
and "restoring files to their original folders" fall under the same command,
IMHO. And no, I could not have read the manual since they don't have 
System 7 manuals lying around in the computer clusters....


-- 
Shimpei Yamashita, Stanford University           shimpei@leland.stanford.edu

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

>From stk@uropax.contrib.de (Stefan Kurth)
Date: 9 May 1994 02:13:04 +0200
Organization: Contributed Software GbR

Speaking of arrow keys in lists: what would be the correct behaviour when
the user types down-arrow, but nothing is currently selected? Should the
topmost or the bottom-most item be selected? The standard file package
behaves different from finder windows in this regard, which is a really
annoying inconsistency, if you ask me.

_____________________________________________________________________
Stefan Kurth              Berlin, Germany              stk@contrib.de

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

>From gdl@stlawrence.maths (Greg Landweber)
Date: 15 May 1994 21:41:25 GMT
Organization: (none)

In article <2qjv6g$cj4@uropax.contrib.de> stk@uropax.contrib.de (Stefan Kurth) writes:
   Speaking of arrow keys in lists: what would be the correct behaviour when
   the user types down-arrow, but nothing is currently selected? Should the
   topmost or the bottom-most item be selected? The standard file package
   behaves different from finder windows in this regard, which is a really
   annoying inconsistency, if you ask me.

I'm not 100% sure, but I think that in such a situation the arrow keys
do nothing.  I'm using the ArrowKeyInList routine straight out of More
Macintosh Toolbox, and it returns empty handed when passed a list with
no current selection.  Of course, the sample code and the
documentation may not agree (and I seem to recall that the sample code
had a few bugs).

-- Greg
   gdl@maths.ox.ac.uk

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

>From Bruce@hoult.actrix.gen.nz (Bruce Hoult)
Date: Mon, 16 May 1994 16:41:52 +1200 (NZST)
Organization: (none)

dowdy@apple.com (Tom Dowdy) writes:
> However, I'd like to ask you if you now use the "Put Away" menu
> item in System 7, which performs the same function.  Or, do
> you continue to drag the disk to the trash.

I can't remember the last time I dragged a disk to the trash.  It's
always <apple>-Y for me.

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

>From ruhl@du.edu (ROBERT A. UHL )
Date: Mon, 16 May 1994 17:24:43 GMT
Organization: University of Denver

In article <2qtjl0$ob9@acme.gatech.edu> gt7344b@prism.gatech.edu (MMMMM MMMMM) writes:
>In article <1994May12.111049.29637@prz.tu-berlin.de> pcastine@tubprz.prz.tu-berlin.de (Peter Castine) writes:
>>In article <Cpnryv.CsE@du.edu> ruhl@du.edu (ROBERT A. UHL ) writes:
>>I honestly can *NOT* understand all this bitching about (3) above. If
>>you don't want to drag the disk to the trash, then DON'T DO IT. Hit
>>Command-Y and shut up. 
>>
I'd like to say that the above quote belongs to Peter castine, not me;
the poster misquoted. The quote is not at all my style.
-- 
- -------------------------------------------------------
| Bob Uhl | Spectre                  | Christos Anesti! |
| U of D  | Baron Robert von Raetzin | Alithos Anesti!  |
- -------------------------------------------------------

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

>From Bruce@hoult.actrix.gen.nz (Bruce Hoult)
Date: Tue, 17 May 1994 18:14:49 +1200 (NZST)
Organization: (none)

stk@uropax.contrib.de (Stefan Kurth) writes:
> Speaking of arrow keys in lists: what would be the correct behaviour when
> the user types down-arrow, but nothing is currently selected? Should the
> topmost or the bottom-most item be selected? The standard file package
> behaves different from finder windows in this regard, which is a really
> annoying inconsistency, if you ask me.

It annoys me too.  I much prefer getting the topmost item in this situation,
and that's how I write my own programs.

I think Finder windows are the *only* place it happens the other way around,
and it's stupid.

Think how you select the third (say) item in a list.  In the Finder you need
to hit the up arrow once, then down twice.  Anywhere else you just hit down
three times (or hold the key down for items further down the list).

-- Bruce

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

>From jdc0864@u.cc.utah.edu (Jeff Croft)
Date: 17 May 1994 01:31:02 -0600
Organization: University Of Utah Computer Center

David Gillies (D.A.G.Gillies@bradford.ac.uk) wrote:

: Keeping volumes mounted is a time-saving feature. If you had to wait the
: twenty seconds or so it takes to mount a floppy every time you popped one out
: of the slot in the Standard File dialog, you'd go mad. It's not perfect, but
: until someone comes up with abetter solution we're stuck with it. 

Gee. It's too bad that it takes that long to mount a floppy.

                 Jeff


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

>From Ron_Hunsinger@bmug.org (Ron Hunsinger)
Date: Tue, 17 May 94 06:50:16 PST
Organization: Berkeley Macintosh Users Group

resnick@cogsci.uiuc.edu (Pete Resnick) writes:

>Ron_Hunsinger@bmug.org (Ron Hunsinger) writes:
>
>>If Apple was hard-pressed, I suppose the active Finder could look in
>>the boot blocks of the other System Folder's volume to get the name of
>>the other Finder, then open the other Finder's resource fork and get the 
>>folder names from it.  And do all this only if the destination folder 
>>matches the id of the blessed folder (available from vcbFndrInfo).
>
>I think you are getting confused here. The question is, if I drag to a
>non-blessed system folder, why can't the Finder figure out where to
>put the files? To realize it's a legitamate (albeit unblessed) system
>folder in the first place, 

You're right, I was confused here.  I had forgotten that it is now
permitted again to have more than one system folder on a volume.  I
still think it's spooky to do so, though.

>you must *already* notice that there is a
>System and a Finder in that folder. You don't need to go looking in
>boot blocks to figure that out; you simply need to look at file types.

Well, I think that looking at vcbFndrInfo for the directory id of the
blessed folder is easier than looking at file types.  But yeah, if you
want to support unblessed system folders, you will have to scan the 
files inside the folder.

I hadn't realized that the System and Finder files now had their own
unique type/creator.  Back on system 3 or so it was not uncommon for
people to create files with the same type/creator as the Finder, so
they wouldn't have to hassle with BNDL resources to give the file an
icon.  Apple started it (if memory serves me right, but I could be
wrong) by doing this with the Clipboard File and the Scrapbook File,
and then other vendors did the same with their "just-as-important"
data and preference files.

In light of that, are you sure that identifying the files by type/creator
is reliable?  I still find ZSYS/MACS and ZSYS/ERIK files on my disk that 
were put there by current non-Apple software.  I know that System 7 now 
uses zsys/MACS and FNDR/MACS for the System and Finder, but are you 
sure that nobody is going to try to get a free icon out of the new codes
like they did out of the old ones?  And like many people do now by giving
their preferences files a type of 'pref'?

Related Question That May Answer This Question: How do the utility 
programs that let you switch between system folders on the same volume
deal with the possibility that the folders might be in different
languages?  If they ignore the problem, using the System/Finder names
from the boot blocks, then you should also.  If they identify System/
Finder by their type/creator, as you are suggesting, and copy the
names to the boot blocks, then your argument gains a lot of support.

Similar Question:  What happens now when you copy files that have the
"wrong" names but the "right" type/creator into a folder on a volume
that does not already have a blessed folder?  That is, if I rename
System and Finder to something else, say "System copy" and "Finder copy",
and copy them into a folder on an otherwise blank disk, does that folder 
get blessed?  Should it?  Do those names get copied to the boot blocks?  
What if the names are longer than 15 bytes?  If the folder gets blessed, 
that bolsters your contention that a system folder is defined in terms of 
the types of the files within it, rather than their names.  And if not, 
you are of course free to argue that this is yet another oversight that
ought to be corrected, but you will then have the additional burden of
convincing us that this would be the correct behavior.  You would have
to answer questions like: What if I have two finders in the same folder 
under different names?  Which one is the real one?  What if I remove
one of them from the blessed folder?  Does the folder become unblessed,
or does the other finder get selected?  Which other one if I started
with more than two?

>Once you discover that there are appropriate System and Finder files
>using the file types, you can then open the appropriate one (I forget
>whether the fld# is in the System or the Finder; I believe it's the
>former) and do the GetResource from that file (I guess using
>Get1Resource instead of GetResource actually). You won't get the ones
>from the Swedish system since the Hindu (or whatever) system is the
>current resource file. It doesn't have to be the blessed folder since
>any system folder will be reasonable to put things into appropriate
>places.

You're right about the fld# resource being in the System file.  Too bad.
The resource map for the System file is huge, and it takes a while to
open it.  Of course, you only need to open it to get the folder names,
and you only need those if you are actually going to disburse files
into the appropriate subfolders, and you aren't going to do that until
the user responds to the dialog that comes up asking the user whether 
it's OK to do so.  All of which means you could hide the time it takes 
by doing it while the user is reading the dialog.

-Ron Hunsinger

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

>From ruhl@du.edu (ROBERT A. UHL )
Date: 11 May 94 21:53:07 GMT
Organization: University of Denver

In article <zig.768162596@wc.novell.com> zig@wc.novell.com (Zig Zichterman) writes:
>One place Apple violates its suggested guidelines in in the Finder's
>"About This Macintosh..." menu item. The Mac HI Guidelines book (pages 67-70)
>suggests that the ellipsis (...) should appear only on menu items that 
>require *additional* information before they can complete (such as
>choosing a file from an Open... dialog, or setting up options in a
>Preferences... dialog, and so on). For menu items that execute without
>further information from the user, such as Cut, Copy, showing an About
>box, and so on, the ellipsis should not appear.

Oops...
I thought that the ellipsis indicated a dialog box (and, as far as I
know, that item is a dialog box).

>--Zig Zichterman
>ziggr@eWorld.com 
>


-- 
- -------------------------------------------------------
| Bob Uhl | Spectre                  | Christos Anesti! |
| U of D  | Baron Robert von Raetzin | Alithos Anesti!  |
- -------------------------------------------------------

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

>From egurney@vcd.hp.com (Eddy J. Gurney)
Subject: List Manager clikLoop problem... but whose it?
Date: Mon, 9 May 1994 22:02:04 GMT
Organization: Hewlett-Packard VCD

Over the weekend, I was adding some new features to some lists I have
in my app, and came across an interesting problem.  Running under Think
C 7, all optimizations on.

I have a List Manager click loop, declared as follows (yes, it is declared
pascal Boolean; I know a Pascal boolean is 1 bit and a C boolean is 16
bits... and that Think C should take care of everything for me :-)...

pascal Boolean MyClickLoop(void);

now, if MyClickLoop looks like this:

pascal Boolean MyClickLoop(void)
{
    Boolaen result = true;

    return true;
}

everything works as expected.

BUT if MyClickLoop uses something like this:

pascal Boolean MyClickLoop(void)
{
    Boolean result = true;

    return result;
}

it *DOESN'T* work.  I compared the disassembly of the two; nothing
out of the ordinary, really:

First version (at least the important parts):

LINK    A6
 ...
MOVE.B  #$01,$0008(A6)
UNLK    A6
RTS

Second version:

LINK    A6
MOVE.L  D7,-(A7)
MOVEQ   #$01,D7
 ...
MOVE.B  D7,$0008(A6)
MOVE.L  (A7)+,D7
UNLK    A6
RTS

Now, this shouldn't make any difference, EXCEPT that the List Manager
(_Pack0) calls the user-defined clikLoop routine with the following 
code:

JSR     (A0)
BEQ     ...

As you can see, it immediately checks the Z condition code after the
routine finishes... which assumes that the last command executed in
the user-defined clikLoop routine sets that condition code correctly.
This is NOT the case in the second version, since the MOVE.L (A7)+,D7
(to restore the value of D7) clobbers the condition code set by the
MOVE.B D7,$0008(A6).  [If more than one register needed to be saved on
the stack and a MOVEM was used, this wouldn't matter since it doesn't
change the condition codes.  So this is kind of a "special" case (but
it SHOULD still work!)]  So my real clikLoop routine has a bunch of
"return true" and "return false" all over it, instead of a bunch of
"result = true" and "result = false" with one "return result" at the
end... 

Anyway... whose problem is this?  Should Think C be "smart" enough to
work around this, or is the List Manager doing a Bad Thing by assuming
the condition codes are valid without first popping something off the
stack?

--
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 sears@netcom.com (Daniel Sears)
Date: Tue, 10 May 1994 05:23:17 GMT
Organization: NETCOM On-line Communication Services (408 241-9760 guest)

Eddy,

your summary of the clikLoop problem was very good.
I've been having problems porting my clickLoop to the PPC
with its mixed mode madness and your summary clarified things.

On page 4-101 of Mo' Mac Toolbox, it says:

	A click-loop procedure should ordinarily set the Z flag to 1
	just before returning.  If a click-loop sets the Z flag to 0,
	then the LClick function immediately returns.

It later says in the Assembly Language Information section:

	Your click-loop procedure should ordinarily set register d0 to 1.
	To stop the LClick function from calling your procedure for the
	current mouse-down event, set register d0 to 0.

This second section could be a docubug or it could mean shut up,
just stop calling me.

As for whose problem this is, it sounds like a ThinkC code generation bug.
I can't think of any reason why

	return true; and result = true; return result; should be different.

Hope this helps.

Dan
-- 

E-mail:     sears@netcom.com
Phone:      415.695.0650
Address:    2440 16th Street #283
            San Francisco, CA 94103-4211

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

>From leblonk@netcom.com (Marcel Blonk)
Date: Tue, 10 May 1994 08:32:14 GMT
Organization: NETCOM On-line Communication Services (408 241-9760 guest)

: As for whose problem this is, it sounds like a ThinkC code generation bug.
: I can't think of any reason why

It's definitely not a Think C bug, since C compilers don't have anything 
to do with returning condition codes as function results. Maybe the 
Think C manual says somewhere that the CC return values are undefined (but 
not likely, since there is NO reason at all to assume that the CC should 
have any significance)

so:

:         return true; and result = true; return result; should be different.

are EXACTLY equal in C terms.

Who to blaim? Apple I'd have to say. Their documentation says to declare 
the ClickLoop proc as a pascal Boolean returning function (in fact, the 
assembly-language note only reasserts that). So, if in this case, the 
ClickLoop is supposed to return with the Z-bit set appropiately, the 
documentation should have said so (and should have indicated that this 
routine can only be written with the appropiate assembler glue code) 
(It's a strange peace of programming interface anyway, since it also 
states that D5 contains the current mouse point "for your convenience". 
That's a real no-no, if you ask me. The least they could have done, is 
move D5 to D1 (it is eg. impossible to declare D5 as a pragma parameter, 
only D0-D1 and A0-A1 (maybe one more), since that is the convention that 
is used throughout the system)

Anyway, to conclude, seeing that the Z-bit has to be set appropiately, the 
only way to write a proper ClickLoop function, is to add assembler glue 
code. You can in no way rely on the C compiler to do this for you.

mb


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

>From peter.lewis@info.curtin.edu.au (Peter N Lewis)
Date: Wed, 11 May 1994 14:06:00 +0800
Organization: NCRPDA, Curtin University

>On page 4-101 of Mo' Mac Toolbox, it says:
>
>        A click-loop procedure should ordinarily set the Z flag to 1
>        just before returning.  If a click-loop sets the Z flag to 0,
>        then the LClick function immediately returns.

This is correct for the 68k machines, at least in my experience.
>
>It later says in the Assembly Language Information section:
>
>        Your click-loop procedure should ordinarily set register d0 to 1.
>        To stop the LClick function from calling your procedure for the
>        current mouse-down event, set register d0 to 0.

This works only in that it sets the Z flag above.  My solution (in Pascal)
was to do it like this:

{$PUSH}
{$D-}
   function MyClickLoop: boolean; 
{ returns the bloody equal flag for gods sake! }
   begin
      MyClickLoop := MyClickLoop2; { BE VERY CAREFUL!  Returns the equal flag! }
   end;
{$POP}

Comments left unchanged :-)
   Peter.
_______________________________________________________________________
Peter N Lewis <peter.lewis@info.curtin.edu.au>       Ph: +61 9 368 2055

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

>From Dave Allcott <davidall@bedford.symantec.com>
Date: 11 May 1994 14:32:18 GMT
Organization: Symantec Corporation

In article <searsCpKMyu.Avp@netcom.com> Daniel Sears, sears@netcom.com writes:
>As for whose problem this is, it sounds like a ThinkC code generation bug.
>I can't think of any reason why
>
>	return true; and result = true; return result; should be different.
>
>Hope this helps.

I thinks it's still arguable but I'll see what we can do about it in the future.
We should at least have oddities like this documented.

Dave

Depending on condition codes between function calls. tsk tsk. :)

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

>From Mark A. Saper <saper@umich.edu>
Subject: Opening a file with C standard i-o routines
Date: 9 May 1994 15:41:13 GMT
Organization: Biophysic, Univ. of Michigan

This is a question from a novice:

I am writing a drag and drop routine that handles AE's to open a
document.  The result from this is an FSSpec.  How can I use this to open
a file and read it with Think C's standard I/O routines like gets?  I can
open the file, read it into a buffer with Toolbox functions, but is there
any way to link the standard I/O stream with my allocated buffer?

Thanks for your help.
																														Mark Saper, saper@umich.edu

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

>From rmah@panix.com (Robert S. Mah)
Date: Mon, 09 May 1994 19:01:12 -0500
Organization: One Step Beyond

Mark A. Saper <saper@umich.edu> wrote:

> I am writing a drag and drop routine that handles AE's to open a
> document.  The result from this is an FSSpec.  How can I use this to open
> a file and read it with Think C's standard I/O routines like gets?  I can
> open the file, read it into a buffer with Toolbox functions, but is there
> any way to link the standard I/O stream with my allocated buffer?

Translate the FSSpec to a full pathname and then send that to fopen.
Code to do this is on the developer CD's and on ftp.apple.com in 
/dts/mac/snippets/files/ (or somewhere like that)

Cheers,
Rob
___________________________________________________________________________
Robert S. Mah  -=-  One Step Beyond  -=-  212-947-6507  -=-  rmah@panix.com

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

>From marks77@aol.com (MarkS77)
Date: 9 May 1994 20:46:07 -0400
Organization: America Online, Inc. (1-800-827-6364)

This may not be the solution you want, but I've been extracting the file name,
using toolbox calls to set the current directory and just using the standard
C++ stream techniques to access the file.

Mark



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

>From rmah@panix.com (Robert S. Mah)
Date: Tue, 10 May 1994 01:44:48 -0500
Organization: One Step Beyond

marks77@aol.com (MarkS77) wrote:

> This may not be the solution you want, but I've been extracting the file
> name, using toolbox calls to set the current directory and just using the
> standard C++ stream techniques to access the file.

Don't use working directory functions.  The main reason they exist is to
ensure backward compatibility with the old 400K disks (i.e. the MFS file 
system).

If you need to use standard ANSI (or UNIX or C++ streams) files use the
full
pathname.  This is 100% safe and guaranteed to always work.  All it takes
is
the addition of 1 function to create the path name from the FSSpec.

Cheers,
Rob
___________________________________________________________________________
Robert S. Mah  -=-  One Step Beyond  -=-  212-947-6507  -=-  rmah@panix.com

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

>From marks77@aol.com (MarkS77)
Date: 10 May 1994 23:42:02 -0400
Organization: America Online, Inc. (1-800-827-6364)

In article <rmah-090594190112@rmah.dialup.access.net>, rmah@panix.com (Robert
S. Mah) writes:

Don't use working directory functions.  The main reason they exist is to
ensure backward compatibility with the old 400K disks (i.e. the MFS file 
system).


Actually, I usually get an SFReply from Standard File and use the 
vRefNum to do a SetVol call. After this all I need is the file name 
to do use standard C++ I/O. Are we talking about the same thing?

Mark

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

>From rmah@panix.com (Robert S. Mah)
Date: Wed, 11 May 1994 01:06:17 -0500
Organization: One Step Beyond

marks77@aol.com (MarkS77) wrote:

> rmah@panix.com (Robert S. Mah) writes:
> 
> Don't use working directory functions.  The main reason they exist is to
> ensure backward compatibility with the old 400K disks (i.e. the MFS file 
> system).
> 
> Actually, I usually get an SFReply from Standard File and use the 
> vRefNum to do a SetVol call. After this all I need is the file name 
> to do use standard C++ I/O. Are we talking about the same thing?

Yes, that's what I mean.  Don't use SetVol.  There's a tech note on it
that explains why and the inherent dangers.  Convert it to the full 
pathname, it's much safer.

Cheers,
Rob
___________________________________________________________________________
Robert S. Mah  -=-  One Step Beyond  -=-  212-947-6507  -=-  rmah@panix.com

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

>From Daniel C. Flatin <dcf@mps.ohio-state.edu>
Date: 11 May 1994 15:49:05 GMT
Organization: Physics Dept., The Ohio State University

Here is how I use the Mac FSSpec and the standard io calls. I think I
got some of this information from "The Mac Programming Public Domain FAQ"


Dan Flatin
Physics Department
The Ohio State University
dcf@mps.ohio-state.edu

/* ----------------------------------------------------------------------
    This is an fopen which uses a folder FSSpec for the file path instead
    of a full path name.
- -------------------------------------------------------------------- */
FILE    *fopenFS( char *name, FSSpec folder, const char *mode )
{
    FILE        *cFile;
    short       oldWDVol, oldTrueVol;
    long        oldDir, oldProc, folderID;

    cFile = nil;
    
    /* save current working directory */
    if ( GetVol( nil, &oldWDVol ) )
        return( nil );
    /* save current default volume info */
    if ( GetWDInfo( oldWDVol, &oldTrueVol, &oldDir, &oldProc ) )
        return( nil );
    FolderFFSpecToDirID( folder, &folderID );
    /* set selected info as default */
    if ( HSetVol( nil, folder.vRefNum, folderID ) )
        return( nil );
    
    fflush( nil );                      // flush all buffers
    
    cFile = fopen( name, mode );        // open the file
    
    HSetVol( nil, oldTrueVol, oldDir ); // restore default volume info
    
    SetVol( nil, oldWDVol );            // restore working directory
    return( cFile );
}


/* ----------------------------------------------------------------------
    This version of GetFOpen does not require a full path name to open
    the file. The use of full path names to identify files is frowned
    upon by Apple.
- -------------------------------------------------------------------- */
FILE    *GetFOpen( void )
{
    FILE                *cFile;
    StandardFileReply   mySFR;
    SFTypeList          myTypeList;
    char                name[64];
    short               oldWDVol, oldTrueVol;
    long                oldDir, oldProc;

    cFile = nil;
    
    myTypeList[0] = 'TEXT';
    StandardGetFile( nil, 1, myTypeList, &mySFR );
    
    if ( mySFR.sfGood )
    {
        /* save current working directory */
        if ( GetVol( nil, &oldWDVol ) )
            return( nil );
        /* save current default volume info */
        if ( GetWDInfo( oldWDVol, &oldTrueVol, &oldDir, &oldProc ) )
            return( nil );
        /* set selected info as default */
        if ( HSetVol( nil, mySFR.sfFile.vRefNum, mySFR.sfFile.parID ) )
            return( nil );
        
        PascalStrCpy( name, (char *)mySFR.sfFile.name );
        p2cstr( (unsigned char *)name );
        
        fflush( nil );                      // flush all buffers
        
        cFile = fopen( name, "r" );         // open the file
        
        HSetVol( nil, oldTrueVol, oldDir ); // restore default volume info
        
        SetVol( nil, oldWDVol );            // restore working directory
    }
    return( cFile );
}


/* ----------------------------------------------------------------------
    the folder FSSpec contains the volume reference number and the name.
    We need PBGetCatInfo() to get the directory ID. This routine does not
    (yet) check to see that the FFSpec does indeed describe a folder.
- -------------------------------------------------------------------- */
OSErr   FolderFFSpecToDirID( FSSpec folder, long *theDirID )
{
    CInfoPBRec              pb;
    OSErr                   err;
    
    pb.hFileInfo.ioCompletion = NULL;
    pb.hFileInfo.ioNamePtr = folder.name;
    pb.hFileInfo.ioVRefNum = folder.vRefNum;
    pb.hFileInfo.ioFDirIndex = 0;
    pb.hFileInfo.ioDirID = folder.parID;

    err = PBGetCatInfo( &pb, FALSE);
    
    if (  err == noErr)
        *theDirID = pb.dirInfo.ioDrDirID;
    else
        *theDirID = 0;
    
    return ( err );
}


/* ----------------------------------------------------------------------
    PascalStrCpy

    Just like strcpy except that it takes pascal strings as arguments.
- -------------------------------------------------------------------- */
char *PascalStrCpy( char *s1, char *s2 )
{
    *s1 = *s2;
    return( (char *)memcpy( s1+1, s2+1, *s1 ) );
}

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

>From scouten@maroon.tc.umn.edu (Eric Scouten)
Subject: Sym CDK vs CodeWarrior PPC: first impressions
Date: Tue, 10 May 1994 14:23:26 GMT
Organization: University of Minnesota, Student Affairs

Just got my copy of Symantec's CDK yesterday and ran some tests of it
against CodeWarrior PPC on a large application. (Don't consider these tests
scientific by any means; it's just a first glance.)

The application was the Art Class demo from Symantec's TCL 2.0 demos. For
SC++ I used it unmodified from the TCL 2.0.1 disks; for CW, I used the
version that was patched in my CW TCL port (see my earlier post on
comp.sys.mac.oop.tcl for details). Here are the stats:


 SC++ CDK    CW/PPC
 --------   --------
    10         12     Compile project from scratch (160+ files)
     4          1     Link/build application

   330K       415K    Final application size
    85K       1.5M    Number of lines compiled* (see explanation below)


Tests were conducted on my PowerMac 6100/60, 16MB RAM, 160MB disk, virtual
memory off, very few extensions (only those required for debugging).


Getting the CDK to run in 16MB is a hassle. I have to maintain two copies
of the Think Project Manager on my disk; one set for 5MB partition (for
compiling), the other set for 3.5MB (for linking, to share with the 8.5MB
ToolServer partition).

To me, the CDK package is *much* less attractive than the Symantec 68K
compiler or either CodeWarrior compiler. It lacks the quick
compile-link-run turnaround that the others have, and debugging is a step
down from awful.

I don't have two Macs sitting side-by-side to do debugging, so the Apple
debugger that's included with the package is completely useless. Even if I
could convince another debugger to work with the CDK-built apps, it would
be only minimally useful, since there's no access to symbolic information
-- the CDK compiler emits line numbers only.

To its credit, the CDK package produces much smaller code (note the almost
25% difference in app size above). I haven't tested execution speed between
the two compilers.


*Number of lines compiled: I attribute the relatively slow compile time for
CodeWarrior to the fact that most of the TCL headers couldn't be
precompiled. (CW doesn't allow class definitions in precompiled headers.
<hint, hint> ) Thus, CodeWarrior was compiling 17 times more code in only
20% more time. (!)

When CW is able to manage class definitions in the headers, there will be
no comparison! <hint, hint>


BTW, the Bedrock Exception Library is pretty flaky when compiled under
either PPC compiler. Fairly simple things, like opening too many new
documents, cause fatal crashes. (It does seem to be more stable when
compiled under Symantec's 68K compiler.)


-Eric


-- 
Eric Scouten * Univ of Minn * Student Affairs * Minneapolis, MN 55455 USA
             *  <scouten@maroon.tc.umn.edu>   * +1 612 626 0746

I always thought that 'Intel Inside' was a warning required by
Truth in Advertising laws...
   -Anonymous

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

>From cwat03@cs.aukuni.ac.nz (Christopher James F Waters)
Subject: Where is the inheritance in AE objects?
Date: 26 Apr 1994 23:19:37 GMT
Organization: University of Auckland

I am writing my first scriptable application. After coming to grips with IM
InterApplication Communications and the AE registry it isn't really as 
difficult as I expected. However there is one thing that puzzles me. The 
registry talks about inheritance all the time and it is mentioned briefly in
IM but there doesn't seem to be any way that inheritance is enforced. Is it
up to me to ensure that all subclasses include the properties and elements
of their superclass? I would have thought that there would be a field in the
aete resource for specifying the superclass, then it wouldn't be necessary to
redfine properties and elements that have been defined previously.

Also, am I right in thinking that the aete shouldn't contain definitions for
abstract classes?

Chris Waters.
Department of Electrical & Electronic Engineering
University of Auckland.

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

>From rmah@panix.com (Robert S. Mah)
Date: Tue, 26 Apr 1994 21:13:01 -0500
Organization: One Step Beyond

cwat03@cs.aukuni.ac.nz (Christopher James F Waters) wrote:

> registry talks about inheritance all the time and it is mentioned briefly 
> in IM but there doesn't seem to be any way that inheritance is enforced.
> Is it up to me to ensure that all subclasses include the properties and 
> elements of their superclass? 

Yes.  The inheritance is conceptual only.

Cheers,
Rob
___________________________________________________________________________
Robert S. Mah  -=-  One Step Beyond  -=-  212-947-6507  -=-  rmah@panix.com

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

>From paul@ctalk.exnet.com (Paul G Smith)
Date: Wed, 27 Apr 94 12:49:03 GMT
Organization: commstalk, & Full Moon Software Inc


In article <2pk7i9$ffl@ccu2.auckland.ac.nz> (comp.sys.mac.programmer), cwat03@cs.aukuni.ac.nz (Christopher James F Waters) writes:
> 
> I am writing my first scriptable application. After coming to grips with IM
> InterApplication Communications and the AE registry it isn't really as 
> difficult as I expected. However there is one thing that puzzles me. The 
> registry talks about inheritance all the time and it is mentioned briefly in
> IM but there doesn't seem to be any way that inheritance is enforced. Is it
> up to me to ensure that all subclasses include the properties and elements
> of their superclass? I would have thought that there would be a field in the
> aete resource for specifying the superclass, then it wouldn't be necessary to
> redfine properties and elements that have been defined previously.
> 
> Also, am I right in thinking that the aete shouldn't contain definitions for
> abstract classes?
> 
> Chris Waters.
> Department of Electrical & Electronic Engineering
> University of Auckland.
> 

As it happens, the AppleScript 1.1 headers do define a constant you
can use to indicate object inheritance (this from ASRegistry.h):

	pInherits	= 0x6340235e,	//  'c@#^'  //

You can define a property, using this constant, to indicate an object
inherits the properties and elements of another class. Here is an
example of the aete definition for a sub-class:

		/* [4] */
		"my subclass",
		cSubClass,
		"A radio button",
		{	/* array Properties: 1 elements */
			/* [1] */
			"<inheritance>",
			pInherits,
			cSuperClass,
			"subclass of my superclass",
			reserved,
			singleItem,
			notEnumerated,
			readWrite,
			reserved, reserved, reserved, reserved,
			reserved, reserved, reserved, reserved, reserved,
			notFeminine,
			notMasculine,
			singular,
		},
		{	/* array Elements: 0 elements */
		},

The definition will say, to the user who examines your program
Dictionary using a Script Editor, that the class inherits from another;
the Dictionary display will format the property as something like:
	<inheritance> superclass name

The above is not the whole story. You do NOT have to duplicate all the
properties class by class, and the 'pInherits' property is no more than
a hint to the user, because AppleScript will allow any property,
declared anywhere in the aete, to be specified for 'get data' or 'set
data' for any class. In other words, AppleScript doesn't know or care
what object classes support what properties: it is up to the program
that is asked to resolve those properties to complain if an incorrect
property is specified. However, because users look to the Dictionary
to tell them what properties are valid for what object classes, you
should use the 'pInherits' mechanism to tell them what's going on.

Lastly, you might want to look out for the next issue of 'develop'
magazine, which includes an article I wrote about developing
OSA-savvy programs. It doesn't cover the 'pInherits' property, but it
does come with a lot of sample code that will be helpful to newcomers
to the OSA. ('develop' magazine is published by Apple Computer Inc.)


best regards, Paul

- --------------------------------------------------------------
Paul G Smith, Commstalk HQ          ||  UK ph: +44 727 844232
P O Box 116, ST ALBANS              ||    fax: +44 727 856139
Hertfordshire. AL1 2RL. UK          ||  US ph: 408 253 7199
& Full Moon Software, Inc           ||    fax: 408 252 2378
P O Box 700237, SAN JOSE, CA 95170  ||  AppleLink: COMMSTALK.HQ 

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

>From Alan_B._Harper@bmug.org (Alan B. Harper)
Date: Tue,  3 May 94 10:41:34 PST
Organization: Berkeley Macintosh Users Group

As far as I can tell, the "inheritance" in apple-event objects is purely for 
the solopsistic inconvenience of the designer of the classes.  There seems to be

no support for inheritance, and there is no reason at all for abstract classes. 

I have been proceeding by ignoring inheritance, and it doesn't seem to be a 
problem.  I haven't written my aete yet, though.

BTW, is your application recordable?  How do you handle open events for 
files?  As far as I can tell, the only way to send yourself an "open file" apple

event is to parse the FSSpec into an absolute file name and then send it to
yourself.  
Do you know if there is a better way?

Alan

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

>From d88-jwa@dront.nada.kth.se (Jon Wätte)
Date: 4 May 1994 07:40:33 GMT
Organization: The Royal Institute of Technology

In <001479A1.fc@bmug.org> Alan_B._Harper@bmug.org (Alan B. Harper) writes:

>files?  As far as I can tell, the only way to send yourself an "open file" apple

>event is to parse the FSSpec into an absolute file name and then send it to
>yourself.  
>Do you know if there is a better way?

Definately. You can put the FSSpec in the array of files, or you
can put aliases there, created by NewAlias. The latter is the most
preferrable.
-- 
 -- Jon W{tte, h+@nada.kth.se, Mac Hacker Deluxe (on a Swedish scale) --

   "Just because you're paranoid(P) doesn't mean they aren't after(A) you"
          !(P -> !A) == !(!P | !A) == !(!(P & A)) == P & A

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

>From leonardr@netcom.com (Leonard Rosenthol)
Date: Wed, 4 May 1994 17:42:46 GMT
Organization: Aladdin Systems, Inc.

In article <2q7jhh$gqr@news.kth.se>, d88-jwa@dront.nada.kth.se (Jon Wätte)
wrote:

> In <001479A1.fc@bmug.org> Alan_B._Harper@bmug.org (Alan B. Harper) writes:
> 
> >files?  As far as I can tell, the only way to send yourself an "open
file" apple
> 
> >event is to parse the FSSpec into an absolute file name and then send it to
> >yourself.  
> >Do you know if there is a better way?
> 
> Definately. You can put the FSSpec in the array of files, or you
> can put aliases there, created by NewAlias. The latter is the most
> preferrable.
>
   Yup,  that's the way.  And here is the code from my DropShell that
shows how to do it...

Leonard
- ---
/*
   This routine is the low level routine used by the SendODOCToSelf
   routine.  It gets passed the list of files (in an AEDescList)
   to be sent as the data for the 'odoc', builds up the event
   and sends off the event.  

   It is broken out from SendODOCToSelf so that a SendODOCListToSelf could
   easily be written and it could then call this routine - but that is left
   as an exercise to the reader.
   
   Read the comments in the code for the order and details
*/
void _SendDocsToSelf (AEDescList *aliasList)
{
   OSErr       err;
   AEAddressDesc  theTarget;
   AppleEvent     openDocAE, replyAE;

/*
   First we create the target for the event.   We call another
   utility routine for creating the target.
*/
   err = GetTargetFromSelf(&theTarget);
   if (err == noErr) {
      /* Next we create the Apple event that will later get sent. */
      err = AECreateAppleEvent(kCoreEventClass, kAEOpenDocuments,
&theTarget, kAutoGenerateReturnID, kAnyTransactionID, &openDocAE);

      if (err == noErr) {
         /* Now add the aliasDescList to the openDocAE */
         err = AEPutParamDesc(&openDocAE, keyDirectObject, aliasList);

         if (err == noErr) {
            /*
               and finally send the event
               Since we are sending to ourselves, no need for reply.
            */
            err = AESend(&openDocAE, &replyAE, kAENoReply +
kAECanInteract, kAENormalPriority, 3600, NULL, NULL);

            /*
               NOTE: Since we are not requesting a reply, we do not need to
               need to dispose of the replyAE.  It is there simply as a 
               placeholder.
            */
         }

      /* 
         Dispose of the aliasList descriptor
         We do this instead of the caller since it needs to be done
         before disposing the AEVT
      */
         err = AEDisposeDesc(aliasList);
      }

   /*and of course dispose of the openDoc AEVT itself*/
      err = AEDisposeDesc(&openDocAE);
   }
}

/*
   This is the routine called by SelectFile to send a single odoc to ourselves.
   
   It calls the above low level routine to do the dirty work of sending
the AEVT -
   all we do here is build a AEDescList of the file to be opened.
*/
void SendODOCToSelf (FSSpec *theFileSpec) {

   OSErr    err;
   AEDescList  aliasList;
   AEDesc      aliasDesc;
   AliasHandle aliasH;
   
   /*Create the descList to hold the list of files*/
   err = AECreateList(NULL, 0, false, &aliasList);

   if (err == noErr) {
      /* First we setup the type of descriptor */
      aliasDesc.descriptorType = typeAlias;

      /*
         Now we add the file to descList by creating an alias and then
         adding it into the descList using AEPutDesc
      */
      err = NewAlias(NULL, theFileSpec, &aliasH);
      aliasDesc.dataHandle = (Handle)aliasH;
      err = AEPutDesc(&aliasList, 0, &aliasDesc);
      DisposHandle((Handle)aliasH);

      /*Now call the real gut level routine to do the dirty work*/
      _SendDocsToSelf(&aliasList);

      /*_SendDocsToSelf will dispose of aliasList for me*/
   }
}
- ------------------------------------------------------------------------
Leonard Rosenthol                      Internet:       leonardr@netcom.com
Director of Advanced Technology        AppleLink:      MACgician
Aladdin Systems, Inc.                  GEnie:          MACgician

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

>From isis@netcom.com (Mike Cohen)
Date: Wed, 4 May 1994 17:45:41 GMT
Organization: ISIS International

Alan_B._Harper@bmug.org (Alan B. Harper) writes:

>BTW, is your application recordable?  How do you handle open events for 
>files?  As far as I can tell, the only way to send yourself an "open file" apple
>event is to parse the FSSpec into an absolute file name and then send it to
>yourself.  
>Do you know if there is a better way?

>Alan

No, the open file event takes an alias, not a file name. It's very easy to
create an alias from a FSSpec (or, you could just send the FSSpec, since 
there's a built-in coercion handler for alias <-> FSSpec.
-- 
Mike Cohen - isis@netcom.com
NewtonMail, eWorld: MikeC / ALink: D6734 / AOL: MikeC20

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

>From greer@utdallas.edu (Dale M. Greer)
Date: 4 May 1994 19:57:23 GMT
Organization: The University of Texas at Dallas

Mike Cohen (isis@netcom.com) wrote:
> Alan_B._Harper@bmug.org (Alan B. Harper) writes:

> >BTW, is your application recordable?  How do you handle open events for 
> >files?  As far as I can tell, the only way to send yourself an "open file" apple
> >event is to parse the FSSpec into an absolute file name and then send it to
> >yourself.  
> >Do you know if there is a better way?

> >Alan

> No, the open file event takes an alias, not a file name. It's very easy to
> create an alias from a FSSpec (or, you could just send the FSSpec, since 
> there's a built-in coercion handler for alias <-> FSSpec.

It works with full file path names too.

--

Dale Greer, greer@utdallas.edu


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

>From jwbaxter@olympus.net (John W. Baxter)
Date: Wed, 04 May 1994 20:30:55 -0700
Organization: Internet for the Olympic Peninsula

In article <2q8un3$he@news.utdallas.edu>, greer@utdallas.edu (Dale M.
Greer) wrote:

> Mike Cohen (isis@netcom.com) wrote:
> > Alan_B._Harper@bmug.org (Alan B. Harper) writes:
> 
> > >BTW, is your application recordable?  How do you handle open events for 
> > >files?  As far as I can tell, the only way to send yourself an "open file" apple
> > >event is to parse the FSSpec into an absolute file name and then send it to
> > >yourself.  
> > >Do you know if there is a better way?
> 
> > >Alan
> 
> > No, the open file event takes an alias, not a file name. It's very easy to
> > create an alias from a FSSpec (or, you could just send the FSSpec, since 
> > there's a built-in coercion handler for alias <-> FSSpec.
> 
> It works with full file path names too.

"It" only works with full path names if the application has prepared itself
for non-standard forms of the open document event, or something has
installed a system coercion for TEXT to FSSpec (TEXT to alias wouldn't help
typical applications).  Recently, "something" has indeed added a system
handler for TEXT to FSSpec...I believe that the something is AppleScript,
but it could be one of the apps running at this moment in my Mac.  But
there is one, which is why full path name works...relative path name
probably works, too.

The definition of the open document event calls for a list of aliases in
the direct parameter.  Since (a) an alias isn't what the application
ultimately wants (it wants an FSSpec) and (b) the Apple Event Manager will
coerce the alias to an FSSpec for you, and (c) even if something
[incorrectly] sends a single alias rather than a list of one alias, the
event handler should

1.  ask for the direct parameter as a list (if a single item was there, you
get a list of that one item, courtesy of the AE Manager)
2.  count the number of items in the list
3a.  ask for each item from the list, as an FSSpec (since that's how you
want them).
3b.  do something with each item.

The extended form of the open event has a list of object specifiers. 
Conveniently, the needed coercions are in place so that you can ask for
those, instead of the above, if you support the extended form.  That too is
new since the beginning (again probably it is AppleScript doing it...easy
to test by starting without AppleScript).
-- 
John Baxter    Port Ludlow, WA, USA  [West shore, Puget Sound]
   jwbaxter@pt.olympus.net

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

>From jonpugh@netcom.com (Jon Pugh)
Date: Wed, 11 May 1994 07:58:17 GMT
Organization: NETCOM On-line Communication Services (408 241-9760 guest)

Alan B. Harper (Alan_B._Harper@bmug.org) wrote:
> As far as I can tell, the "inheritance" in apple-event objects is purely for 
> the solopsistic [sic] inconvenience of the designer of the classes.  There 
> seems to be no support for inheritance, and there is no reason at all for 
> abstract classes. 

> I have been proceeding by ignoring inheritance, and it doesn't seem to be a 
> problem.  I haven't written my aete yet, though.

This is essentially correct.  You do not need to worry about abstract classes
and there is no support for any objects, only their resolution.  Your OSL
callbacks do all the object stuff and they can be object oriented.  I'm doing
some abstract inherited objects in my current project.  I have an app with
two document types.  Since I want to be able to talk about documents, docfoos
and docbars, it makes sense to subclass them and implement them as inherited
objects.

As usual, all the work is on my shoulders, but I'm used to that.  ;)

Jon


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

>From perlis_a@math.lsu.edu (Alexander Perlis)
Subject: [Q] How to prevent _DragWindow from selecting the window?
Date: 9 May 1994 20:32:29 GMT
Organization: Louisiana State University InterNetNews Site

The _DragWindow trap follows the mouse with an outline of a window and  
then moves the window to the new location when the user releases the  
mouse. After moving the window, unless the user held down the command-key  
when initiating the drag, the window is also selected.

I would like to let users move non-frontmost windows around even when the  
frontmost window is modal and must remain frontmost. If I could fake  
_DragWindow into thinking that the command-key had been held down on the  
previous mouseDown event, I'd be in business. Or if I could patch into  
_DragWindow in the appropriate place to prevent the window selection, I  
would also be in business.

However, tracing through the _DragWindow code is hopeless for my  
less-than-perfect abilities because this routine is in various pieces  
which involve calls to the infamous Layer Manager which we are not  
supposed to touch and not even supposed to try to understand. Patching  
_DragWindow seems to be a bad idea.

How can I convince _DragWindow that the command-key was held down? Or is  
there a better or more obvious way to prevent _DragWindow from selecting  
the window after the drag?

Mystified,
Alexander Perlis
perlis_a@math.lsu.edu

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

>From dean@genmagic.com (Dean Yu)
Date: 10 May 1994 02:36:17 GMT
Organization: General Magic, Inc.

In article <2qm6kt$2m8h@te6000.otc.lsu.edu>, perlis_a@math.lsu.edu
(Alexander Perlis) wrote:
> How can I convince _DragWindow that the command-key was held down? Or is  
> there a better or more obvious way to prevent _DragWindow from selecting  
> the window after the drag?

  How about not calling DragWindow, and calling DragGrayRgn instead? If you
want to be really cool, you can call ClipAbove first so that the region is
clipped behind any window that is above the one that you're dragging. When
the user lets up, you can then call MoveWindow to move the window, passing
false in the front parameter to keep the window where it is.

-- Dean Yu
   Negative Ethnic Role Model
   General Magic, Inc.

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

>From Guenther Blaschek <blaschek@jk.uni-linz.ac.at>
Date: Tue, 10 May 1994 10:16:02 CDT
Organization: University of Linz, Austria

In article <dean-090594193343@dean_yu.genmagic.com> Dean Yu, dean@genmagic.com
writes:
>> How can I convince _DragWindow that the command-key was held down? Or is
>> there a better or more obvious way to prevent _DragWindow from selecting
>> the window after the drag?
>
>  How about not calling DragWindow, and calling DragGrayRgn instead? If you
>want to be really cool, you can call ClipAbove first so that the region is
>clipped behind any window that is above the one that you're dragging. When
>the user lets up, you can then call MoveWindow to move the window, passing
>false in the front parameter to keep the window where it is.

Here's how I did it:

VAR
  windH,windV:Integer; {global variables}

PROCEDURE MyMoveWindow (theWindow: WindowPtr; h, v: Integer; front: Boolean);
  BEGIN
    windH := h;
    windV := v
  END;

PROCEDURE MyDragWindow (w: WindowPtr; pt: Point; bounds: Rect);
  VAR
    oldA5, oldMove: LongInt;
  BEGIN
    oldA5 := SetCurrentA5;
    oldMove := GetTrapAddress($A91B); {MoveWindow}
    SetTrapAddress(LongInt(@MyMoveWindow), $A91B); {patch MoveWindow}
    windH := -32000;
    DragWindow(w, pt, bounds);
    SetTrapAddress(oldMove, $A91B); {restore the patch}
    IF windH <> -32000 THEN {only if MyMoveWindow was called}
      MoveWindow(w, windH, windV, FALSE); {never move the window to front}
    oldA5 := SetA5(oldA5)
  END;

Call MyDragWindow instead of DragWindow.
MyDragWindow temporarily patches MoveWindow by replacing it with MyMoveWindow.
MyMoveWindow simply remembers the position where the window should be moved.
If windH<>-32000 (i.e., if MyMoveWindow was called during DragWindow), the
original MoveWindow is called with the last parameter set to FALSE, which
makes MoveWindow behave as if the command key had been pressed.

 e -- Guenther Blaschek                Tel.:   +43-732-2468-521
gu -- Johannes Kepler University Linz  Fax:    +43-732-2468-426
        Institute of Computer Science  e-Mail: gue@soft.uni-linz.ac.at
                  Software Department          Blaschek@jk.uni-linz.ac.at
                   Altenbergerstr. 69
                 A-4040 Linz, Austria

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

>From Kevin.R.Boyce@gsfc.nasa.gov (Kevin R. Boyce)
Date: Tue, 10 May 1994 12:23:16 -0400
Organization: NASA/GSFC

perlis_a@math.lsu.edu (Alexander Perlis) wrote:

> The _DragWindow trap follows the mouse with an outline of a window and  
> then moves the window to the new location when the user releases the  
> mouse. After moving the window, unless the user held down the command-key  
> when initiating the drag, the window is also selected.

Here's some code that does what Dean Yu suggested (without using ClipAbove
-- that would add to the coolness).  This is a part of my DoMouseDown
routine.


	short		windowPart;
	WindowPtr	whichWindow;
	RgnHandle	rgn, clipRgn;
	Rect		r;
	long		lDistVH;
	short		h,v;
	GrafPtr		savePort;
	
	...
	
	windowPart = FindWindow(evp->where, &whichWindow);
	switch(windowPart)
	{
	case inDrag:
		if( progDialog == whichWindow || psStopped == processingState )
		{
			/*
			 * Just do a normal drag.
			 */
			DragWindow(whichWindow, evp->where, &dragRect);
		}
		else
		{
			/*
			 * If we're processing, and trying to drag the main window,
			 * drag it but don't select it.  (We don't want to allow the user
			 * to change any settings while processing.)  Calling DragWindow()
			 * generates an activate event (and activates the frame) unless
			 * the command key is held down.  Turning on cmdKey in the event
			 * (*evp) doesn't help; DragWindow must check the keyboard.  Yuck.
			 * So I drag it by hand.
			 */
			GetPort( &savePort );
			SetPort( WMgrPort );
			rgn = NewRgn();
			clipRgn = NewRgn();
			GetClip( clipRgn );
			ClipRect( &screenBits.bounds );
			r = (*((WindowPeek)whichWindow)->strucRgn)->rgnBBox;
			RectRgn( rgn, &r );
			r = (*((WindowPeek)whichWindow)->contRgn)->rgnBBox;
			h = r.left - evp->where.h;
			v = r.top - evp->where.v;
			lDistVH = DragGrayRgn( rgn, evp->where, &dragRect, &dragRect, 0, nil );
			if( lDistVH != 0x80008000 )
			{
				h += evp->where.h + ( lDistVH & 0xFFFF );
				v += evp->where.v + ( (lDistVH & 0xFFFF0000) >> 16 );
				MoveWindow( whichWindow, h, v, FALSE );
			}
			SetClip( clipRgn );
			SetPort( savePort );
			DisposeRgn( rgn );
			DisposeRgn( clipRgn );
		}
		break;

It works in my program, on my machine, with my system.  Anything else is
not guaranteed.  But at least it gets the local<->global coordinate
transformation right.
-- 
Kevin      Kevin.R.Boyce@gsfc.nasa.gov
You can blow out a candle, but you can't blow out a fire.
Once the flame begin to catch, the wind will blow it higher.
           --Peter Gabriel, 1980  _Biko_

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

>From dean@genmagic.com (Dean Yu)
Date: 10 May 1994 16:47:56 GMT
Organization: General Magic, Inc.

In article <19940510.101602449417.NETNEWS@ALIJKU11>, Guenther Blaschek
<blaschek@jk.uni-linz.ac.at> wrote:
> Call MyDragWindow instead of DragWindow.
> MyDragWindow temporarily patches MoveWindow by replacing it with MyMoveWindow.
> MyMoveWindow simply remembers the position where the window should be moved.
> If windH<>-32000 (i.e., if MyMoveWindow was called during DragWindow), the
> original MoveWindow is called with the last parameter set to FALSE, which
> makes MoveWindow behave as if the command key had been pressed.

  This is really gross and is exactly why I tell people not to patch
things. This code assumes that DragWindow calls MoveWindow to move the
window after the drag is done. Sure, it's true today but it might not be
tomorrow. If someone like Microsoft makes this assumption, it shackles
system software from ever changing.
  Roll your own. Don't patch.

-- Dean Yu
   Negative Ethnic Role Model
   General Magic, Inc.

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

>From d88-jwa@dront.nada.kth.se (Jon Wätte)
Date: 10 May 1994 17:25:26 GMT
Organization: The Royal Institute of Technology

In <Kevin.R.Boyce-100594122316@sofa.gsfc.nasa.gov> Kevin.R.Boyce@gsfc.nasa.gov (Kevin R. Boyce) writes:

>			GetClip( clipRgn );
>			ClipRect( &screenBits.bounds );

This won't work when you have more than one screen.
You should use
			SetClip ( GetGrayRgn ( ) ) ;
instead.

Interesting trivia: you can pass something "sufficiently close" to
what screenBits . bounds is as a limnitRect to DragWindow; the
toolbox will check for that case and figure out you mean to drag
the window within the whole gray region instead. Talk about
compatibility hack...

-- 
 -- Jon W{tte, h+@nada.kth.se, Mac Hacker Deluxe (on a Swedish scale) --
   The word "politics" is derived from the word "poly", meaning
   "many", and the word "ticks", meaning "blood sucking parasites".
                     -- Larry Hardiman

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

>From Guenther Blaschek <blaschek@jk.uni-linz.ac.at>
Date: Wed, 11 May 1994 09:29:07 CDT
Organization: University of Linz, Austria

In article <dean-100594094430@dean_yu.genmagic.com> Dean Yu, dean@genmagic.com
writes:
>> Call MyDragWindow instead of DragWindow.
>> MyDragWindow temporarily patches MoveWindow by replacing it with
MyMoveWindow.
>> MyMoveWindow simply remembers the position where the window should be moved.
>> If windH<>-32000 (i.e., if MyMoveWindow was called during DragWindow), the
>> original MoveWindow is called with the last parameter set to FALSE, which
>> makes MoveWindow behave as if the command key had been pressed.
>
>  This is really gross and is exactly why I tell people not to patch
>things. This code assumes that DragWindow calls MoveWindow to move the
>window after the drag is done. Sure, it's true today but it might not be
>tomorrow. If someone like Microsoft makes this assumption, it shackles
>system software from ever changing.
>  Roll your own. Don't patch.

It is correct that the code assumes that DragWindow calls MoveWindow,
but I did not guess that or get this knowledge thru experiments.
Rather, IT'S DOCUMENTED IN INSIDE MACINTOSH!

IM Vol. I, p. 289:
"... When the mouse button is released, DragWindow calls MoveWindow to move
theWindow to the location to which it was dragged. If theWindow isn't the
active window (and the Command key wasn't being held down), DragWindow
makes it the active window by passing TRUE for the front parameter when
calling MoveWindow. ..."

I believe that temporarily patching MoveWindow is actually safer than
re-implementing DragWindow. If, for some reason, the mechanism to move
windows changed, the re-implementation would not work any longer, whereas
my solution would still work because the new DragWindow would be called
which would then call MoveWindow -- and that's guaranteed because it is
documented.

 e -- Guenther Blaschek                Tel.:   +43-732-2468-521
gu -- Johannes Kepler University Linz  Fax:    +43-732-2468-426
        Institute of Computer Science  e-Mail: gue@soft.uni-linz.ac.at
                  Software Department          Blaschek@jk.uni-linz.ac.at
                   Altenbergerstr. 69
                 A-4040 Linz, Austria

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

>From parkb@bigbang.Stanford.EDU (Brian Park)
Subject: [Q] casting Str255 <--> (char*)
Date: 6 May 1994 21:07:07 GMT
Organization: Stanford University

I'm having a little problem understanding casting a (char*) to
(Str255), with strict prototype checks.
Consider the following small code segment in THNIK C 7.0:

void do_pascal(Str255 p);
void do_c(char *c)
{
	char t[256];

	strcpy(t, c);
	CtoPStr(t);
	do_pascal(t);	/* gives compile time error here */
}

It gives an error, saying prototype doesn't match.  Now I try

	do_pascal((Str255)t);	/* error */
	do_pascal((Str255*)t);	/* error */
	do_pascal(*(Str255*)t); /* compiles */

Obviously, I thought I understood C strings/arrays, but I don't.
Shouldn't the first one work?  I don't even understand what the
third one is saying, "convert t into a pointer to a pointer to array
of 256 characters, then convert it to a pointer to an array of 256 char"?
That's what I said in the first one. :-)

Brian Park

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

>From Carl R. Osterwald <carl_osterwald@nrel.gov>
Date: Fri, 6 May 1994 00:16:10 GMT
Organization: National Renewable Energy Laboratory

In article <2qebhr$2lk@nntp2.Stanford.EDU> Brian Park,
parkb@bigbang.Stanford.EDU writes:
>I'm having a little problem understanding casting a (char*) to
>(Str255), with strict prototype checks.
>Consider the following small code segment in THNIK C 7.0:
>
>void do_pascal(Str255 p);
>void do_c(char *c)
>{
>	char t[256];
>
>	strcpy(t, c);
>	CtoPStr(t);
>	do_pascal(t);	/* gives compile time error here */
/****argument does not match prototype****/
>}
>
>It gives an error, saying prototype doesn't match.  Now I try
>
>	do_pascal((Str255)t);	/* error */
/****illegal cast****/
>	do_pascal((Str255*)t);	/* error */
/****argument does not match prototype****/
>	do_pascal(*(Str255*)t); /* compiles */

The Macintosh header files define Pascal strings with _unsigned chars_,
like:
  unsigned char Str255[256], Str63[64], Str31[32], *StringPtr;

So the argument to do_pascal is really a pointer to an unsigned char. 
Your first attempt to call do_pascal is rejected because t is a pointer
to a normal c char.  The second fails because you are trying to cast a
pointer into an array.  The third fails because you cast a pointer to an
unsigned char into a pointer to an array, which is different to the
compiler.  The last one works (compiles) because you dereference the
pointer to an array.  I don't think it will give the right answer,
though.  So, you can change the do_pascal call to:
  do_pascal( (unsigned char *)t );

Better yet, change the argument to do_pascal to a StringPtr, and you end
up with:
void do_pascal(StringPtr p);
void do_c(char *c)
{
	char t[256];

	strcpy(t, c);
	CtoPStr(t);
	do_pascal( (StringPtr)t );
}

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

>From Shahid Alam <shahid@mail.utexas.edu>
Date: 7 May 1994 00:07:25 GMT
Organization: UT Austin/General Libraries/Library Systems

In article <2qebhr$2lk@nntp2.Stanford.EDU> Brian Park,
parkb@bigbang.Stanford.EDU writes:
> I'm having a little problem understanding casting a (char*) to
> (Str255), with strict prototype checks.
> Consider the following small code segment in THNIK C 7.0:
> 
> void do_pascal(Str255 p);
> void do_c(char *c)
> {
> 	char t[256];
> 
> 	strcpy(t, c);
> 	CtoPStr(t);
> 	do_pascal(t);	/* gives compile time error here */
> }

The definition of Str255 is

	typedef unsigned char Str255[256];
			^^^^^^^^
It's that unsigned that's causing this statement to be flagged as an
error:

	char[256]   <>    unsigned char[256]

With complete typechecking this conversion must be explicit. However,
explicit conversion is also a problem since, you cannot typecast to
array.  Arrays, while glorified pointers, are special in that they
cannot represent an lvalue, and similarly cannot be cast to. Which is
what your problem in the next statement is:

> 
> It gives an error, saying prototype doesn't match.  Now I try
> 
> 	do_pascal((Str255)t);	/* error */

In order to cast to an array you must cast to the pointer to the array.
The following does not work however, because here you are basically
typecasting a "char[256]", conceptually same as "char*" in C, which is
what t is, to a "unsigned char[256]*", conceptually "unsigned char**",
thus the problem.


> 	do_pascal((Str255*)t);	/* error */

And the following typecast, "char[256]*" (pointer to t, or pointer to
array of char) to "unsigned char[256]*" (String255*, or pointer to an
array of unsigned char), works:

> 	do_pascal(*(Str255*)t); /* compiles */
>
> Obviously, I thought I understood C strings/arrays, but I don't.
> Shouldn't the first one work?  I don't even understand what the
> third one is saying, "convert t into a pointer to a pointer to array
> of 256 characters, then convert it to a pointer to an array of 256 char"?
> That's what I said in the first one. :-)

This is all as I understand it.  I don't have K&R handy.  If I am mistaken,
I'm sure somebody will be kind enough to point it out.

> Brian Park
_____________________________________________________________________________
Shahid M. Alam                                        
shahid@mail.utexas.edu

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

>From parkb@bigbang.Stanford.EDU (Brian Park)
Date: 9 May 1994 02:12:33 GMT
Organization: Stanford University

Carl R. Osterwald  <carl_osterwald@nrel.gov> wrote:
>So the argument to do_pascal is really a pointer to an unsigned char. 
[...]
>  do_pascal( (unsigned char *)t );

yes, yes!  Now I get it!  I did know that (char *) != (unsigned char *), 
but didn't connect it to this problem.  Feel pretty stupid now.  
I still think that casting to (Str255) should be legal but who am I to
argue with a compiler?  As Carl suggested, the proper way around all
this is to use the pre-defined type StringPtr.  Thanks all.

Brian Park

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

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