Linux Zone

| HowTo Linux Zone | Linux Zone Home | E-Mail Me |

The Linux Emacspeak HOWTO


Jim Van Zandt, jrv@vanzandt.mv.com

v.1.6, 10 April 1999

This document describes how a blind user can use Linux with a speech

synthesizer to replace the video display. It describes how to get

Linux running on your own PC, and how to set it up for speech output.

It suggests how to learn about Unix.

______________________________________________________________________

Table of Contents

 

1. Introduction

2. Stage 1. DOS with speech

2.1 Getting Linux on CDROM

2.2 Getting Linux by FTP

2.3 Linux Documentation

3. Stage 2. Terminal to remote UNIX system

3.1 Learning Unix

3.2 Learning Emacs

4. Stage 3. Terminal to local Linux system

4.1 Installing Linux

4.2 Learning Unix System Administration

5. Stage 4. Emacspeak under Linux

5.1 Emacspeak Introduction - Speech Enabled Normal Commands

5.2 Emacspeak Introduction - New Commands

5.3 Emacspeak Introduction - Using the Help System

6. Footnotes and References

6.1 JAWS

6.2 TELIX

6.3 COMMO

6.4 SimTel

6.5 InfoMagic

6.6 Walnut Creek

6.7 Red Hat

6.8 Craftwork

6.9 Yggdrasil

6.10 Emacs for DOS

6.11 GNU Mirror Sites

6.12 Emacspeak with Earlier Slackware Releases

7. Frequently Asked Questions (FAQ)

7.1 Why does it say "space" after each character?

7.2 Why the high pitched tone from a DECtalk?

7.3 Why the "No library autorevert in search path" message?

7.4 How do I change Emacspeak defaults?

7.5 What if an error message is not spoken?

7.6 The terminal emulator is the most problematic portion of Emacspeak.

7.7 In a term buffer, the first half screen is not spoken

7.8 Term mode gets flaky after a long session.

8. Legalese

 

______________________________________________________________________

1. Introduction

Emacspeak is an Emacs subsystem that allows the user to get feedback

using synthesized speech.

Screen reading programs allow a visually impaired user to get feedback

using synthesized speech. Such programs have been commercially

available for well over a decade. Most of them run on PC's under DOS,

and there are now a few screen-readers for the Windows platform.

However, screen-readers for the UNIX environment have been conspicuous

in their absence.

This means that most visually impaired computer users face the

additional handicap of being DOS-impaired :-)

Emacspeak is an emacs subsystem that provides basic speech access.

Emacspeak will always have the shortcoming that it will only work

under Emacs. This said, there is very little that cannot be done

inside Emacs, so it's not a real shortcoming:-) Within Emacs, you can

open a "shell window" where you can run commands and examine their

output, even output which has scrolled out of the window. Emacs

provides special modes for running certain commands. For example, it

can parse error messages printed by a compiler and open a separate

edit window with the cursor at the point of the error. It can also

run a debugger and keep a separate edit window open at the point in

the source code corresponding to the program counter.

Emacspeak does have a significant advantage: since it runs inside

Emacs, a structure-sensitive, fully customizable editor, Emacspeak

often has more context-specific information about what it is speaking

than its commercial counterparts. In this sense, Emacspeak is not a

"screenreader", it is a subsystem that produces speech output. A

traditional screen-reader speaks the content of the screen, leaving it

to the user to interpret the visually laid-out information.

Emacspeak, on the other hand, treats speech as a first-class output

mode; it speaks the information in a manner that is easy to comprehend

when listening.

This initial version provides a basic speech subsystem for Emacs;

using Emacs' power and flexibility, it has proven straightforward to

add modules that customize how things are spoken, e.g. depending on

the major/minor mode of a given buffer. Note that the basic speech

functionality provided by Emacspeak is sufficient to use most Emacs

packages effectively; adding package-specific customizations makes the

interaction much smoother. This is because package-specific

extensions can take advantage of the current context.

Emacspeak will only work with emacs. However, emacs can be used to

run any program that has a command-line interface (ls, cd, rm,

adduser, etc.). In general use M-x shell to run such programs.

You can even run those like less or lynx which use escape sequences to

control the appearance of the screen. The key to this is term mode,

which you get with the emacs command M-x term.

Let me insert here some explanation, because the word "terminal" is

used in several senses. The original terminal was of course an

electromechanical device that translated keystrokes into character

codes and received the same codes and printed the characters.

Eventually these were replaced by entirely electronic "dumb terminals"

which also implemented escape sequences to clear the screen, move the

cursor, etc. Unix adapted to these by introducing an abstract notion

of a "terminal" with very general capabilities. A program like a text

editor issues generic commands, which are translated into the commands

suitable for your terminal. The choice of translation is controlled

by the variable "TERM" in the environment. One common value for this

variable is "vt100", since many terminals implement the same commands

as the DEC VT100. The Emacs command `M-x term' starts a virtual

terminal with its own set of cursor commands. It notifies the

operating system of this by setting the environment variable "TERM" to

the value "eterm" (which is why it is sometimes called eterm mode).

Note that this Unix "terminal" is concerned only with escape commands

for the display. Let me just mention a couple of other kinds of

"terminal" to distinguish them from the Unix concept: For DOS, there

are "terminal emulators" like COMMO and TELIX that simulate a

terminal, and can be used to connect to a remote computer via a serial

port (and usually a modem). That is, they accept keystrokes and send

the character codes out a serial port, and receive character codes

from the serial port and display them. Unix has similar programs,

such as minicom and seyon. Both DOS and Unix have another program

called "telnet" which can establish a similar connection to a separate

computer using the Internet (that is, a TCP/IP connection rather than

a serial connection). The program "kermit" is available for both DOS

and Unix, and can establish either kind of connection. However, none

of these should be confused with the eterm mode of emacs. There is

nothing about eterm mode that implies a connection to a remote

computer.

Note that in most cases there is an emacs mode that works better than

the separate program in an eterm buffer. That is, instead of "less",

just open a buffer on the file. Instead of "lynx", use w3. Instead

of "man", use `M-x man', and type the name of the program in the

minibuffer.

Remember, though: ordinary command-line oriented programs are best run

in shell mode, which starts with the command `M-x shell'.

Emacs is a large program, but it does not all have to be in RAM,

because Linux has virtual memory. You can designate a swap partition,

so that programs (or parts of programs) can be swapped out when they

are not being used. You can comfortably run emacs with 8 MB of ram

plus 8 MB of swap space.

This document is limited to the following:

 

· Linux (not Free BSD)

· The Slackware distribution (not Red Hat, Debian, etc.)

· Speech output only (not Braille - see the Access HOWTO)

· DECtalk (Dectalk Express and MultiVoice), DoubleTalk, LiteTalk,

Braille 'n Speak, Type 'n Speak, Braille Lite, Apollo, and Accent

synthesizers (--not the SmarTalk, a sound card, etc.)

· Use of Emacs, with T. V. Raman's Emacspeak package, to drive the

synthesizer.

The use of adaptive technology with Linux, and in particular, using

adaptive technology to make Linux accessible to those who could not

use it otherwise, is covered in the Linux Access HOWTO.

If you would like to help extend this document to cover one or more of

the other alternatives, or point me to a discussion somewhere else,

please contact me.

The most recent version of this document should be available in

several formats at <ftp://metalab.unc.edu/pub/Linux/docs/HOWTO/> and

its mirrors (see below). The plain text version should be available

at <ftp://leb.net/pub/blinux/doc/>.

Emacspeak was written by T. V. Raman raman@adobe.com. Emacspeak has a

Web page at

<http://www.cs.cornell.edu/Info/People/raman/emacspeak/emacspeak.html>.

Emacspeak supports several speech synthesizers. The software required

depends on which you have.

If you have a DECtalk Express or MultiVoice, you need the basic

Emacspeak package, tcl (an interpreter), and tclx (extensions for

tcl). You can get the source package for Emacspeak from the Emacspeak

web page, or a binary package in one of the popular distributions of

Linux (Slackware, Red Hat, or Debian). I build each of these

packages. Since I normally run Debian, the Debian package will be

available a little sooner than the others. At this writing, the most

recent release of Emacspeak is version 7.0. Here are some URLs:

<http://leb.net/pub/blinux/emacspeak/cornell.mirror>

<ftp://leb.net/pub/blinux/emacspeak/blinux/emacspeak-6.0-2.i386.rpm>

 

Note: there are European mirrors of the blinux site which you should

use if they closer:

<ftp://ftp.uni-muenster.de/share/public6/>

<ftp://ftp.gwdg.de/pub/linux/misc/blinux/>

 

For the internal DECtalk PC, you also need a kernel driver which is

available from <ftp://leb.net/pub/blinux/dectalk_pc-0.91.tgz>

Extract it with the command: `tar xfz dectalk_pc-0.91.tgz' and then

follow the installation instructions found in the README file. This

driver apparently works with both the original DECTALK-pc and the new

DECTALK-PC II.

For the external DoubleTalk, LiteTalk, Accent, or Apollo synthesizers,

or for the Braille 'n Speak, Type 'n Speak, or Braille Lite devices in

"speech box" mode, you need the Emacspeak package and a separate

"speech server" which comes in the emacspeak-ss package:

<ftp://leb.net/pub/blinux/emacspeak/blinux/emacspeak-ss-0.5.tar.gz>

 

The DoubleTalk and LiteTalk are also supported by a separate speech

server which has been packaged for Red Hat and Debian systems:

<http://www.mv.com/ipusers/vanzandt/emacspeak-dt-tcl-1.2.tar.gz>

<ftp://leb.net/pub/blinux/emacspeak/blinux/emacspeak-

dt-1.2-1.i386.rpm> <http://www.mv.com/ipusers/vanzandt/emacspeak-

dt_0.27-1_i386.deb> <http://www.mv.com/ipusers/vanzandt/emacspeak-dt-

tcl_1.2-1_all.deb>

 

For the internal DoubleTalk, you need three pieces of software: the

basic Emacspeak package, the emacspeak-ss or emacspeak-dt package, and

a device driver. Here are some URLs for the device driver:

<ftp://leb.net/pub/blinux/emacspeak/blinux/dtlk-1.12.tar.gz>

<http://www.mv.com/ipusers/vanzandt/dtlk-1.12.tar.gz>

<http://www.mv.com/ipusers/vanzandt/dtlk_1.12-1_i386.deb>

 

 

There is a server for the Braille 'n Speak, Braille Lite, and Type 'n

Speak devices used in "speech box" mode:

<ftp://leb.net/pub/blinux/emacspeak/blinux/emacspeak-bs-

tcl-1.2.tar.gz> <ftp://leb.net/pub/blinux/emacspeak/blinux/emacspeak-

bs-tcl_1.2-1_all.deb> <ftp://leb.net/pub/blinux/emacspeak/blinux/emac&SHY;

speak-bs-1.2-1.i386.rpm>

 

Once again, the emacspeak-ss server handles all the synthesizers other

than the DECtalk. You should use that one if you don't mind building

and installing a source package.

Computer hardware, Unix user commands, Unix system administration,

Emacs, and Emacspeak are each substantial subjects. Attempting to

learn all of them at once is likely to lead to frustration. Instead,

I suggest that the new user go through a sequence of stages, learning

about only one system at a time.

 

2. Stage 1. DOS with speech

Most blind computer users have speech synthesizers with a screen

reader program like JAWS [``JAWS'']. (References in this format refer

to entries in the "Footnotes and References" section below.) Using

this setup, install and become familiar with some terminal emulator

like Telix [``TELIX''] or Commo [``COMMO''], which are available from

the SimTel archive [``SimTel''] among others.

 

2.1. Getting Linux on CDROM

If you have or can borrow a CDROM drive, I recommend you get one of

the many good distributions of Linux on that medium. The instructions

below are for the Slackware distribution. I am most familiar with

disks from InfoMagic [``InfoMagic'']. Another source is Walnut Creek

[``Walnut Creek''] (where the whole idea of inexpensive CDROMs full of

programs from Internet archives got its start). Distributions other

than Slackware are available from Red Hat [``Red Hat''], Craftwork

[``Craftwork''], and Yggdrasil [``Yggdrasil'']. As a rule, these

CDROMs use the "ISO 9660" format, which can be read under DOS. (They

also use the "Rock Ridge extensions" which add extra files in each

directory. Linux uses the extra information to give you long

filenames, both upper and lower case characters in filenames, and file

permissions.)

 

2.2. Getting Linux by FTP

Another way to get Linux and its documentation is by FTP over the

Internet. The home site for the Slackware distribution is Walnut

Creek [``Walnut Creek'']. It is also carried by sunsite and many of

it mirror sites. Here is a partial list:

 

· USA (home site) <ftp://ftp.cdrom.com/pub/linux/slackware>

· UK/Europe

<ftp://src.doc.ic.ac.uk/public/Mirrors/ftp.cdrom.com/pub/linux/slackware-3.1>

· Japan <ftp://ftp.cs.titech.ac.jp/pub/os/linux/slackware>

· Taiwan <ftp://NCTUCCCA.edu.tw/OS/Linux/Slackware>

· Hong Kong <ftp://ftp.cs.cuhk.hk/pub/slackware>

· USA <ftp://metalab.unc.edu/pub/Linux/distributions/slackware>

· USA

<ftp://uiarchive.cso.uiuc.edu/pub/systems/linux/sunsite/distributions/slackware>

More sites are listed in the INFO-SHEET:

<http://metalab.unc.edu/pub/Linux/welcome.html> <ftp://meta&SHY;

lab.unc.edu/pub/Linux/docs/HOWTO/INFO-SHEET>

<ftp://uiarchive.cso.uiuc.edu/pub/systems/linux/sun&SHY;

site/docs/HOWTO/INFO-SHEET>

 

 

2.3. Linux Documentation

Read the Linux documentation. I will quote here the file names and

locations on the first disk of InfoMagic's December 1996 "Developer's

Resource" set of six CDROMs, as seen under DOS. Other CDROM sets

should have similar information, though perhaps differently arranged.

The Slackware distribution is on disk 2 of the set. Matt Welsh's step

by step guide to installing Slackware is in

\doc\install-\install-.002. (This is a 245 page book!)

More general information is in the Linux "Frequently Asked Questions"

list in \docs\linux.faq\linux-fa.asc. Longer descriptions are in

"HOWTO" documents (of which this is one). They are found in \docs.

Note particularly \docs\hardware, which lists which kinds of hardware

are supported by Linux, \docs\meta-faq, which points to sources of

information (that is, a more extensive version of this paragraph), and

\help\index, which is a list of the HOWTO documents with short

descriptions. The Linux installation HOWTO, \docs\installation, is

another (much shorter, somewhat older) version of Matt Welsh's

installation instructions.

One note on reading the documentation. You may run into files with

ASCII highlighting, where character-backspace-character stands for

"bold", and underscore-backspace-character stands for "italics". One

way to handle this is to use the less program, which displays these

sequences in alternate colors. A DOS screenreader can, for example,

search for such highlighted text. A DOS version of less can be

obtained by FTP from the SimTel archive [``SimTel'']. Within the

SimTel collection, look for directory msdos/textutil. For example,

try <ftp://ftp.coast.net/pub/SimTel/msdos/textutil>.

I will suggest four alternatives for learning Emacs commands (see

section [``Learning Emacs'']). The first option is to install Emacs

under DOS and learn it while using the DOS screen reader. Where to

get Emacs for DOS is a "frequently asked question" [``Emacs for

DOS''].

The source code for Emacs (about 10 MB) can be gotten from

<ftp://prep.ai.mit.edu/pub/gnu/> (look for emacs-19.34b.tar.gz or

similar), or from one of many mirrors of the GNU collection [``Gnu

Mirrors''].

 

3. Stage 2. Terminal to remote UNIX system

 

 

Arrange for what is called a "shell account" on some Unix system.

Most Internet Service Providers (ISPs) can provide this service. Use

the terminal emulator program and a modem to dial in. Learn the basic

Unix commands. If the system has Emacs installed, or you can persuade

the system administrator to install it, this is your second chance to

learn it. It is probably best to learn it at this point, because

administering a Unix system (the next stage) will call for you to edit

files. Therefore, I include here my suggestions for learning both

Unix and Emacs.

 

3.1. Learning Unix

When you arrange for a shell account, or set up a new account on your

own machine, you will have to decide on a username and a password.

Your username will also be used in your email address, so try to find

something short and memorable. Your password is important, and should

be hard to guess. That usually means at least six characters,

including at least one non-alphanumeric character.

When a Unix system is ready for you to log in, it normally displays a

prompt ending with "login:". At this point you should type in your

username. It will then prompt you for your password, and will turn

off command echoing while you type it in.

The command to finish a terminal session is logout.

To learn about a command, use the man command to display its manual

page. For example, learn more about the cp command by typing man cp.

Of course, this helps only if you know or can guess the command name.

However, each man page has a line near the beginning with the command

name and a short description of what the command does. You can search

a database of these lines using the command apropos. Thus, typing

apropos working will list lines that include the word "working".

Here's what that command prints here:

 

cd (n) - Change working directory

pwd (n) - Return the current working directory

Cwd (3pm) - get pathname of current working directory

chdir (2) - change working directory

fchdir (2) - change working directory

get_current_dir_name (3) - Get current working directory

getcwd (3) - Get current working directory

getwd (3) - Get current working directory

pwd (1) - print name of current/working directory

rcsclean (1) - clean up working files

 

 

 

The numbers in parentheses are sections of the manual. User commands

are in section 1. Functions called from within programs are in sec&SHY;

tions 2 and 3. Commands used mostly by the system administrator are

in section 8. You can find out more about the on-line manual with the

command man man.

Under Unix, commands normally accept options starting with a minus

sign rather than the forward slash used under DOS. In a path,

directory names are separated by forward slashes rather than backward

slashes. Both operating systems have a "standard input", by default

the keyboard, and a "standard output", by default the display screen.

You can redirect the standard input using "<", and redirect the output

using ">". You can use the output from one command as the input of

another by separating the two commands with "|". This is called the

"pipe" symbol.

The program that interprets your command is a "shell". Under DOS,

COMMAND.COM is the shell. Most Unix shells are descendents of either

the Bourne shell sh or the C shell csh. The shell most commonly used

with Linux is the "Bourne again shell", or bash.

If a program gets "stuck", here is a sequence of keystrokes to try:

 

· Control-Q. You may have sent a control-S, which halts all output,

without realizing it. The control-Q will restart it.

· Control-D, which signals "end of file" under Unix (similar to

control-Z under DOS), in case the program expects input which you

are not prepared to supply.

· Control-C is an interrupt, which may halt the program.

· Control-Z puts the program in the background. At this point you

may simply log out, although you will be warned about the

background process and will have to repeat the logout command. You

can instead kill the process, as follows: Run ps with no arguments.

It will list a header line, then one line for each of your

processes. The first item on each line is the process id number,

or PID. The command used to start the process (or at least the

beginning of it) appears at the end of the line. If the PID were

117, you would kill the process with the command kill -9 117.

· If running Linux from the console, alt-2, or some other alt-number

combination, will switch to a different virtual console. You can

log in there just as if you had sat down to a different terminal.

· If your machine is connected to a network, you can log in from

another machine.

· Control-alt-del should reboot the computer nondestructively.

· As a last resort, you can hit "reset" or cycle the power. This

will leave the filesystems in an invalid state, since some buffers

will not have been written to disk. The kernel will discover this

while booting, and will take time to check and repair the

filesystems. Actual data loss is unlikely unless you had something

else going on at the time.

Guido Gonzato Guido@ibogfs.cineca.it has written an excellent guide to

Linux for (former) DOS users, the DOS2Linux mini-HOWTO. You can

probably find it where you found this document, or else at

<ftp://metalab.unc.edu/pub/Linux/docs/HOWTO/mini/>.

You can find general Unix information, including manual pages for

several systems at <http://www.cis.ohio-

state.edu/hypertext/man_pages.html>

There is a tutorial entitled "Beginning Unix and the C Shell" at

<http://www.eng.hawaii.edu:80/Courses/C.unix/page-03.html>.

You can get general help from <http://www.nova.edu/Inter-

Links/UNIXhelp/TOP_.html> or <http://www.eecs.nwu.edu/unix.html>

You can find a list of books on UNIX at

<http://www.eskimo.com/~cher/eskimospace/booklist.html>.

 

3.2. Learning Emacs

When you start Emacs, you will normally list on the command line one

or more files which you will be editing. To edit a file named

"foobar" with Emacs, you would enter the command emacs foobar. If you

enter the command emacs with no arguments, GNU Emacs will print out an

introduction which includes the first five commands you need to learn,

approximately as follows:

Type C-h for help; (`C-' means use CTRL key.)

Type C-x u to undo changes.

Type C-h t for a tutorial on using Emacs.

Type C-h i to enter Info, which you can use to read GNU documentation.

To kill the Emacs job, type C-x C-c.

 

 

Note the way Emacs documentation refers to key combinations. C-h

means hold the control key down while typing "h". You will also run

into key combinations like M-v, which is pronounced "meta v". The

tutorial suggests holding down the key labeled "edit" or "meta" then

typing "v". I have never run across a keyboard with those keys, so I

always use the escape key instead: typing "Esc" then "v" (two separate

keystrokes). After using Emacs for a long time, I discovered that

under Linux, the left "Alt" key works like a "meta" key. You may want

to use this. On the other hand, some of these key combinations may

conflict with your screen reader or communications program under DOS.

Using the escape key is more reliable.

Three of the above commands start with C-h, which may be treated as a

backspace by your communications program. In that case, you may

access the help command using the long form M-x help. Conversely, you

may find that pressing the backspace key starts the help command.

This issue is treated in the Emacs FAQ, which is available within

Emacs using C-h F or M-x help F. Look for the question "Why does the

`Backspace' key invoke help?". In the mean time, you can end the help

session with the command C-g. (This is the keyboard-quit command,

which cancels any prefix keys you have typed.)

You may also find that C-s and C-q are unavailable because they are

used for flow control (XON and XOFF). You should look at the question

"How do I handle C-s and C-q being used for flow control?" in the FAQ.

For the particular command C-x C-s (save buffer), you may substitute

the command C-x s (save-some-buffers). The former command saves the

current buffer, while the latter asks the user about each of the

modified buffers.

Note in particular the command "C-h t" to start the Emacs tutorial.

That is one the first things you will want to try. I will only make a

couple of comments on the tutorial. To move the cursor, it gives the

four commands C-f, C-b, C-p, and C-n (for forward, back, previous

line, and next line). These commands always work. However, with a

properly installed Emacs, the regular arrow keys should also work.

Try them out and use them if you are more comfortable with them.

Similarly, you may be able to use home, end, page down, and page up

keys in place of the standard commands C-a, C-e, C-v, and M-v.

Finally, all Emacspeak commands begin with C-e. Once you start using

Emacspeak, you will have to type it twice to get the end of line

function. (The "End" key should be unaffected by Emacspeak.)

 

 

 

4. Stage 3. Terminal to local Linux system

 

This arrangement again requires a DOS machine with a speech

synthesizer and a terminal emulator program. However, instead of

dialing up a remote computer, it is used as a terminal to a local

computer running Linux. To get to this point, you need to install

Linux on a machine. You may be able to prevail on a knowledgeable

friend to help you with this. However, it is also possible to install

it yourself with speech feedback for almost the whole procedure.

 

4.1. Installing Linux

 

First, some background. Even the simplest Unix system requires a

program called the kernel and a root file system. The kernel has all

the device drivers and resource management functions. One normally

thinks of a "file system" as residing on a hard disk or floppy disk,

but during an installation it is usually in ram. Linux is normally

installed by writing a kernel image to a floppy disk, called the "boot

floppy", configuring it to reserve a section of RAM for a ramdisk,

then filling that ramdisk with data from a second floppy disk, called

the "root floppy". As soon as both floppies have been read in, the

user can log in as "root" and complete the installation. The sighted

user logs in on the "system console", that is, the computer's own

keyboard and video display. However, remember that Unix has been a

multiprocessing operating system from the very beginning. Even this

very primitive Unix system, running out of a small ramdisk, also

supports logins from a terminal connected to a serial port. This is

what a blind user can use.

To connect the two computers, you can use a "null modem", a serial

cable that connects ground to ground, and transmit on each end to

receive on the other. The cable that comes with the DOS application

LapLink will work fine. It is particularly handy, in fact, because it

has both a 9 pin and a 25 pin connector on each end. If you want to

check a cable or have one made, here are the required connections:

For two 9 pin connectors, connect pin 2 (receive data) to pin 3, pin 3

(transmit data) to pin 2, and pin 5 (signal ground) to pin 5.

For two 25 pin connectors, connect pin 2 (receive data) to pin 3, pin

3 (transmit data) to pin 2, and pin 7 (signal ground) to pin 7.

For a 9 pin connector (first) to a 25 pin connector (second), connect

pin 2 (receive data) to pin 2 (transmit data), pin 3 (transmit data)

to pin 3 (receive data), and pin 5 (signal ground) to pin 7 (signal

ground).

You may have noted that I have included no connections for the

"handshaking" signals. During login, the serial port is handled by

the program agetty. Recent versions of this program accept a -L

switch which tells it not to expect modem control signals. The

version in Slackware 3.0 does, but the one on the 3.0 (and earlier)

installation root disks does not. However, Pat Volkerding has assured

me that the root disks in the next release of Slackware will have the

updated version of agetty. It is also possible to use the earlier

root disks [``Emacspeak with Earlier Slackware Releases''].

Consult the documentation on your CDROM, or downloaded from an FTP

site, and choose a boot disk with the proper kernel features for your

hardware (IDE or SCSI, CDROM driver, etc.). I have the InfoMagic

September 1996 "Developer's Resource" set of six CDROMs. Slackware

3.1 is on disk 1 of that set, mostly in the two directories slackwar

and slakware. (Note the difference in spelling. You will access them

in alphabetical order: first slackwar, then slakware.)

Documentation on the boot floppies is in \bootdsks.144\which.one. A

copy of the DOS program for writing boot images to a floppy,

rawrite.exe, is in the same directory. Assuming the CDROM is the M

drive under DOS, one might use these commands to write to a floppy

disk in the A drive:

 

 

 

 

C>m:

M>cd \bootdsks.144

M>rawrite scsinet.s a:

 

 

 

Similarly, to write the "text" root disk:

 

 

C>m:

M>cd \rootdsks

M>rawrite text.gz a:

 

 

 

If you install from floppies, you should also copy the Emacspeak

package onto a floppy with a command like this:

 

 

C>copy m:\contrib\emacspea.tgz a:

 

 

 

For the actual installation, proceed as follows: Use the null modem to

connect the computer running DOS and equipped with speech output

(which I will call the "DOS machine") to the computer into which you

want to install Linux (the "Linux machine").

Boot the DOS machine, and start your terminal emulation program. Set

it up for 9600 baud, no parity, eight data bits, 1 stop bit.

On the Linux machine, insert the "boot" disk and boot (power up, cntl-

alt-del, or hit the reset switch). It should read the disk for five

seconds or so, beep, and stop with the following text:

(Note: in the following, the large blocks of text quoted from the

installation disks are preceded by "-- begin quote" and followed by

"-- end quote". To skip to the end of a quote, you may search for two

dashes starting in the first column. I have word wrapped some

sections to limit the line lengths.)

 

-- begin quote

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

Welcome to the Slackware96 Linux (v. 3.1.0) bootkernel disk!

If you have any extra parameters to pass to the kernel, enter them at

the prompt below after one of the valid configuration names (ramdisk,

mount, drive2)

Here are some examples (and more can be found in the BOOTING file):

ramdisk hd=cyl,hds,secs (Where "cyl", "hds", and "secs" are the

number of cylinders, sectors, and heads

on the drive. Most machines won't need

this.)

In a pinch, you can boot your system with a command like:

mount root=/dev/hda1

On machines with low memory, you can use mount root=/dev/fd1 or mount

root=/dev/fd0 to install without a ramdisk. See LOWMEM.TXT for

details.

If you would rather load the root/install disk from your second

floppy drive: drive2 (or even this: ramdisk root=/dev/fd1)

DON'T SWITCH ANY DISKS YET! This prompt is just for entering extra

parameters. If you don't need to enter any parameters, hit ENTER to

continue.

boot:

 

 

 

-- end quote

 

 

I have almost always been able to just hit "enter" at this point.

After your entry, the Linux machine should read the floppy for another

twenty seconds or so, then boot the kernel. The first thing it prints

is "Loading ramdisk...", which is somewhat misleading. In this case,

"ramdisk" is actually the name of the kernel configuration.

Each device driver in the kernel displays a line or two. The

particular disk I'm using (the "bare.i" bootdisk) displays more than

one screen's worth. It is possible to type shift-page up to scroll

the text back. On my machine, the boot messages are as follows:

 

-- begin quote

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

Loading ramdisk.....

Uncompressing Linux...done.

Now booting the kernel

Console: colour VGA+ 80x25, 1 virtual console (max 63)

Calibrating delay loop.. ok - 35.94 BogoMIPS

Memory: 23028k/24768k available (688k kernel code, 384k reserved,

668k data)

Swansea University Computer Society NET3.035 for Linux 2.0

NET3: Unix domain sockets 0.12 for Linux NET3.035.

Swansea University Computer Society TCP/IP for NET3.034

IP Protocols: ICMP, UDP, TCP

VFS: Diskquotas version dquot_5.6.0 initialized

Checking 386/387 coupling... Ok, fpu using exception 16 error reporting.

Checking 'hlt' instruction... Ok.

Linux version 2.0.0 (root@darkstar) (gcc version 2.7.2) #1 Mon Jun 10

21:11:56 CDT 1996

Serial driver version 4.13 with no serial options enabled

tty00 at 0x03f8 (irq = 4) is a 16550A

PS/2 auxiliary pointing device detected -- driver installed.

Ramdisk driver initialized : 16 ramdisks of 49152K size

hda: IBM-DBOA-2720, 689MB w/64KB Cache, LBA, CHS=700/32/63

ide0: at 0x1f0-0x1f7,0x3f6 on irq 14

Floppy drive(s): fd0 is 1.44M

Started kswapd v 1.4.2.2

FDC 0 is a 8272A

Partition check:

hda: hda1 hda2 hda3

VFS: Insert root floppy disk to be loaded into ramdisk and press ENTER

 

 

 

-- end quote

 

 

Some messages will of course be different on a machine with different

hardware. Now, insert the "text" rootdisk and press ENTER. After it

is read, the following is displayed on the console:

 

-- begin quote

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

RAMDISK: Compressed image found at block 0

JAVA Binary support v1.01 for Linux 1.3.98 (C)1996 Brian A. Lantz

VFS: Mounted root (minix filesystem).

INIT: version 2.60 booting

none on /proc type proc (rw)

INIT: Entering runlevel: 4

 

Welcome to the Slackware Linux installation disk ,version 3.1.0-text!

### READ THE INSTRUCTIONS BELOW CAREFULLY! ###

You will need one or more partitions of type "Linux native"

prepared. It is also recommended that you create a swap partition

(type "Linux swap") prior to installation. Most users can use the

Linux "fdisk" utility to create and tag the types of all these

partitions. OS/2 Boot Manager users, however, should create their

Linux partitions with OS/2 "fdisk", add the bootable (root) partition

to the Boot Manager menu, and then use the Linux "fdisk" to tag the

partitions as type "Linux native".

If you have 4 megabytes or less of RAM, you MUST ACTIVATE a swap

partition before running setup. After making the partition with fdisk,

use:

mkswap /dev/<partition> <number of blocks> ; swapon /dev/<partition>

Once you have prepared the disk partitions for Linux, type "setup" to

begin the installation process.

You may now login as "root".

slackware login:

 

 

 

-- end quote

 

 

The program that prints the login prompt is called agetty. The

Slackware 3.1 root disks are set up to allow logins only from the

computer's own keyboard. You will have to reconfigure it to also

allow logins from a serial port. This requires typing four lines on

the Linux machine keyboard, with no voice feedback. If you realize

you have made a mistake before hitting the carriage return, you can

erase it with the backspace key. You can also discard what you have

typed on a line with control-C. Here is what you type:

 

 

root

cat >>/etc/inittab

s1:45:respawn:/sbin/agetty 9600 ttyS0

control-D

init q

 

 

 

I will repeat that with explanations of what is going on.

First, type "root" and a single carriage return to log in (no password

is needed). Next, you need to append one line to /etc/inittab. Type

the following two lines:

cat >>/etc/inittab

s1:45:respawn:/sbin/agetty 9600 ttyS0

 

 

 

Finish each line with the "enter" key. Then type a control-D, which

signals end of file to a Unix program. (Note: In the second line, the

next to last character is an upper case "S". Everything else is in

lower case.) This adds a line to the configuration file of the

program init, to instruct it to use agetty to watch for logins on the

first serial port on the Linux machine, called "COM1" under DOS, or

"/dev/ttyS0" under Linux. To use the second port instead, change the

last item on the above line to "ttyS1".

Then type

 

 

init q

 

 

 

which causes init to reread /etc/inittab. At this point the DOS

machine should display the login prompt (the third of the blocks of

text quoted above). On the DOS machine, type root, and finish the

installation. (The next thing you should do is create and enable a

swap partition.)

If you don't get the Slackware installation disk prompt, try the

following:

· Type a single carriage return on the DOS machine.

· Recheck the terminal setup (9600 baud, no parity, eight data bits,

1 stop bit)

· Disconnect the null modem from the DOS machine. In its place,

connect a modem which supports the Hayes "AT" commands. Type AT

and a carriage return. You should get a reply of "OK" from the

modem.

Once you get the above prompt on the DOS machine, you may type root

and a carriage return to log in, and complete the installation like

any other user. Of course, you must remember to include these

packages: emacs, tcl, and tclX.

The installation script will offer to prepare a boot floppy. You

should do this, since it is the most foolproof way to boot Linux. You

will probably also want to install lilo (which is an abbreviation for

"Linux loader") and/or loadlin (which is an abbreviation for "load

Linux"). The installation script can install lilo. Loadlin is a DOS

program that will let you boot from DOS to Linux. Install it on a DOS

partition, and copy a compressed kernel file (usually named zImage) to

the same partition. While running DOS, you may boot Linux with a

command like loadlin zimage root=/dev/hda3 ro/. (I have assumed here

that the kernel image is in the same directory as the loadlin program.

You may find it more convenient to store kernel images in

subdirectories named for the kernel version.)

After the Slackware setup script finishes the main installation, it

will tell you to restart by pressing cntl-alt-del. Before doing that,

you should install emacspeak. It can be found with the other

"contributed" software. In the InfoMagic set, it is in

slackwar/contrib. Assuming you are installing Linux directly from a

CDROM, the setup script will mount the CDROM under /CDROM, and you may

install emacspeak with the following command:

 

 

# installpkg /CDROM/slackwar/contrib/emacspeak.tgz

 

 

 

If you install from floppies, insert the floppy you made earlier and

type this:

 

# mount -tmsdos /dev/fd0 /floppy

# cp /floppy/emacspea.tgz /tmp/emacspeak.tgz

# installpkg /tmp/emacspeak.tgz

 

 

 

You should not install the package directly off the floppy disk,

because the DOS filesystem will not allow the full filename, so the

installpkg program will think the package name is "emacspea" and will

store its records under that name.

If you have a DoubleTalk or LiteTalk speech synthesizer, you should

also install the emacspeak-dt package.

Reboot the Linux machine with the new boot floppy, with the DOS

machine still connected. You should get a login prompt on the DOS

machine. Celebrate! After getting this system working, you need to

learn emacs (third option) and Unix system administration.

 

4.2. Learning Unix System Administration

 

Mostly you will learn system administration as the need arises. First

adding a user (yourself), then installing programs, and so forth. The

exception to this is making backups, which you should learn before you

need them.

Among the many programs you will need to learn are these:

adduser

Register a new user, including creating a home directory and

adding an entry in /etc/passwd.

 

tar

Create and unpack .tar files, which are collections of files

(something like .zip files). To list the contents of an

archive, use tar -tf foobar.tar. For a more verbose listing,

use tar -tvf foobar.tar. To unpack an archive, use tar -xf

foobar.tar.

 

chmod

Change permissions of a file or directory.

 

chown

Change ownership of a file or directory.

 

find

Search directories recursively. For example, the command find .

-name '*alpha*' -print means: search starting in the current

directory (.) for a file whose name contains the string "alpha"

(-name '*alpha*'), and print its path and name (-print). (With

GNU find, the -print is optional.)

 

du Display the amount of space occupied by files or subdirectories.

For a file with "holes", this may be much less than the length

of the file.

 

df Display filesystem capacities, free space, and where they are

mounted.

 

mount

Display filesystems, where they are mounted, and the mount

flags.

 

ifconfig

Configure and check internet protocol (IP) network interfaces,

including Ethernet cards, SLIP links, and PLIP links.

 

route

Configure and check IP network routing, after the interface is

configured.

 

ping

Check IP network connectivity, after the interfaces and routes

are configured.

 

ftp

Transfer files across the Internet.

 

Here are some programs you may want to install:

agrep

Approximate grep searches for approximate, not exact, string

matches (also called "fuzzy string searches").

 

archie

Search Internet archives for files.

 

flip

Convert text files between Unix and DOS formats.

 

glimpse

Fuzzy string searches in large collection of files (uses agrep).

 

lynx

Text mode web browser.

Here are some Web pages related to Unix system administration:

 

General information <http://www.ensta.fr/internet/unix/sys_admin/> or

<http://www.sai.msu.su/sysadm.html>

There is a Unix system administration tutorial at

<http://www.iem.ac.ru/sysadm.html>

UnixWorld Online Magazine Home Page <http://www.wcmh.com/uworld/>

Internet Essentials for UNIX System Administrators Tutorial

<http://www.greatcircle.com/tutorials/ieusa.html>

Pointers to Unix goodies available on the Internet

<http://www.ensta.fr/internet/unix/>

Pointers to Unix system administration "goodies" available on the

Internet <http://www.ensta.fr/internet/unix/sys_admin/>

 

5. Stage 4. Emacspeak under Linux

 

The Slackware setup script for Emacspeak should create the needed

environment variables and install a script emacspeak that starts emacs

with emacspeak. This is your fourth option for learning Emacs. This

is the first time you will be able to actually use Emacspeak. A short

tutorial appears below. Within Emacs, you may type C-h C-e to get a

list of the commands. To search for a command, use C-h a. To get an

explanation for a key sequence, use C-h k. There is also an info file

which is part of the Emacspeak distribution. Within emacs, you may

type C-h i to open the directory to the info pages. Search for the

emacspeak menu item by typing C-s emacspeak, then two carriage returns

(one to terminate the search, and a second one to go to the info page.

If you have the standalone info program installed, you can consult the

info file with the command info Emacspeak.

 

5.1. Emacspeak Introduction - Speech Enabled Normal Commands

All of the normal Emacs movement commands will speak the relevant

information after moving. Here are some of the cursor movement

functions that have been speech enabled. Note that this list only

enumerates a few of these speech enabled commands; the purpose of

emacspeak is to speech-enable all of emacs and provide you spoken

feedback as you work. Thus, this list is here only as a

representative example of the kind of speech-enabling extensions

Emacspeak provides.

 

`C-n' or

`M-x next-line' or `down'" Moves the cursor to the next line and

speaks it.

 

`C-p' or

`M-x previous-line' or `up'" Moves the cursor to the previous

line and speaks it.

 

`M-f' or

`M-x forward-word' or" Moves the cursor to the next word and

speaks it. Places point on the first character of the next

work, rather than on the space preceding it (This is my personal

preference).

 

 

`M-b' or

`M-x backward-word'" Moves the cursor to the previous word and

speaks it.

 

`M-C-b' or

`M-x backward-sexp'" Moves the cursor to the previous sexp and

speaks it. If the sexp spans more than a line, only the first

line is spoken.

 

`M-<' or

`M-x beginning-of-buffer'" Speaks line moved to.

 

`M->' or

`M-x end-of-buffer'" Speaks line moved to.

 

`M-m' or

`M-x back-to-indentation'" Speaks entire current line. A useful

way of hearing the current line.

 

5.2. Emacspeak Introduction - New Commands

Emacspeak provides a number of commands for reading portions of the

current buffer, getting status information, and modifying Emacspeak's

state.

All of the commands are documented in the subsequent sections. They

can be classified into types:

The first group of commands are for listening to chunks of

information. The names of these commands all start with the common

prefix `emacspeak-'. All Emacspeak commands are bound to the keymap

EMACSPEAK-KEYMAP and are accessed with the key `Control e'. Thus, the

Emacspeak command "emacspeak-speak-line" is bound to `l' in keymap

EMACSPEAK-KEYMAP and can be accessed with the keystroke `Control-e l'.

Here are some of the commands for reading text:

 

`C-e c' or

`M-x emacspeak-speak-char'" Speak current character, using the

phonetic alphabet.

 

`C-e w' or

`M-x emacspeak-speak-word'" Speak current word.

 

`C-e l' or

`M-x emacspeak-speak-line'" Speak current line. With prefix `C-

u', speaks the rest of the line from point. With negative

prefix `C-u -', speaks from start of line to point. Voicifies

if voice-lock-mode is on. Indicates indentation with a tone if

audio indentation is in use. Indicates position of point with

an aural highlight if option emacspeak-show-point is turned on

--see command `M-x emacspeak-show-point'.

 

`C-e .' or

`M-x emacspeak-speak-sentence'" Speak the current sentence.

 

The second category of commands provided by Emacspeak report status of

various kinds.

 

`C-e k' or

`M-x emacspeak-speak-current-kill'" Speak the current kill entry

(which would be yanked by the next C-y).

 

`C-e =' or

`M-x emacspeak-speak-current-column'" State the column where

point is.

 

`C-e C-l' or

`M-x emacspeak-speak-line-number'" State the line where point

is.

 

`C-e m' or `M-x emacspeak-speak-line-number'

Speak the mode-line: the name of the buffer, how far point is

into the current buffer as a percentage, and the major mode.

 

`C-e M' or `M-x emacspeak-speak-minor-mode-line'

Speak the minor modes that are in effect.

 

`C-e v' or `M-x emacspeak-speak-version'

Announce the emacspeak version.

The third category of commands provided by Emacspeak manipulate the

state of the speech device. The names of these commands start with

the common prefix `dtk-'. Many of these commands take the prefix

`Control-e d'. Thus, the command "dtk-set-rate" is bound to `r' in

keymap EMACSPEAK-DTK-SUBMAP and can be executed by pressing `Control e

d r'.

 

`C-e s' or

`M-x dtk-stop'" Stop speech now. In addition, any command that

causes speech output will discard anything in the speech buffer.

 

`C-e d V' or `M-x emacspeak-dtk-speak-version'

Use this to find out which version of the Dectalk firmware you

have.

 

`C-e d I' or `M-x dtk-toggle-stop-immediately-while-typing'

Toggle state of variable dtk-stop-immediately-while-typing. As

the name implies, if true then speech flushes immediately as you

type.

 

`C-e d i' or `M-x emacspeak-toggle-audio-indentation'

Toggle state of Emacspeak audio indentation. Specifying the

method of indentation as `tone' results in the DECtalk producing

a tone whose length is a function of the line's indentation.

Specifying `speak' results in the number of initial spaces being

spoken.

 

`C-e d k' or `M-x emacspeak-toggle-character-echo'

Toggle state of Emacspeak character echo (that is, whether

typed characters are echoed).

`C-e d w' or `M-x emacspeak-toggle-word-echo'

Toggle state of Emacspeak word echo (initially on).

 

`C-e d l' or `M-x emacspeak-toggle-line-echo'

Toggle state of Emacspeak line echo (that is, whether typed

text is echoed after typing enter).

 

`C-e d p' or `M-x dtk-set-punctuations'

Set punctuation state. Possible values are `some', `all', or

`none'.

 

`C-e d q' or `M-x dtk-toggle-quiet'

Toggle state of the speech device between being quiet and

talkative. Useful if you want to continue using an emacs

session that has emacspeak loaded but wish to make the speech

shut up.

 

`C-e d R' or `M-x dtk-reset-state'

Restore sanity to the Dectalk. Typically used after the Dectalk

has been power cycled.

 

`C-e d SPC' or `M-x dtk-toggle-splitting-on-white-space'

Toggle state of emacspeak that decides if we split text purely

by clause boundaries, or also include whitespace.

 

`C-e d r' or `M-x dtk-set-rate'

Set speaking rate for the dectalk.

 

`C-e d s' or `M-x dtk-toggle-split-caps'

Toggle split caps mode. In split caps mode, a transition from

lower case to upper case is treated like the beginning of a new

word. This is useful when reading Hungarian notation in program

source code.

 

`C-e d v' or `M-x voice-lock-mode'

Toggle Voice Lock mode (initially off). When Voice Lock mode is

enabled, text is voiceified as you type it, as follows:

· Comments are spoken in voice-lock-comment-personality; (That is

a variable whose value should be a personality name.)

· Strings are spoken in voice-lock-string-personality.

· Documentation strings are spoken in voice-lock-doc-string-

personality.

· Function and variable names in their defining forms are spoken

in voice-lock-function-name-personality.

· Certain other expressions are spoken in other personalities

according to the value of the variable voice-lock-keywords.

 

5.3. Emacspeak Introduction - Using the Help System

 

When you press C-h to get the help index, the screen will appear, but

Emacspeak will not speak the window. The only thing spoken is "Type

one of the options listed or Space to scroll:".

Here is the menu that Emacspeak is not speaking:

 

-- begin quote

 

 

 

 

You have typed C-h, the help character. Type a Help option:

(Use SPC or DEL to scroll through this text. Type q to exit the Help

command.)

a command-apropos. Give a substring, and see a list of commands

(functions interactively callable) that contain

that substring. See also the apropos command.

b describe-bindings. Display table of all key bindings.

c describe-key-briefly. Type a command key sequence;

it prints the function name that sequence runs.

f describe-function. Type a function name and get documentation of

it.

C-f Info-goto-emacs-command-node. Type a function name;

it takes you to the Info node for that command.

F view-emacs-FAQ. Shows emacs frequently asked questions file.

i info. The info documentation reader.

k describe-key. Type a command key sequence;

it displays the full documentation.

C-k Info-goto-emacs-key-command-node. Type a command key sequence;

it takes you to the Info node for the command bound to that

key.

l view-lossage. Shows last 100 characters you typed.

m describe-mode. Print documentation of current major mode,

which describes the commands peculiar to it.

n view-emacs-news. Shows emacs news file.

p finder-by-keyword. Find packages matching a given topic keyword.

s describe-syntax. Display contents of syntax table, plus

explanations

t help-with-tutorial. Select the Emacs learn-by-doing tutorial.

v describe-variable. Type name of a variable;

it displays the variable's documentation and value.

w where-is. Type command name; it prints which keystrokes

invoke that command.

C-c print Emacs copying permission (General Public License).

C-d print Emacs ordering information.

C-n print news of recent Emacs changes.

C-p print information about the GNU project.

C-w print information on absence of warranty for GNU Emacs.

 

 

 

-- end quote

 

 

Suppose you type "a", for command-apropos.

The next spoken prompt is "Apropos command (regexp):"

Now you type some word you think is part of an emacs command, like

"visit".

The help system will display the first section of the help, but will

leave the cursor in the other window. The spoken text is "Type C-x 1

to remove help window. M-C-v to scroll the help." At this point, I

think it's more helpful to move point to the other window with C-x o,

then you can use regular navigation commands to speak the help text.

You can delete the help window with C-x 0, which will also put point

back where it was.

The complete menu displayed by help-for-help is also visible if you do

a describe function on help-for-help. In a future version of

Emacspeak, Raman plans to add a message to that effect when the user

presses C-h ?

 

6. Footnotes and References

6.1. JAWS

Job Access With Speech (JAWS) is a screen reader which runs under

Microsoft MSDOS. JAWS for Windows supports Windows 95, Windows 98 and

Windows NT. Both are products of Henter-Joyce, Inc., 2100 62nd Avenue

North, St. Petersburg, FL 33702, telephone: 800-336-5658. For

details, see <http://www.hj.com>.

 

6.2. TELIX

 

TELIX is a shareware terminal emulator for MSDOS. It can be obtained

by FTP from the SimTel archive [``SimTel'']. Within the SimTel

collection, look for directory msdos/telix. For example, try

<ftp://ftp.coast.net/pub/SimTel/msdos/telix>. The latest version of

the program itself is in the four files tlx322-1.zip, tlx322-2.zip,

tlx322-3.zip, and tlx322-4.zip.

 

6.3. COMMO

 

COMMO is another shareware terminal emulator for DOS. In the SimTel

archive [``SimTel''], it is in directory msdos/commprog, file

commo66.zip. For example, try

<ftp://ftp.coast.net/pub/SimTel/msdos/commprog/commo66.zip>.

 

6.4. SimTel

 

The SimTel archive is maintained by Keith Petersen w8sdz@Simtel.Net.

CD-ROM copies of Simtel.Net collections are available from Walnut

Creek CDROM [``Walnut Creek'']. The primary ftp sites are

<ftp://ftp.simtel.net/pub/simtelnet>, and

<oak.oakland.edu://pub/simtelnet>. There are many mirror sites, as

listed in the following table:

 

· US, ALL (primary) <ftp://ftp.simtel.net/pub/simtelnet>

· US, California <ftp://ftp.cdrom.com/pub/simtelnet>

· US, California <ftp://ftp.digital.com/pub/micro/pc/simtelnet>

· US, California <ftp://ftp.lib.sonoma.edu/pub/simtelnet>

· US, Illinois

<ftp://uiarchive.cso.uiuc.edu/pub/systems/pc/simtelnet>

 

· US, Massachusetts <ftp://ftp.bu.edu/pub/mirrors/simtelnet>

· US, Michigan <ftp://oak.oakland.edu/pub/simtelnet>

· US, New York <ftp://ftp.rge.com/pub/systems/simtelnet>

· US, Oklahoma <ftp://ftp.ou.edu/pub/simtelnet>

· US, Oregon <ftp://ftp.orst.edu/pub/simtelnet>

· US, Pennsylvania <ftp://ftp.epix.net/pub/simtelnet>

· US, Utah <ftp://ftp.cyber-naut.com/pub/simtelnet>

· US, Virginia <ftp://mirrors.aol.com/pub/simtelnet>

· Argentina <ftp://ftp.satlink.com/pub/mirrors/simtelnet>

· Australia <ftp://ftp.iniaccess.net.au/pub/simtelnet>

· Australia <ftp://sunsite.anu.edu.au/pub/pc/simtelnet>

· Austria, Vienna <ftp://ftp.univie.ac.at/mirror/simtelnet>

· Belgium <ftp://ftp.linkline.be/mirror/simtelnet>

· Belgium <ftp://ftp.tornado.be/pub/simtelnet>

· Bulgaria <ftp://ftp.eunet.bg/pub/simtelnet>

· Brazil <ftp://ftp.iis.com.br/pub/simtelnet>

· Brazil <ftp://ftp.unicamp.br/pub/simtelnet>

· Canada, Ottawa <ftp://ftp.crc.doc.ca/systems/ibmpc/simtelnet>

· Canada, Vancouver <ftp://ftp.direct.ca/pub/simtelnet>

· Chile

<ftp://sunsite.dcc.uchile.cl/pub/Mirror/simtelnet>

· China <ftp://ftp.pku.edu.cn/pub/simtelnet>

· Czech Republic <ftp://ftp.eunet.cz/pub/simtelnet>

· Czech Republic <ftp://ftp.zcu.cz/pub/simtelnet>

· Czech Republic <ftp://pub.vse.cz/pub/simtelnet>

· Finland

<ftp://ftp.funet.fi/mirrors/ftp.simtel.net/pub/simtelnet>

· France <ftp://ftp.grolier.fr/pub/simtelnet>

· France <ftp://ftp.ibp.fr/pub/simtelnet>

· Germany <ftp://ftp.mpi-sb.mpg.de/pub/simtelnet>

· Germany <ftp://ftp.rz.ruhr-uni-bochum.de/pub/simtelnet>

· Germany <ftp://ftp.tu-chemnitz.de/pub/simtelnet>

· Germany <ftp://ftp.uni-heidelberg.de/pub/simtelnet>

· Germany <ftp://ftp.uni-

magdeburg.de/pub/mirrors/simtelnet>

· Germany <ftp://ftp.uni-paderborn.de/pub/simtelnet>

· Germany <ftp://ftp.uni-

trier.de/pub/pc/mirrors/Simtel.net>

· Germany <ftp://ftp.rz.uni-

wuerzburg.de/pub/pc/simtelnet>

· Greece <ftp://ftp.ntua.gr/pub/pc/simtelnet>

· Hong Kong <ftp://ftp.cs.cuhk.hk/pub/simtelnet>

· Hong Kong <ftp://ftp.hkstar.com/pub/simtelnet>

· Hong Kong <ftp://sunsite.ust.hk/pub/simtelnet>

· Ireland <ftp://ftp.iol.ie/pub/simtelnet>

· Israel <ftp://ftp.huji.ac.il/pub/simtelnet>

· Italy <ftp://cis.utovrm.it/simtelnet>

· Italy <ftp://ftp.flashnet.it/pub/simtelnet>

· Italy <ftp://ftp.unina.it/pub/simtelnet>

· Italy <ftp://mcftp.mclink.it/pub/simtelnet>

· Japan <ftp://ftp.iij.ad.jp/pub/simtelnet>

· Japan <ftp://ftp.riken.go.jp/pub/simtelnet>

· Japan <ftp://ftp.saitama-u.ac.jp/pub/simtelnet>

· Japan <ftp://ftp.u-aizu.ac.jp/pub/PC/simtelnet>

· Japan <ftp://ftp.web.ad.jp/pub/simtelnet>

· Japan <ftp://ring.aist.go.jp/pub/simtelnet>

· Japan <ftp://ring.asahi-net.or.jp/pub/simtelnet>

· Latvia <ftp://ftp.lanet.lv/pub/mirror/simtelnet>

· Malaysia <ftp://ftp.jaring.my/pub/simtelnet>

· Malaysia <ftp://ftp.mimos.my/pub/simtelnet>

· Mexico <ftp://ftp.gdl.iteso.mx/pub/simtelnet>

· Netherlands <ftp://ftp.euro.net/d5/simtelnet>

· Netherlands <ftp://ftp.nic.surfnet.nl/mirror-

archive/software/simtelnet>

· New Zealand <ftp://ftp.vuw.ac.nz/pub/simtelnet>

· Norway <ftp://ftp.bitcon.no/pub/simtelnet>

· Poland <ftp://ftp.cyf-kr.edu.pl/pub/mirror/Simtel.Net>

· Poland <ftp://ftp.icm.edu.pl/pub/simtelnet>

· Poland <ftp://ftp.man.poznan.pl/pub/simtelnet>

 

· Portugal <ftp://ftp.ip.pt/pub/simtelnet>

· Portugal <ftp://ftp.ua.pt/pub/simtelnet>

· Romania <ftp://ftp.sorostm.ro/pub/simtelnet>

· Singapore <ftp://ftp.nus.sg/pub/simtelnet>

· Slovakia <ftp://ftp.uakom.sk/pub/simtelnet>

· Slovenia <ftp://ftp.arnes.si/software/simtelnet>

· South Africa <ftp://ftp.is.co.za/pub/simtelnet>

· South Africa <ftp://ftp.sun.ac.za/pub/simtelnet>

· South Korea <ftp://ftp.nuri.net/pub/simtelnet>

· South Korea <ftp://ftp.sogang.ac.kr/pub/simtelnet>

· South Korea <ftp://sunsite.snu.ac.kr/pub/simtelnet>

· Spain <ftp://ftp.rediris.es/mirror/simtelnet>

· Sweden <ftp://ftp.sunet.se/pub/simtelnet>

· Switzerland <ftp://sunsite.cnlab-

switch.ch/mirror/simtelnet>

· Taiwan <ftp://ftp.ncu.edu.tw/Packages/simtelnet>

· Taiwan <ftp://nctuccca.edu.tw/mirror/simtelnet>

· Thailand <ftp://ftp.nectec.or.th/pub/mirrors/simtelnet>

· UK, Edinburgh <ftp://emwac.ed.ac.uk/mirrors/simtelnet>

· UK, London <ftp://ftp.demon.co.uk/pub/simtelnet>

· UK, Lancaster <ftp://micros.hensa.ac.uk/pub/simtelnet>

· UK, London <ftp://sunsite.doc.ic.ac.uk/packages/simtelnet>

 

6.5. InfoMagic

Simtel Ste D-InfoMagic is at 11950 N. Highway 89, Flagstaff AZ

86004, telephone 800-800-6613 or 520-526-9565, fax 520-526-9573,

email: info@infomagic.com, web: <http://www.infomagic.com>.

 

6.6. Walnut Creek

Walnut Creek CDROM has many useful CDROMs. They are at 4041 Pike ,

Concord, CA 94520, USA. Telephone (800) 786-9907 or (510) 674-0783,

or FAX (510) 674-0821. email: orders@cdrom.com. Web:

<http://www.cdrom.com/>

 

6.7. Red Hat

Red Hat Software: telephone 800-454-5502 or 203-454-5500, fax:

203-454-2582, email: sales@redhat.com. Web: <http://www.redhat.com>.

 

 

6.8. Craftwork

CraftWork Solutions, 4320 Stevens Creek Blvd, Suite 170, San Jose CA

95129, telephone 800-985-1878, email: info@craftwork.com, web:

<http://www.craftwork.com>.

 

6.9. Yggdrasil

Yggdrasil Computing, 4880 Stevens Creek Blvd., Suite 205, San Jose CA

95129-1024, telephone 800-261-6630 or 408-261-6630, fax: 408-261-6631,

email: info@yggdrasil.com, web: <http://www.yggdrasil.com>.

 

6.10. Emacs for DOS

From the Emacs FAQ of November 11, 1996:

--begin quote

 

93: Where can I get Emacs for my PC running MS-DOS?

A pre-built binary distribution of Emacs 19.34 should be available by

the beginning of November 1996 from the Simtel archives, the main site

of which is at

<ftp://ftp.simtel.net/pub/simtelnet/gnu/djgpp/v2gnu/>

If you prefer to compile Emacs for yourself, you will need a 386 (or

better) processor, and are running MS-DOS 3.0 or later. According to

Eli Zaretskii eliz@is.elta.co.il and Darrel Hankerson

hankedr@dms.auburn.edu, you will need the following:

Compiler: djgpp version 1.12 maint 1 or later. Djgpp 2.0 or later is

recommended, since 1.x is being phased out. Djgpp 2 supports long

filenames under Windows 95.

You can get the latest release of djgpp by retrieving all of the files

in

<ftp://ftp.simtel.net/pub/simtelnet/gnu/djgpp>

Gunzip and tar:

The easiest way is to use "djtar" which comes with djgpp v2.x, because

it can open gzip'ed tarfiles (i.e., those ending with ".tar.gz") in

one step. Djtar comes in "djdev201.zip", from the URL mentioned

above.

Utilities: make, mv, sed, rm.

All of these utilities are available at

<ftp://ftp.simtel.net/pub/simtelnet/gnu/djgpp/v2gnu>

16-bit utilities can be found in GNUish:

<ftp://ftp.simtel.net/pub/simtelnet/gnu/gnuish>

The file INSTALL in the top-level directory of the Emacs source

contains some additional information regarding Emacs under MS-DOS. In

addition, the file etc/MSDOS contains some information on the

differences between the Unix and MS-DOS versions of Emacs.

 

For the most comprehensive information on running GNU Emacs on a PC,

see the file prepared by Michael Ernst mernst@theory.lcs.mit.edu at

<ftp://theory.lcs.mit.edu/pub/emacs/pc-emacs.gz>

For a list of other MS-DOS implementations of Emacs (and Emacs look-

alikes), consult the list of "Emacs implementations and literature,"

available at

<ftp://rtfm.mit.edu/pub/usenet/comp.emacs/>

Note that while many of these programs look similar to Emacs, they

often lack certain features, such as the Emacs Lisp extension

language.

 

--end quote

 

 

 

6.11. GNU Mirror Sites

The GNU collection at <ftp://prep.ai.mit.edu/pub/gnu> is mirrored at

many sites. Mirrors in USA include these:

· <ftp://labrea.stanford.edu/pub/gnu>

· <ftp://wuarchive.wustl.edu/systems/gnu>

· <ftp://ftp.kpc.com/pub/mirror/gnu>

· <ftp://f.ms.uky.edu/pub3/gnu>

· <ftp://jaguar.utah.edu/gnustuff>

· <ftp://ftp.hawaii.edu/mirrors/gnu>

· <ftp://uiarchive.cso.uiuc.edu/gnu>

· <ftp://uiarchive.cso.uiuc.edu/pub/gnu>

· <ftp://ftp.cs.columbia.edu/archives/gnu/prep>

· <ftp://gatekeeper.dec.com/pub/GNU>

· <ftp://ftp.uu.net/systems/gnu>

 

6.12. Emacspeak with Earlier Slackware Releases

If you want to install Slackware 3.0 or earlier, you will need to

prepare a full null modem cable, including modem control signals.

For two DB25 (25 pin) connectors, the required connections are:

· 1 (Frame Ground) - 1 (Frame Ground)

· 2 (Receive Data) - 3 (Transmit Data)

· 3 (Transmit Data) - 2 (Receive Data)

· 4 (Request To Send) - 5 (Clear To Send)

· 5 (Clear To Send) - 4 (Request To Send)

· 6 (Data Set Ready) - 20 (Data Terminal Ready)

· 7 (Signal Ground) - 7 (Signal Ground)

· 8 (Carrier Detect) - 20 (Data Terminal Ready)

· 20 (Data Terminal Ready) - 6 (Data Set Ready)

· 20 (Data Terminal Ready) - 8 (Carrier Detect)

For two DB9 connectors, the connections are:

· 1 (Carrier Detect) - 4 (Data Terminal Ready)

· 2 (Receive Data) - 3 (Transmit Data)

· 3 (Transmit Data) - 2 (Receive Data)

· 4 (Data Terminal Ready) - 6 (Data Set Ready)

· 4 (Data Terminal Ready) - 1 (Carrier Detect)

· 5 (Signal Ground) - 5 (Signal Ground)

· 6 (Data Set Ready) - 4 (Data Terminal Ready)

· 7 (Request To Send) - 8 (Clear To Send)

· 8 (Clear To Send) - 7 (Request To Send)

· 9 (Ring Indicator) not connected

For a DB9 (listed first) to a DB25 (second), the connections are:

· 1 (Carrier Detect) - 20 (Data Terminal Ready)

· 2 (Receive Data) - 2 (Transmit Data)

· 3 (Transmit Data) - 3 (Receive Data)

· 4 (Data Terminal Ready) - 6 (Data Set Ready)

· 4 (Data Terminal Ready) - 8 (Carrier Detect)

· 5 (Signal Ground) - 7 (Signal Ground)

· 6 (Data Set Ready) - 20(Data Terminal Ready)

· 7 (Request To Send) - 5 (Clear To Send)

· 8 (Clear To Send) - 4 (Request To Send)

· 9 (Ring Indicator) not connected

 

7. Frequently Asked Questions (FAQ)

7.1. Why does it say "space" after each character?

Your DECtalk Express has old firmware. Use the Emacspeak command `C-e

d V' to find out your version. You should be running a version no

older than 4.2bw from March 1995. If you have an earlier version, you

can find an updated version at

<http://www.ultranet.com/~rongemma/tips_upd.htm>, a WWW site

maintained by Ron Jemma of the Dectalk Group at DEC. Alternatively,

you can send email to Anne Nelson at DECnelson@dectlk.enet.dec.com.

The most recent version at this writing is 4.3 release AA X01 May 20

1996.

 

7.2. Why the high pitched tone from a DECtalk?

On occasion when reading the DECtalk will produce high pitch tones

that last for several words or more, if this happens in a buffer it

will often repeat within the same buffer.

The problem is due to remaining bugs in the Dectalk firmware. When

emacspeak produces tones, especially when split caps is on, the dtk

sometime goes into squealing mode.

If you notice this happening in particular text documents, just turn

off split caps mode locally with `C-e d s'.

 

 

7.3. Why the "No library autorevert in search path" message?

What is the significance of the message "No library autorevert in

search path" which is spoken (or at least queued for speech) when

emacspeak 7.0 starts?

It's completely insignificant. autorevert is a new minor mode provided

by emacs 20 and emacspeak looks for it and if found speech-enables it.

 

7.4. How do I change Emacspeak defaults?

What is the best way to change Emacspeak defaults for things such as

speech rate, default punctuation mode, etc.?

Just put the needed changes in your .emacs file. ".emacs" is a file

in your home directory that is loaded by emacs when it starts (shortly

after reading emacspeak). It is the place to do personal

modifications.

Here is an example which resets the speech rate and redefines a

function (courtesy of Greg Priest-Dorman priestdo@cs.vassar.edu):

 

 

;;

(dtk-set-rate 380 1)

;;

(defun emacspeak-speak-time ()

"Speak the time. "

(interactive)

(dtk-speak (format-time-string "%A %B %e, %I %M %p"

(current-time) )))

;;

 

 

 

 

7.5. What if an error message is not spoken?

An error message was displayed on the screen, but not reported by

Emacspeak

In general, if emacs hits an error and you don't get to hear the

message because it went by too quickly, here is what you should do:

1) Switch to the *Messages* buffer and see if you see the message

there. 99% of the time it will be there.

2) If some portion of emacs or an emacs application throws an error

without leaving an appropriate message in the *Messages* buffer, then

turn on emacs' debugging facility by `M-x set-variable ret' `debug-on-

error ret' `t ret' this sets debugon-on-error to true now repeat what

caused the error you will be placed in a backtrace buffer.

Warning: do not read the entire contents of the backtrace buffer at

one shot with emacspeak. Go line by line. (courtesy of T. V. Raman

raman@Adobe.COM)

 

7.6. The terminal emulator is the most problematic portion of Emacs&SHY;

peak.

It's not an emacspeak problem-- it's a terminal problem. Getting a

terminal emulator working correctly inside emacs is not a joke-- and

eterm is an excellent piece of work, but depending on how some old app

behaves you will (or should always expect to) see some weirdness.

After all, remember all of these UNIX terminal apps work from all

kinds of terminals ranging from vt52's to new devices.

 

7.7. In a term buffer, the first half screen is not spoken

 

When starting a term buffer, no output is spoken in line mode by

Emacspeak until the cursor has made it about half way down the screen

I've not seen this-- and I am running emacs 20.

When you start term it is in character mode. When you switch to line

mode make sure the cursor is at the end of the buffer-- otherwise what

you send will never go to the shell.

Also, in general use M-x shell (comint-mode) for running things you

would run in line mode in eterm-- it's been around longer and far more

robust. M-x term specializes in its character-mode of terminal

emulation and may not always take care of everything in line mode.

(courtesy of T. V. Raman raman@Adobe.COM)

 

7.8. Term mode gets flaky after a long session.

Sometimes, after long sessions with a term buffer, I will experience

similar problems as do you with spech in the term becoming very flaky.

Output may or may not be spoken (I have not determined the pattern).

if the term becomes flaky, enter character mode and issue a reset.

the above is usually a result of running some curses based app that

leaves the terminal in a screwy state.

Many curses based apps follow slightly different conventions on where

they leave the cursor while you edit-- 60-70% of them leave the cursor

just after the character you typed with a null character after point.

Others leave a space character there which is what you hear.

Experiment between setting TERM to vt100 and eterm. Depending on

whether the app was linked against curses or ncurses (former uses

TERMCAP and latter uses TERMINFO) you will get different results.

 

 

8. Legalese

Copyright (c) 1998 by James R. Van Zandt jrv@vanzandt.mv.com. This

document may be distributed under the terms set forth in the LDP

license at <http://metalab.unc.edu/LDP/COPYRIGHT.html>.

If you have questions, please contact Tim Bynum, the Linux HOWTO

coordinator, at tjbynum@metalab.unc.edu or linux-

howto@metalab.unc.edu.


| HowTo Linux Zone | Linux Zone Home | E-Mail Me |

Copyright 1999

Linux Zone