annotate lisp/net/rcirc.el @ 66258:4e4cce911e2e

Add arch tagline
author Miles Bader <miles@gnu.org>
date Thu, 20 Oct 2005 23:02:18 +0000
parents 684cec8133e3
children 79d2a5d86ee4
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
66248
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1 ;;; rcirc.el --- default, simple IRC client.
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
2
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
3 ;; Copyright (C) 2005 Free Software Foundation, Inc.
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
4
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
5 ;; Author: Ryan Yeske
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
6 ;; URL: http://www.nongnu.org/rcirc
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
7 ;; Keywords: comm
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
8
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
9 ;; This file is not currently part of GNU Emacs.
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
10
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
11 ;; This file is free software; you can redistribute it and/or modify
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
12 ;; it under the terms of the GNU General Public License as published by
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
13 ;; the Free Software Foundation; either version 2, or (at your option)
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
14 ;; any later version.
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
15
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
16 ;; This file is distributed in the hope that it will be useful,
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
17 ;; but WITHOUT ANY WARRANTY; without even the implied warranty of
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
18 ;; MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
19 ;; GNU General Public License for more details.
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
20
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
21 ;; You should have received a copy of the GNU General Public License
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
22 ;; along with GNU Emacs; see the file COPYING. If not, write to
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
23 ;; the Free Software Foundation, Inc., 59 Temple Place - Suite 330,
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
24 ;; Boston, MA 02111-1307, USA.
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
25
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
26 ;;; Commentary:
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
27
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
28 ;; rcirc is an Internet Relay Chat (IRC) client for Emacs
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
29
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
30 ;; IRC is a form of instant communication over the Internet. It is
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
31 ;; mainly designed for group (many-to-many) communication in
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
32 ;; discussion forums called channels, but also allows one-to-one
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
33 ;; communication.
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
34
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
35 ;; Open a new irc connection with:
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
36 ;; M-x irc RET
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
37
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
38 ;;; Code:
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
39
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
40 (require 'ring)
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
41 (require 'time-date)
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
42 (eval-when-compile (require 'cl))
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
43
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
44 (defvar rcirc-server "irc.freenode.net"
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
45 "The default server to connect to.")
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
46
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
47 (defvar rcirc-port 6667
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
48 "The default port to connect to.")
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
49
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
50 (defvar rcirc-nick (user-login-name)
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
51 "Your nick.")
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
52
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
53 (defvar rcirc-user-name (user-login-name)
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
54 "Your user name sent to the server when connecting.")
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
55
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
56 (defvar rcirc-user-full-name (if (string= (user-full-name) "")
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
57 rcirc-user-name
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
58 (user-full-name))
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
59 "The full name sent to the server when connecting.")
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
60
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
61 (defvar rcirc-startup-channels-alist nil
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
62 "Alist of channels to join at startup.
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
63 Each element looks like (REGEXP . CHANNEL-LIST).")
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
64
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
65 (defvar rcirc-fill-flag t
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
66 "*Non-nil means fill messages printed in channel buffers.")
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
67
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
68 (defvar rcirc-fill-column nil
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
69 "*If non-nil, fill to this column, otherwise use value of `fill-column'.")
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
70
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
71 (defvar rcirc-fill-prefix nil
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
72 "*Text to insert before filled lines.
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
73 If nil, calculate the prefix dynamically to line up text
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
74 underneath each nick.")
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
75
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
76 (defvar rcirc-ignore-channel-activity nil
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
77 "If non-nil, ignore activity in this channel.")
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
78 (make-variable-buffer-local 'rcirc-ignore-channel-activity)
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
79
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
80 (defvar rcirc-ignore-all-activity-flag nil
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
81 "*Non-nil means track activity, but do not display it in the modeline.")
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
82
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
83 (defvar rcirc-time-format "%H:%M "
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
84 "*Describes how timestamps are printed.
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
85 Used as the first arg to `format-time-string'.")
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
86
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
87 (defvar rcirc-input-ring-size 1024
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
88 "*Size of input history ring.")
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
89
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
90 (defvar rcirc-read-only-flag t
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
91 "*Non-nil means make text in irc buffers read-only.")
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
92
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
93 (defvar rcirc-buffer-maximum-lines nil
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
94 "*The maximum size in lines for rcirc buffers.
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
95 Channel buffers are truncated from the top to be no greater than this
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
96 number. If zero or nil, no truncating is done.")
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
97
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
98 (defvar rcirc-authinfo-file-name
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
99 "~/.rcirc-authinfo"
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
100 "File containing rcirc authentication passwords.
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
101 The file consists of a single list, with each element itself a
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
102 list with a SERVER-REGEXP string, a NICK-REGEXP string, a METHOD
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
103 and the remaining method specific ARGUMENTS. The valid METHOD
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
104 symbols are `nickserv', `chanserv' and `bitlbee'.
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
105
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
106 The required ARGUMENTS for each METHOD symbol are:
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
107 `nickserv': PASSWORD
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
108 `chanserv': CHANNEL PASSWORD
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
109 `bitlbee': PASSWORD
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
110
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
111 Example:
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
112 ((\"freenode\" \"bob\" nickserv \"p455w0rd\")
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
113 (\"freenode\" \"bob\" chanserv \"#bobland\" \"passwd99\")
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
114 (\"bitlbee\" \"robert\" bitlbee \"sekrit\"))")
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
115
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
116 (defvar rcirc-auto-authenticate-flag (file-readable-p rcirc-authinfo-file-name)
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
117 "*Non-nil means automatically send authentication string to server.
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
118 See also `rcirc-authinfo-file-name'.")
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
119
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
120 (defvar rcirc-print-hooks nil
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
121 "Hook run after text is printed.
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
122 Called with 5 arguments, PROCESS, SENDER, RESPONSE, TARGET and TEXT.")
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
123
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
124 (defvar rcirc-prompt "%n> "
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
125 "Prompt string to use in irc buffers.
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
126
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
127 The following replacements are made:
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
128 %n is your nick.
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
129 %s is the server.
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
130 %t is the buffer target, a channel or a user.
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
131
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
132 Setting this alone will not affect the prompt;
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
133 use `rcirc-update-prompt' after changing this variable.")
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
134
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
135 (defvar rcirc-prompt-start-marker nil)
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
136 (defvar rcirc-prompt-end-marker nil)
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
137
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
138 (defvar rcirc-nick-table nil)
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
139
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
140 (defvar rcirc-activity nil
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
141 "List of channels with unviewed activity.")
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
142
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
143 (defvar rcirc-activity-string ""
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
144 "String displayed in modeline representing `rcirc-activity'.")
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
145 (put 'rcirc-activity-string 'risky-local-variable t)
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
146
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
147 (defvar rcirc-process nil
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
148 "The server process associated with this buffer.")
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
149
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
150 (defvar rcirc-target nil
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
151 "The channel or user associated with this buffer.")
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
152
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
153 (defvar rcirc-channels nil
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
154 "Joined channels.")
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
155
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
156 (defvar rcirc-private-chats nil
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
157 "Private chats open.")
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
158
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
159 (defvar rcirc-urls nil
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
160 "List of urls seen in the current buffer.")
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
161
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
162 (defvar rcirc-keepalive-seconds 60
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
163 "Number of seconds between keepalive pings.")
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
164
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
165
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
166 (defun rcirc-version (&optional here)
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
167 "Return rcirc version string.
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
168 If optional argument HERE is non-nil, insert string at point."
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
169 (interactive "P")
66258
4e4cce911e2e Add arch tagline
Miles Bader <miles@gnu.org>
parents: 66252
diff changeset
170 (let ((version "rcirc.el 0.9 $Revision: 1.3 $"))
66248
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
171 (if here
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
172 (insert version)
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
173 (if (interactive-p)
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
174 (message "%s" version)
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
175 version))))
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
176
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
177 (defvar rcirc-startup-channels nil)
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
178 ;;;###autoload
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
179 (defun rcirc (&optional server port nick channels)
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
180 "Connect to IRC.
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
181
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
182 If any of the the optional SERVER, PORT, NICK or CHANNELS are not
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
183 supplied, they are taken from the variables `rcirc-server',
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
184 `rcirc-port', `rcirc-nick', and `rcirc-startup-channels',
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
185 respectively."
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
186 (interactive (list (read-string "IRC Server: " rcirc-server)
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
187 (read-string "IRC Port: " (number-to-string rcirc-port))
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
188 (read-string "IRC Nick: " rcirc-nick)))
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
189 (or server (setq server rcirc-server))
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
190 (or port (setq port rcirc-port))
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
191 (or nick (setq nick rcirc-nick))
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
192 (or channels
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
193 (setq channels
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
194 (if (interactive-p)
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
195 (delete ""
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
196 (split-string
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
197 (read-string "Channels: "
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
198 (mapconcat 'identity
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
199 (rcirc-startup-channels server)
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
200 " "))
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
201 "[, ]+"))
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
202 (rcirc-startup-channels server))))
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
203 (or global-mode-string (setq global-mode-string '("")))
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
204 (and (not (memq 'rcirc-activity-string global-mode-string))
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
205 (setq global-mode-string
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
206 (append global-mode-string '(rcirc-activity-string))))
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
207 (add-hook 'window-configuration-change-hook 'rcirc-update-activity)
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
208 (rcirc-connect server port nick rcirc-user-name rcirc-user-full-name
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
209 channels))
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
210
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
211 ;;;###autoload
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
212 (defalias 'irc 'rcirc)
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
213
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
214
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
215 (defvar rcirc-process-output nil)
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
216 (defvar rcirc-last-buffer nil)
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
217 (defvar rcirc-topic nil)
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
218 (defvar rcirc-keepalive-timer nil)
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
219 (make-variable-buffer-local 'rcirc-topic)
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
220 (defun rcirc-connect (server port nick user-name full-name startup-channels)
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
221 "Return a connection to SERVER on PORT.
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
222
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
223 User will identify using the values of NICK, USER-NAME and
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
224 FULL-NAME. The variable list of channel names in
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
225 STARTUP-CHANNELS will automatically be joined on startup."
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
226 (save-excursion
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
227 (message "Connecting to %s..." server)
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
228 (let* ((inhibit-eol-conversion)
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
229 (port-number (if (stringp port)
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
230 (string-to-number port)
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
231 port))
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
232 (process (open-network-stream server nil server port-number)))
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
233 ;; set up process
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
234 (set-process-coding-system process 'raw-text 'raw-text)
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
235 (set-process-filter process 'rcirc-filter)
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
236 (switch-to-buffer (concat "*" (process-name process) "*"))
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
237 (set-process-buffer process (current-buffer))
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
238 (set-process-sentinel process 'rcirc-sentinel)
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
239 (rcirc-mode process nil)
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
240 (make-local-variable 'rcirc-nick-table)
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
241 (setq rcirc-nick-table (make-hash-table :test 'equal))
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
242 (make-local-variable 'rcirc-server)
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
243 (setq rcirc-server server)
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
244 (make-local-variable 'rcirc-nick)
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
245 (setq rcirc-nick nick)
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
246 (make-local-variable 'rcirc-process-output)
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
247 (setq rcirc-process-output nil)
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
248 (make-local-variable 'rcirc-last-buffer)
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
249 (setq rcirc-last-buffer (current-buffer))
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
250 (make-local-variable 'rcirc-channels)
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
251 (setq rcirc-channels nil)
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
252 (make-local-variable 'rcirc-private-chats)
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
253 (setq rcirc-private-chats nil)
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
254 (make-local-variable 'rcirc-startup-channels)
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
255 (setq rcirc-startup-channels startup-channels)
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
256
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
257 ;; identify
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
258 (rcirc-send-string process (concat "NICK " nick))
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
259 (rcirc-send-string process (concat "USER " user-name
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
260 " hostname servername :"
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
261 full-name))
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
262
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
263 ;; setup ping timer if necessary
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
264 (unless rcirc-keepalive-timer
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
265 (setq rcirc-keepalive-timer
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
266 (run-at-time 0 rcirc-keepalive-seconds 'rcirc-keepalive)))
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
267
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
268 (message "Connecting to %s...done" server)
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
269
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
270 ;; return process object
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
271 process)))
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
272
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
273 (defun rcirc-keepalive ()
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
274 "Send keep alive pings to active rcirc processes."
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
275 (if (rcirc-process-list)
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
276 (mapc (lambda (process)
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
277 (with-current-buffer (process-buffer process)
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
278 (rcirc-send-string process (concat "PING " rcirc-server))))
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
279 (rcirc-process-list))
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
280 (cancel-timer rcirc-keepalive-timer)
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
281 (setq rcirc-keepalive-timer nil)))
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
282
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
283 (defvar rcirc-log-buffer "*rcirc log*")
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
284 (defvar rcirc-log-p nil
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
285 "If non-nil, write information to `rcirc-log-buffer'.")
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
286 (defun rcirc-log (process text)
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
287 "Add an entry to the debug log including PROCESS and TEXT.
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
288 Debug text is written to `rcirc-log-buffer' if `rcirc-log-p' is
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
289 non-nil."
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
290 (when rcirc-log-p
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
291 (save-excursion
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
292 (save-window-excursion
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
293 (set-buffer (get-buffer-create rcirc-log-buffer))
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
294 (goto-char (point-max))
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
295 (insert (concat
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
296 "["
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
297 (format-time-string "%Y-%m-%dT%T ") (process-name process)
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
298 "] "
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
299 text))))))
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
300
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
301 (defvar rcirc-sentinel-hooks nil
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
302 "Hook functions called when the process sentinel is called.
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
303 Functions are called with PROCESS and SENTINEL arguments.")
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
304
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
305 (defun rcirc-sentinel (process sentinel)
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
306 "Called when PROCESS receives SENTINEL."
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
307 (let ((sentinel (replace-regexp-in-string "\n" "" sentinel)))
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
308 (rcirc-log process (format "SENTINEL: %S %S\n" process sentinel))
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
309 (with-current-buffer (process-buffer process)
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
310 (dolist (target (append rcirc-channels
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
311 rcirc-private-chats
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
312 (list (current-buffer))))
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
313 (rcirc-print process "rcirc.el" "ERROR" target
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
314 (format "%s: %s (%S)"
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
315 (process-name process)
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
316 sentinel
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
317 (process-status process)) t)
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
318 ;; remove the prompt from buffers
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
319 (with-current-buffer (if (eq target (current-buffer))
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
320 (current-buffer)
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
321 (rcirc-get-buffer process target))
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
322 (let ((inhibit-read-only t))
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
323 (delete-region rcirc-prompt-start-marker
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
324 rcirc-prompt-end-marker)))))
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
325 (run-hook-with-args 'rcirc-sentinel-hooks process sentinel)))
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
326
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
327 (defun rcirc-process-list ()
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
328 "Return a list of rcirc processes."
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
329 (let (ps)
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
330 (mapc (lambda (p)
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
331 (when (process-buffer p)
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
332 (with-current-buffer (process-buffer p)
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
333 (when (eq major-mode 'rcirc-mode)
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
334 (setq ps (cons p ps))))))
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
335 (process-list))
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
336 ps))
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
337
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
338 (defvar rcirc-receive-message-hooks nil
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
339 "Hook functions run when a message is recieved from server.
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
340 Function is called with PROCESS COMMAND SENDER ARGS and LINE.")
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
341 (defun rcirc-filter (process output)
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
342 "Called when PROCESS receives OUTPUT."
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
343 (rcirc-log process output)
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
344 (with-current-buffer (process-buffer process)
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
345 (setq rcirc-process-output (concat rcirc-process-output output))
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
346 (when (= (aref rcirc-process-output
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
347 (1- (length rcirc-process-output))) ?\n)
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
348 (mapc (lambda (line)
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
349 (rcirc-process-server-response process line))
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
350 (delete "" (split-string rcirc-process-output "[\n\r]")))
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
351 (setq rcirc-process-output nil))))
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
352
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
353 (defvar rcirc-trap-errors nil)
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
354 (defun rcirc-process-server-response (process text)
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
355 (if rcirc-trap-errors
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
356 (condition-case err
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
357 (rcirc-process-server-response-1 process text)
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
358 (error
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
359 (rcirc-print process "RCIRC" "ERROR" nil
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
360 (format "rcirc: error processing: \"%s\" %s" text err))))
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
361 (rcirc-process-server-response-1 process text)))
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
362
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
363 (defun rcirc-process-server-response-1 (process text)
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
364 (if (string-match "^\\(:\\([^ ]+\\) \\)?\\([^ ]+\\) \\(.+\\)$" text)
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
365 (let* ((sender (match-string 2 text))
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
366 (cmd (match-string 3 text))
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
367 (args (match-string 4 text))
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
368 (handler (intern-soft (concat "rcirc-handler-" cmd))))
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
369 (string-match "^\\([^:]*\\):?\\(.+\\)?$" args)
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
370 (let* ((args1 (match-string 1 args))
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
371 (args2 (match-string 2 args))
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
372 (args (append (delete "" (split-string args1 " "))
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
373 (list args2))))
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
374 (if (not (fboundp handler))
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
375 (rcirc-handler-generic process cmd sender args text)
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
376 (funcall handler process sender args text))
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
377 (run-hook-with-args 'rcirc-receive-message-hooks
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
378 process cmd sender args text)))
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
379 (message "UNHANDLED: %s" text)))
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
380
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
381 (defun rcirc-handler-generic (process command sender args text)
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
382 "Generic server response handler."
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
383 (rcirc-print process sender command nil
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
384 (mapconcat 'identity (cdr args) " ")))
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
385
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
386 (defun rcirc-send-string (process string)
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
387 "Send PROCESS a STRING plus a newline."
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
388 (let ((string (concat (encode-coding-string string
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
389 buffer-file-coding-system)
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
390 "\n")))
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
391 (rcirc-log process string)
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
392 (process-send-string process string)))
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
393
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
394 (defun rcirc-server (process)
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
395 "Return PROCESS server, given by the 001 response."
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
396 (with-current-buffer (process-buffer process)
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
397 rcirc-server))
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
398
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
399 (defun rcirc-nick (process)
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
400 "Return PROCESS nick."
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
401 (with-current-buffer (process-buffer process)
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
402 rcirc-nick))
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
403
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
404 (defvar rcirc-max-message-length 450
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
405 "Messages longer than this value will be split.")
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
406
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
407 (defun rcirc-send-message (process target message &optional noticep)
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
408 "Send TARGET associated with PROCESS a privmsg with text MESSAGE.
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
409 If NOTICEP is non-nil, send a notice instead of privmsg."
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
410 ;; max message length is 512 including CRLF
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
411 (let* ((response (if noticep "NOTICE" "PRIVMSG"))
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
412 (oversize (> (length message) rcirc-max-message-length))
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
413 (text (if oversize
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
414 (substring message 0 rcirc-max-message-length)
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
415 message))
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
416 (text (if (string= text "")
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
417 " "
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
418 text))
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
419 (more (if oversize
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
420 (substring message rcirc-max-message-length))))
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
421 (rcirc-print process (rcirc-nick process) response target text)
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
422 (rcirc-send-string process (concat response " " target " :" text))
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
423 (if more
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
424 (rcirc-send-message process target more noticep))))
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
425
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
426 (defvar rcirc-input-ring nil)
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
427 (defvar rcirc-input-ring-index 0)
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
428 (defun rcirc-prev-input-string (arg)
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
429 (ring-ref rcirc-input-ring (+ rcirc-input-ring-index arg)))
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
430
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
431 (defun rcirc-insert-prev-input (arg)
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
432 (interactive "p")
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
433 (when (<= rcirc-prompt-end-marker (point))
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
434 (delete-region rcirc-prompt-end-marker (point-max))
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
435 (insert (rcirc-prev-input-string 0))
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
436 (setq rcirc-input-ring-index (1+ rcirc-input-ring-index))))
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
437
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
438 (defun rcirc-insert-next-input (arg)
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
439 (interactive "p")
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
440 (when (<= rcirc-prompt-end-marker (point))
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
441 (delete-region rcirc-prompt-end-marker (point-max))
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
442 (setq rcirc-input-ring-index (1- rcirc-input-ring-index))
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
443 (insert (rcirc-prev-input-string -1))))
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
444
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
445 (defvar rcirc-nick-completions nil)
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
446 (defvar rcirc-nick-completion-start-offset nil)
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
447 (defun rcirc-complete-nick ()
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
448 "Cycle through nick completions from list of nicks in channel."
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
449 (interactive)
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
450 (if (eq last-command 'rcirc-complete-nick)
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
451 (setq rcirc-nick-completions
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
452 (append (cdr rcirc-nick-completions)
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
453 (list (car rcirc-nick-completions))))
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
454 (setq rcirc-nick-completion-start-offset
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
455 (- (save-excursion
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
456 (if (re-search-backward " " rcirc-prompt-end-marker t)
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
457 (1+ (point))
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
458 rcirc-prompt-end-marker))
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
459 rcirc-prompt-end-marker))
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
460 (setq rcirc-nick-completions
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
461 (let ((completion-ignore-case t))
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
462 (all-completions
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
463 (buffer-substring
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
464 (+ rcirc-prompt-end-marker
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
465 rcirc-nick-completion-start-offset)
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
466 (point))
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
467 (mapcar (lambda (x) (cons x nil))
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
468 (rcirc-channel-nicks rcirc-process
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
469 (rcirc-buffer-target)))))))
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
470 (let ((completion (car rcirc-nick-completions)))
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
471 (when completion
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
472 (delete-region (+ rcirc-prompt-end-marker
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
473 rcirc-nick-completion-start-offset)
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
474 (point))
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
475 (insert (concat completion
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
476 (if (= (+ rcirc-prompt-end-marker
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
477 rcirc-nick-completion-start-offset)
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
478 rcirc-prompt-end-marker)
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
479 ": "))))))
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
480
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
481 (defun rcirc-buffer-target (&optional buffer)
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
482 "Return the name of target for BUFFER.
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
483 If buffer is nil, return the target of the current buffer."
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
484 (with-current-buffer (or buffer (current-buffer))
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
485 rcirc-target))
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
486
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
487 (defvar rcirc-mode-map (make-sparse-keymap)
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
488 "Keymap for rcirc mode.")
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
489
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
490 (define-key rcirc-mode-map (kbd "RET") 'rcirc-send-input)
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
491 (define-key rcirc-mode-map (kbd "M-p") 'rcirc-insert-prev-input)
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
492 (define-key rcirc-mode-map (kbd "M-n") 'rcirc-insert-next-input)
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
493 (define-key rcirc-mode-map (kbd "TAB") 'rcirc-complete-nick)
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
494 (define-key rcirc-mode-map (kbd "C-c C-b") 'rcirc-browse-url)
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
495 (define-key rcirc-mode-map (kbd "C-c C-c") 'rcirc-edit-multiline)
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
496 (define-key rcirc-mode-map (kbd "C-c C-j") 'rcirc-cmd-join)
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
497 (define-key rcirc-mode-map (kbd "C-c C-k") 'rcirc-cmd-kick)
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
498 (define-key rcirc-mode-map (kbd "C-c C-l") 'rcirc-cmd-list)
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
499 (define-key rcirc-mode-map (kbd "C-c C-d") 'rcirc-cmd-mode)
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
500 (define-key rcirc-mode-map (kbd "C-c C-m") 'rcirc-cmd-msg)
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
501 (define-key rcirc-mode-map (kbd "C-c C-r") 'rcirc-cmd-nick) ; rename
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
502 (define-key rcirc-mode-map (kbd "C-c C-o") 'rcirc-cmd-oper)
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
503 (define-key rcirc-mode-map (kbd "C-c C-p") 'rcirc-cmd-part)
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
504 (define-key rcirc-mode-map (kbd "C-c C-q") 'rcirc-cmd-query)
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
505 (define-key rcirc-mode-map (kbd "C-c C-t") 'rcirc-cmd-topic)
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
506 (define-key rcirc-mode-map (kbd "C-c C-n") 'rcirc-cmd-names)
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
507 (define-key rcirc-mode-map (kbd "C-c C-w") 'rcirc-cmd-whois)
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
508 (define-key rcirc-mode-map (kbd "C-c C-x") 'rcirc-cmd-quit)
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
509 (define-key rcirc-mode-map (kbd "C-c TAB") ; C-i
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
510 'rcirc-toggle-ignore-channel-activity)
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
511 (define-key rcirc-mode-map (kbd "C-c C-s") 'rcirc-switch-to-server-buffer)
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
512 (define-key rcirc-mode-map (kbd "C-c C-a") 'rcirc-jump-to-first-unread-line)
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
513
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
514 (define-key global-map (kbd "C-c `") 'rcirc-next-active-buffer)
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
515 (define-key global-map (kbd "C-c C-@") 'rcirc-next-active-buffer)
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
516 (define-key global-map (kbd "C-c C-SPC") 'rcirc-next-active-buffer)
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
517
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
518 (defvar rcirc-mode-hook nil
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
519 "Hook run when setting up rcirc buffer.")
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
520
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
521 (defun rcirc-mode (process target)
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
522 "Major mode for irc channel buffers.
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
523
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
524 \\{rcirc-mode-map}"
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
525 (kill-all-local-variables)
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
526 (use-local-map rcirc-mode-map)
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
527 (setq mode-name "rcirc")
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
528 (setq major-mode 'rcirc-mode)
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
529
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
530 (make-local-variable 'rcirc-input-ring)
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
531 (setq rcirc-input-ring (make-ring rcirc-input-ring-size))
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
532 (make-local-variable 'rcirc-process)
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
533 (setq rcirc-process process)
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
534 (make-local-variable 'rcirc-target)
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
535 (setq rcirc-target target)
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
536 (make-local-variable 'rcirc-urls)
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
537 (setq rcirc-urls nil)
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
538 (setq use-hard-newlines t)
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
539 (when (rcirc-channel-p rcirc-target)
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
540 (setq header-line-format 'rcirc-topic))
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
541
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
542 ;; setup the prompt and markers
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
543 (make-local-variable 'rcirc-prompt-start-marker)
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
544 (setq rcirc-prompt-start-marker (make-marker))
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
545 (set-marker rcirc-prompt-start-marker (point-max))
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
546 (make-local-variable 'rcirc-prompt-end-marker)
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
547 (setq rcirc-prompt-end-marker (make-marker))
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
548 (set-marker rcirc-prompt-end-marker (point-max))
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
549 (rcirc-update-prompt)
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
550 (goto-char rcirc-prompt-end-marker)
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
551 (make-local-variable 'overlay-arrow-position)
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
552 (setq overlay-arrow-position (make-marker))
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
553 (set-marker overlay-arrow-position nil)
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
554
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
555 (run-hooks 'rcirc-mode-hook))
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
556
66252
684cec8133e3 (with-rcirc-process-buffer): Move above its first user.
Romain Francoise <romain@orebokech.com>
parents: 66250
diff changeset
557 (defmacro with-rcirc-process-buffer (process &rest body)
684cec8133e3 (with-rcirc-process-buffer): Move above its first user.
Romain Francoise <romain@orebokech.com>
parents: 66250
diff changeset
558 (declare (indent 1) (debug t))
684cec8133e3 (with-rcirc-process-buffer): Move above its first user.
Romain Francoise <romain@orebokech.com>
parents: 66250
diff changeset
559 `(with-current-buffer (process-buffer ,process)
684cec8133e3 (with-rcirc-process-buffer): Move above its first user.
Romain Francoise <romain@orebokech.com>
parents: 66250
diff changeset
560 ,@body))
684cec8133e3 (with-rcirc-process-buffer): Move above its first user.
Romain Francoise <romain@orebokech.com>
parents: 66250
diff changeset
561
66248
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
562 (defun rcirc-update-prompt ()
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
563 "Reset the prompt string in the current buffer."
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
564 (let ((inhibit-read-only t)
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
565 (prompt (or rcirc-prompt "")))
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
566 (mapc (lambda (rep)
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
567 (setq prompt
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
568 (replace-regexp-in-string (car rep) (cdr rep) prompt)))
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
569 (list (cons "%n" (with-rcirc-process-buffer rcirc-process
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
570 rcirc-nick))
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
571 (cons "%s" (with-rcirc-process-buffer rcirc-process
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
572 rcirc-server))
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
573 (cons "%t" (or rcirc-target ""))))
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
574 (save-excursion
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
575 (delete-region rcirc-prompt-start-marker rcirc-prompt-end-marker)
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
576 (goto-char rcirc-prompt-start-marker)
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
577 (let ((start (point)))
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
578 (insert-before-markers prompt)
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
579 (set-marker rcirc-prompt-start-marker start)
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
580 (when (not (zerop (- rcirc-prompt-end-marker
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
581 rcirc-prompt-start-marker)))
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
582 (add-text-properties rcirc-prompt-start-marker
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
583 rcirc-prompt-end-marker
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
584 (list 'face 'rcirc-prompt-face
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
585 'read-only t 'field t
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
586 'front-sticky t 'rear-nonsticky t)))))))
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
587
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
588 (defun rcirc-channel-p (target)
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
589 "Return t if TARGET is a channel name."
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
590 (and target
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
591 (not (zerop (length target)))
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
592 (or (eq (aref target 0) ?#)
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
593 (eq (aref target 0) ?&))))
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
594
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
595 (defun rcirc-kill-buffer-hook ()
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
596 "Part the channel when killing an rcirc buffer."
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
597 (when (eq major-mode 'rcirc-mode)
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
598 (rcirc-clear-activity (current-buffer))
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
599 (when (and rcirc-process
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
600 (eq (process-status rcirc-process) 'open))
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
601 (if (rcirc-channel-p rcirc-target)
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
602 (rcirc-cmd-part "" rcirc-process rcirc-target)
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
603 ;; remove target from privchat list
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
604 (when rcirc-target
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
605 (let ((target (downcase rcirc-target)))
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
606 (with-rcirc-process-buffer rcirc-process
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
607 (setq rcirc-private-chats
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
608 (delete target rcirc-private-chats)))))))))
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
609 (add-hook 'kill-buffer-hook 'rcirc-kill-buffer-hook)
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
610
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
611 (defun rcirc-get-buffer-name (process target)
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
612 "Return buffer name based on PROCESS and TARGET."
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
613 (concat (and target (downcase target)) "@" (process-name process)))
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
614
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
615 (defun rcirc-get-buffer (process target &optional error)
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
616 "Return the buffer associated with the PROCESS and TARGET.
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
617 If TARGET is nil and ERROR is nil, return the process buffer."
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
618 (let ((buffer (and target
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
619 (get-buffer (rcirc-get-buffer-name process target)))))
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
620 (if (and buffer (buffer-live-p buffer))
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
621 buffer
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
622 (if error
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
623 (error "Buffer associated with %s does not exist" target)
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
624 (process-buffer process)))))
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
625
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
626 (defun rcirc-get-buffer-create (process target)
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
627 "Return the buffer named associated with the PROCESS and TARGET.
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
628 Create the buffer if it doesn't exist. If TARGET is nil, return
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
629 the process buffer."
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
630 (with-current-buffer (process-buffer process)
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
631 (if (not target)
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
632 (current-buffer)
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
633 (let ((target (downcase target)))
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
634 ;; add private chats to list. we dont add channels here, they
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
635 ;; are managed by the join/part/quit handlers
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
636 (when (and (not (rcirc-channel-p target))
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
637 (not (member target rcirc-private-chats)))
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
638 (with-rcirc-process-buffer process
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
639 (setq rcirc-private-chats (cons target rcirc-private-chats))))
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
640 ;; create and setup a buffer, or return the existing one
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
641 (let ((bufname (rcirc-get-buffer-name process target)))
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
642 (with-current-buffer (get-buffer-create bufname)
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
643 (if (or (not rcirc-process)
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
644 (not (equal (process-status rcirc-process) 'open)))
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
645 (rcirc-mode process target)
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
646 (setq rcirc-target target))
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
647 (current-buffer)))))))
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
648
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
649 (defun rcirc-send-input ()
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
650 "Send input to target associated with the current buffer."
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
651 (interactive)
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
652 (if (not (eq (process-status rcirc-process) 'open))
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
653 (error "Network connection to %s is not open"
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
654 (process-name rcirc-process))
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
655 ;; update last buffer
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
656 (rcirc-set-last-buffer rcirc-process (current-buffer))
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
657 (if (< (point) rcirc-prompt-end-marker)
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
658 ;; copy the line down to the input area
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
659 (progn
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
660 (forward-line 0)
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
661 (let ((start (if (eq (point) (point-min))
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
662 (point)
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
663 (if (get-text-property (1- (point)) 'hard)
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
664 (point)
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
665 (previous-single-property-change (point) 'hard))))
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
666 (end (next-single-property-change (1+ (point)) 'hard)))
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
667 (goto-char (point-max))
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
668 (insert (replace-regexp-in-string
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
669 "\n\\s-+" " "
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
670 (buffer-substring-no-properties start end)))))
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
671 ;; assume text has been read
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
672 (when (marker-position overlay-arrow-position)
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
673 (set-marker overlay-arrow-position nil))
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
674 ;; process input
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
675 (goto-char (point-max))
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
676 (let ((target (rcirc-buffer-target))
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
677 (start rcirc-prompt-end-marker))
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
678 (when (not (equal 0 (- (point) start)))
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
679 ;; delete a trailing newline
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
680 (when (eq (point) (point-at-bol))
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
681 (delete-backward-char 1))
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
682 (let ((input (buffer-substring-no-properties
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
683 rcirc-prompt-end-marker (point))))
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
684 ;; process a /cmd
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
685 (if (string-match "^/\\([^ ]+\\) ?\\(.*\\)$" input)
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
686 (let* ((command (match-string 1 input))
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
687 (fun (intern-soft (concat "rcirc-cmd-" command)))
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
688 (args (match-string 2 input)))
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
689 (newline)
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
690 (with-current-buffer (current-buffer)
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
691 (delete-region rcirc-prompt-end-marker (point))
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
692 (if (string= command "me")
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
693 (rcirc-print rcirc-process (rcirc-nick rcirc-process)
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
694 "ACTION" target args)
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
695 (rcirc-print rcirc-process (rcirc-nick rcirc-process)
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
696 "COMMAND" target input))
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
697 (set-marker rcirc-prompt-end-marker (point))
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
698 (if (fboundp fun)
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
699 (funcall fun args rcirc-process target)
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
700 (rcirc-send-string rcirc-process
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
701 (concat command " " args)))))
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
702 ;; send message to server
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
703 (if (not rcirc-target)
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
704 (message "Not joined")
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
705 (delete-region rcirc-prompt-end-marker (point))
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
706 (mapc (lambda (message)
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
707 (rcirc-send-message rcirc-process target message))
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
708 (split-string input "\n"))))
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
709 ;; add to input-ring
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
710 (save-excursion
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
711 (ring-insert rcirc-input-ring input)
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
712 (setq rcirc-input-ring-index 0))))))))
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
713
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
714 (defvar rcirc-parent-buffer nil)
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
715 (defvar rcirc-window-configuration nil)
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
716 (defun rcirc-edit-multiline ()
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
717 "Move current edit to a dedicated buffer."
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
718 (interactive)
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
719 (let ((pos (1+ (- (point) rcirc-prompt-end-marker))))
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
720 (goto-char (point-max))
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
721 (let ((text (buffer-substring rcirc-prompt-end-marker (point)))
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
722 (parent (buffer-name))
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
723 (process rcirc-process))
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
724 (delete-region rcirc-prompt-end-marker (point))
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
725 (setq rcirc-window-configuration (current-window-configuration))
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
726 (pop-to-buffer (concat "*multiline " parent "*"))
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
727 (rcirc-multiline-edit-mode)
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
728 (setq rcirc-parent-buffer parent)
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
729 (setq rcirc-process process)
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
730 (insert text)
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
731 (and (> pos 0) (goto-char pos)))))
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
732
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
733 (define-derived-mode rcirc-multiline-edit-mode
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
734 text-mode "rcirc multi"
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
735 "Major mode for multiline edits
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
736 \\{rcirc-multiline-edit-mode-map}"
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
737 (make-local-variable 'rcirc-parent-buffer)
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
738 (make-local-variable 'rcirc-process))
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
739
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
740 (define-key rcirc-multiline-edit-mode-map
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
741 (kbd "C-c C-c") 'rcirc-multiline-edit-submit)
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
742 (define-key rcirc-multiline-edit-mode-map
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
743 (kbd "C-x C-s") 'rcirc-multiline-edit-submit)
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
744 (define-key rcirc-multiline-edit-mode-map
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
745 (kbd "C-c C-k") 'rcirc-multiline-edit-cancel)
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
746 (define-key rcirc-multiline-edit-mode-map
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
747 (kbd "ESC ESC ESC") 'rcirc-multiline-edit-cancel)
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
748
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
749 (defun rcirc-multiline-edit-submit ()
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
750 "Send the text in buffer back to parent buffer."
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
751 (interactive)
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
752 (assert (and (eq major-mode 'rcirc-multiline-edit-mode)))
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
753 (assert rcirc-parent-buffer)
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
754 (let ((text (buffer-substring (point-min) (point-max)))
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
755 (buffer (current-buffer))
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
756 (pos (point)))
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
757 (set-buffer rcirc-parent-buffer)
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
758 (goto-char (point-max))
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
759 (insert text)
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
760 (goto-char (+ rcirc-prompt-end-marker (1- pos)))
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
761 (kill-buffer buffer)
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
762 (set-window-configuration rcirc-window-configuration)))
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
763
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
764 (defun rcirc-multiline-edit-cancel ()
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
765 "Cancel the multiline edit."
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
766 (interactive)
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
767 (assert (and (eq major-mode 'rcirc-multiline-edit-mode)))
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
768 (kill-buffer (current-buffer))
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
769 (set-window-configuration rcirc-window-configuration))
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
770
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
771 (defun rcirc-last-buffer (process)
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
772 "Return the last working buffer for PROCESS.
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
773 Used for displaying messages that don't have an explicit destination."
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
774 (with-current-buffer (process-buffer process)
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
775 (or (and rcirc-last-buffer
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
776 (buffer-live-p rcirc-last-buffer)
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
777 rcirc-last-buffer)
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
778 (current-buffer))))
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
779
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
780 (defun rcirc-set-last-buffer (process buffer)
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
781 "Set the last working buffer for PROCESS to BUFFER."
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
782 (with-current-buffer (process-buffer process)
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
783 (setq rcirc-last-buffer buffer)))
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
784
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
785 (defun rcirc-format-response-string (process sender response target text)
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
786 (concat (when rcirc-time-format
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
787 (format-time-string rcirc-time-format (current-time)))
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
788 (cond ((or (string= response "PRIVMSG")
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
789 (string= response "NOTICE")
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
790 (string= response "ACTION"))
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
791 (let (first middle end)
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
792 (cond ((string= response "PRIVMSG")
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
793 (setq first "<" middle "> "))
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
794 ((string= response "NOTICE")
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
795 (setq first "-" middle "- "))
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
796 (t
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
797 (setq first "[" middle " " end "]")))
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
798 (concat first
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
799 (rcirc-facify (rcirc-user-nick sender)
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
800 (if (string= sender
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
801 (rcirc-nick process))
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
802 'rcirc-my-nick-face
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
803 'rcirc-other-nick-face))
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
804 middle
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
805 (rcirc-mangle-text process text)
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
806 end)))
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
807 ((string= response "COMMAND")
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
808 text)
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
809 ((string= response "ERROR")
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
810 (propertize text 'face 'font-lock-warning-face))
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
811 (t
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
812 (rcirc-mangle-text
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
813 process
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
814 (rcirc-facify
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
815 (concat "*** "
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
816 (when (not (string= sender (rcirc-server process)))
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
817 (concat (rcirc-user-nick sender) " "))
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
818 (when (zerop (string-to-number response))
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
819 (concat response " "))
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
820 (when (and target (not (string= target rcirc-target)))
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
821 (concat target " "))
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
822 text)
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
823 'rcirc-server-face))))))
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
824
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
825 (defvar rcirc-activity-type nil)
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
826 (make-variable-buffer-local 'rcirc-activity-type)
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
827 (defun rcirc-print (process sender response target text &optional activity)
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
828 "Print TEXT in the buffer associated with TARGET.
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
829 Format based on SENDER and RESPONSE. If ACTIVITY is non-nil,
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
830 record activity."
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
831 (let* ((buffer (cond ((bufferp target)
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
832 target)
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
833 ((not target)
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
834 (rcirc-last-buffer process))
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
835 ((not (rcirc-channel-p target))
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
836 (rcirc-get-buffer-create process target))
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
837 ((rcirc-get-buffer process target))
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
838 (t (process-buffer process))))
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
839 (inhibit-read-only t))
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
840 (with-current-buffer buffer
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
841 (let ((moving (= (point) rcirc-prompt-end-marker))
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
842 (old-point (point-marker))
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
843 (fill-start (marker-position rcirc-prompt-start-marker)))
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
844
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
845 (unless (string= sender (rcirc-nick process))
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
846 ;; only decode text from other senders, not ours
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
847 (setq text (decode-coding-string text buffer-file-coding-system))
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
848 ;; mark the line with overlay arrow
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
849 (unless (or (marker-position overlay-arrow-position)
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
850 (get-buffer-window (current-buffer)))
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
851 (set-marker overlay-arrow-position
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
852 (marker-position rcirc-prompt-start-marker))))
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
853
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
854 ;; temporarily set the marker insertion-type because
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
855 ;; insert-before-markers results in hidden text in new buffers
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
856 (goto-char rcirc-prompt-start-marker)
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
857 (set-marker-insertion-type rcirc-prompt-start-marker t)
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
858 (set-marker-insertion-type rcirc-prompt-end-marker t)
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
859 (insert
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
860 (rcirc-format-response-string process sender response target text)
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
861 (propertize "\n" 'hard t))
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
862 (set-marker-insertion-type rcirc-prompt-start-marker nil)
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
863 (set-marker-insertion-type rcirc-prompt-end-marker nil)
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
864
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
865 ;; fill the text we just inserted, maybe
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
866 (when (and rcirc-fill-flag
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
867 (not (string= response "372"))) ;/motd
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
868 (let ((fill-prefix
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
869 (or rcirc-fill-prefix
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
870 (make-string
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
871 (+ (if rcirc-time-format
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
872 (length (format-time-string
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
873 rcirc-time-format))
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
874 0)
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
875 (cond ((or (string= response "PRIVMSG")
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
876 (string= response "NOTICE"))
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
877 (+ (length (rcirc-user-nick sender))
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
878 2)) ; <>
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
879 ((string= response "ACTION")
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
880 (+ (length (rcirc-user-nick sender))
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
881 1)) ; [
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
882 (t 3)) ; ***
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
883 1)
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
884 ? )))
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
885 (fill-column (or rcirc-fill-column fill-column)))
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
886 (fill-region fill-start rcirc-prompt-start-marker 'left t)))
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
887
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
888 ;; truncate buffer if it is very long
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
889 (save-excursion
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
890 (when (and rcirc-buffer-maximum-lines
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
891 (> rcirc-buffer-maximum-lines 0)
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
892 (= (forward-line (- rcirc-buffer-maximum-lines)) 0))
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
893 (delete-region (point-min) (point))))
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
894
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
895 ;; set inserted text to be read-only
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
896 (when rcirc-read-only-flag
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
897 (put-text-property rcirc-prompt-start-marker fill-start 'read-only t)
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
898 (let ((inhibit-read-only t))
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
899 (put-text-property rcirc-prompt-start-marker fill-start
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
900 'front-sticky t)
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
901 (put-text-property (1- (point)) (point) 'rear-nonsticky t)))
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
902
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
903 ;; set the window point for buffers show in windows
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
904 (walk-windows (lambda (w)
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
905 (unless (eq (selected-window) w)
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
906 (when (and (eq (current-buffer)
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
907 (window-buffer w))
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
908 (>= (window-point w)
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
909 rcirc-prompt-end-marker))
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
910 (set-window-point w (point-max)))))
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
911 nil t)
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
912
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
913 ;; restore the point
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
914 (goto-char (if moving rcirc-prompt-end-marker old-point))
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
915
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
916 ;; flush undo (can we do something smarter here?)
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
917 (buffer-disable-undo)
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
918 (buffer-enable-undo))
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
919
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
920 ;; record modeline activity
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
921 (when activity
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
922 (let ((nick-match
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
923 (string-match (concat "\\b"
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
924 (regexp-quote (rcirc-nick process))
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
925 "\\b")
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
926 text)))
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
927 (when (or (not rcirc-ignore-channel-activity)
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
928 ;; always notice when our nick is mentioned, even
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
929 ;; if ignoring channel activity
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
930 nick-match)
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
931 (rcirc-record-activity
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
932 (current-buffer)
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
933 (when (or nick-match (not (rcirc-channel-p rcirc-target)))
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
934 'nick)))))
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
935
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
936 (run-hook-with-args 'rcirc-print-hooks
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
937 process sender response target text))))
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
938
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
939 (defun rcirc-startup-channels (server)
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
940 "Return the list of startup channels for server."
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
941 (let (channels)
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
942 (dolist (i rcirc-startup-channels-alist)
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
943 (if (string-match (car i) server)
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
944 (setq channels (append channels (cdr i)))))
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
945 channels))
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
946
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
947 (defun rcirc-join-channels (process channels)
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
948 "Join CHANNELS."
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
949 (save-window-excursion
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
950 (mapc (lambda (channel)
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
951 (with-current-buffer (process-buffer process)
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
952 (let (rcirc-last-buffer) ; make sure /join text is
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
953 ; printed in server buffer
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
954 (rcirc-print process (rcirc-nick process) "COMMAND"
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
955 nil (concat "/join " channel)))
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
956 (rcirc-cmd-join channel process)))
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
957 channels)))
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
958
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
959 ;;; nick management
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
960 (defun rcirc-user-nick (user)
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
961 "Return the nick from USER. Remove any non-nick junk."
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
962 (if (string-match "^[@%+]?\\([^! ]+\\)!?" (or user ""))
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
963 (match-string 1 user)
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
964 user))
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
965
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
966 (defun rcirc-user-non-nick (user)
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
967 "Return the non-nick portion of USER."
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
968 (if (string-match "^[@+]?[^! ]+!?\\(.*\\)" (or user ""))
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
969 (match-string 1 user)
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
970 user))
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
971
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
972 (defun rcirc-nick-channels (process nick)
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
973 "Return list of channels for NICK."
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
974 (let ((nick (rcirc-user-nick nick)))
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
975 (with-current-buffer (process-buffer process)
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
976 (mapcar (lambda (x) (car x))
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
977 (gethash nick rcirc-nick-table)))))
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
978
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
979 (defun rcirc-put-nick-channel (process nick channel)
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
980 "Add CHANNEL to list associated with NICK."
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
981 (with-current-buffer (process-buffer process)
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
982 (let* ((nick (rcirc-user-nick nick))
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
983 (chans (gethash nick rcirc-nick-table))
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
984 (record (assoc channel chans)))
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
985 (if record
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
986 (setcdr record (current-time))
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
987 (puthash nick (cons (cons channel (current-time))
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
988 chans)
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
989 rcirc-nick-table)))))
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
990
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
991 (defun rcirc-nick-remove (process nick)
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
992 "Remove NICK from table."
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
993 (with-current-buffer (process-buffer process)
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
994 (remhash nick rcirc-nick-table)))
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
995
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
996 (defun rcirc-remove-nick-channel (process nick channel)
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
997 "Remove the CHANNEL from list associated with NICK."
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
998 (with-current-buffer (process-buffer process)
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
999 (let* ((nick (rcirc-user-nick nick))
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1000 (chans (gethash nick rcirc-nick-table))
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1001 (newchans (assq-delete-all channel chans)))
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1002 (if newchans
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1003 (puthash nick newchans rcirc-nick-table)
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1004 (remhash nick rcirc-nick-table)))))
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1005
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1006 (defun rcirc-channel-nicks (process channel)
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1007 "Return the list of nicks in CHANNEL sorted by last activity."
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1008 (with-current-buffer (process-buffer process)
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1009 (let (nicks)
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1010 (maphash
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1011 (lambda (k v)
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1012 (let ((record (assoc channel v)))
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1013 (if record
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1014 (setq nicks (cons (cons k (cdr record)) nicks)))))
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1015 rcirc-nick-table)
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1016 (mapcar (lambda (x) (car x))
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1017 (sort nicks (lambda (x y) (time-less-p (cdr y) (cdr x))))))))
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1018
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1019 ;;; activity tracking
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1020 (or (assq 'rcirc-ignore-channel-activity minor-mode-alist)
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1021 (setq minor-mode-alist
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1022 (cons '(rcirc-ignore-channel-activity " Ignore") minor-mode-alist)))
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1023
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1024 (defun rcirc-toggle-ignore-channel-activity (&optional all)
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1025 "Toggle the value of `rcirc-ignore-channel-activity'.
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1026 If ALL is non-nil, instead toggle the value of
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1027 `rcirc-ignore-all-activity-flag'."
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1028 (interactive "P")
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1029 (if all
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1030 (progn
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1031 (setq rcirc-ignore-all-activity-flag
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1032 (not rcirc-ignore-all-activity-flag))
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1033 (message (concat "Global activity "
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1034 (if rcirc-ignore-all-activity-flag
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1035 "hidden"
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1036 "displayed")))
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1037 (rcirc-update-activity-string))
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1038 (setq rcirc-ignore-channel-activity
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1039 (not rcirc-ignore-channel-activity)))
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1040 (force-mode-line-update))
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1041
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1042 (defvar rcirc-switch-to-buffer-function 'switch-to-buffer
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1043 "Function to use when switching buffers.
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1044 Possible values are `switch-to-buffer', `pop-to-buffer', and
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1045 `display-buffer'.")
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1046
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1047 (defun rcirc-switch-to-server-buffer ()
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1048 "Switch to the server buffer associated with current channel buffer."
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1049 (interactive)
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1050 (funcall rcirc-switch-to-buffer-function (process-buffer rcirc-process)))
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1051
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1052 (defun rcirc-jump-to-first-unread-line ()
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1053 "Move the point to the first unread line in this buffer."
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1054 (interactive)
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1055 (when (marker-position overlay-arrow-position)
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1056 (goto-char overlay-arrow-position)))
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1057
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1058 (defvar rcirc-last-non-irc-buffer nil
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1059 "The buffer to switch to when there is no more activity.")
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1060
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1061 (defun rcirc-next-active-buffer (arg)
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1062 "Go to the ARGth rcirc buffer with activity.
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1063 The function given by `rcirc-switch-to-buffer-function' is used to
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1064 show the buffer."
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1065 (interactive "p")
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1066 (if rcirc-activity
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1067 (progn
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1068 (unless (eq major-mode 'rcirc-mode)
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1069 (setq rcirc-last-non-irc-buffer (current-buffer)))
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1070 (if (and (> arg 0)
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1071 (<= arg (length rcirc-activity)))
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1072 (funcall rcirc-switch-to-buffer-function
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1073 (nth (1- arg) rcirc-activity))
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1074 (message "Invalid arg: %d" arg)))
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1075 (if (eq major-mode 'rcirc-mode)
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1076 (if (not (and rcirc-last-non-irc-buffer
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1077 (buffer-live-p rcirc-last-non-irc-buffer)))
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1078 (message "No last buffer.")
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1079 (funcall rcirc-switch-to-buffer-function rcirc-last-non-irc-buffer)
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1080 (setq rcirc-last-non-irc-buffer nil))
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1081 (message "No channel activity. Go start something."))))
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1082
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1083 (defvar rcirc-activity-hooks nil
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1084 "Hook to be run when there is channel activity.
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1085
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1086 Functions are called with a single argument, the buffer with the
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1087 activity. Only run if the buffer is not visible and
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1088 `rcirc-ignore-channel-activity' is non-nil.")
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1089
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1090 (defun rcirc-record-activity (buffer type)
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1091 "Record BUFFER activity with TYPE."
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1092 (with-current-buffer buffer
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1093 (when (not (get-buffer-window (current-buffer) t))
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1094 (add-to-list 'rcirc-activity (current-buffer) 'append)
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1095 (if (not rcirc-activity-type)
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1096 (setq rcirc-activity-type type))
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1097 (rcirc-update-activity-string)))
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1098 (run-hook-with-args 'rcirc-activity-hooks buffer))
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1099
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1100 (defun rcirc-clear-activity (buffer)
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1101 "Clear the BUFFER activity."
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1102 (setq rcirc-activity (delete buffer rcirc-activity))
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1103 (with-current-buffer buffer
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1104 (setq rcirc-activity-type nil)))
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1105
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1106 (defun rcirc-update-activity-string ()
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1107 "Update mode-line string."
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1108 (setq rcirc-activity-string
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1109 (if (or rcirc-ignore-all-activity-flag
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1110 (not rcirc-activity))
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1111 ""
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1112 (concat " [" (mapconcat
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1113 (lambda (b)
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1114 (let ((s (rcirc-short-buffer-name b)))
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1115 (with-current-buffer b
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1116 (if (not (eq rcirc-activity-type 'nick))
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1117 s
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1118 (rcirc-facify s
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1119 'rcirc-mode-line-nick-face)))))
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1120 rcirc-activity ",") "]"))))
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1121
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1122 (defun rcirc-short-buffer-name (buffer)
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1123 "Return a short name for BUFFER to use in the modeline indicator."
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1124 (with-current-buffer buffer
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1125 (or rcirc-target (process-name rcirc-process))))
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1126
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1127 (defun rcirc-update-activity ()
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1128 "Go through visible windows and remove buffers from activity list."
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1129 (walk-windows (lambda (w) (rcirc-clear-activity (window-buffer w))))
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1130 (rcirc-update-activity-string))
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1131
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1132
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1133 ;;; /commands these are called with 3 args: PROCESS, TARGET, which is
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1134 ;; the current buffer/channel/user, and ARGS, which is a string
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1135 ;; containing the text following the /cmd.
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1136
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1137 (defmacro defun-rcirc-command (command argument docstring interactive-form
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1138 &rest body)
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1139 "Define a command."
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1140 `(defun ,(intern (concat "rcirc-cmd-" (symbol-name command)))
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1141 (,@argument &optional process target)
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1142 ,(concat docstring "\n\nNote: If PROCESS or TARGET are nil, the values of"
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1143 "\nbuffer local variables `rcirc-process' and `rcirc-target',"
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1144 "\nwill be used.")
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1145 ,interactive-form
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1146 (let ((process (or process rcirc-process))
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1147 (target (or target rcirc-target)))
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1148 ,@body)))
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1149
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1150 (defun-rcirc-command msg (message)
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1151 "Send private MESSAGE to TARGET."
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1152 (interactive "i")
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1153 (if (null message)
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1154 (progn
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1155 (setq target (completing-read "Message nick: "
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1156 (with-current-buffer
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1157 (process-buffer rcirc-process)
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1158 rcirc-nick-table)))
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1159 (when (> (length target) 0)
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1160 (setq message (read-string (format "Message %s: " target)))
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1161 (when (> (length message) 0)
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1162 (rcirc-send-message process target message))))
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1163 (if (not (string-match "\\([^ ]+\\) \\(.+\\)" message))
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1164 (message "Not enough args, or something.")
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1165 (setq target (match-string 1 message)
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1166 message (match-string 2 message))
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1167 (rcirc-send-message process target message))))
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1168
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1169 (defun-rcirc-command query (nick)
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1170 "Open a private chat buffer to NICK."
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1171 (interactive (list (completing-read "Query nick: "
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1172 (with-current-buffer
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1173 (process-buffer rcirc-process)
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1174 rcirc-nick-table))))
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1175 (let ((new-buffer (eq (rcirc-get-buffer rcirc-process nick)
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1176 (process-buffer rcirc-process))))
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1177 (switch-to-buffer (rcirc-get-buffer-create process nick))
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1178 (when new-buffer
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1179 (rcirc-cmd-whois nick))))
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1180
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1181 (defun-rcirc-command join (args)
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1182 "Join CHANNEL."
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1183 (interactive "sJoin channel: ")
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1184 (let* ((channel (car (split-string args)))
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1185 (buffer (rcirc-get-buffer-create process channel)))
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1186 (when (not (eq (selected-window) (minibuffer-window)))
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1187 (funcall rcirc-switch-to-buffer-function buffer))
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1188 (rcirc-send-string process (concat "JOIN " args))
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1189 (rcirc-set-last-buffer process buffer)))
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1190
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1191 (defun-rcirc-command part (channel)
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1192 "Part CHANNEL."
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1193 (interactive "sPart channel: ")
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1194 (let ((channel (if (> (length channel) 0) channel target)))
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1195 (rcirc-send-string process (concat "PART " channel " :" (rcirc-version)))))
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1196
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1197 (defun-rcirc-command quit (reason)
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1198 "Send a quit message to server with REASON."
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1199 (interactive "sQuit reason: ")
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1200 (rcirc-send-string process (concat "QUIT :" reason)))
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1201
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1202 (defun-rcirc-command nick (nick)
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1203 "Change nick to NICK."
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1204 (interactive "i")
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1205 (when (null nick)
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1206 (setq nick (read-string "New nick: " (rcirc-nick process))))
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1207 (rcirc-send-string process (concat "NICK " nick)))
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1208
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1209 (defun-rcirc-command names (channel)
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1210 "Display list of names in CHANNEL or in current channel if CHANNEL is nil.
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1211 If called interactively, prompt for a channel when prefix arg is supplied."
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1212 (interactive "P")
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1213 (if (interactive-p)
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1214 (if channel
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1215 (setq channel (read-string "List names in channel: " target))))
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1216 (let ((channel (if (> (length channel) 0)
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1217 channel
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1218 target)))
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1219 (rcirc-send-string process (concat "NAMES " channel))))
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1220
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1221 (defun-rcirc-command topic (topic)
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1222 "List TOPIC for the TARGET channel.
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1223 With a prefix arg, prompt for new topic."
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1224 (interactive "P")
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1225 (if (and (interactive-p) topic)
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1226 (setq topic (read-string "New Topic: " rcirc-topic)))
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1227 (rcirc-send-string process (concat "TOPIC " target
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1228 (when (> (length topic) 0)
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1229 (concat " :" topic)))))
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1230
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1231 (defun-rcirc-command whois (nick)
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1232 "Request information from server about NICK."
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1233 (interactive (list
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1234 (completing-read "Whois: "
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1235 (with-current-buffer
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1236 (process-buffer rcirc-process)
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1237 rcirc-nick-table))))
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1238 (rcirc-set-last-buffer rcirc-process (current-buffer))
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1239 (rcirc-send-string process (concat "WHOIS " nick)))
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1240
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1241 (defun-rcirc-command mode (args)
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1242 "Set mode with ARGS."
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1243 (interactive (list (concat (read-string "Mode nick or channel: ")
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1244 " " (read-string "Mode: "))))
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1245 (rcirc-send-string process (concat "MODE " args)))
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1246
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1247 (defun-rcirc-command list (channels)
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1248 "Request information on CHANNELS from server."
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1249 (interactive "sList Channels: ")
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1250 (rcirc-send-string process (concat "LIST " channels)))
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1251
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1252 (defun-rcirc-command oper (args)
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1253 "Send operator command to server."
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1254 (interactive "sOper args: ")
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1255 (rcirc-send-string process (concat "OPER " args)))
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1256
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1257 (defun-rcirc-command quote (message)
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1258 "Send MESSAGE literally to server."
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1259 (interactive "sServer message: ")
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1260 (rcirc-send-string process message))
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1261
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1262 (defun-rcirc-command kick (arg)
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1263 "Kick NICK from current channel."
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1264 (interactive (list
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1265 (concat (completing-read "Kick nick: "
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1266 (rcirc-channel-nicks rcirc-process
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1267 rcirc-target))
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1268 (read-from-minibuffer "Kick reason: "))))
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1269 (let* ((arglist (split-string arg))
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1270 (argstring (concat (car arglist) " :"
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1271 (mapconcat 'identity (cdr arglist) " "))))
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1272 (rcirc-send-string process (concat "KICK " target " " argstring))))
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1273
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1274 (defun rcirc-cmd-ctcp (args &optional process target)
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1275 (if (string-match "^\\([^ ]+\\)\\s-+\\(.+\\)$" args)
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1276 (let ((target (match-string 1 args))
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1277 (request (match-string 2 args)))
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1278 (rcirc-send-message process target
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1279 (concat "\C-a" (upcase request) "\C-a")))
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1280 (rcirc-print process (rcirc-nick process) "ERROR" target
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1281 "usage: /ctcp NICK REQUEST")))
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1282
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1283 (defun rcirc-cmd-me (args &optional process target)
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1284 (rcirc-send-string process (format "PRIVMSG %s :\C-aACTION %s\C-a"
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1285 target args)))
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1286
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1287 (defun rcirc-message-leader (sender face)
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1288 "Return a string with SENDER propertized with FACE."
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1289 (rcirc-facify (concat "<" (rcirc-user-nick sender) "> ") face))
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1290
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1291 (defun rcirc-facify (string face)
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1292 "Return a copy of STRING with FACE property added."
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1293 (propertize (or string "") 'face face 'rear-nonsticky t))
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1294
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1295 ;; shy grouping must be used within this regexp
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1296 (defvar rcirc-url-regexp
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1297 "\\b\\(?:\\(?:www\\.\\|\\(?:s?https?\\|ftp\\|file\\|gopher\\|news\\|telnet\
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1298 \\|wais\\|mailto\\):\\)\\(?://[-a-zA-Z0-9_.]+:[0-9]*\\)?\\(?:[-a-zA-Z0-9_=!?#$\
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1299 @~`%&*+|\\/:;.,]\\|\\w\\)+\\(?:[-a-zA-Z0-9_=#$@~`%&*+|\\/]\\|\\w\\)\\)"
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1300 "Regexp matching URL's. Set to nil to disable URL features in rcirc.")
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1301
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1302 (defun rcirc-browse-url (&optional arg)
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1303 "Prompt for url to browse based on urls in buffer."
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1304 (interactive)
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1305 (let ((completions (mapcar (lambda (x) (cons x nil)) rcirc-urls))
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1306 (initial-input (car rcirc-urls))
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1307 (history (cdr rcirc-urls)))
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1308 (browse-url (completing-read "rcirc browse-url: "
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1309 completions nil nil initial-input 'history)
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1310 arg)))
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1311
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1312 (defun rcirc-map-regexp (function regexp string)
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1313 "Return a copy of STRING after calling FUNCTION for each REGEXP match.
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1314 FUNCTION takes 3 arguments, MATCH-START, MATCH-END, and STRING."
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1315 (let ((start 0))
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1316 (while (string-match regexp string start)
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1317 (setq start (match-end 0))
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1318 (funcall function (match-beginning 0) (match-end 0) string)))
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1319 string)
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1320
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1321 (defvar rcirc-nick-syntax-table
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1322 (let ((table (make-syntax-table text-mode-syntax-table)))
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1323 (mapc (lambda (c) (modify-syntax-entry c "w" table))
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1324 "[]\\`_^{|}-")
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1325 (modify-syntax-entry ?' "_" table)
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1326 table)
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1327 "Syntax table which includes all nick characters as word constituents.")
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1328
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1329 (defun rcirc-mangle-text (process text)
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1330 "Return TEXT with properties added based on various patterns."
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1331 ;; ^B
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1332 (setq text
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1333 (rcirc-map-regexp (lambda (start end string)
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1334 (add-text-properties
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1335 start end
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1336 (list 'face 'bold 'rear-nonsticky t)
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1337 string))
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1338 ".*?"
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1339 text))
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1340 (while (string-match "\\(.*\\)[]\\(.*\\)" text) ; deal with 
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1341 (setq text (concat (match-string 1 text)
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1342 (match-string 2 text))))
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1343 ;; my nick
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1344 (setq text
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1345 (with-syntax-table rcirc-nick-syntax-table
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1346 (rcirc-map-regexp (lambda (start end string)
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1347 (add-text-properties
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1348 start end
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1349 (list 'face 'rcirc-nick-in-message-face
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1350 'rear-nonsticky t)
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1351 string))
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1352 (concat "\\b"
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1353 (regexp-quote (rcirc-nick process))
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1354 "\\b")
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1355 text)))
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1356 ;; urls
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1357 (setq text
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1358 (rcirc-map-regexp
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1359 (lambda (start end string)
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1360 (let ((orig-face (get-text-property start 'face string)))
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1361 (add-text-properties start end
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1362 (list 'face (list orig-face 'bold)
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1363 'rear-nonsticky t)
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1364 string))
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1365 (push (substring string start end) rcirc-urls))
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1366 rcirc-url-regexp
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1367 text))
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1368 text)
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1369
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1370
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1371 ;;; handlers
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1372 ;; these are called with the server PROCESS, the SENDER, which is a
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1373 ;; server or a user, depending on the command, the ARGS, which is a
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1374 ;; list of strings, and the TEXT, which is the original server text,
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1375 ;; verbatim
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1376 (defun rcirc-handler-001 (process sender args text)
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1377 (rcirc-handler-generic process "001" sender args text)
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1378 ;; set the real server name
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1379 (with-current-buffer (process-buffer process)
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1380 (setq rcirc-server sender)
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1381 (setq rcirc-nick (car args))
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1382 (rcirc-update-prompt)
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1383 (when rcirc-auto-authenticate-flag (rcirc-authenticate))
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1384 (let (rcirc-last-buffer)
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1385 (rcirc-join-channels process rcirc-startup-channels))))
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1386
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1387 (defun rcirc-handler-PRIVMSG (process sender args text)
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1388 (let ((target (if (rcirc-channel-p (car args))
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1389 (car args)
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1390 (rcirc-user-nick sender)))
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1391 (message (or (cadr args) "")))
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1392 (if (string-match "^\C-a\\(.*\\)\C-a$" message)
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1393 (rcirc-handler-CTCP process target sender (match-string 1 message))
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1394 (rcirc-print process sender "PRIVMSG" target message t))
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1395 ;; update nick timestamp
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1396 (if (member target (rcirc-nick-channels process sender))
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1397 (rcirc-put-nick-channel process sender target))))
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1398
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1399 (defun rcirc-handler-NOTICE (process sender args text)
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1400 (let ((target (car args))
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1401 (message (cadr args)))
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1402 (rcirc-print process sender "NOTICE"
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1403 (cond ((rcirc-channel-p target)
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1404 target)
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1405 ((string-match "^\\[\\(#[^ ]+\\)\\]" message)
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1406 (match-string 1 message))
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1407 (sender
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1408 (if (string= sender (rcirc-server process))
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1409 (process-buffer process)
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1410 (rcirc-user-nick sender))))
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1411 message t)
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1412 (and sender (rcirc-put-nick-channel process sender target))))
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1413
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1414 (defun rcirc-handler-WALLOPS (process sender args text)
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1415 (let ((target (rcirc-user-nick sender)))
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1416 (rcirc-print process sender "WALLOPS" target (car args) t)))
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1417
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1418 (defun rcirc-handler-JOIN (process sender args text)
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1419 (let ((channel (downcase (car args)))
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1420 (nick (rcirc-user-nick sender)))
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1421 (rcirc-get-buffer-create process channel)
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1422 (rcirc-print process sender "JOIN" channel "")
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1423
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1424 ;; print in private chat buffer if it exists
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1425 (if (not (eq (process-buffer rcirc-process)
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1426 (rcirc-get-buffer rcirc-process nick)))
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1427 (rcirc-print process sender "JOIN" nick channel))
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1428
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1429 (rcirc-put-nick-channel process sender channel)
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1430 (if (string= nick (rcirc-nick process))
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1431 (setq rcirc-channels (cons channel rcirc-channels)))))
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1432
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1433 ;; PART and KICK are handled the same way
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1434 (defun rcirc-handler-PART-or-KICK (process response channel sender nick args)
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1435 (rcirc-print process sender response channel (concat channel " " args))
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1436
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1437 ;; print in private chat buffer if it exists
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1438 (when (not (eq (process-buffer rcirc-process)
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1439 (rcirc-get-buffer rcirc-process nick)))
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1440 (rcirc-print process sender response nick (concat channel " " args)))
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1441
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1442 (if (not (string= nick (rcirc-nick process)))
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1443 ;; this is someone else leaving
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1444 (rcirc-remove-nick-channel process nick channel)
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1445 ;; this is us leaving
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1446 (mapc (lambda (n)
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1447 (rcirc-remove-nick-channel process n channel))
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1448 (rcirc-channel-nicks process channel))
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1449 (setq rcirc-channels (delete channel rcirc-channels))
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1450 (with-current-buffer (rcirc-get-buffer process channel)
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1451 (setq rcirc-target nil))))
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1452
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1453 (defun rcirc-handler-PART (process sender args text)
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1454 (rcirc-handler-PART-or-KICK process "PART"
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1455 (car args) sender (rcirc-user-nick sender)
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1456 (cadr args)))
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1457
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1458 (defun rcirc-handler-KICK (process sender args text)
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1459 (rcirc-handler-PART-or-KICK process "KICK" (car args) sender (cadr args)
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1460 (caddr args)))
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1461
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1462 (defun rcirc-handler-QUIT (process sender args text)
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1463 (let ((nick (rcirc-user-nick sender)))
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1464 (mapc (lambda (channel)
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1465 (rcirc-print process sender "QUIT" channel (apply 'concat args)))
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1466 (rcirc-nick-channels process nick))
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1467
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1468 ;; print in private chat buffer if it exists
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1469 (if (not (eq (process-buffer rcirc-process)
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1470 (rcirc-get-buffer rcirc-process nick)))
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1471 (rcirc-print process sender "QUIT" nick (apply 'concat args)))
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1472
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1473 (rcirc-nick-remove process nick)))
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1474
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1475 (defun rcirc-handler-NICK (process sender args text)
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1476 (let* ((old-nick (rcirc-user-nick sender))
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1477 (new-nick (car args))
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1478 (channels (rcirc-nick-channels process old-nick)))
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1479 ;; print message to nick's channels
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1480 (dolist (target channels)
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1481 (rcirc-print process sender "NICK" target new-nick))
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1482 ;; update private chat buffer, if it exists
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1483 (with-current-buffer (rcirc-get-buffer process old-nick)
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1484 (when (not (equal (process-buffer rcirc-process)
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1485 (current-buffer)))
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1486 (rcirc-print process sender "NICK" old-nick new-nick)
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1487 (setq rcirc-target new-nick)
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1488 (rename-buffer (rcirc-get-buffer-name process new-nick))))
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1489 ;; remove old nick and add new one
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1490 (with-current-buffer (process-buffer process)
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1491 (let ((v (gethash old-nick rcirc-nick-table)))
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1492 (remhash old-nick rcirc-nick-table)
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1493 (puthash new-nick v rcirc-nick-table))
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1494 ;; if this is our nick...
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1495 (when (string= old-nick rcirc-nick)
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1496 (setq rcirc-nick new-nick)
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1497 ;; update prompts
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1498 (mapc (lambda (target)
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1499 (with-current-buffer (rcirc-get-buffer process target)
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1500 (rcirc-update-prompt)))
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1501 (append rcirc-channels rcirc-private-chats))
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1502 ;; reauthenticate
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1503 (when rcirc-auto-authenticate-flag (rcirc-authenticate))))))
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1504
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1505 (defun rcirc-handler-PING (process sender args text)
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1506 (rcirc-send-string process (concat "PONG " (car args))))
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1507
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1508 (defun rcirc-handler-PONG (process sender args text)
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1509 ;; do nothing
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1510 )
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1511
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1512 (defun rcirc-handler-TOPIC (process sender args text)
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1513 (let ((topic (cadr args)))
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1514 (rcirc-print process sender "TOPIC" (car args) topic)
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1515 (with-current-buffer (rcirc-get-buffer process (car args))
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1516 (setq rcirc-topic topic))))
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1517
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1518 (defun rcirc-handler-332 (process sender args text)
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1519 "RPL_TOPIC"
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1520 (with-current-buffer (rcirc-get-buffer process (cadr args))
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1521 (setq rcirc-topic (caddr args))))
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1522
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1523 (defun rcirc-handler-333 (process sender args text)
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1524 "Not in rfc1459.txt"
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1525 (with-current-buffer (rcirc-get-buffer process (cadr args))
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1526 (let ((setter (caddr args))
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1527 (time (current-time-string
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1528 (seconds-to-time
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1529 (string-to-number (cadddr args))))))
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1530 (rcirc-print process sender "TOPIC" (cadr args)
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1531 (format "%s (%s on %s)" rcirc-topic setter time)))))
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1532
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1533 (defun rcirc-handler-477 (process sender args text)
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1534 "ERR_NOCHANMODES"
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1535 (rcirc-print process sender "477" (cadr args) (caddr args)))
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1536
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1537 (defun rcirc-handler-MODE (process sender args text)
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1538 (let ((target (car args))
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1539 (msg (mapconcat 'identity (cdr args) " ")))
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1540 (rcirc-print process sender "MODE"
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1541 (if (string= target (rcirc-nick process))
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1542 nil
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1543 target)
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1544 msg)
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1545
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1546 ;; print in private chat buffers if they exist
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1547 (mapc (lambda (nick)
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1548 (when (not (eq (process-buffer rcirc-process)
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1549 (rcirc-get-buffer rcirc-process nick)))
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1550 (rcirc-print process sender "MODE" nick msg)))
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1551 (cddr args))))
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1552
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1553 (defun rcirc-get-temp-buffer-create (process channel)
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1554 "Return a buffer based on PROCESS and CHANNEL."
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1555 (let ((tmpnam (concat " " (downcase channel) "TMP" (process-name process))))
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1556 (get-buffer-create tmpnam)))
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1557
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1558 (defun rcirc-handler-353 (process sender args text)
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1559 "RPL_NAMREPLY"
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1560 (let ((channel (downcase (caddr args))))
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1561 (mapc (lambda (nick)
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1562 (rcirc-put-nick-channel process nick channel))
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1563 (delete "" (split-string (cadddr args) " ")))
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1564 (with-current-buffer (rcirc-get-temp-buffer-create process channel)
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1565 (goto-char (point-max))
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1566 (insert (car (last args)) " "))))
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1567
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1568 (defun rcirc-handler-366 (process sender args text)
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1569 "RPL_ENDOFNAMES"
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1570 (let* ((channel (cadr args))
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1571 (buffer (rcirc-get-temp-buffer-create process channel)))
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1572 (with-current-buffer buffer
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1573 (rcirc-print process sender "NAMES" channel
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1574 (buffer-substring (point-min) (point-max))))
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1575 (kill-buffer buffer)))
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1576
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1577 (defun rcirc-handler-433 (process sender args text)
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1578 "ERR_NICKNAMEINUSE"
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1579 (rcirc-handler-generic process "433" sender args text)
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1580 (let* ((new-nick (concat (cadr args) "`")))
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1581 (with-current-buffer (process-buffer process)
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1582 (rcirc-cmd-nick new-nick nil process))))
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1583
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1584 (defun rcirc-authenticate ()
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1585 "Send authentication to process associated with current buffer.
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1586 Passwords are read from `rcirc-authinfo-file-name' (which see)."
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1587 (interactive)
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1588 (let ((password-alist
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1589 (with-temp-buffer
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1590 (insert-file-contents-literally rcirc-authinfo-file-name)
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1591 (goto-char (point-min))
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1592 (read (current-buffer)))))
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1593 (with-current-buffer (process-buffer rcirc-process)
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1594 (dolist (i password-alist)
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1595 (let ((server (car i))
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1596 (nick (cadr i))
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1597 (method (caddr i))
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1598 (args (cdddr i)))
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1599 (when (and (string-match server rcirc-server)
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1600 (string-match nick rcirc-nick))
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1601 (cond ((equal method 'nickserv)
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1602 (rcirc-send-string
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1603 rcirc-process
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1604 (concat
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1605 "PRIVMSG nickserv :identify "
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1606 (car args))))
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1607 ((equal method 'chanserv)
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1608 (rcirc-send-string
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1609 rcirc-process
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1610 (concat
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1611 "PRIVMSG chanserv :identify "
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1612 (car args) " " (cadr args))))
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1613 ((equal method 'bitlbee)
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1614 (rcirc-send-string
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1615 rcirc-process
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1616 (concat "PRIVMSG #bitlbee :identify " (car args))))
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1617 (t
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1618 (message "No %S authentication method defined"
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1619 method)))))))))
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1620
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1621 (defun rcirc-handler-INVITE (process sender args text)
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1622 (rcirc-print process sender "INVITE" nil (mapconcat 'identity args " ") t))
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1623
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1624 (defun rcirc-handler-ERROR (process sender args text)
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1625 (rcirc-print process sender "ERROR" nil (mapconcat 'identity args " ")))
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1626
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1627 (defun rcirc-handler-CTCP (process target sender text)
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1628 (if (string-match "^\\([^ ]+\\) *\\(.*\\)$" text)
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1629 (let* ((request (upcase (match-string 1 text)))
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1630 (args (match-string 2 text))
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1631 (nick (rcirc-user-nick sender))
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1632 (handler (intern-soft (concat "rcirc-handler-ctcp-" request))))
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1633 (if (not (fboundp handler))
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1634 (rcirc-print process sender "ERROR" target
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1635 (format "unhandled ctcp: %s" text))
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1636 (funcall handler process target sender args)
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1637 (if (not (string= request "ACTION"))
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1638 (rcirc-print process sender "CTCP" target
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1639 (format "%s" text)))))))
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1640
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1641 (defun rcirc-handler-ctcp-VERSION (process target sender args)
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1642 (rcirc-send-string process
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1643 (concat "NOTICE " (rcirc-user-nick sender)
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1644 " :\C-aVERSION " (rcirc-version)
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1645 " - http://www.nongnu.org/rcirc"
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1646 "\C-a")))
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1647
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1648 (defun rcirc-handler-ctcp-ACTION (process target sender args)
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1649 (rcirc-print process sender "ACTION" target args t))
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1650
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1651 (defun rcirc-handler-ctcp-TIME (process target sender args)
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1652 (rcirc-send-string process
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1653 (concat "NOTICE " (rcirc-user-nick sender)
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1654 " :\C-aTIME " (current-time-string) "\C-a")))
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1655
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1656 (defface rcirc-my-nick-face
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1657 '((((type tty) (class color)) (:foreground "blue" :weight bold))
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1658 (((class color) (background light)) (:foreground "Blue"))
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1659 (((class color) (background dark)) (:foreground "LightSkyBlue"))
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1660 (t (:inverse-video t :bold t)))
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1661 "The rcirc face used to highlight my messages."
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1662 :group 'rcirc)
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1663
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1664 (defface rcirc-other-nick-face
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1665 '((((type tty) (class color)) (:foreground "yellow" :weight light))
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1666 (((class grayscale) (background light))
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1667 (:foreground "Gray90" :bold t :italic t))
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1668 (((class grayscale) (background dark))
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1669 (:foreground "DimGray" :bold t :italic t))
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1670 (((class color) (background light)) (:foreground "DarkGoldenrod"))
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1671 (((class color) (background dark)) (:foreground "LightGoldenrod"))
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1672 (t (:bold t :italic t)))
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1673 "The rcirc face used to highlight other messages."
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1674 :group 'rcirc)
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1675
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1676 (defface rcirc-server-face
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1677 '((((type tty pc) (class color) (background light)) (:foreground "red"))
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1678 (((type tty pc) (class color) (background dark)) (:foreground "red1"))
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1679 (((class grayscale) (background light))
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1680 (:foreground "DimGray" :bold t :italic t))
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1681 (((class grayscale) (background dark))
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1682 (:foreground "LightGray" :bold t :italic t))
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1683 (((class color) (background light)) (:foreground "gray40"))
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1684 (((class color) (background dark)) (:foreground "chocolate1"))
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1685 (t (:bold t :italic t)))
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1686 "The rcirc face used to highlight server messages."
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1687 :group 'rcirc)
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1688
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1689 (defface rcirc-nick-in-message-face
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1690 '((((type tty) (class color)) (:foreground "cyan" :weight bold))
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1691 (((class grayscale) (background light)) (:foreground "LightGray" :bold t))
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1692 (((class grayscale) (background dark)) (:foreground "DimGray" :bold t))
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1693 (((class color) (background light)) (:foreground "Purple"))
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1694 (((class color) (background dark)) (:foreground "Cyan"))
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1695 (t (:bold t)))
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1696 "The rcirc face used to highlight instances of nick within messages."
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1697 :group 'rcirc)
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1698
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1699 (defface rcirc-prompt-face
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1700 '((((background dark)) (:foreground "cyan"))
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1701 (t (:foreground "dark blue")))
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1702 "The rcirc face to use to highlight prompts."
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1703 :group 'rcirc)
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1704
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1705 (defface rcirc-mode-line-nick-face
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1706 '((t (:bold t)))
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1707 "The rcirc face used indicate activity directed at you."
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1708 :group 'rcirc)
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1709
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1710 ;; When using M-x flyspell-mode, only check words past the input marker
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1711 (put 'rcirc-mode 'flyspell-mode-predicate 'rcirc-looking-at-input)
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1712 (defun rcirc-looking-at-input ()
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1713 "Returns true if point is past the input marker."
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1714 (>= (point) rcirc-prompt-end-marker))
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1715
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1716
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1717 (provide 'rcirc)
66258
4e4cce911e2e Add arch tagline
Miles Bader <miles@gnu.org>
parents: 66252
diff changeset
1718
4e4cce911e2e Add arch tagline
Miles Bader <miles@gnu.org>
parents: 66252
diff changeset
1719 ;; arch-tag: b471b7e8-6b5a-4399-b2c6-a3c78dfc8ffb
66248
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1720 ;;; rcirc.el ends here