annotate lisp/telnet.el @ 2778:071fa2f469d7

* dispnew.c (direct_output_for_insert): Compute the face of the character we're inserting properly.
author Jim Blandy <jimb@redhat.com>
date Fri, 14 May 1993 14:39:15 +0000
parents 2715e893d220
children ec0c98304624
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
658
7cbd4fcd8b0f *** empty log message ***
Eric S. Raymond <esr@snark.thyrsus.com>
parents: 584
diff changeset
1 ;;; telnet.el --- run a telnet session from within an Emacs buffer
775
1ca26ccad38e *** empty log message ***
Eric S. Raymond <esr@snark.thyrsus.com>
parents: 707
diff changeset
2
841
2cdce064065f entered into RCS
Eric S. Raymond <esr@snark.thyrsus.com>
parents: 775
diff changeset
3 ;;; Copyright (C) 1985, 1988, 1992 Free Software Foundation, Inc.
2cdce064065f entered into RCS
Eric S. Raymond <esr@snark.thyrsus.com>
parents: 775
diff changeset
4
775
1ca26ccad38e *** empty log message ***
Eric S. Raymond <esr@snark.thyrsus.com>
parents: 707
diff changeset
5 ;; Author: William F. Schelter
1ca26ccad38e *** empty log message ***
Eric S. Raymond <esr@snark.thyrsus.com>
parents: 707
diff changeset
6 ;; Maintainer: FSF
48
82ef7404837f Initial revision
root <root>
parents:
diff changeset
7
82ef7404837f Initial revision
root <root>
parents:
diff changeset
8 ;; This file is part of GNU Emacs.
82ef7404837f Initial revision
root <root>
parents:
diff changeset
9
82ef7404837f Initial revision
root <root>
parents:
diff changeset
10 ;; GNU Emacs is free software; you can redistribute it and/or modify
82ef7404837f Initial revision
root <root>
parents:
diff changeset
11 ;; it under the terms of the GNU General Public License as published by
707
e4253da532fb *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 658
diff changeset
12 ;; the Free Software Foundation; either version 2, or (at your option)
48
82ef7404837f Initial revision
root <root>
parents:
diff changeset
13 ;; any later version.
82ef7404837f Initial revision
root <root>
parents:
diff changeset
14
82ef7404837f Initial revision
root <root>
parents:
diff changeset
15 ;; GNU Emacs is distributed in the hope that it will be useful,
82ef7404837f Initial revision
root <root>
parents:
diff changeset
16 ;; but WITHOUT ANY WARRANTY; without even the implied warranty of
82ef7404837f Initial revision
root <root>
parents:
diff changeset
17 ;; MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
82ef7404837f Initial revision
root <root>
parents:
diff changeset
18 ;; GNU General Public License for more details.
82ef7404837f Initial revision
root <root>
parents:
diff changeset
19
82ef7404837f Initial revision
root <root>
parents:
diff changeset
20 ;; You should have received a copy of the GNU General Public License
82ef7404837f Initial revision
root <root>
parents:
diff changeset
21 ;; along with GNU Emacs; see the file COPYING. If not, write to
82ef7404837f Initial revision
root <root>
parents:
diff changeset
22 ;; the Free Software Foundation, 675 Mass Ave, Cambridge, MA 02139, USA.
82ef7404837f Initial revision
root <root>
parents:
diff changeset
23
2562
2715e893d220 Commentary added.
Eric S. Raymond <esr@snark.thyrsus.com>
parents: 1577
diff changeset
24 ;;; Commentary:
2715e893d220 Commentary added.
Eric S. Raymond <esr@snark.thyrsus.com>
parents: 1577
diff changeset
25
2715e893d220 Commentary added.
Eric S. Raymond <esr@snark.thyrsus.com>
parents: 1577
diff changeset
26 ;; This mode is intended to be used for telnet or rsh to a remode host;
2715e893d220 Commentary added.
Eric S. Raymond <esr@snark.thyrsus.com>
parents: 1577
diff changeset
27 ;; `telnet' and `rsh' are the two entry points. Multiple telnet or rsh
2715e893d220 Commentary added.
Eric S. Raymond <esr@snark.thyrsus.com>
parents: 1577
diff changeset
28 ;; sessions are supported.
2715e893d220 Commentary added.
Eric S. Raymond <esr@snark.thyrsus.com>
parents: 1577
diff changeset
29 ;;
2715e893d220 Commentary added.
Eric S. Raymond <esr@snark.thyrsus.com>
parents: 1577
diff changeset
30 ;; Normally, input is sent to the remote telnet/rsh line-by-line, as you
2715e893d220 Commentary added.
Eric S. Raymond <esr@snark.thyrsus.com>
parents: 1577
diff changeset
31 ;; type RET or LFD. C-c C-c sends a C-c to the remote immediately;
2715e893d220 Commentary added.
Eric S. Raymond <esr@snark.thyrsus.com>
parents: 1577
diff changeset
32 ;; C-c C-z sends C-z immediately. C-c C-q followed by any character
2715e893d220 Commentary added.
Eric S. Raymond <esr@snark.thyrsus.com>
parents: 1577
diff changeset
33 ;; sends that character immediately.
2715e893d220 Commentary added.
Eric S. Raymond <esr@snark.thyrsus.com>
parents: 1577
diff changeset
34 ;;
2715e893d220 Commentary added.
Eric S. Raymond <esr@snark.thyrsus.com>
parents: 1577
diff changeset
35 ;; All RET characters are filtered out of the output coming back from the
2715e893d220 Commentary added.
Eric S. Raymond <esr@snark.thyrsus.com>
parents: 1577
diff changeset
36 ;; remote system. The mode tries to do other useful translations based
2715e893d220 Commentary added.
Eric S. Raymond <esr@snark.thyrsus.com>
parents: 1577
diff changeset
37 ;; on what it sees coming back from the other system before the password
2715e893d220 Commentary added.
Eric S. Raymond <esr@snark.thyrsus.com>
parents: 1577
diff changeset
38 ;; query. It knows about UNIX, ITS, TOPS-20 and Explorer systems.
2715e893d220 Commentary added.
Eric S. Raymond <esr@snark.thyrsus.com>
parents: 1577
diff changeset
39
775
1ca26ccad38e *** empty log message ***
Eric S. Raymond <esr@snark.thyrsus.com>
parents: 707
diff changeset
40 ;;; Code:
48
82ef7404837f Initial revision
root <root>
parents:
diff changeset
41
2562
2715e893d220 Commentary added.
Eric S. Raymond <esr@snark.thyrsus.com>
parents: 1577
diff changeset
42 ;; to do fix software types for lispm:
2715e893d220 Commentary added.
Eric S. Raymond <esr@snark.thyrsus.com>
parents: 1577
diff changeset
43 ;; to eval current expression. Also to try to send escape keys correctly.
2715e893d220 Commentary added.
Eric S. Raymond <esr@snark.thyrsus.com>
parents: 1577
diff changeset
44 ;; essentially we'll want the rubout-handler off.
48
82ef7404837f Initial revision
root <root>
parents:
diff changeset
45
82ef7404837f Initial revision
root <root>
parents:
diff changeset
46 ;; filter is simplistic but should be okay for typical shell usage.
82ef7404837f Initial revision
root <root>
parents:
diff changeset
47 ;; needs hacking if it is going to deal with asynchronous output in a sane
82ef7404837f Initial revision
root <root>
parents:
diff changeset
48 ;; manner
82ef7404837f Initial revision
root <root>
parents:
diff changeset
49
82ef7404837f Initial revision
root <root>
parents:
diff changeset
50 (require 'comint)
707
e4253da532fb *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 658
diff changeset
51
48
82ef7404837f Initial revision
root <root>
parents:
diff changeset
52 (defvar telnet-new-line "\r")
82ef7404837f Initial revision
root <root>
parents:
diff changeset
53 (defvar telnet-mode-map nil)
82ef7404837f Initial revision
root <root>
parents:
diff changeset
54 (defvar telnet-prompt-pattern "^[^#$%>]*[#$%>] *")
82ef7404837f Initial revision
root <root>
parents:
diff changeset
55 (defvar telnet-replace-c-g nil)
82ef7404837f Initial revision
root <root>
parents:
diff changeset
56 (make-variable-buffer-local
82ef7404837f Initial revision
root <root>
parents:
diff changeset
57 (defvar telnet-remote-echoes t
82ef7404837f Initial revision
root <root>
parents:
diff changeset
58 "True if the telnet process will echo input."))
82ef7404837f Initial revision
root <root>
parents:
diff changeset
59 (make-variable-buffer-local
82ef7404837f Initial revision
root <root>
parents:
diff changeset
60 (defvar telnet-interrupt-string "\C-c" "String sent by C-c."))
82ef7404837f Initial revision
root <root>
parents:
diff changeset
61
82ef7404837f Initial revision
root <root>
parents:
diff changeset
62 (defvar telnet-count 0
82ef7404837f Initial revision
root <root>
parents:
diff changeset
63 "Number of output strings read from the telnet process
82ef7404837f Initial revision
root <root>
parents:
diff changeset
64 while looking for the initial password.")
82ef7404837f Initial revision
root <root>
parents:
diff changeset
65
82ef7404837f Initial revision
root <root>
parents:
diff changeset
66 (defvar telnet-initial-count -50
1577
a52da8d63ff3 Doc fix.
Christopher Zaborsky <rogue@erratum.com>
parents: 1418
diff changeset
67 "Initial value of `telnet-count'. Should be set to the negative of the
48
82ef7404837f Initial revision
root <root>
parents:
diff changeset
68 number of terminal writes telnet will make setting up the host connection.")
82ef7404837f Initial revision
root <root>
parents:
diff changeset
69
82ef7404837f Initial revision
root <root>
parents:
diff changeset
70 (defvar telnet-maximum-count 4
1577
a52da8d63ff3 Doc fix.
Christopher Zaborsky <rogue@erratum.com>
parents: 1418
diff changeset
71 "Maximum value `telnet-count' can have.
48
82ef7404837f Initial revision
root <root>
parents:
diff changeset
72 After this many passes, we stop looking for initial setup data.
82ef7404837f Initial revision
root <root>
parents:
diff changeset
73 Should be set to the number of terminal writes telnet will make
82ef7404837f Initial revision
root <root>
parents:
diff changeset
74 rejecting one login and prompting for the again for a username and password.")
82ef7404837f Initial revision
root <root>
parents:
diff changeset
75
82ef7404837f Initial revision
root <root>
parents:
diff changeset
76 (defun telnet-interrupt-subjob ()
82ef7404837f Initial revision
root <root>
parents:
diff changeset
77 (interactive)
82ef7404837f Initial revision
root <root>
parents:
diff changeset
78 "Interrupt the program running through telnet on the remote host."
82ef7404837f Initial revision
root <root>
parents:
diff changeset
79 (send-string nil telnet-interrupt-string))
82ef7404837f Initial revision
root <root>
parents:
diff changeset
80
82ef7404837f Initial revision
root <root>
parents:
diff changeset
81 (defun telnet-c-z ()
82ef7404837f Initial revision
root <root>
parents:
diff changeset
82 (interactive)
82ef7404837f Initial revision
root <root>
parents:
diff changeset
83 (send-string nil "\C-z"))
82ef7404837f Initial revision
root <root>
parents:
diff changeset
84
82ef7404837f Initial revision
root <root>
parents:
diff changeset
85 (defun send-process-next-char ()
82ef7404837f Initial revision
root <root>
parents:
diff changeset
86 (interactive)
82ef7404837f Initial revision
root <root>
parents:
diff changeset
87 (send-string nil
82ef7404837f Initial revision
root <root>
parents:
diff changeset
88 (char-to-string
82ef7404837f Initial revision
root <root>
parents:
diff changeset
89 (let ((inhibit-quit t))
82ef7404837f Initial revision
root <root>
parents:
diff changeset
90 (prog1 (read-char)
82ef7404837f Initial revision
root <root>
parents:
diff changeset
91 (setq quit-flag nil))))))
82ef7404837f Initial revision
root <root>
parents:
diff changeset
92
82ef7404837f Initial revision
root <root>
parents:
diff changeset
93 ; initialization on first load.
82ef7404837f Initial revision
root <root>
parents:
diff changeset
94 (if telnet-mode-map
82ef7404837f Initial revision
root <root>
parents:
diff changeset
95 nil
82ef7404837f Initial revision
root <root>
parents:
diff changeset
96 (setq telnet-mode-map (copy-keymap comint-mode-map))
82ef7404837f Initial revision
root <root>
parents:
diff changeset
97 (define-key telnet-mode-map "\C-m" 'telnet-send-input)
82ef7404837f Initial revision
root <root>
parents:
diff changeset
98 ; (define-key telnet-mode-map "\C-j" 'telnet-send-input)
82ef7404837f Initial revision
root <root>
parents:
diff changeset
99 (define-key telnet-mode-map "\C-c\C-q" 'send-process-next-char)
82ef7404837f Initial revision
root <root>
parents:
diff changeset
100 (define-key telnet-mode-map "\C-c\C-c" 'telnet-interrupt-subjob)
82ef7404837f Initial revision
root <root>
parents:
diff changeset
101 (define-key telnet-mode-map "\C-c\C-z" 'telnet-c-z))
82ef7404837f Initial revision
root <root>
parents:
diff changeset
102
82ef7404837f Initial revision
root <root>
parents:
diff changeset
103 ;;maybe should have a flag for when have found type
82ef7404837f Initial revision
root <root>
parents:
diff changeset
104 (defun telnet-check-software-type-initialize (string)
82ef7404837f Initial revision
root <root>
parents:
diff changeset
105 "Tries to put correct initializations in. Needs work."
82ef7404837f Initial revision
root <root>
parents:
diff changeset
106 (let ((case-fold-search t))
82ef7404837f Initial revision
root <root>
parents:
diff changeset
107 (cond ((string-match "unix" string)
82ef7404837f Initial revision
root <root>
parents:
diff changeset
108 (setq telnet-prompt-pattern comint-prompt-regexp)
82ef7404837f Initial revision
root <root>
parents:
diff changeset
109 (setq telnet-new-line "\n"))
82ef7404837f Initial revision
root <root>
parents:
diff changeset
110 ((string-match "tops-20" string) ;;maybe add telnet-replace-c-g
82ef7404837f Initial revision
root <root>
parents:
diff changeset
111 (setq telnet-prompt-pattern "[@>]*"))
82ef7404837f Initial revision
root <root>
parents:
diff changeset
112 ((string-match "its" string)
82ef7404837f Initial revision
root <root>
parents:
diff changeset
113 (setq telnet-prompt-pattern "^[^*>]*[*>] *"))
82ef7404837f Initial revision
root <root>
parents:
diff changeset
114 ((string-match "explorer" string) ;;explorer telnet needs work
82ef7404837f Initial revision
root <root>
parents:
diff changeset
115 (setq telnet-replace-c-g ?\n))))
82ef7404837f Initial revision
root <root>
parents:
diff changeset
116 (setq comint-prompt-regexp telnet-prompt-pattern))
82ef7404837f Initial revision
root <root>
parents:
diff changeset
117
82ef7404837f Initial revision
root <root>
parents:
diff changeset
118 (defun telnet-initial-filter (proc string)
82ef7404837f Initial revision
root <root>
parents:
diff changeset
119 ;For reading up to and including password; also will get machine type.
82ef7404837f Initial revision
root <root>
parents:
diff changeset
120 (cond ((string-match "No such host" string)
82ef7404837f Initial revision
root <root>
parents:
diff changeset
121 (kill-buffer (process-buffer proc))
82ef7404837f Initial revision
root <root>
parents:
diff changeset
122 (error "No such host."))
82ef7404837f Initial revision
root <root>
parents:
diff changeset
123 ((string-match "passw" string)
82ef7404837f Initial revision
root <root>
parents:
diff changeset
124 (telnet-filter proc string)
82ef7404837f Initial revision
root <root>
parents:
diff changeset
125 (let* ((echo-keystrokes 0)
82ef7404837f Initial revision
root <root>
parents:
diff changeset
126 (password (read-password)))
82ef7404837f Initial revision
root <root>
parents:
diff changeset
127 (setq telnet-count 0)
82ef7404837f Initial revision
root <root>
parents:
diff changeset
128 (send-string proc (concat password telnet-new-line))))
82ef7404837f Initial revision
root <root>
parents:
diff changeset
129 (t (telnet-check-software-type-initialize string)
82ef7404837f Initial revision
root <root>
parents:
diff changeset
130 (telnet-filter proc string)
82ef7404837f Initial revision
root <root>
parents:
diff changeset
131 (cond ((> telnet-count telnet-maximum-count)
82ef7404837f Initial revision
root <root>
parents:
diff changeset
132 (set-process-filter proc 'telnet-filter))
82ef7404837f Initial revision
root <root>
parents:
diff changeset
133 (t (setq telnet-count (1+ telnet-count)))))))
82ef7404837f Initial revision
root <root>
parents:
diff changeset
134
82ef7404837f Initial revision
root <root>
parents:
diff changeset
135 (defun telnet-filter (proc string)
82ef7404837f Initial revision
root <root>
parents:
diff changeset
136 (let ((at-end
82ef7404837f Initial revision
root <root>
parents:
diff changeset
137 (and (eq (process-buffer proc) (current-buffer))
82ef7404837f Initial revision
root <root>
parents:
diff changeset
138 (= (point) (point-max)))))
82ef7404837f Initial revision
root <root>
parents:
diff changeset
139 (save-excursion
82ef7404837f Initial revision
root <root>
parents:
diff changeset
140 (set-buffer (process-buffer proc))
82ef7404837f Initial revision
root <root>
parents:
diff changeset
141 (goto-char (process-mark proc))
82ef7404837f Initial revision
root <root>
parents:
diff changeset
142 (let ((now (point)))
707
e4253da532fb *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 658
diff changeset
143 ;; Insert STRING, omitting all C-m characters.
48
82ef7404837f Initial revision
root <root>
parents:
diff changeset
144 (let ((index 0) c-m)
82ef7404837f Initial revision
root <root>
parents:
diff changeset
145 (while (setq c-m (string-match "\C-m" string index))
82ef7404837f Initial revision
root <root>
parents:
diff changeset
146 (insert-before-markers (substring string index c-m))
82ef7404837f Initial revision
root <root>
parents:
diff changeset
147 (setq index (1+ c-m)))
82ef7404837f Initial revision
root <root>
parents:
diff changeset
148 (insert-before-markers (substring string index)))
82ef7404837f Initial revision
root <root>
parents:
diff changeset
149 (and telnet-replace-c-g
82ef7404837f Initial revision
root <root>
parents:
diff changeset
150 (subst-char-in-region now (point) ?\C-g telnet-replace-c-g)))
82ef7404837f Initial revision
root <root>
parents:
diff changeset
151 ; (if (and (integer-or-marker-p last-input-start)
82ef7404837f Initial revision
root <root>
parents:
diff changeset
152 ; (marker-position last-input-start)
82ef7404837f Initial revision
root <root>
parents:
diff changeset
153 ; telnet-remote-echoes)
82ef7404837f Initial revision
root <root>
parents:
diff changeset
154 ; (delete-region last-input-start last-input-end))
82ef7404837f Initial revision
root <root>
parents:
diff changeset
155 )
82ef7404837f Initial revision
root <root>
parents:
diff changeset
156 (if at-end
82ef7404837f Initial revision
root <root>
parents:
diff changeset
157 (goto-char (point-max)))))
82ef7404837f Initial revision
root <root>
parents:
diff changeset
158
82ef7404837f Initial revision
root <root>
parents:
diff changeset
159 (defun telnet-send-input ()
82ef7404837f Initial revision
root <root>
parents:
diff changeset
160 (interactive)
707
e4253da532fb *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 658
diff changeset
161 ; (comint-send-input telnet-new-line telnet-remote-echoes)
e4253da532fb *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 658
diff changeset
162 (comint-send-input)
e4253da532fb *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 658
diff changeset
163 (if telnet-remote-echoes
e4253da532fb *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 658
diff changeset
164 (delete-region comint-last-input-start
e4253da532fb *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 658
diff changeset
165 comint-last-input-end)))
48
82ef7404837f Initial revision
root <root>
parents:
diff changeset
166
258
1e0bc00dca7a *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 48
diff changeset
167 ;;;###autoload
48
82ef7404837f Initial revision
root <root>
parents:
diff changeset
168 (defun telnet (arg)
82ef7404837f Initial revision
root <root>
parents:
diff changeset
169 "Open a network login connection to host named HOST (a string).
82ef7404837f Initial revision
root <root>
parents:
diff changeset
170 Communication with HOST is recorded in a buffer *HOST-telnet*.
82ef7404837f Initial revision
root <root>
parents:
diff changeset
171 Normally input is edited in Emacs and sent a line at a time."
82ef7404837f Initial revision
root <root>
parents:
diff changeset
172 (interactive "sOpen telnet connection to host: ")
82ef7404837f Initial revision
root <root>
parents:
diff changeset
173 (let ((name (concat arg "-telnet" )))
82ef7404837f Initial revision
root <root>
parents:
diff changeset
174 (switch-to-buffer (make-comint name "telnet"))
82ef7404837f Initial revision
root <root>
parents:
diff changeset
175 (set-process-filter (get-process name) 'telnet-initial-filter)
1414
2ba9b06d4247 (telnet): Wait for telnet output before sending `open'.
Richard M. Stallman <rms@gnu.org>
parents: 841
diff changeset
176 ;; Don't send the `open' cmd till telnet is ready for it.
2ba9b06d4247 (telnet): Wait for telnet output before sending `open'.
Richard M. Stallman <rms@gnu.org>
parents: 841
diff changeset
177 (accept-process-output (get-process name))
1418
d8dc740867ee (telnet): Do erase-buffer after the initial output.
Richard M. Stallman <rms@gnu.org>
parents: 1414
diff changeset
178 (erase-buffer)
48
82ef7404837f Initial revision
root <root>
parents:
diff changeset
179 (send-string name (concat "open " arg "\n"))
82ef7404837f Initial revision
root <root>
parents:
diff changeset
180 (telnet-mode)
82ef7404837f Initial revision
root <root>
parents:
diff changeset
181 (setq telnet-count telnet-initial-count)))
82ef7404837f Initial revision
root <root>
parents:
diff changeset
182
82ef7404837f Initial revision
root <root>
parents:
diff changeset
183 (defun telnet-mode ()
2562
2715e893d220 Commentary added.
Eric S. Raymond <esr@snark.thyrsus.com>
parents: 1577
diff changeset
184 "This mode is for using telnet (or rsh) from a buffer to another host.
1577
a52da8d63ff3 Doc fix.
Christopher Zaborsky <rogue@erratum.com>
parents: 1418
diff changeset
185 It has most of the same commands as comint-mode.
48
82ef7404837f Initial revision
root <root>
parents:
diff changeset
186 There is a variable ``telnet-interrupt-string'' which is the character
82ef7404837f Initial revision
root <root>
parents:
diff changeset
187 sent to try to stop execution of a job on the remote host.
82ef7404837f Initial revision
root <root>
parents:
diff changeset
188 Data is sent to the remote host when RET is typed.
82ef7404837f Initial revision
root <root>
parents:
diff changeset
189
82ef7404837f Initial revision
root <root>
parents:
diff changeset
190 \\{telnet-mode-map}
2562
2715e893d220 Commentary added.
Eric S. Raymond <esr@snark.thyrsus.com>
parents: 1577
diff changeset
191 "
48
82ef7404837f Initial revision
root <root>
parents:
diff changeset
192 (interactive)
82ef7404837f Initial revision
root <root>
parents:
diff changeset
193 (comint-mode)
82ef7404837f Initial revision
root <root>
parents:
diff changeset
194 (setq major-mode 'telnet-mode
82ef7404837f Initial revision
root <root>
parents:
diff changeset
195 mode-name "Telnet"
82ef7404837f Initial revision
root <root>
parents:
diff changeset
196 comint-prompt-regexp telnet-prompt-pattern)
82ef7404837f Initial revision
root <root>
parents:
diff changeset
197 (use-local-map telnet-mode-map)
82ef7404837f Initial revision
root <root>
parents:
diff changeset
198 (run-hooks 'telnet-mode-hook))
82ef7404837f Initial revision
root <root>
parents:
diff changeset
199
2562
2715e893d220 Commentary added.
Eric S. Raymond <esr@snark.thyrsus.com>
parents: 1577
diff changeset
200 ;;;###autoload
2715e893d220 Commentary added.
Eric S. Raymond <esr@snark.thyrsus.com>
parents: 1577
diff changeset
201 (defun rsh (arg)
2715e893d220 Commentary added.
Eric S. Raymond <esr@snark.thyrsus.com>
parents: 1577
diff changeset
202 "Open a network login connection to host named HOST (a string).
2715e893d220 Commentary added.
Eric S. Raymond <esr@snark.thyrsus.com>
parents: 1577
diff changeset
203 Communication with HOST is recorded in a buffer *HOST-rsh*.
2715e893d220 Commentary added.
Eric S. Raymond <esr@snark.thyrsus.com>
parents: 1577
diff changeset
204 Normally input is edited in Emacs and sent a line at a time."
2715e893d220 Commentary added.
Eric S. Raymond <esr@snark.thyrsus.com>
parents: 1577
diff changeset
205 (interactive "sOpen rsh connection to host: ")
2715e893d220 Commentary added.
Eric S. Raymond <esr@snark.thyrsus.com>
parents: 1577
diff changeset
206 (require 'shell)
2715e893d220 Commentary added.
Eric S. Raymond <esr@snark.thyrsus.com>
parents: 1577
diff changeset
207 (let ((name (concat arg "-rsh" )))
2715e893d220 Commentary added.
Eric S. Raymond <esr@snark.thyrsus.com>
parents: 1577
diff changeset
208 (switch-to-buffer (make-comint name "rsh"))
2715e893d220 Commentary added.
Eric S. Raymond <esr@snark.thyrsus.com>
parents: 1577
diff changeset
209 (set-process-filter (get-process name) 'telnet-initial-filter)
2715e893d220 Commentary added.
Eric S. Raymond <esr@snark.thyrsus.com>
parents: 1577
diff changeset
210 (telnet-mode)
2715e893d220 Commentary added.
Eric S. Raymond <esr@snark.thyrsus.com>
parents: 1577
diff changeset
211 (setq telnet-count -16)))
2715e893d220 Commentary added.
Eric S. Raymond <esr@snark.thyrsus.com>
parents: 1577
diff changeset
212
48
82ef7404837f Initial revision
root <root>
parents:
diff changeset
213 (defun read-password ()
82ef7404837f Initial revision
root <root>
parents:
diff changeset
214 (let ((answ "") tem)
82ef7404837f Initial revision
root <root>
parents:
diff changeset
215 (message "Reading password...")
557
46b8522b8f89 *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 258
diff changeset
216 (while (prog1 (not (memq (setq tem (read-char)) '(?\C-m ?\n ?\C-g)))
46b8522b8f89 *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 258
diff changeset
217 (setq quit-flag nil))
48
82ef7404837f Initial revision
root <root>
parents:
diff changeset
218 (setq answ (concat answ (char-to-string tem))))
82ef7404837f Initial revision
root <root>
parents:
diff changeset
219 answ))
584
4cd7543be581 *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 557
diff changeset
220
4cd7543be581 *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 557
diff changeset
221 (provide 'telnet)
4cd7543be581 *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 557
diff changeset
222
658
7cbd4fcd8b0f *** empty log message ***
Eric S. Raymond <esr@snark.thyrsus.com>
parents: 584
diff changeset
223 ;;; telnet.el ends here