1MSH(1)                             [nmh-1.3]                            MSH(1)
2
3
4

NAME

6       msh - nmh shell (and BBoard reader)
7

SYNOPSIS

9       msh [-prompt string] [-scan | -noscan] [-topcur | -notopcur] [file]
10            [-version] [-help]
11

DESCRIPTION

13       msh is an interactive program that implements a subset  of  the  normal
14       nmh commands operating on a single file in packf'dformat.  That is, msh
15       is used to read a file that contains a number of messages,  as  opposed
16       to the standard nmh style of reading a number of files, each file being
17       a separate message in a folder.  msh's chief advantage is that the nor‐
18       mal  nmh  style  does not allow a file to have more than one message in
19       it.  Hence, msh is ideal for reading BBoards, as these files are deliv‐
20       ered  by  the transport system in this format.  In addition, msh can be
21       used on other files, such as message archives which  have  been  packed
22       (see  packf(1)).   Finally, msh is an excellent nmh tutor.  As the only
23       commands available to the user are nmh commands, this allows nmh begin‐
24       ners  to  concentrate  on  how  commands to nmh are formed and (more or
25       less) what they mean.
26
27       When invoked, msh reads the named file, and enters a command loop.  The
28       user  may  type most of the normal nmh commands.  The syntax and seman‐
29       tics of these commands typed to msh are identical to their nmh counter‐
30       parts.   In  cases where the nature of msh would be inconsistent (e.g.,
31       specifying a +folder with some commands),  msh  will  duly  inform  the
32       user.  The commands that msh currently supports (in some slightly modi‐
33       fied or restricted forms) are:
34
35            ali
36            burst
37            comp
38            dist
39            folder
40            forw
41            inc
42            mark
43            mhmail
44            mhn
45            msgchk
46            next
47            packf
48            pick
49            prev
50            refile
51            repl
52            rmm
53            scan
54            send
55            show
56            sortm
57            whatnow
58            whom
59
60       In addition, msh has a help command which gives a brief  overview.   To
61       terminate  msh,  type CTRL-D, or use the quit command.  If msh is being
62       invoked from bbc, then typing CTRL-D will also  tell  bbc  to  exit  as
63       well,  while using the quit command will return control to bbc, and bbc
64       will continue examining the list of BBoards that it is scanning.
65
66       If the file is writable and has been modified,  then  using  quit  will
67       query the user if the file should be updated.
68
69       The -prompt string switch sets the prompting string for msh.
70
71       You  may wish to use an alternate nmh profile for the commands that msh
72       executes; see mh-profile(5) for details about the $MH environment vari‐
73       able.
74
75       When  invoked  from  bbc,  two special features are enabled: First, the
76       -scan switch directs msh to do a “scan unseen” on start-up if new items
77       are  present  in the BBoard.  This feature is best used from bbc, which
78       correctly sets the stage.  Second, the mark command in  msh  acts  spe‐
79       cially  when  you  are  reading  a  BBoard,  since msh will consult the
80       sequence “unseen” in determining what messages you have actually  read.
81       When  msh  exits,  it reports this information to bbc.  In addition, if
82       you give the mark command with no arguments, msh will interpret  it  as
83mark  -sequence  unseen  -delete -nozero all” Hence, to discard all of
84       the messages in the current BBoard you're reading, just  use  the  mark
85       command with no arguments.
86
87       Normally,  the  exit  command  is identical to the quit command in msh.
88       When run under bbc however, exit directs msh to mark  all  messages  as
89       seen and then quit.  For speedy type-in, this command is often abbrevi‐
90       ated as just qe.
91
92       When invoked from vmh, another special feature is enabled: The `topcur'
93       switch  directs msh to have the current message “track” the top line of
94       the vmh scan window.  Normally, msh has the current message “track” the
95       center of the window (under -notopcur, which is the default).
96
97       msh  supports an output redirection facility.  Commands may be followed
98       by one of
99
100            ^> file~^write output to file
101            ^>> file~^append output to file
102            ^| command~^pipe output to UNIX command
103
104       If file starts with a “ ” (tilde),  then  a  csh-like  expansion  takes
105       place.   Note  that  command  is interpreted by sh.  Also note that msh
106       does NOT support  history  substitutions,  variable  substitutions,  or
107       alias substitutions.
108
109       When  parsing  commands to the left of any redirection symbol, msh will
110       honor `\' (back-slash) as the  quote  next-character  symbol,  and  `“'
111       (double-quote)  as  quote-word  delimiters.  All other input tokens are
112       separated by whitespace (spaces and tabs).
113
114

FILES

116       $HOME/.mh_profile          The user profile
117       /etc/nmh/mts.conf          nmh mts configuration file
118
119

PROFILE COMPONENTS

121       Path:                To determine the user's nmh directory
122       Msg-Protect:         To set mode when creating a new `file'
123       fileproc:            Program to file messages
124       showproc:            Program to show messages
125
126

SEE ALSO

128       bbc(1)
129
130

DEFAULTS

132       `file' defaults to “./msgbox”
133       `-prompt (msh) '
134       `-noscan'
135       `-notopcur'
136
137

CONTEXT

139       None
140
141

BUGS

143       The argument to the -prompt switch must  be  interpreted  as  a  single
144       token by the shell that invokes msh.  Therefore, one must usually place
145       the argument to this switch inside double-quotes.
146
147       There is a strict limit of messages per file in  packf'd  format  which
148       msh can handle.  Usually, this limit is 1000 messages.
149
150       Please remember that msh is not the C-Shell, and that a lot of the nice
151       facilities provided by the latter are not present in the former.
152
153       In particular, msh does not understand back-quoting, so the only effec‐
154       tive  way  to  use  pick  inside  msh  is to always use the -seq select
155       switch.  Clever users of nmh will put the line
156
157            pick: -seq select -list
158
159       in their .mh_profile file so that pick works equally well from both the
160       shell and msh.
161
162       sortm always uses -noverbose and if -textfield field is used, -limit 0.
163
164       The  msh  program  inherits  most (if not all) of the bugs from the nmh
165       commands it implements.
166
167
168
169MH.6.8                            1 June 2008                           MSH(1)
Impressum