annotate lisp/telnet.el @ 775:1ca26ccad38e

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