unofficial mirror of emacs-devel@gnu.org 
 help / color / mirror / code / Atom feed
* Info tutorial is out of date
@ 2006-07-15 14:44 Drew Adams
  2006-07-15 15:04 ` David Kastrup
                   ` (3 more replies)
  0 siblings, 4 replies; 114+ messages in thread
From: Drew Adams @ 2006-07-15 14:44 UTC (permalink / raw)


I just tried the beginning of the Info tutorial again, after a lapse of a
couple decades (!). It doesn't seem to have changed much. I remembered it
with more fondness than I felt this time around. Keep in mind that, like
Info, it was created long before the Web and mice and such. Back around that
campfire, it made sense to explain in detail about nodes and menus and the
magic keys you used to get around. Nowadays, some of it seems quaint, some
seems crippling.

Here's my rant; take it for what you will. Hope it helps somehow.

The start of the tutorial teaches you `n', then `p', then `m', then `C-l',
and so on. Those keys should be regarded nowadays as shortcuts - quick
alternatives to the obvious navigational equivalents of clicking links or
using the menu-bar menu. Don't forget that the user somehow got into the
Info tutorial with no help - probably by clicking the link at the `dir'
node.

I don't even see why `C-l' is mentioned anymore, especially at the very
beginning of the tutorial. It was important back when 14K baud was a fast
transmission speed and your screen got "garbaged" (to quote the tutorial)
from time to time. You needed to learn `C-l' at the beginning, because if
your screen got garbled then you were lost in the tutorial - that was a game
in itself (much more interesting than invisible text). `C-l' is just a
vestige of the bad-ole-days - lose it.

With absolutely no instruction, a user will figure out immediately how to
move among nodes - the equivalent of `n', `p', `u', and `m', because they
*see* the corresponding links and buttons. Clicking links and buttons is a
fine way to get around, to get the info you need - at least in the
beginning. Teaching `n' and `p' does not need to take up the first several
minutes of the tutorial - it should be presented much later, perhaps in a
(brief) lesson on keyboard shortcuts.

It's OK at some point to point out that, unlike Web pages but like the
structure of a book, Info nodes are organized into a tree (menu): up, next,
and so on. But a lite version of that explanation will suffice, nowadays.
Again, all this emphasis on navigation commands is but a vestige of a time
when there were no links or buttons, when the universe was still a mouseless
void.

What it *is* important to teach up front are the important functionalities
of Info that are *not* so obvious (visible). Foremost among these are `i',
`s', and `l' (and, later, `g').

The first thing the tutorial should do is take a tour of the menu-bar menu -
that is, those menu items that are the most important. This is also the
opportunity to point out the key bindings indicated in the menu. That is the
way to introduce the shortcuts `i', `s', and `l', for instance - in passing.

Touring the menu can also be used to introduce the structure of a normal
Info manual. By that, I don't mean menus with up and next, so much as
showing that there is a table of contents (or two or three) and an index,
and how to use them effectively. And if the Info manual had a glossary (it
should, especially since it has its own jargon), then that could be
introduced too.

Users will also find the toolbar by themselves, and they may use that first
for some things (such as index lookup), because it is more obvious than the
menu-bar menu. It's worth taking a tour of the menu because it shows the
keyboard shortcuts, which the toolbar icons do not. Showing the menu-bar
menu and its shortcuts will help wean newbies from the toolbar, at least in
terms of awareness.

BTW, the help text (tooltip) for the search toolbar icon should not scare
people away by mentioning regular expressions. It should say simply `Search
the manual'. If you don't think that's enough, then it could say `Search the
manual (regexp is OK)'. None of the tooltips should use the word "file" -
they should say "manual". And we should think about changing the keyword
`File:' at the top of each node to `Manual:' - there is no reason that users
should think in terms of files here.

I'll say one more time, in passing, that an icon for deletion (X) should not
be used for quitting Info - that is a bad idea. Several other possibilities
were suggested previously (e.g. the international icon for an exit: arrow
exiting a room), and there are lots of quit icons to choose from. But that
particular X is often used for deletion, a confusion we don't want here.

The Info tutorial itself should be accessible (listed) in the menu of the
first node of the Info manual. Instead, it is only mentioned in the text of
that node, in terms of `h'. Before entering the tutorial, we should tell
users how to exit it, to get back where they were. BTW, `h' should not bring
up the tutorial, it should display a mini-version of what `C-h m' shows: a
short list of the main key bindings - about the same as what's in the
menu-bar menu, but with some explanation. There is no need to have a key
binding just to bring up the Info tutorial - people won't be doing that 30
times a day.

In general (exceptions can be made), key bindings should not be introduced
until much later, and then they should be introduced as shortcuts for
functionalities the user already knows by then. It is the functionalities
that should be on the agenda, not the keys. The emphasis is all wrong in
this respect. You lose the forest of functionalities because of all the
trees of keys.

The node `Invisible text in Emacs Info' is incomprehensible to me
("invisible text is really a part of the text"!?). Yow! Why are we telling
users about killing and yanking Info text? (I guess printing is OK.) Why is
this near the beginning of the tutorial? I really, really do not get this.

This node (`Help-Inv') will scare anyone away from using Info. It is worse
than unneeded; it is a downright nuisance. 3/4 of it is  composed of crazy
disclaimers that users won't understand ("Only the invisibility property is
affected by Visible mode" (yow!), and "When, in this tutorial, we refer to
the `Emacs' behavior, we mean the _default_ Emacs behavior" (YOW!!)). BTW,
what is the reason for the menu in this node? It doesn't seem to be used or
useful or understandable.

The rule in the tutorial should be that we don't tell people things - we
walk them through doing things. Node `Help-Inv' is not just confusing and
useless; it also violates this rule. If it were really important for users
to know about `visible-mode' and such, then the tutorial should walk them
through using it. But in this case, please don't; just get rid of this node!
This appears to be an ugly hack to enable the same tutorial to be used in
Emacs and standalone Info. Spare the user this kind of all-too-visible
bandaid.

In general, instead of introducing so many key bindings (e.g. `]'), the
tutorial should spend the user's time taking a tour of Info *functionality*.
Touring the menu-bar menu is a good way to explore the main functionalities:
show what's there and what it does. In addition to the features in the
menu-bar menu, teach SPC and DEL - that's about it. In the menu-bar menu,
teach these first: `q', `l', `s', and `g'. Why? because they're not obvious
(visible, as in links and buttons), and they're essential.

Most of what is presented now in the tutorial is either obvious or arcane.
The most important things to teach are index lookup and search. They should
be done with care, and simple regexp search can be taught here with useful
examples. It's good to teach `goto-node' (`g') too, because people will find
instructions in emails and on Web sites to go to node `Blah'.

Perhaps some of my remarks are inappropriate wrt the standalone reader - I
don't know. I used the tutorial only inside Emacs. Adjust my remarks as
needed. If the standalone Info still uses only keyboard keys, so that
everything I suggested above is irrelevant, then perhaps we need two
different tutorials now.

HTH.

^ permalink raw reply	[flat|nested] 114+ messages in thread

end of thread, other threads:[~2006-07-21  1:11 UTC | newest]

Thread overview: 114+ messages (download: mbox.gz follow: Atom feed
-- links below jump to the message on this page --
2006-07-15 14:44 Info tutorial is out of date Drew Adams
2006-07-15 15:04 ` David Kastrup
2006-07-15 17:07   ` Drew Adams
2006-07-16  6:25     ` Richard Stallman
2006-07-16 17:33       ` Drew Adams
2006-07-16 18:02         ` Eli Zaretskii
2006-07-17 16:06         ` Richard Stallman
2006-07-20 19:03       ` Slawomir Nowaczyk
2006-07-20 23:10         ` Miles Bader
2006-07-21  1:11           ` Slawomir Nowaczyk
2006-07-15 17:46 ` Thien-Thi Nguyen
2006-07-15 23:41   ` Drew Adams
2006-07-16  8:29     ` Thien-Thi Nguyen
2006-07-16 17:33       ` Drew Adams
2006-07-16 17:52       ` Eli Zaretskii
2006-07-16 18:51         ` Thien-Thi Nguyen
2006-07-15 22:14 ` Alan Mackenzie
2006-07-15 22:56   ` martin rudalics
2006-07-15 23:41     ` Drew Adams
2006-07-15 23:41   ` Drew Adams
2006-07-16  0:26     ` Drew Adams
2006-07-16  6:23     ` David Kastrup
2006-07-16 17:33       ` Drew Adams
2006-07-16 17:49         ` David Kastrup
2006-07-20 19:03           ` Slawomir Nowaczyk
2006-07-16 18:42         ` Jay Belanger
2006-07-16 19:24           ` Lennart Borgman
2006-07-16 20:13             ` Jay Belanger
2006-07-16 20:28               ` Lennart Borgman
2006-07-20 19:03               ` Slawomir Nowaczyk
2006-07-20 19:35                 ` Jay Belanger
2006-07-16 22:16           ` Mathias Dahl
2006-07-17  3:09           ` Stefan Monnier
2006-07-17  3:54             ` Luc Teirlinck
2006-07-17  5:07               ` Luc Teirlinck
2006-07-17  5:54               ` Eli Zaretskii
2006-07-17 16:54                 ` Drew Adams
2006-07-17 19:06                   ` Eli Zaretskii
2006-07-17 23:01                     ` Drew Adams
2006-07-18  3:32                       ` Eli Zaretskii
2006-07-18  4:37                         ` Drew Adams
2006-07-18 19:42                           ` Eli Zaretskii
2006-07-18 22:19                             ` Drew Adams
2006-07-19  3:01                               ` Eli Zaretskii
2006-07-17 16:37               ` Drew Adams
2006-07-17 19:01                 ` Eli Zaretskii
2006-07-17 23:01                   ` Drew Adams
2006-07-18  3:34                     ` Eli Zaretskii
2006-07-18  4:37                       ` Drew Adams
2006-07-18 19:43                         ` Eli Zaretskii
2006-07-18 22:19                           ` Drew Adams
2006-07-19  3:02                             ` Eli Zaretskii
2006-07-18 13:37                 ` Richard Stallman
2006-07-18  0:13               ` Richard Stallman
2006-07-18  4:40                 ` Luc Teirlinck
2006-07-18  5:03                   ` Drew Adams
2006-07-18 15:00                   ` Richard Stallman
2006-07-17  4:20             ` Luc Teirlinck
2006-07-18  2:03             ` Miles Bader
2006-07-18 14:24               ` Stefan Monnier
2006-07-19  3:18                 ` Miles Bader
2006-07-17 16:06           ` Richard Stallman
2006-07-17 16:37           ` Drew Adams
2006-07-17 17:03             ` Jay Belanger
2006-07-17 17:11               ` Drew Adams
2006-07-17 19:01                 ` Jay Belanger
2006-07-17 23:01                   ` Drew Adams
2006-07-17 13:21         ` Alan Mackenzie
2006-07-17 16:37           ` Drew Adams
2006-07-20 19:03             ` Slawomir Nowaczyk
2006-07-20 22:41             ` Richard Stallman
     [not found]       ` <87k66devap.fsf_-_@hans.local.net>
2006-07-16 20:28         ` Info tutorial is out of date; mouse usage David Kastrup
2006-07-16 21:13           ` Drew Adams
2006-07-16  9:08     ` Info tutorial is out of date Alan Mackenzie
2006-07-16 17:33       ` Drew Adams
2006-07-16 18:44         ` Thien-Thi Nguyen
2006-07-16 22:28         ` Mathias Dahl
2006-07-16 23:35         ` Alan Mackenzie
2006-07-16 22:57           ` Mathias Dahl
2006-07-17  1:07           ` Drew Adams
2006-07-17  9:33             ` Alan Mackenzie
2006-07-17 12:49             ` Robert J. Chassell
2006-07-17  8:19           ` Alan Mackenzie
2006-07-18  2:29         ` Miles Bader
2006-07-18  4:37           ` Drew Adams
2006-07-18  7:03             ` Thien-Thi Nguyen
2006-07-18 15:00             ` "shortcut" Richard Stallman
2006-07-19  3:35             ` Info tutorial is out of date Miles Bader
2006-07-17  1:40       ` Richard Stallman
2006-07-17  2:16         ` Jay Belanger
2006-07-17  9:44         ` Alan Mackenzie
2006-07-17 12:25           ` Sascha Wilde
2006-07-17 14:37             ` Mathias Dahl
2006-07-17 14:41               ` Lennart Borgman
2006-07-17 16:37             ` Drew Adams
2006-07-17 18:57               ` Eli Zaretskii
2006-07-17 23:01                 ` Drew Adams
2006-07-18  9:38                   ` Alan Mackenzie
2006-07-18 15:28                     ` Drew Adams
2006-07-18 16:57                       ` Thien-Thi Nguyen
2006-07-18 17:39                         ` Drew Adams
2006-07-18 19:06                           ` Thien-Thi Nguyen
2006-07-18 17:34                       ` Thien-Thi Nguyen
2006-07-17 16:37           ` Drew Adams
2006-07-19  2:23           ` Brad Collins
2006-07-19  9:53             ` Alan Mackenzie
2006-07-19 14:38             ` Richard Stallman
2006-07-17 12:48         ` Robert J. Chassell
2006-07-18  0:12           ` Richard Stallman
2006-07-18 13:39             ` David Hansen
2006-07-16  2:16   ` Jorgen Schaefer
2006-07-16 17:30   ` Richard Stallman
2006-07-16  6:25 ` Richard Stallman
2006-07-16 17:33   ` Drew Adams

Code repositories for project(s) associated with this public inbox

	https://git.savannah.gnu.org/cgit/emacs.git

This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox;
as well as URLs for read-only IMAP folder(s) and NNTP newsgroup(s).