Mercurial > emacs
comparison lisp/rlogin.el @ 2387:cb44857cab89
moby rlogin-filter fixes
author | Noah Friedman <friedman@splode.com> |
---|---|
date | Sat, 27 Mar 1993 08:21:02 +0000 |
parents | 9e7ec92a4fdf |
children | 845db675b3e9 |
comparison
equal
deleted
inserted
replaced
2386:ded35864afbe | 2387:cb44857cab89 |
---|---|
1 ;;; rlogin.el --- remote login interface | 1 ;;; rlogin.el --- remote login interface |
2 | 2 |
3 ;; Maintainer: Noah Friedman <friedman@prep.ai.mit.edu> | 3 ;; Maintainer: Noah Friedman <friedman@prep.ai.mit.edu> |
4 ;; Keywords: unix, comm | 4 ;; Keywords: unix, comm |
5 | 5 |
6 ;; Copyright (C) 1992 Free Software Foundation, Inc. | 6 ;; Copyright (C) 1992, 1993 Free Software Foundation, Inc. |
7 ;; | 7 ;; |
8 ;; This program is free software; you can redistribute it and/or modify | 8 ;; This program is free software; you can redistribute it and/or modify |
9 ;; it under the terms of the GNU General Public License as published by | 9 ;; it under the terms of the GNU General Public License as published by |
10 ;; the Free Software Foundation; either version 2, or (at your option) | 10 ;; the Free Software Foundation; either version 2, or (at your option) |
11 ;; any later version. | 11 ;; any later version. |
24 ;; Cambridge, MA 02139, USA. | 24 ;; Cambridge, MA 02139, USA. |
25 ;; | 25 ;; |
26 | 26 |
27 ;;; Commentary: | 27 ;;; Commentary: |
28 | 28 |
29 ;; Support for remote login over Internet using rlogin(1). | 29 ;; Support for remote logins using `rlogin'. |
30 ;; | 30 ;; |
31 ;; Todo: add directory tracking using ange-ftp style patchnames for the cwd. | 31 ;; Todo: add directory tracking using ange-ftp style patchnames for the cwd. |
32 | 32 |
33 ;;; Code: | 33 ;;; Code: |
34 | 34 |
49 (define-key rlogin-mode-map "\C-c\C-c" 'rlogin-send-Ctrl-C) | 49 (define-key rlogin-mode-map "\C-c\C-c" 'rlogin-send-Ctrl-C) |
50 (define-key rlogin-mode-map "\C-c\C-z" 'rlogin-send-Ctrl-Z) | 50 (define-key rlogin-mode-map "\C-c\C-z" 'rlogin-send-Ctrl-Z) |
51 (define-key rlogin-mode-map "\C-c\C-\\" 'rlogin-send-Ctrl-backslash) | 51 (define-key rlogin-mode-map "\C-c\C-\\" 'rlogin-send-Ctrl-backslash) |
52 (define-key rlogin-mode-map "\C-d" 'rlogin-delchar-or-send-Ctrl-D))) | 52 (define-key rlogin-mode-map "\C-d" 'rlogin-delchar-or-send-Ctrl-D))) |
53 | 53 |
54 ;;;###autoload | |
54 (defun rlogin (host) | 55 (defun rlogin (host) |
55 (interactive "sOpen rlogin connection to host: ") | 56 (interactive "sOpen rlogin connection to host: ") |
56 (let* ((buffer-name (concat "rlogin-" host)) | 57 (let* ((buffer-name (concat "rlogin-" host)) |
57 (*buffer-name* (concat "*" buffer-name "*"))) | 58 (*buffer-name* (concat "*" buffer-name "*"))) |
58 (cond ((not (comint-check-proc *buffer-name*)) | 59 (cond ((not (comint-check-proc *buffer-name*)) |
63 (if xargs | 64 (if xargs |
64 (setq xargs (append xargs host)) | 65 (setq xargs (append xargs host)) |
65 (setq xargs (list host))) | 66 (setq xargs (list host))) |
66 (set-buffer (apply 'make-comint buffer-name rlogin-program nil xargs)) | 67 (set-buffer (apply 'make-comint buffer-name rlogin-program nil xargs)) |
67 (setq proc (get-process buffer-name)) | 68 (setq proc (get-process buffer-name)) |
69 (set-marker (process-mark proc) (point-min)) | |
68 (set-process-filter proc 'rlogin-filter) | 70 (set-process-filter proc 'rlogin-filter) |
69 (rlogin-mode)))) | 71 (rlogin-mode)))) |
70 (switch-to-buffer *buffer-name*))) | 72 (switch-to-buffer *buffer-name*))) |
71 | 73 |
74 ;;;###autoload | |
72 (defun rlogin-mode () | 75 (defun rlogin-mode () |
73 (interactive) | 76 (interactive) |
74 (comint-mode) | 77 (comint-mode) |
75 (setq comint-prompt-regexp shell-prompt-pattern) | 78 (setq comint-prompt-regexp shell-prompt-pattern) |
76 (setq major-mode 'rlogin-mode) | 79 (setq major-mode 'rlogin-mode) |
77 (setq mode-name "Rlogin") | 80 (setq mode-name "Rlogin") |
78 (use-local-map rlogin-mode-map) | 81 (use-local-map rlogin-mode-map) |
79 (run-hooks 'rlogin-mode-hook)) | 82 (run-hooks 'rlogin-mode-hook)) |
80 | 83 |
81 (defun rlogin-filter (proc string) | 84 (defun rlogin-filter (proc string) |
82 (let ((process-buffer (process-buffer proc)) | 85 (let ((old-buffer (current-buffer)) |
83 (at-eobp (eobp))) | 86 (old-match-data (match-data)) |
84 (save-excursion | 87 at-max-pos |
85 (set-buffer process-buffer) | 88 moving) |
86 (goto-char (point-max)) | 89 (unwind-protect |
87 (let ((now (point)) | 90 (progn |
88 process-mark) | 91 (set-buffer (process-buffer proc)) |
89 (insert string) | 92 (setq moving (= (point) (process-mark proc))) |
90 (subst-char-in-region now (point) ?\C-m ?\ ) | 93 (save-excursion |
91 (subst-char-in-region now (point) ?\M-r ?\ ) | 94 (goto-char (process-mark proc)) |
92 (setq process-mark (process-mark proc)) | 95 (save-restriction |
93 (and process-mark | 96 (let ((beg (point))) |
94 (set-marker process-mark (point))))) | 97 (insert-before-markers string) |
95 (and at-eobp | 98 (narrow-to-region beg (point)) |
96 (eq process-buffer (current-buffer)) | 99 (goto-char (point-min)) |
97 (goto-char (point-max))))) | 100 (while (search-forward "\C-m" nil t) |
101 (delete-char -1)) | |
102 (setq string (buffer-substring (point-min) (point-max))) | |
103 (goto-char (point-max)))) | |
104 (set-marker (process-mark proc) (point))) | |
105 (and moving | |
106 (goto-char (process-mark proc)))) | |
107 (set-buffer old-buffer) | |
108 (store-match-data old-match-data)))) | |
98 | 109 |
99 (defun rlogin-send-Ctrl-C () | 110 (defun rlogin-send-Ctrl-C () |
100 (interactive) | 111 (interactive) |
101 (send-string nil "\C-c")) | 112 (send-string nil "\C-c")) |
102 | 113 |