annotate lisp/net/rcirc.el @ 72707:d7f93349a89e

*** empty log message ***
author YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
date Fri, 08 Sep 2006 08:18:39 +0000
parents 249ed2e06deb
children 7e254a2d157c
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
68648
067115a6e738 Update years in copyright notice; nfc.
Thien-Thi Nguyen <ttn@gnuvola.org>
parents: 68578
diff changeset
3 ;; Copyright (C) 2005, 2006 Free Software Foundation, Inc.
66248
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
66272
79d2a5d86ee4 Now part of GNU Emacs. Update FSF's address.
Romain Francoise <romain@orebokech.com>
parents: 66258
diff changeset
9 ;; This file is part of GNU Emacs.
66248
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
66272
79d2a5d86ee4 Now part of GNU Emacs. Update FSF's address.
Romain Francoise <romain@orebokech.com>
parents: 66258
diff changeset
22 ;; along with GNU Emacs; see the file COPYING. If not, write to the
79d2a5d86ee4 Now part of GNU Emacs. Update FSF's address.
Romain Francoise <romain@orebokech.com>
parents: 66258
diff changeset
23 ;; Free Software Foundation, Inc., 51 Franklin Street, Fifth Floor,
79d2a5d86ee4 Now part of GNU Emacs. Update FSF's address.
Romain Francoise <romain@orebokech.com>
parents: 66258
diff changeset
24 ;; Boston, MA 02110-1301, USA.
66248
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
66703
6cfb275aa300 Use split-string OMIT-NULLS argument.
Eli Zaretskii <eliz@gnu.org>
parents: 66272
diff changeset
28 ;; Internet Relay Chat (IRC) is a form of instant communication over
6cfb275aa300 Use split-string OMIT-NULLS argument.
Eli Zaretskii <eliz@gnu.org>
parents: 66272
diff changeset
29 ;; the Internet. It is mainly designed for group (many-to-many)
6cfb275aa300 Use split-string OMIT-NULLS argument.
Eli Zaretskii <eliz@gnu.org>
parents: 66272
diff changeset
30 ;; communication in discussion forums called channels, but also allows
6cfb275aa300 Use split-string OMIT-NULLS argument.
Eli Zaretskii <eliz@gnu.org>
parents: 66272
diff changeset
31 ;; one-to-one communication.
66248
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
32
66703
6cfb275aa300 Use split-string OMIT-NULLS argument.
Eli Zaretskii <eliz@gnu.org>
parents: 66272
diff changeset
33 ;; Rcirc has simple defaults and clear and consistent behaviour.
6cfb275aa300 Use split-string OMIT-NULLS argument.
Eli Zaretskii <eliz@gnu.org>
parents: 66272
diff changeset
34 ;; Message arrival timestamps, activity notification on the modeline,
6cfb275aa300 Use split-string OMIT-NULLS argument.
Eli Zaretskii <eliz@gnu.org>
parents: 66272
diff changeset
35 ;; message filling, nick completion, and keepalive pings are all
6cfb275aa300 Use split-string OMIT-NULLS argument.
Eli Zaretskii <eliz@gnu.org>
parents: 66272
diff changeset
36 ;; enabled by default, but can easily be adjusted or turned off. Each
6cfb275aa300 Use split-string OMIT-NULLS argument.
Eli Zaretskii <eliz@gnu.org>
parents: 66272
diff changeset
37 ;; discussion takes place in its own buffer and there is a single
6cfb275aa300 Use split-string OMIT-NULLS argument.
Eli Zaretskii <eliz@gnu.org>
parents: 66272
diff changeset
38 ;; server buffer per connection.
66248
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 ;; Open a new irc connection with:
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
41 ;; M-x irc RET
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
42
72468
5e47ca87ee3c Rcirc update from Ryan Yeske
Miles Bader <miles@gnu.org>
parents: 71442
diff changeset
43 ;;; Todo:
5e47ca87ee3c Rcirc update from Ryan Yeske
Miles Bader <miles@gnu.org>
parents: 71442
diff changeset
44
66248
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
45 ;;; Code:
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 (require 'ring)
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
48 (require 'time-date)
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
49 (eval-when-compile (require 'cl))
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
50
66703
6cfb275aa300 Use split-string OMIT-NULLS argument.
Eli Zaretskii <eliz@gnu.org>
parents: 66272
diff changeset
51 (defgroup rcirc nil
6cfb275aa300 Use split-string OMIT-NULLS argument.
Eli Zaretskii <eliz@gnu.org>
parents: 66272
diff changeset
52 "Simple IRC client."
6cfb275aa300 Use split-string OMIT-NULLS argument.
Eli Zaretskii <eliz@gnu.org>
parents: 66272
diff changeset
53 :version "22.1"
68960
6e3160901812 (rcirc-connect): Make all arguments optional, and default to global variable
Eli Zaretskii <eliz@gnu.org>
parents: 68838
diff changeset
54 :prefix "rcirc-"
69461
1527bb09ec30 Revision: emacs@sv.gnu.org/emacs--devo--0--patch-156
Miles Bader <miles@gnu.org>
parents: 69460
diff changeset
55 :link '(custom-manual "(rcirc)")
66703
6cfb275aa300 Use split-string OMIT-NULLS argument.
Eli Zaretskii <eliz@gnu.org>
parents: 66272
diff changeset
56 :group 'applications)
66248
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
57
69860
000a5d4aa083 (rcirc-default-server): Rename from rcirc-server.
Eli Zaretskii <eliz@gnu.org>
parents: 69694
diff changeset
58 (defcustom rcirc-default-server "irc.freenode.net"
66703
6cfb275aa300 Use split-string OMIT-NULLS argument.
Eli Zaretskii <eliz@gnu.org>
parents: 66272
diff changeset
59 "The default server to connect to."
6cfb275aa300 Use split-string OMIT-NULLS argument.
Eli Zaretskii <eliz@gnu.org>
parents: 66272
diff changeset
60 :type 'string
6cfb275aa300 Use split-string OMIT-NULLS argument.
Eli Zaretskii <eliz@gnu.org>
parents: 66272
diff changeset
61 :group 'rcirc)
66248
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
62
69860
000a5d4aa083 (rcirc-default-server): Rename from rcirc-server.
Eli Zaretskii <eliz@gnu.org>
parents: 69694
diff changeset
63 (defcustom rcirc-default-port 6667
66703
6cfb275aa300 Use split-string OMIT-NULLS argument.
Eli Zaretskii <eliz@gnu.org>
parents: 66272
diff changeset
64 "The default port to connect to."
6cfb275aa300 Use split-string OMIT-NULLS argument.
Eli Zaretskii <eliz@gnu.org>
parents: 66272
diff changeset
65 :type 'integer
6cfb275aa300 Use split-string OMIT-NULLS argument.
Eli Zaretskii <eliz@gnu.org>
parents: 66272
diff changeset
66 :group 'rcirc)
66248
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
67
69860
000a5d4aa083 (rcirc-default-server): Rename from rcirc-server.
Eli Zaretskii <eliz@gnu.org>
parents: 69694
diff changeset
68 (defcustom rcirc-default-nick (user-login-name)
66703
6cfb275aa300 Use split-string OMIT-NULLS argument.
Eli Zaretskii <eliz@gnu.org>
parents: 66272
diff changeset
69 "Your nick."
6cfb275aa300 Use split-string OMIT-NULLS argument.
Eli Zaretskii <eliz@gnu.org>
parents: 66272
diff changeset
70 :type 'string
6cfb275aa300 Use split-string OMIT-NULLS argument.
Eli Zaretskii <eliz@gnu.org>
parents: 66272
diff changeset
71 :group 'rcirc)
66248
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
72
69860
000a5d4aa083 (rcirc-default-server): Rename from rcirc-server.
Eli Zaretskii <eliz@gnu.org>
parents: 69694
diff changeset
73 (defcustom rcirc-default-user-name (user-login-name)
66703
6cfb275aa300 Use split-string OMIT-NULLS argument.
Eli Zaretskii <eliz@gnu.org>
parents: 66272
diff changeset
74 "Your user name sent to the server when connecting."
6cfb275aa300 Use split-string OMIT-NULLS argument.
Eli Zaretskii <eliz@gnu.org>
parents: 66272
diff changeset
75 :type 'string
6cfb275aa300 Use split-string OMIT-NULLS argument.
Eli Zaretskii <eliz@gnu.org>
parents: 66272
diff changeset
76 :group 'rcirc)
6cfb275aa300 Use split-string OMIT-NULLS argument.
Eli Zaretskii <eliz@gnu.org>
parents: 66272
diff changeset
77
69860
000a5d4aa083 (rcirc-default-server): Rename from rcirc-server.
Eli Zaretskii <eliz@gnu.org>
parents: 69694
diff changeset
78 (defcustom rcirc-default-user-full-name (if (string= (user-full-name) "")
71442
00a28b680b71 (rcirc-default-user-full-name): Default to `rcirc-default-user-name' instead
Eli Zaretskii <eliz@gnu.org>
parents: 71440
diff changeset
79 rcirc-default-user-name
70215
90d76f24753a Revision: emacs@sv.gnu.org/emacs--devo--0--patch-247
Miles Bader <miles@gnu.org>
parents: 69860
diff changeset
80 (user-full-name))
66703
6cfb275aa300 Use split-string OMIT-NULLS argument.
Eli Zaretskii <eliz@gnu.org>
parents: 66272
diff changeset
81 "The full name sent to the server when connecting."
6cfb275aa300 Use split-string OMIT-NULLS argument.
Eli Zaretskii <eliz@gnu.org>
parents: 66272
diff changeset
82 :type 'string
6cfb275aa300 Use split-string OMIT-NULLS argument.
Eli Zaretskii <eliz@gnu.org>
parents: 66272
diff changeset
83 :group 'rcirc)
66248
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
84
70215
90d76f24753a Revision: emacs@sv.gnu.org/emacs--devo--0--patch-247
Miles Bader <miles@gnu.org>
parents: 69860
diff changeset
85 (defcustom rcirc-startup-channels-alist '(("^irc.freenode.net$" "#rcirc"))
66248
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
86 "Alist of channels to join at startup.
66703
6cfb275aa300 Use split-string OMIT-NULLS argument.
Eli Zaretskii <eliz@gnu.org>
parents: 66272
diff changeset
87 Each element looks like (SERVER-REGEXP . CHANNEL-LIST)."
6cfb275aa300 Use split-string OMIT-NULLS argument.
Eli Zaretskii <eliz@gnu.org>
parents: 66272
diff changeset
88 :type '(alist :key-type string :value-type (repeat string))
6cfb275aa300 Use split-string OMIT-NULLS argument.
Eli Zaretskii <eliz@gnu.org>
parents: 66272
diff changeset
89 :group 'rcirc)
66248
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
90
66703
6cfb275aa300 Use split-string OMIT-NULLS argument.
Eli Zaretskii <eliz@gnu.org>
parents: 66272
diff changeset
91 (defcustom rcirc-fill-flag t
6cfb275aa300 Use split-string OMIT-NULLS argument.
Eli Zaretskii <eliz@gnu.org>
parents: 66272
diff changeset
92 "*Non-nil means line-wrap messages printed in channel buffers."
6cfb275aa300 Use split-string OMIT-NULLS argument.
Eli Zaretskii <eliz@gnu.org>
parents: 66272
diff changeset
93 :type 'boolean
6cfb275aa300 Use split-string OMIT-NULLS argument.
Eli Zaretskii <eliz@gnu.org>
parents: 66272
diff changeset
94 :group 'rcirc)
66248
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
95
66703
6cfb275aa300 Use split-string OMIT-NULLS argument.
Eli Zaretskii <eliz@gnu.org>
parents: 66272
diff changeset
96 (defcustom rcirc-fill-column nil
6cfb275aa300 Use split-string OMIT-NULLS argument.
Eli Zaretskii <eliz@gnu.org>
parents: 66272
diff changeset
97 "*Column beyond which automatic line-wrapping should happen.
68563
979fba30166f (rcirc-debug): Fix docstring.
Juanma Barranquero <lekktu@gmail.com>
parents: 68079
diff changeset
98 If nil, use value of `fill-column'. If 'frame-width, use the
66703
6cfb275aa300 Use split-string OMIT-NULLS argument.
Eli Zaretskii <eliz@gnu.org>
parents: 66272
diff changeset
99 maximum frame width."
6cfb275aa300 Use split-string OMIT-NULLS argument.
Eli Zaretskii <eliz@gnu.org>
parents: 66272
diff changeset
100 :type '(choice (const :tag "Value of `fill-column'")
6cfb275aa300 Use split-string OMIT-NULLS argument.
Eli Zaretskii <eliz@gnu.org>
parents: 66272
diff changeset
101 (const :tag "Full frame width" frame-width)
6cfb275aa300 Use split-string OMIT-NULLS argument.
Eli Zaretskii <eliz@gnu.org>
parents: 66272
diff changeset
102 (integer :tag "Number of columns"))
6cfb275aa300 Use split-string OMIT-NULLS argument.
Eli Zaretskii <eliz@gnu.org>
parents: 66272
diff changeset
103 :group 'rcirc)
66248
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
104
66703
6cfb275aa300 Use split-string OMIT-NULLS argument.
Eli Zaretskii <eliz@gnu.org>
parents: 66272
diff changeset
105 (defcustom rcirc-fill-prefix nil
66248
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
106 "*Text to insert before filled lines.
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
107 If nil, calculate the prefix dynamically to line up text
66703
6cfb275aa300 Use split-string OMIT-NULLS argument.
Eli Zaretskii <eliz@gnu.org>
parents: 66272
diff changeset
108 underneath each nick."
6cfb275aa300 Use split-string OMIT-NULLS argument.
Eli Zaretskii <eliz@gnu.org>
parents: 66272
diff changeset
109 :type '(choice (const :tag "Dynamic" nil)
6cfb275aa300 Use split-string OMIT-NULLS argument.
Eli Zaretskii <eliz@gnu.org>
parents: 66272
diff changeset
110 (string :tag "Prefix text"))
6cfb275aa300 Use split-string OMIT-NULLS argument.
Eli Zaretskii <eliz@gnu.org>
parents: 66272
diff changeset
111 :group 'rcirc)
66248
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
112
66703
6cfb275aa300 Use split-string OMIT-NULLS argument.
Eli Zaretskii <eliz@gnu.org>
parents: 66272
diff changeset
113 (defvar rcirc-ignore-buffer-activity-flag nil
6cfb275aa300 Use split-string OMIT-NULLS argument.
Eli Zaretskii <eliz@gnu.org>
parents: 66272
diff changeset
114 "If non-nil, ignore activity in this buffer.")
6cfb275aa300 Use split-string OMIT-NULLS argument.
Eli Zaretskii <eliz@gnu.org>
parents: 66272
diff changeset
115 (make-variable-buffer-local 'rcirc-ignore-buffer-activity-flag)
66248
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
116
69860
000a5d4aa083 (rcirc-default-server): Rename from rcirc-server.
Eli Zaretskii <eliz@gnu.org>
parents: 69694
diff changeset
117 (defvar rcirc-low-priority-flag nil
000a5d4aa083 (rcirc-default-server): Rename from rcirc-server.
Eli Zaretskii <eliz@gnu.org>
parents: 69694
diff changeset
118 "If non-nil, activity in this buffer is considered low priority.")
000a5d4aa083 (rcirc-default-server): Rename from rcirc-server.
Eli Zaretskii <eliz@gnu.org>
parents: 69694
diff changeset
119 (make-variable-buffer-local 'rcirc-low-priority-flag)
000a5d4aa083 (rcirc-default-server): Rename from rcirc-server.
Eli Zaretskii <eliz@gnu.org>
parents: 69694
diff changeset
120
66703
6cfb275aa300 Use split-string OMIT-NULLS argument.
Eli Zaretskii <eliz@gnu.org>
parents: 66272
diff changeset
121 (defcustom rcirc-time-format "%H:%M "
66248
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
122 "*Describes how timestamps are printed.
66703
6cfb275aa300 Use split-string OMIT-NULLS argument.
Eli Zaretskii <eliz@gnu.org>
parents: 66272
diff changeset
123 Used as the first arg to `format-time-string'."
6cfb275aa300 Use split-string OMIT-NULLS argument.
Eli Zaretskii <eliz@gnu.org>
parents: 66272
diff changeset
124 :type 'string
6cfb275aa300 Use split-string OMIT-NULLS argument.
Eli Zaretskii <eliz@gnu.org>
parents: 66272
diff changeset
125 :group 'rcirc)
66248
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
126
66703
6cfb275aa300 Use split-string OMIT-NULLS argument.
Eli Zaretskii <eliz@gnu.org>
parents: 66272
diff changeset
127 (defcustom rcirc-input-ring-size 1024
6cfb275aa300 Use split-string OMIT-NULLS argument.
Eli Zaretskii <eliz@gnu.org>
parents: 66272
diff changeset
128 "*Size of input history ring."
6cfb275aa300 Use split-string OMIT-NULLS argument.
Eli Zaretskii <eliz@gnu.org>
parents: 66272
diff changeset
129 :type 'integer
6cfb275aa300 Use split-string OMIT-NULLS argument.
Eli Zaretskii <eliz@gnu.org>
parents: 66272
diff changeset
130 :group 'rcirc)
66248
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
131
66703
6cfb275aa300 Use split-string OMIT-NULLS argument.
Eli Zaretskii <eliz@gnu.org>
parents: 66272
diff changeset
132 (defcustom rcirc-read-only-flag t
68563
979fba30166f (rcirc-debug): Fix docstring.
Juanma Barranquero <lekktu@gmail.com>
parents: 68079
diff changeset
133 "*Non-nil means make text in IRC buffers read-only."
66703
6cfb275aa300 Use split-string OMIT-NULLS argument.
Eli Zaretskii <eliz@gnu.org>
parents: 66272
diff changeset
134 :type 'boolean
6cfb275aa300 Use split-string OMIT-NULLS argument.
Eli Zaretskii <eliz@gnu.org>
parents: 66272
diff changeset
135 :group 'rcirc)
66248
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
136
66703
6cfb275aa300 Use split-string OMIT-NULLS argument.
Eli Zaretskii <eliz@gnu.org>
parents: 66272
diff changeset
137 (defcustom rcirc-buffer-maximum-lines nil
66248
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
138 "*The maximum size in lines for rcirc buffers.
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
139 Channel buffers are truncated from the top to be no greater than this
66703
6cfb275aa300 Use split-string OMIT-NULLS argument.
Eli Zaretskii <eliz@gnu.org>
parents: 66272
diff changeset
140 number. If zero or nil, no truncating is done."
6cfb275aa300 Use split-string OMIT-NULLS argument.
Eli Zaretskii <eliz@gnu.org>
parents: 66272
diff changeset
141 :type '(choice (const :tag "No truncation" nil)
6cfb275aa300 Use split-string OMIT-NULLS argument.
Eli Zaretskii <eliz@gnu.org>
parents: 66272
diff changeset
142 (integer :tag "Number of lines"))
6cfb275aa300 Use split-string OMIT-NULLS argument.
Eli Zaretskii <eliz@gnu.org>
parents: 66272
diff changeset
143 :group 'rcirc)
66248
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
144
72468
5e47ca87ee3c Rcirc update from Ryan Yeske
Miles Bader <miles@gnu.org>
parents: 71442
diff changeset
145 (defcustom rcirc-show-maximum-output t
5e47ca87ee3c Rcirc update from Ryan Yeske
Miles Bader <miles@gnu.org>
parents: 71442
diff changeset
146 "*If non-nil, scroll buffer to keep the point at the bottom of
72616
1c7de7b9540b (rcirc-keywords): New variable.
Eli Zaretskii <eliz@gnu.org>
parents: 72468
diff changeset
147 the window."
1c7de7b9540b (rcirc-keywords): New variable.
Eli Zaretskii <eliz@gnu.org>
parents: 72468
diff changeset
148 :type 'boolean
1c7de7b9540b (rcirc-keywords): New variable.
Eli Zaretskii <eliz@gnu.org>
parents: 72468
diff changeset
149 :group 'rcirc)
72468
5e47ca87ee3c Rcirc update from Ryan Yeske
Miles Bader <miles@gnu.org>
parents: 71442
diff changeset
150
68731
85be285e3494 (rcirc-startup-channels-alist): Add irc.freenode.net and #emacs as defaults.
Eli Zaretskii <eliz@gnu.org>
parents: 68648
diff changeset
151 (defcustom rcirc-authinfo nil
85be285e3494 (rcirc-startup-channels-alist): Add irc.freenode.net and #emacs as defaults.
Eli Zaretskii <eliz@gnu.org>
parents: 68648
diff changeset
152 "List of authentication passwords.
85be285e3494 (rcirc-startup-channels-alist): Add irc.freenode.net and #emacs as defaults.
Eli Zaretskii <eliz@gnu.org>
parents: 68648
diff changeset
153 Each element of the list is a list with a SERVER-REGEXP string
85be285e3494 (rcirc-startup-channels-alist): Add irc.freenode.net and #emacs as defaults.
Eli Zaretskii <eliz@gnu.org>
parents: 68648
diff changeset
154 and a method symbol followed by method specific arguments.
85be285e3494 (rcirc-startup-channels-alist): Add irc.freenode.net and #emacs as defaults.
Eli Zaretskii <eliz@gnu.org>
parents: 68648
diff changeset
155
85be285e3494 (rcirc-startup-channels-alist): Add irc.freenode.net and #emacs as defaults.
Eli Zaretskii <eliz@gnu.org>
parents: 68648
diff changeset
156 The valid METHOD symbols are `nickserv', `chanserv' and
85be285e3494 (rcirc-startup-channels-alist): Add irc.freenode.net and #emacs as defaults.
Eli Zaretskii <eliz@gnu.org>
parents: 68648
diff changeset
157 `bitlbee'.
66248
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 The required ARGUMENTS for each METHOD symbol are:
68731
85be285e3494 (rcirc-startup-channels-alist): Add irc.freenode.net and #emacs as defaults.
Eli Zaretskii <eliz@gnu.org>
parents: 68648
diff changeset
160 `nickserv': NICK PASSWORD
85be285e3494 (rcirc-startup-channels-alist): Add irc.freenode.net and #emacs as defaults.
Eli Zaretskii <eliz@gnu.org>
parents: 68648
diff changeset
161 `chanserv': NICK CHANNEL PASSWORD
85be285e3494 (rcirc-startup-channels-alist): Add irc.freenode.net and #emacs as defaults.
Eli Zaretskii <eliz@gnu.org>
parents: 68648
diff changeset
162 `bitlbee': NICK PASSWORD
66248
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
163
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
164 Example:
68731
85be285e3494 (rcirc-startup-channels-alist): Add irc.freenode.net and #emacs as defaults.
Eli Zaretskii <eliz@gnu.org>
parents: 68648
diff changeset
165 ((\"freenode\" nickserv \"bob\" \"p455w0rd\")
85be285e3494 (rcirc-startup-channels-alist): Add irc.freenode.net and #emacs as defaults.
Eli Zaretskii <eliz@gnu.org>
parents: 68648
diff changeset
166 (\"freenode\" chanserv \"bob\" \"#bobland\" \"passwd99\")
85be285e3494 (rcirc-startup-channels-alist): Add irc.freenode.net and #emacs as defaults.
Eli Zaretskii <eliz@gnu.org>
parents: 68648
diff changeset
167 (\"bitlbee\" bitlbee \"robert\" \"sekrit\"))"
85be285e3494 (rcirc-startup-channels-alist): Add irc.freenode.net and #emacs as defaults.
Eli Zaretskii <eliz@gnu.org>
parents: 68648
diff changeset
168 :type '(alist :key-type (string :tag "Server")
85be285e3494 (rcirc-startup-channels-alist): Add irc.freenode.net and #emacs as defaults.
Eli Zaretskii <eliz@gnu.org>
parents: 68648
diff changeset
169 :value-type (choice (list :tag "NickServ"
85be285e3494 (rcirc-startup-channels-alist): Add irc.freenode.net and #emacs as defaults.
Eli Zaretskii <eliz@gnu.org>
parents: 68648
diff changeset
170 (const nickserv)
85be285e3494 (rcirc-startup-channels-alist): Add irc.freenode.net and #emacs as defaults.
Eli Zaretskii <eliz@gnu.org>
parents: 68648
diff changeset
171 (string :tag "Nick")
85be285e3494 (rcirc-startup-channels-alist): Add irc.freenode.net and #emacs as defaults.
Eli Zaretskii <eliz@gnu.org>
parents: 68648
diff changeset
172 (string :tag "Password"))
85be285e3494 (rcirc-startup-channels-alist): Add irc.freenode.net and #emacs as defaults.
Eli Zaretskii <eliz@gnu.org>
parents: 68648
diff changeset
173 (list :tag "ChanServ"
85be285e3494 (rcirc-startup-channels-alist): Add irc.freenode.net and #emacs as defaults.
Eli Zaretskii <eliz@gnu.org>
parents: 68648
diff changeset
174 (const chanserv)
85be285e3494 (rcirc-startup-channels-alist): Add irc.freenode.net and #emacs as defaults.
Eli Zaretskii <eliz@gnu.org>
parents: 68648
diff changeset
175 (string :tag "Nick")
85be285e3494 (rcirc-startup-channels-alist): Add irc.freenode.net and #emacs as defaults.
Eli Zaretskii <eliz@gnu.org>
parents: 68648
diff changeset
176 (string :tag "Channel")
85be285e3494 (rcirc-startup-channels-alist): Add irc.freenode.net and #emacs as defaults.
Eli Zaretskii <eliz@gnu.org>
parents: 68648
diff changeset
177 (string :tag "Password"))
85be285e3494 (rcirc-startup-channels-alist): Add irc.freenode.net and #emacs as defaults.
Eli Zaretskii <eliz@gnu.org>
parents: 68648
diff changeset
178 (list :tag "BitlBee"
85be285e3494 (rcirc-startup-channels-alist): Add irc.freenode.net and #emacs as defaults.
Eli Zaretskii <eliz@gnu.org>
parents: 68648
diff changeset
179 (const bitlbee)
85be285e3494 (rcirc-startup-channels-alist): Add irc.freenode.net and #emacs as defaults.
Eli Zaretskii <eliz@gnu.org>
parents: 68648
diff changeset
180 (string :tag "Nick")
85be285e3494 (rcirc-startup-channels-alist): Add irc.freenode.net and #emacs as defaults.
Eli Zaretskii <eliz@gnu.org>
parents: 68648
diff changeset
181 (string :tag "Password"))))
66703
6cfb275aa300 Use split-string OMIT-NULLS argument.
Eli Zaretskii <eliz@gnu.org>
parents: 66272
diff changeset
182 :group 'rcirc)
66248
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
183
68731
85be285e3494 (rcirc-startup-channels-alist): Add irc.freenode.net and #emacs as defaults.
Eli Zaretskii <eliz@gnu.org>
parents: 68648
diff changeset
184 (defcustom rcirc-auto-authenticate-flag t
66703
6cfb275aa300 Use split-string OMIT-NULLS argument.
Eli Zaretskii <eliz@gnu.org>
parents: 66272
diff changeset
185 "*Non-nil means automatically send authentication string to server.
68731
85be285e3494 (rcirc-startup-channels-alist): Add irc.freenode.net and #emacs as defaults.
Eli Zaretskii <eliz@gnu.org>
parents: 68648
diff changeset
186 See also `rcirc-authinfo'."
66703
6cfb275aa300 Use split-string OMIT-NULLS argument.
Eli Zaretskii <eliz@gnu.org>
parents: 66272
diff changeset
187 :type 'boolean
6cfb275aa300 Use split-string OMIT-NULLS argument.
Eli Zaretskii <eliz@gnu.org>
parents: 66272
diff changeset
188 :group 'rcirc)
66248
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
189
66703
6cfb275aa300 Use split-string OMIT-NULLS argument.
Eli Zaretskii <eliz@gnu.org>
parents: 66272
diff changeset
190 (defcustom rcirc-prompt "> "
68563
979fba30166f (rcirc-debug): Fix docstring.
Juanma Barranquero <lekktu@gmail.com>
parents: 68079
diff changeset
191 "Prompt string to use in IRC buffers.
66248
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
192
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
193 The following replacements are made:
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
194 %n is your nick.
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
195 %s is the server.
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
196 %t is the buffer target, a channel or a user.
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
197
66703
6cfb275aa300 Use split-string OMIT-NULLS argument.
Eli Zaretskii <eliz@gnu.org>
parents: 66272
diff changeset
198 Setting this alone will not affect the prompt;
6cfb275aa300 Use split-string OMIT-NULLS argument.
Eli Zaretskii <eliz@gnu.org>
parents: 66272
diff changeset
199 use either M-x customize or also call `rcirc-update-prompt'."
6cfb275aa300 Use split-string OMIT-NULLS argument.
Eli Zaretskii <eliz@gnu.org>
parents: 66272
diff changeset
200 :type 'string
6cfb275aa300 Use split-string OMIT-NULLS argument.
Eli Zaretskii <eliz@gnu.org>
parents: 66272
diff changeset
201 :set 'rcirc-set-changed
6cfb275aa300 Use split-string OMIT-NULLS argument.
Eli Zaretskii <eliz@gnu.org>
parents: 66272
diff changeset
202 :initialize 'custom-initialize-default
6cfb275aa300 Use split-string OMIT-NULLS argument.
Eli Zaretskii <eliz@gnu.org>
parents: 66272
diff changeset
203 :group 'rcirc)
6cfb275aa300 Use split-string OMIT-NULLS argument.
Eli Zaretskii <eliz@gnu.org>
parents: 66272
diff changeset
204
72616
1c7de7b9540b (rcirc-keywords): New variable.
Eli Zaretskii <eliz@gnu.org>
parents: 72468
diff changeset
205 (defcustom rcirc-keywords nil
1c7de7b9540b (rcirc-keywords): New variable.
Eli Zaretskii <eliz@gnu.org>
parents: 72468
diff changeset
206 "List of keywords to highlight in message text."
1c7de7b9540b (rcirc-keywords): New variable.
Eli Zaretskii <eliz@gnu.org>
parents: 72468
diff changeset
207 :type '(repeat string)
1c7de7b9540b (rcirc-keywords): New variable.
Eli Zaretskii <eliz@gnu.org>
parents: 72468
diff changeset
208 :group 'rcirc)
1c7de7b9540b (rcirc-keywords): New variable.
Eli Zaretskii <eliz@gnu.org>
parents: 72468
diff changeset
209
68079
61e9ea461d3c (rcirc-ignore-list): New option.
Alex Schroeder <alex@gnu.org>
parents: 68077
diff changeset
210 (defcustom rcirc-ignore-list ()
61e9ea461d3c (rcirc-ignore-list): New option.
Alex Schroeder <alex@gnu.org>
parents: 68077
diff changeset
211 "List of ignored nicks.
61e9ea461d3c (rcirc-ignore-list): New option.
Alex Schroeder <alex@gnu.org>
parents: 68077
diff changeset
212 Use /ignore to list them, use /ignore NICK to add or remove a nick."
61e9ea461d3c (rcirc-ignore-list): New option.
Alex Schroeder <alex@gnu.org>
parents: 68077
diff changeset
213 :type '(repeat string)
61e9ea461d3c (rcirc-ignore-list): New option.
Alex Schroeder <alex@gnu.org>
parents: 68077
diff changeset
214 :group 'rcirc)
61e9ea461d3c (rcirc-ignore-list): New option.
Alex Schroeder <alex@gnu.org>
parents: 68077
diff changeset
215
61e9ea461d3c (rcirc-ignore-list): New option.
Alex Schroeder <alex@gnu.org>
parents: 68077
diff changeset
216 (defvar rcirc-ignore-list-automatic ()
61e9ea461d3c (rcirc-ignore-list): New option.
Alex Schroeder <alex@gnu.org>
parents: 68077
diff changeset
217 "List of ignored nicks added to `rcirc-ignore-list' because of renaming.
61e9ea461d3c (rcirc-ignore-list): New option.
Alex Schroeder <alex@gnu.org>
parents: 68077
diff changeset
218 When an ignored person renames, their nick is added to both lists.
61e9ea461d3c (rcirc-ignore-list): New option.
Alex Schroeder <alex@gnu.org>
parents: 68077
diff changeset
219 Nicks will be removed from the automatic list on follow-up renamings or
61e9ea461d3c (rcirc-ignore-list): New option.
Alex Schroeder <alex@gnu.org>
parents: 68077
diff changeset
220 parts.")
61e9ea461d3c (rcirc-ignore-list): New option.
Alex Schroeder <alex@gnu.org>
parents: 68077
diff changeset
221
72616
1c7de7b9540b (rcirc-keywords): New variable.
Eli Zaretskii <eliz@gnu.org>
parents: 72468
diff changeset
222 (defcustom rcirc-bright-nicks nil
1c7de7b9540b (rcirc-keywords): New variable.
Eli Zaretskii <eliz@gnu.org>
parents: 72468
diff changeset
223 "List of nicks to be emphasized.
70215
90d76f24753a Revision: emacs@sv.gnu.org/emacs--devo--0--patch-247
Miles Bader <miles@gnu.org>
parents: 69860
diff changeset
224 See `rcirc-bright-nick' face."
72616
1c7de7b9540b (rcirc-keywords): New variable.
Eli Zaretskii <eliz@gnu.org>
parents: 72468
diff changeset
225 :type '(repeat string)
70215
90d76f24753a Revision: emacs@sv.gnu.org/emacs--devo--0--patch-247
Miles Bader <miles@gnu.org>
parents: 69860
diff changeset
226 :group 'rcirc)
90d76f24753a Revision: emacs@sv.gnu.org/emacs--devo--0--patch-247
Miles Bader <miles@gnu.org>
parents: 69860
diff changeset
227
72616
1c7de7b9540b (rcirc-keywords): New variable.
Eli Zaretskii <eliz@gnu.org>
parents: 72468
diff changeset
228 (defcustom rcirc-dim-nicks nil
1c7de7b9540b (rcirc-keywords): New variable.
Eli Zaretskii <eliz@gnu.org>
parents: 72468
diff changeset
229 "List of nicks to be deemphasized.
70215
90d76f24753a Revision: emacs@sv.gnu.org/emacs--devo--0--patch-247
Miles Bader <miles@gnu.org>
parents: 69860
diff changeset
230 See `rcirc-dim-nick' face."
72616
1c7de7b9540b (rcirc-keywords): New variable.
Eli Zaretskii <eliz@gnu.org>
parents: 72468
diff changeset
231 :type '(repeat string)
70215
90d76f24753a Revision: emacs@sv.gnu.org/emacs--devo--0--patch-247
Miles Bader <miles@gnu.org>
parents: 69860
diff changeset
232 :group 'rcirc)
90d76f24753a Revision: emacs@sv.gnu.org/emacs--devo--0--patch-247
Miles Bader <miles@gnu.org>
parents: 69860
diff changeset
233
66703
6cfb275aa300 Use split-string OMIT-NULLS argument.
Eli Zaretskii <eliz@gnu.org>
parents: 66272
diff changeset
234 (defcustom rcirc-print-hooks nil
6cfb275aa300 Use split-string OMIT-NULLS argument.
Eli Zaretskii <eliz@gnu.org>
parents: 66272
diff changeset
235 "Hook run after text is printed.
6cfb275aa300 Use split-string OMIT-NULLS argument.
Eli Zaretskii <eliz@gnu.org>
parents: 66272
diff changeset
236 Called with 5 arguments, PROCESS, SENDER, RESPONSE, TARGET and TEXT."
6cfb275aa300 Use split-string OMIT-NULLS argument.
Eli Zaretskii <eliz@gnu.org>
parents: 66272
diff changeset
237 :type 'hook
6cfb275aa300 Use split-string OMIT-NULLS argument.
Eli Zaretskii <eliz@gnu.org>
parents: 66272
diff changeset
238 :group 'rcirc)
66248
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
239
68731
85be285e3494 (rcirc-startup-channels-alist): Add irc.freenode.net and #emacs as defaults.
Eli Zaretskii <eliz@gnu.org>
parents: 68648
diff changeset
240 (defcustom rcirc-always-use-server-buffer-flag nil
85be285e3494 (rcirc-startup-channels-alist): Add irc.freenode.net and #emacs as defaults.
Eli Zaretskii <eliz@gnu.org>
parents: 68648
diff changeset
241 "Non-nil means messages without a channel target will go to the server buffer."
85be285e3494 (rcirc-startup-channels-alist): Add irc.freenode.net and #emacs as defaults.
Eli Zaretskii <eliz@gnu.org>
parents: 68648
diff changeset
242 :type 'boolean
85be285e3494 (rcirc-startup-channels-alist): Add irc.freenode.net and #emacs as defaults.
Eli Zaretskii <eliz@gnu.org>
parents: 68648
diff changeset
243 :group 'rcirc)
85be285e3494 (rcirc-startup-channels-alist): Add irc.freenode.net and #emacs as defaults.
Eli Zaretskii <eliz@gnu.org>
parents: 68648
diff changeset
244
70215
90d76f24753a Revision: emacs@sv.gnu.org/emacs--devo--0--patch-247
Miles Bader <miles@gnu.org>
parents: 69860
diff changeset
245 (defcustom rcirc-decode-coding-system 'utf-8
69860
000a5d4aa083 (rcirc-default-server): Rename from rcirc-server.
Eli Zaretskii <eliz@gnu.org>
parents: 69694
diff changeset
246 "Coding system used to decode incoming irc messages."
000a5d4aa083 (rcirc-default-server): Rename from rcirc-server.
Eli Zaretskii <eliz@gnu.org>
parents: 69694
diff changeset
247 :type 'coding-system
000a5d4aa083 (rcirc-default-server): Rename from rcirc-server.
Eli Zaretskii <eliz@gnu.org>
parents: 69694
diff changeset
248 :group 'rcirc)
000a5d4aa083 (rcirc-default-server): Rename from rcirc-server.
Eli Zaretskii <eliz@gnu.org>
parents: 69694
diff changeset
249
000a5d4aa083 (rcirc-default-server): Rename from rcirc-server.
Eli Zaretskii <eliz@gnu.org>
parents: 69694
diff changeset
250 (defcustom rcirc-encode-coding-system 'utf-8
000a5d4aa083 (rcirc-default-server): Rename from rcirc-server.
Eli Zaretskii <eliz@gnu.org>
parents: 69694
diff changeset
251 "Coding system used to encode outgoing irc messages."
000a5d4aa083 (rcirc-default-server): Rename from rcirc-server.
Eli Zaretskii <eliz@gnu.org>
parents: 69694
diff changeset
252 :type 'coding-system
000a5d4aa083 (rcirc-default-server): Rename from rcirc-server.
Eli Zaretskii <eliz@gnu.org>
parents: 69694
diff changeset
253 :group 'rcirc)
000a5d4aa083 (rcirc-default-server): Rename from rcirc-server.
Eli Zaretskii <eliz@gnu.org>
parents: 69694
diff changeset
254
000a5d4aa083 (rcirc-default-server): Rename from rcirc-server.
Eli Zaretskii <eliz@gnu.org>
parents: 69694
diff changeset
255 (defcustom rcirc-coding-system-alist nil
72616
1c7de7b9540b (rcirc-keywords): New variable.
Eli Zaretskii <eliz@gnu.org>
parents: 72468
diff changeset
256 "Alist to decide a coding system to use for a channel I/O operation.
69860
000a5d4aa083 (rcirc-default-server): Rename from rcirc-server.
Eli Zaretskii <eliz@gnu.org>
parents: 69694
diff changeset
257 The format is ((PATTERN . VAL) ...).
000a5d4aa083 (rcirc-default-server): Rename from rcirc-server.
Eli Zaretskii <eliz@gnu.org>
parents: 69694
diff changeset
258 PATTERN is either a string or a cons of strings.
000a5d4aa083 (rcirc-default-server): Rename from rcirc-server.
Eli Zaretskii <eliz@gnu.org>
parents: 69694
diff changeset
259 If PATTERN is a string, it is used to match a target.
000a5d4aa083 (rcirc-default-server): Rename from rcirc-server.
Eli Zaretskii <eliz@gnu.org>
parents: 69694
diff changeset
260 If PATTERN is a cons of strings, the car part is used to match a
000a5d4aa083 (rcirc-default-server): Rename from rcirc-server.
Eli Zaretskii <eliz@gnu.org>
parents: 69694
diff changeset
261 target, and the cdr part is used to match a server.
000a5d4aa083 (rcirc-default-server): Rename from rcirc-server.
Eli Zaretskii <eliz@gnu.org>
parents: 69694
diff changeset
262 VAL is either a coding system or a cons of coding systems.
000a5d4aa083 (rcirc-default-server): Rename from rcirc-server.
Eli Zaretskii <eliz@gnu.org>
parents: 69694
diff changeset
263 If VAL is a coding system, it is used for both decoding and encoding
000a5d4aa083 (rcirc-default-server): Rename from rcirc-server.
Eli Zaretskii <eliz@gnu.org>
parents: 69694
diff changeset
264 messages.
000a5d4aa083 (rcirc-default-server): Rename from rcirc-server.
Eli Zaretskii <eliz@gnu.org>
parents: 69694
diff changeset
265 If VAL is a cons of coding systems, the car part is used for decoding,
000a5d4aa083 (rcirc-default-server): Rename from rcirc-server.
Eli Zaretskii <eliz@gnu.org>
parents: 69694
diff changeset
266 and the cdr part is used for encoding."
000a5d4aa083 (rcirc-default-server): Rename from rcirc-server.
Eli Zaretskii <eliz@gnu.org>
parents: 69694
diff changeset
267 :type '(alist :key-type (choice (string :tag "Channel Regexp")
000a5d4aa083 (rcirc-default-server): Rename from rcirc-server.
Eli Zaretskii <eliz@gnu.org>
parents: 69694
diff changeset
268 (cons (string :tag "Channel Regexp")
000a5d4aa083 (rcirc-default-server): Rename from rcirc-server.
Eli Zaretskii <eliz@gnu.org>
parents: 69694
diff changeset
269 (string :tag "Server Regexp")))
000a5d4aa083 (rcirc-default-server): Rename from rcirc-server.
Eli Zaretskii <eliz@gnu.org>
parents: 69694
diff changeset
270 :value-type (choice coding-system
000a5d4aa083 (rcirc-default-server): Rename from rcirc-server.
Eli Zaretskii <eliz@gnu.org>
parents: 69694
diff changeset
271 (cons (coding-system :tag "Decode")
000a5d4aa083 (rcirc-default-server): Rename from rcirc-server.
Eli Zaretskii <eliz@gnu.org>
parents: 69694
diff changeset
272 (coding-system :tag "Encode"))))
000a5d4aa083 (rcirc-default-server): Rename from rcirc-server.
Eli Zaretskii <eliz@gnu.org>
parents: 69694
diff changeset
273 :group 'rcirc)
000a5d4aa083 (rcirc-default-server): Rename from rcirc-server.
Eli Zaretskii <eliz@gnu.org>
parents: 69694
diff changeset
274
000a5d4aa083 (rcirc-default-server): Rename from rcirc-server.
Eli Zaretskii <eliz@gnu.org>
parents: 69694
diff changeset
275 (defcustom rcirc-multiline-major-mode 'fundamental-mode
000a5d4aa083 (rcirc-default-server): Rename from rcirc-server.
Eli Zaretskii <eliz@gnu.org>
parents: 69694
diff changeset
276 "Major-mode function to use in multiline edit buffers."
000a5d4aa083 (rcirc-default-server): Rename from rcirc-server.
Eli Zaretskii <eliz@gnu.org>
parents: 69694
diff changeset
277 :type 'function
000a5d4aa083 (rcirc-default-server): Rename from rcirc-server.
Eli Zaretskii <eliz@gnu.org>
parents: 69694
diff changeset
278 :group 'rcirc)
000a5d4aa083 (rcirc-default-server): Rename from rcirc-server.
Eli Zaretskii <eliz@gnu.org>
parents: 69694
diff changeset
279
000a5d4aa083 (rcirc-default-server): Rename from rcirc-server.
Eli Zaretskii <eliz@gnu.org>
parents: 69694
diff changeset
280 (defvar rcirc-nick nil)
000a5d4aa083 (rcirc-default-server): Rename from rcirc-server.
Eli Zaretskii <eliz@gnu.org>
parents: 69694
diff changeset
281
66248
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
282 (defvar rcirc-prompt-start-marker nil)
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
283 (defvar rcirc-prompt-end-marker nil)
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
284
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
285 (defvar rcirc-nick-table nil)
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
286
68079
61e9ea461d3c (rcirc-ignore-list): New option.
Alex Schroeder <alex@gnu.org>
parents: 68077
diff changeset
287 (defvar rcirc-nick-syntax-table
61e9ea461d3c (rcirc-ignore-list): New option.
Alex Schroeder <alex@gnu.org>
parents: 68077
diff changeset
288 (let ((table (make-syntax-table text-mode-syntax-table)))
61e9ea461d3c (rcirc-ignore-list): New option.
Alex Schroeder <alex@gnu.org>
parents: 68077
diff changeset
289 (mapc (lambda (c) (modify-syntax-entry c "w" table))
61e9ea461d3c (rcirc-ignore-list): New option.
Alex Schroeder <alex@gnu.org>
parents: 68077
diff changeset
290 "[]\\`_^{|}-")
61e9ea461d3c (rcirc-ignore-list): New option.
Alex Schroeder <alex@gnu.org>
parents: 68077
diff changeset
291 (modify-syntax-entry ?' "_" table)
61e9ea461d3c (rcirc-ignore-list): New option.
Alex Schroeder <alex@gnu.org>
parents: 68077
diff changeset
292 table)
61e9ea461d3c (rcirc-ignore-list): New option.
Alex Schroeder <alex@gnu.org>
parents: 68077
diff changeset
293 "Syntax table which includes all nick characters as word constituents.")
61e9ea461d3c (rcirc-ignore-list): New option.
Alex Schroeder <alex@gnu.org>
parents: 68077
diff changeset
294
66703
6cfb275aa300 Use split-string OMIT-NULLS argument.
Eli Zaretskii <eliz@gnu.org>
parents: 66272
diff changeset
295 ;; each process has an alist of (target . buffer) pairs
6cfb275aa300 Use split-string OMIT-NULLS argument.
Eli Zaretskii <eliz@gnu.org>
parents: 66272
diff changeset
296 (defvar rcirc-buffer-alist nil)
6cfb275aa300 Use split-string OMIT-NULLS argument.
Eli Zaretskii <eliz@gnu.org>
parents: 66272
diff changeset
297
66248
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
298 (defvar rcirc-activity nil
69860
000a5d4aa083 (rcirc-default-server): Rename from rcirc-server.
Eli Zaretskii <eliz@gnu.org>
parents: 69694
diff changeset
299 "List of buffers with unviewed activity.")
66248
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-activity-string ""
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
302 "String displayed in modeline representing `rcirc-activity'.")
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
303 (put 'rcirc-activity-string 'risky-local-variable t)
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
304
69860
000a5d4aa083 (rcirc-default-server): Rename from rcirc-server.
Eli Zaretskii <eliz@gnu.org>
parents: 69694
diff changeset
305 (defvar rcirc-server-buffer nil
000a5d4aa083 (rcirc-default-server): Rename from rcirc-server.
Eli Zaretskii <eliz@gnu.org>
parents: 69694
diff changeset
306 "The server buffer associated with this channel buffer.")
66248
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
307
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
308 (defvar rcirc-target nil
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
309 "The channel or user associated with this buffer.")
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
310
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
311 (defvar rcirc-urls nil
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
312 "List of urls seen in the current buffer.")
72468
5e47ca87ee3c Rcirc update from Ryan Yeske
Miles Bader <miles@gnu.org>
parents: 71442
diff changeset
313 (put 'rcirc-urls 'permanent-local t)
66248
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
314
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
315 (defvar rcirc-keepalive-seconds 60
69860
000a5d4aa083 (rcirc-default-server): Rename from rcirc-server.
Eli Zaretskii <eliz@gnu.org>
parents: 69694
diff changeset
316 "Number of seconds between keepalive pings.
000a5d4aa083 (rcirc-default-server): Rename from rcirc-server.
Eli Zaretskii <eliz@gnu.org>
parents: 69694
diff changeset
317 If nil, do not send keepalive pings.")
66248
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
318
66703
6cfb275aa300 Use split-string OMIT-NULLS argument.
Eli Zaretskii <eliz@gnu.org>
parents: 66272
diff changeset
319 (defconst rcirc-id-string (concat "rcirc on GNU Emacs " emacs-version))
66248
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
320
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
321 (defvar rcirc-startup-channels nil)
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
322 ;;;###autoload
68731
85be285e3494 (rcirc-startup-channels-alist): Add irc.freenode.net and #emacs as defaults.
Eli Zaretskii <eliz@gnu.org>
parents: 68648
diff changeset
323 (defun rcirc (arg)
66248
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
324 "Connect to IRC.
68731
85be285e3494 (rcirc-startup-channels-alist): Add irc.freenode.net and #emacs as defaults.
Eli Zaretskii <eliz@gnu.org>
parents: 68648
diff changeset
325 If ARG is non-nil, prompt for a server to connect to."
85be285e3494 (rcirc-startup-channels-alist): Add irc.freenode.net and #emacs as defaults.
Eli Zaretskii <eliz@gnu.org>
parents: 68648
diff changeset
326 (interactive "P")
85be285e3494 (rcirc-startup-channels-alist): Add irc.freenode.net and #emacs as defaults.
Eli Zaretskii <eliz@gnu.org>
parents: 68648
diff changeset
327 (if arg
69860
000a5d4aa083 (rcirc-default-server): Rename from rcirc-server.
Eli Zaretskii <eliz@gnu.org>
parents: 69694
diff changeset
328 (let* ((server (read-string "IRC Server: " rcirc-default-server))
000a5d4aa083 (rcirc-default-server): Rename from rcirc-server.
Eli Zaretskii <eliz@gnu.org>
parents: 69694
diff changeset
329 (port (read-string "IRC Port: " (number-to-string rcirc-default-port)))
000a5d4aa083 (rcirc-default-server): Rename from rcirc-server.
Eli Zaretskii <eliz@gnu.org>
parents: 69694
diff changeset
330 (nick (read-string "IRC Nick: " rcirc-default-nick))
68731
85be285e3494 (rcirc-startup-channels-alist): Add irc.freenode.net and #emacs as defaults.
Eli Zaretskii <eliz@gnu.org>
parents: 68648
diff changeset
331 (channels (split-string
85be285e3494 (rcirc-startup-channels-alist): Add irc.freenode.net and #emacs as defaults.
Eli Zaretskii <eliz@gnu.org>
parents: 68648
diff changeset
332 (read-string "IRC Channels: "
69860
000a5d4aa083 (rcirc-default-server): Rename from rcirc-server.
Eli Zaretskii <eliz@gnu.org>
parents: 69694
diff changeset
333 (mapconcat 'identity (rcirc-startup-channels server) " "))
68731
85be285e3494 (rcirc-startup-channels-alist): Add irc.freenode.net and #emacs as defaults.
Eli Zaretskii <eliz@gnu.org>
parents: 68648
diff changeset
334 "[, ]+" t)))
69860
000a5d4aa083 (rcirc-default-server): Rename from rcirc-server.
Eli Zaretskii <eliz@gnu.org>
parents: 69694
diff changeset
335 (rcirc-connect server port nick rcirc-default-user-name rcirc-default-user-full-name
68731
85be285e3494 (rcirc-startup-channels-alist): Add irc.freenode.net and #emacs as defaults.
Eli Zaretskii <eliz@gnu.org>
parents: 68648
diff changeset
336 channels))
85be285e3494 (rcirc-startup-channels-alist): Add irc.freenode.net and #emacs as defaults.
Eli Zaretskii <eliz@gnu.org>
parents: 68648
diff changeset
337 ;; make new connection using defaults unless already connected to
85be285e3494 (rcirc-startup-channels-alist): Add irc.freenode.net and #emacs as defaults.
Eli Zaretskii <eliz@gnu.org>
parents: 68648
diff changeset
338 ;; the default rcirc-server
69860
000a5d4aa083 (rcirc-default-server): Rename from rcirc-server.
Eli Zaretskii <eliz@gnu.org>
parents: 69694
diff changeset
339 (let (connected)
68731
85be285e3494 (rcirc-startup-channels-alist): Add irc.freenode.net and #emacs as defaults.
Eli Zaretskii <eliz@gnu.org>
parents: 68648
diff changeset
340 (dolist (p (rcirc-process-list))
69860
000a5d4aa083 (rcirc-default-server): Rename from rcirc-server.
Eli Zaretskii <eliz@gnu.org>
parents: 69694
diff changeset
341 (when (string= rcirc-default-server (process-name p))
68731
85be285e3494 (rcirc-startup-channels-alist): Add irc.freenode.net and #emacs as defaults.
Eli Zaretskii <eliz@gnu.org>
parents: 68648
diff changeset
342 (setq connected p)))
85be285e3494 (rcirc-startup-channels-alist): Add irc.freenode.net and #emacs as defaults.
Eli Zaretskii <eliz@gnu.org>
parents: 68648
diff changeset
343 (if (not connected)
69860
000a5d4aa083 (rcirc-default-server): Rename from rcirc-server.
Eli Zaretskii <eliz@gnu.org>
parents: 69694
diff changeset
344 (rcirc-connect rcirc-default-server rcirc-default-port
000a5d4aa083 (rcirc-default-server): Rename from rcirc-server.
Eli Zaretskii <eliz@gnu.org>
parents: 69694
diff changeset
345 rcirc-default-nick rcirc-default-user-name
000a5d4aa083 (rcirc-default-server): Rename from rcirc-server.
Eli Zaretskii <eliz@gnu.org>
parents: 69694
diff changeset
346 rcirc-default-user-full-name
000a5d4aa083 (rcirc-default-server): Rename from rcirc-server.
Eli Zaretskii <eliz@gnu.org>
parents: 69694
diff changeset
347 (rcirc-startup-channels rcirc-default-server))
68731
85be285e3494 (rcirc-startup-channels-alist): Add irc.freenode.net and #emacs as defaults.
Eli Zaretskii <eliz@gnu.org>
parents: 68648
diff changeset
348 (switch-to-buffer (process-buffer connected))
69860
000a5d4aa083 (rcirc-default-server): Rename from rcirc-server.
Eli Zaretskii <eliz@gnu.org>
parents: 69694
diff changeset
349 (message "Connected to %s"
000a5d4aa083 (rcirc-default-server): Rename from rcirc-server.
Eli Zaretskii <eliz@gnu.org>
parents: 69694
diff changeset
350 (process-contact (get-buffer-process (current-buffer))
000a5d4aa083 (rcirc-default-server): Rename from rcirc-server.
Eli Zaretskii <eliz@gnu.org>
parents: 69694
diff changeset
351 :host))))))
66248
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
352 ;;;###autoload
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
353 (defalias 'irc 'rcirc)
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
354
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
355
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
356 (defvar rcirc-process-output nil)
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
357 (defvar rcirc-topic nil)
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
358 (defvar rcirc-keepalive-timer nil)
67014
d3d8e2bcfa98 (rcirc-mangle-text): Add bold face property without replacing existing
Eli Zaretskii <eliz@gnu.org>
parents: 66703
diff changeset
359 (defvar rcirc-last-server-message-time nil)
69860
000a5d4aa083 (rcirc-default-server): Rename from rcirc-server.
Eli Zaretskii <eliz@gnu.org>
parents: 69694
diff changeset
360 (defvar rcirc-server nil)
69694
f712cf2b3ceb (rcirc-connect): Add autoload cookie.
Romain Francoise <romain@orebokech.com>
parents: 69461
diff changeset
361
f712cf2b3ceb (rcirc-connect): Add autoload cookie.
Romain Francoise <romain@orebokech.com>
parents: 69461
diff changeset
362 ;;;###autoload
68960
6e3160901812 (rcirc-connect): Make all arguments optional, and default to global variable
Eli Zaretskii <eliz@gnu.org>
parents: 68838
diff changeset
363 (defun rcirc-connect (&optional server port nick user-name full-name startup-channels)
66248
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
364 (save-excursion
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
365 (message "Connecting to %s..." server)
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
366 (let* ((inhibit-eol-conversion)
68960
6e3160901812 (rcirc-connect): Make all arguments optional, and default to global variable
Eli Zaretskii <eliz@gnu.org>
parents: 68838
diff changeset
367 (port-number (if port
6e3160901812 (rcirc-connect): Make all arguments optional, and default to global variable
Eli Zaretskii <eliz@gnu.org>
parents: 68838
diff changeset
368 (if (stringp port)
6e3160901812 (rcirc-connect): Make all arguments optional, and default to global variable
Eli Zaretskii <eliz@gnu.org>
parents: 68838
diff changeset
369 (string-to-number port)
6e3160901812 (rcirc-connect): Make all arguments optional, and default to global variable
Eli Zaretskii <eliz@gnu.org>
parents: 68838
diff changeset
370 port)
69860
000a5d4aa083 (rcirc-default-server): Rename from rcirc-server.
Eli Zaretskii <eliz@gnu.org>
parents: 69694
diff changeset
371 rcirc-default-port))
000a5d4aa083 (rcirc-default-server): Rename from rcirc-server.
Eli Zaretskii <eliz@gnu.org>
parents: 69694
diff changeset
372 (server (or server rcirc-default-server))
000a5d4aa083 (rcirc-default-server): Rename from rcirc-server.
Eli Zaretskii <eliz@gnu.org>
parents: 69694
diff changeset
373 (nick (or nick rcirc-default-nick))
000a5d4aa083 (rcirc-default-server): Rename from rcirc-server.
Eli Zaretskii <eliz@gnu.org>
parents: 69694
diff changeset
374 (user-name (or user-name rcirc-default-user-name))
000a5d4aa083 (rcirc-default-server): Rename from rcirc-server.
Eli Zaretskii <eliz@gnu.org>
parents: 69694
diff changeset
375 (full-name (or full-name rcirc-default-user-full-name))
000a5d4aa083 (rcirc-default-server): Rename from rcirc-server.
Eli Zaretskii <eliz@gnu.org>
parents: 69694
diff changeset
376 (startup-channels startup-channels)
66248
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
377 (process (open-network-stream server nil server port-number)))
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
378 ;; set up process
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
379 (set-process-coding-system process 'raw-text 'raw-text)
66703
6cfb275aa300 Use split-string OMIT-NULLS argument.
Eli Zaretskii <eliz@gnu.org>
parents: 66272
diff changeset
380 (switch-to-buffer (rcirc-generate-new-buffer-name process nil))
66248
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
381 (set-process-buffer process (current-buffer))
69860
000a5d4aa083 (rcirc-default-server): Rename from rcirc-server.
Eli Zaretskii <eliz@gnu.org>
parents: 69694
diff changeset
382 (rcirc-mode process nil)
66248
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
383 (set-process-sentinel process 'rcirc-sentinel)
69860
000a5d4aa083 (rcirc-default-server): Rename from rcirc-server.
Eli Zaretskii <eliz@gnu.org>
parents: 69694
diff changeset
384 (set-process-filter process 'rcirc-filter)
000a5d4aa083 (rcirc-default-server): Rename from rcirc-server.
Eli Zaretskii <eliz@gnu.org>
parents: 69694
diff changeset
385 (make-local-variable 'rcirc-server)
000a5d4aa083 (rcirc-default-server): Rename from rcirc-server.
Eli Zaretskii <eliz@gnu.org>
parents: 69694
diff changeset
386 (setq rcirc-server server)
66703
6cfb275aa300 Use split-string OMIT-NULLS argument.
Eli Zaretskii <eliz@gnu.org>
parents: 66272
diff changeset
387 (make-local-variable 'rcirc-buffer-alist)
6cfb275aa300 Use split-string OMIT-NULLS argument.
Eli Zaretskii <eliz@gnu.org>
parents: 66272
diff changeset
388 (setq rcirc-buffer-alist nil)
66248
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
389 (make-local-variable 'rcirc-nick-table)
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
390 (setq rcirc-nick-table (make-hash-table :test 'equal))
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
391 (make-local-variable 'rcirc-nick)
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
392 (setq rcirc-nick nick)
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
393 (make-local-variable 'rcirc-process-output)
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
394 (setq rcirc-process-output nil)
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
395 (make-local-variable 'rcirc-startup-channels)
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
396 (setq rcirc-startup-channels startup-channels)
67014
d3d8e2bcfa98 (rcirc-mangle-text): Add bold face property without replacing existing
Eli Zaretskii <eliz@gnu.org>
parents: 66703
diff changeset
397 (make-local-variable 'rcirc-last-server-message-time)
d3d8e2bcfa98 (rcirc-mangle-text): Add bold face property without replacing existing
Eli Zaretskii <eliz@gnu.org>
parents: 66703
diff changeset
398 (setq rcirc-last-server-message-time (current-time))
66248
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
399
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
400 ;; identify
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
401 (rcirc-send-string process (concat "NICK " nick))
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
402 (rcirc-send-string process (concat "USER " user-name
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
403 " hostname servername :"
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
404 full-name))
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
405
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
406 ;; setup ping timer if necessary
69860
000a5d4aa083 (rcirc-default-server): Rename from rcirc-server.
Eli Zaretskii <eliz@gnu.org>
parents: 69694
diff changeset
407 (when rcirc-keepalive-seconds
000a5d4aa083 (rcirc-default-server): Rename from rcirc-server.
Eli Zaretskii <eliz@gnu.org>
parents: 69694
diff changeset
408 (unless rcirc-keepalive-timer
000a5d4aa083 (rcirc-default-server): Rename from rcirc-server.
Eli Zaretskii <eliz@gnu.org>
parents: 69694
diff changeset
409 (setq rcirc-keepalive-timer
000a5d4aa083 (rcirc-default-server): Rename from rcirc-server.
Eli Zaretskii <eliz@gnu.org>
parents: 69694
diff changeset
410 (run-at-time 0 rcirc-keepalive-seconds 'rcirc-keepalive))))
66248
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
411
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
412 (message "Connecting to %s...done" server)
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
413
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
414 ;; return process object
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
415 process)))
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
416
66703
6cfb275aa300 Use split-string OMIT-NULLS argument.
Eli Zaretskii <eliz@gnu.org>
parents: 66272
diff changeset
417 (defmacro with-rcirc-process-buffer (process &rest body)
6cfb275aa300 Use split-string OMIT-NULLS argument.
Eli Zaretskii <eliz@gnu.org>
parents: 66272
diff changeset
418 (declare (indent 1) (debug t))
6cfb275aa300 Use split-string OMIT-NULLS argument.
Eli Zaretskii <eliz@gnu.org>
parents: 66272
diff changeset
419 `(with-current-buffer (process-buffer ,process)
6cfb275aa300 Use split-string OMIT-NULLS argument.
Eli Zaretskii <eliz@gnu.org>
parents: 66272
diff changeset
420 ,@body))
6cfb275aa300 Use split-string OMIT-NULLS argument.
Eli Zaretskii <eliz@gnu.org>
parents: 66272
diff changeset
421
69860
000a5d4aa083 (rcirc-default-server): Rename from rcirc-server.
Eli Zaretskii <eliz@gnu.org>
parents: 69694
diff changeset
422 (defmacro with-rcirc-server-buffer (&rest body)
000a5d4aa083 (rcirc-default-server): Rename from rcirc-server.
Eli Zaretskii <eliz@gnu.org>
parents: 69694
diff changeset
423 (declare (indent 0) (debug t))
000a5d4aa083 (rcirc-default-server): Rename from rcirc-server.
Eli Zaretskii <eliz@gnu.org>
parents: 69694
diff changeset
424 `(with-current-buffer rcirc-server-buffer
000a5d4aa083 (rcirc-default-server): Rename from rcirc-server.
Eli Zaretskii <eliz@gnu.org>
parents: 69694
diff changeset
425 ,@body))
000a5d4aa083 (rcirc-default-server): Rename from rcirc-server.
Eli Zaretskii <eliz@gnu.org>
parents: 69694
diff changeset
426
66248
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
427 (defun rcirc-keepalive ()
67014
d3d8e2bcfa98 (rcirc-mangle-text): Add bold face property without replacing existing
Eli Zaretskii <eliz@gnu.org>
parents: 66703
diff changeset
428 "Send keep alive pings to active rcirc processes.
d3d8e2bcfa98 (rcirc-mangle-text): Add bold face property without replacing existing
Eli Zaretskii <eliz@gnu.org>
parents: 66703
diff changeset
429 Kill processes that have not received a server message since the
d3d8e2bcfa98 (rcirc-mangle-text): Add bold face property without replacing existing
Eli Zaretskii <eliz@gnu.org>
parents: 66703
diff changeset
430 last ping."
66248
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
431 (if (rcirc-process-list)
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
432 (mapc (lambda (process)
66703
6cfb275aa300 Use split-string OMIT-NULLS argument.
Eli Zaretskii <eliz@gnu.org>
parents: 66272
diff changeset
433 (with-rcirc-process-buffer process
67014
d3d8e2bcfa98 (rcirc-mangle-text): Add bold face property without replacing existing
Eli Zaretskii <eliz@gnu.org>
parents: 66703
diff changeset
434 (if (> (cadr (time-since rcirc-last-server-message-time))
d3d8e2bcfa98 (rcirc-mangle-text): Add bold face property without replacing existing
Eli Zaretskii <eliz@gnu.org>
parents: 66703
diff changeset
435 rcirc-keepalive-seconds)
d3d8e2bcfa98 (rcirc-mangle-text): Add bold face property without replacing existing
Eli Zaretskii <eliz@gnu.org>
parents: 66703
diff changeset
436 (kill-process process)
d3d8e2bcfa98 (rcirc-mangle-text): Add bold face property without replacing existing
Eli Zaretskii <eliz@gnu.org>
parents: 66703
diff changeset
437 (rcirc-send-string process (concat "PING " rcirc-server)))))
66248
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
438 (rcirc-process-list))
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
439 (cancel-timer rcirc-keepalive-timer)
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
440 (setq rcirc-keepalive-timer nil)))
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
441
66703
6cfb275aa300 Use split-string OMIT-NULLS argument.
Eli Zaretskii <eliz@gnu.org>
parents: 66272
diff changeset
442 (defvar rcirc-debug-buffer " *rcirc debug*")
6cfb275aa300 Use split-string OMIT-NULLS argument.
Eli Zaretskii <eliz@gnu.org>
parents: 66272
diff changeset
443 (defvar rcirc-debug-flag nil
6cfb275aa300 Use split-string OMIT-NULLS argument.
Eli Zaretskii <eliz@gnu.org>
parents: 66272
diff changeset
444 "If non-nil, write information to `rcirc-debug-buffer'.")
6cfb275aa300 Use split-string OMIT-NULLS argument.
Eli Zaretskii <eliz@gnu.org>
parents: 66272
diff changeset
445 (defun rcirc-debug (process text)
66248
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
446 "Add an entry to the debug log including PROCESS and TEXT.
68563
979fba30166f (rcirc-debug): Fix docstring.
Juanma Barranquero <lekktu@gmail.com>
parents: 68079
diff changeset
447 Debug text is written to `rcirc-debug-buffer' if `rcirc-debug-flag'
66703
6cfb275aa300 Use split-string OMIT-NULLS argument.
Eli Zaretskii <eliz@gnu.org>
parents: 66272
diff changeset
448 is non-nil."
6cfb275aa300 Use split-string OMIT-NULLS argument.
Eli Zaretskii <eliz@gnu.org>
parents: 66272
diff changeset
449 (when rcirc-debug-flag
66248
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
450 (save-excursion
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
451 (save-window-excursion
66703
6cfb275aa300 Use split-string OMIT-NULLS argument.
Eli Zaretskii <eliz@gnu.org>
parents: 66272
diff changeset
452 (set-buffer (get-buffer-create rcirc-debug-buffer))
66248
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
453 (goto-char (point-max))
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
454 (insert (concat
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
455 "["
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
456 (format-time-string "%Y-%m-%dT%T ") (process-name process)
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
457 "] "
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
458 text))))))
66703
6cfb275aa300 Use split-string OMIT-NULLS argument.
Eli Zaretskii <eliz@gnu.org>
parents: 66272
diff changeset
459
66248
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
460 (defvar rcirc-sentinel-hooks nil
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
461 "Hook functions called when the process sentinel is called.
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
462 Functions are called with PROCESS and SENTINEL arguments.")
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
463
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
464 (defun rcirc-sentinel (process sentinel)
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
465 "Called when PROCESS receives SENTINEL."
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
466 (let ((sentinel (replace-regexp-in-string "\n" "" sentinel)))
66703
6cfb275aa300 Use split-string OMIT-NULLS argument.
Eli Zaretskii <eliz@gnu.org>
parents: 66272
diff changeset
467 (rcirc-debug process (format "SENTINEL: %S %S\n" process sentinel))
6cfb275aa300 Use split-string OMIT-NULLS argument.
Eli Zaretskii <eliz@gnu.org>
parents: 66272
diff changeset
468 (with-rcirc-process-buffer process
6cfb275aa300 Use split-string OMIT-NULLS argument.
Eli Zaretskii <eliz@gnu.org>
parents: 66272
diff changeset
469 (dolist (buffer (cons nil (mapcar 'cdr rcirc-buffer-alist)))
6cfb275aa300 Use split-string OMIT-NULLS argument.
Eli Zaretskii <eliz@gnu.org>
parents: 66272
diff changeset
470 (with-current-buffer (or buffer (current-buffer))
68731
85be285e3494 (rcirc-startup-channels-alist): Add irc.freenode.net and #emacs as defaults.
Eli Zaretskii <eliz@gnu.org>
parents: 68648
diff changeset
471 (rcirc-print process "rcirc.el" "ERROR" rcirc-target
85be285e3494 (rcirc-startup-channels-alist): Add irc.freenode.net and #emacs as defaults.
Eli Zaretskii <eliz@gnu.org>
parents: 68648
diff changeset
472 (format "%s: %s (%S)"
85be285e3494 (rcirc-startup-channels-alist): Add irc.freenode.net and #emacs as defaults.
Eli Zaretskii <eliz@gnu.org>
parents: 68648
diff changeset
473 (process-name process)
85be285e3494 (rcirc-startup-channels-alist): Add irc.freenode.net and #emacs as defaults.
Eli Zaretskii <eliz@gnu.org>
parents: 68648
diff changeset
474 sentinel
85be285e3494 (rcirc-startup-channels-alist): Add irc.freenode.net and #emacs as defaults.
Eli Zaretskii <eliz@gnu.org>
parents: 68648
diff changeset
475 (process-status process)) t)
85be285e3494 (rcirc-startup-channels-alist): Add irc.freenode.net and #emacs as defaults.
Eli Zaretskii <eliz@gnu.org>
parents: 68648
diff changeset
476 ;; remove the prompt from buffers
66248
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
477 (let ((inhibit-read-only t))
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
478 (delete-region rcirc-prompt-start-marker
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
479 rcirc-prompt-end-marker)))))
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
480 (run-hook-with-args 'rcirc-sentinel-hooks process sentinel)))
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
481
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
482 (defun rcirc-process-list ()
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
483 "Return a list of rcirc processes."
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
484 (let (ps)
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
485 (mapc (lambda (p)
71442
00a28b680b71 (rcirc-default-user-full-name): Default to `rcirc-default-user-name' instead
Eli Zaretskii <eliz@gnu.org>
parents: 71440
diff changeset
486 (when (buffer-live-p (process-buffer p))
66703
6cfb275aa300 Use split-string OMIT-NULLS argument.
Eli Zaretskii <eliz@gnu.org>
parents: 66272
diff changeset
487 (with-rcirc-process-buffer p
66248
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
488 (when (eq major-mode 'rcirc-mode)
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
489 (setq ps (cons p ps))))))
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
490 (process-list))
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
491 ps))
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
492
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
493 (defvar rcirc-receive-message-hooks nil
68563
979fba30166f (rcirc-debug): Fix docstring.
Juanma Barranquero <lekktu@gmail.com>
parents: 68079
diff changeset
494 "Hook functions run when a message is received from server.
979fba30166f (rcirc-debug): Fix docstring.
Juanma Barranquero <lekktu@gmail.com>
parents: 68079
diff changeset
495 Function is called with PROCESS, COMMAND, SENDER, ARGS and LINE.")
66248
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
496 (defun rcirc-filter (process output)
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
497 "Called when PROCESS receives OUTPUT."
66703
6cfb275aa300 Use split-string OMIT-NULLS argument.
Eli Zaretskii <eliz@gnu.org>
parents: 66272
diff changeset
498 (rcirc-debug process output)
6cfb275aa300 Use split-string OMIT-NULLS argument.
Eli Zaretskii <eliz@gnu.org>
parents: 66272
diff changeset
499 (with-rcirc-process-buffer process
67014
d3d8e2bcfa98 (rcirc-mangle-text): Add bold face property without replacing existing
Eli Zaretskii <eliz@gnu.org>
parents: 66703
diff changeset
500 (setq rcirc-last-server-message-time (current-time))
66248
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
501 (setq rcirc-process-output (concat rcirc-process-output output))
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
502 (when (= (aref rcirc-process-output
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
503 (1- (length rcirc-process-output))) ?\n)
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
504 (mapc (lambda (line)
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
505 (rcirc-process-server-response process line))
66703
6cfb275aa300 Use split-string OMIT-NULLS argument.
Eli Zaretskii <eliz@gnu.org>
parents: 66272
diff changeset
506 (split-string rcirc-process-output "[\n\r]" t))
66248
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
507 (setq rcirc-process-output nil))))
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
508
66703
6cfb275aa300 Use split-string OMIT-NULLS argument.
Eli Zaretskii <eliz@gnu.org>
parents: 66272
diff changeset
509 (defvar rcirc-trap-errors-flag t)
66248
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
510 (defun rcirc-process-server-response (process text)
66703
6cfb275aa300 Use split-string OMIT-NULLS argument.
Eli Zaretskii <eliz@gnu.org>
parents: 66272
diff changeset
511 (if rcirc-trap-errors-flag
66248
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
512 (condition-case err
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
513 (rcirc-process-server-response-1 process text)
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
514 (error
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
515 (rcirc-print process "RCIRC" "ERROR" nil
66703
6cfb275aa300 Use split-string OMIT-NULLS argument.
Eli Zaretskii <eliz@gnu.org>
parents: 66272
diff changeset
516 (format "\"%s\" %s" text err) t)))
66248
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
517 (rcirc-process-server-response-1 process text)))
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
518
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
519 (defun rcirc-process-server-response-1 (process text)
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
520 (if (string-match "^\\(:\\([^ ]+\\) \\)?\\([^ ]+\\) \\(.+\\)$" text)
68731
85be285e3494 (rcirc-startup-channels-alist): Add irc.freenode.net and #emacs as defaults.
Eli Zaretskii <eliz@gnu.org>
parents: 68648
diff changeset
521 (let* ((user (match-string 2 text))
85be285e3494 (rcirc-startup-channels-alist): Add irc.freenode.net and #emacs as defaults.
Eli Zaretskii <eliz@gnu.org>
parents: 68648
diff changeset
522 (sender (rcirc-user-nick user))
66248
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
523 (cmd (match-string 3 text))
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
524 (args (match-string 4 text))
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
525 (handler (intern-soft (concat "rcirc-handler-" cmd))))
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
526 (string-match "^\\([^:]*\\):?\\(.+\\)?$" args)
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
527 (let* ((args1 (match-string 1 args))
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
528 (args2 (match-string 2 args))
66703
6cfb275aa300 Use split-string OMIT-NULLS argument.
Eli Zaretskii <eliz@gnu.org>
parents: 66272
diff changeset
529 (args (delq nil (append (split-string args1 " " t)
6cfb275aa300 Use split-string OMIT-NULLS argument.
Eli Zaretskii <eliz@gnu.org>
parents: 66272
diff changeset
530 (list args2)))))
66248
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
531 (if (not (fboundp handler))
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
532 (rcirc-handler-generic process cmd sender args text)
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
533 (funcall handler process sender args text))
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
534 (run-hook-with-args 'rcirc-receive-message-hooks
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
535 process cmd sender args text)))
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
536 (message "UNHANDLED: %s" text)))
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
537
72616
1c7de7b9540b (rcirc-keywords): New variable.
Eli Zaretskii <eliz@gnu.org>
parents: 72468
diff changeset
538 (defvar rcirc-responses-no-activity '("305" "306")
1c7de7b9540b (rcirc-keywords): New variable.
Eli Zaretskii <eliz@gnu.org>
parents: 72468
diff changeset
539 "Responses that don't trigger activity in the mode-line indicator.")
1c7de7b9540b (rcirc-keywords): New variable.
Eli Zaretskii <eliz@gnu.org>
parents: 72468
diff changeset
540
1c7de7b9540b (rcirc-keywords): New variable.
Eli Zaretskii <eliz@gnu.org>
parents: 72468
diff changeset
541 (defun rcirc-handler-generic (process response sender args text)
66248
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
542 "Generic server response handler."
72616
1c7de7b9540b (rcirc-keywords): New variable.
Eli Zaretskii <eliz@gnu.org>
parents: 72468
diff changeset
543 (rcirc-print process sender response nil
1c7de7b9540b (rcirc-keywords): New variable.
Eli Zaretskii <eliz@gnu.org>
parents: 72468
diff changeset
544 (mapconcat 'identity (cdr args) " ")
1c7de7b9540b (rcirc-keywords): New variable.
Eli Zaretskii <eliz@gnu.org>
parents: 72468
diff changeset
545 (not (member response rcirc-responses-no-activity))))
66248
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
546
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
547 (defun rcirc-send-string (process string)
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
548 "Send PROCESS a STRING plus a newline."
69860
000a5d4aa083 (rcirc-default-server): Rename from rcirc-server.
Eli Zaretskii <eliz@gnu.org>
parents: 69694
diff changeset
549 (let ((string (concat (encode-coding-string string rcirc-encode-coding-system)
66248
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
550 "\n")))
69860
000a5d4aa083 (rcirc-default-server): Rename from rcirc-server.
Eli Zaretskii <eliz@gnu.org>
parents: 69694
diff changeset
551 (unless (eq (process-status process) 'open)
68077
7e0fcbf84eb8 (rcirc-send-input): No longer check whether the
Alex Schroeder <alex@gnu.org>
parents: 67014
diff changeset
552 (error "Network connection to %s is not open"
69860
000a5d4aa083 (rcirc-default-server): Rename from rcirc-server.
Eli Zaretskii <eliz@gnu.org>
parents: 69694
diff changeset
553 (process-name process)))
66703
6cfb275aa300 Use split-string OMIT-NULLS argument.
Eli Zaretskii <eliz@gnu.org>
parents: 66272
diff changeset
554 (rcirc-debug process string)
66248
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
555 (process-send-string process string)))
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
556
69860
000a5d4aa083 (rcirc-default-server): Rename from rcirc-server.
Eli Zaretskii <eliz@gnu.org>
parents: 69694
diff changeset
557 (defun rcirc-buffer-process (&optional buffer)
000a5d4aa083 (rcirc-default-server): Rename from rcirc-server.
Eli Zaretskii <eliz@gnu.org>
parents: 69694
diff changeset
558 "Return the process associated with channel BUFFER.
000a5d4aa083 (rcirc-default-server): Rename from rcirc-server.
Eli Zaretskii <eliz@gnu.org>
parents: 69694
diff changeset
559 With no argument or nil as argument, use the current buffer."
72468
5e47ca87ee3c Rcirc update from Ryan Yeske
Miles Bader <miles@gnu.org>
parents: 71442
diff changeset
560 (get-buffer-process (if buffer
5e47ca87ee3c Rcirc update from Ryan Yeske
Miles Bader <miles@gnu.org>
parents: 71442
diff changeset
561 (with-current-buffer buffer
5e47ca87ee3c Rcirc update from Ryan Yeske
Miles Bader <miles@gnu.org>
parents: 71442
diff changeset
562 rcirc-server-buffer)
5e47ca87ee3c Rcirc update from Ryan Yeske
Miles Bader <miles@gnu.org>
parents: 71442
diff changeset
563 rcirc-server-buffer)))
69860
000a5d4aa083 (rcirc-default-server): Rename from rcirc-server.
Eli Zaretskii <eliz@gnu.org>
parents: 69694
diff changeset
564
000a5d4aa083 (rcirc-default-server): Rename from rcirc-server.
Eli Zaretskii <eliz@gnu.org>
parents: 69694
diff changeset
565 (defun rcirc-server-name (process)
000a5d4aa083 (rcirc-default-server): Rename from rcirc-server.
Eli Zaretskii <eliz@gnu.org>
parents: 69694
diff changeset
566 "Return PROCESS server name, given by the 001 response."
66703
6cfb275aa300 Use split-string OMIT-NULLS argument.
Eli Zaretskii <eliz@gnu.org>
parents: 66272
diff changeset
567 (with-rcirc-process-buffer process
69860
000a5d4aa083 (rcirc-default-server): Rename from rcirc-server.
Eli Zaretskii <eliz@gnu.org>
parents: 69694
diff changeset
568 (or rcirc-server rcirc-default-server)))
66248
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
569
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
570 (defun rcirc-nick (process)
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
571 "Return PROCESS nick."
69860
000a5d4aa083 (rcirc-default-server): Rename from rcirc-server.
Eli Zaretskii <eliz@gnu.org>
parents: 69694
diff changeset
572 (with-rcirc-process-buffer process
000a5d4aa083 (rcirc-default-server): Rename from rcirc-server.
Eli Zaretskii <eliz@gnu.org>
parents: 69694
diff changeset
573 (or rcirc-nick rcirc-default-nick)))
000a5d4aa083 (rcirc-default-server): Rename from rcirc-server.
Eli Zaretskii <eliz@gnu.org>
parents: 69694
diff changeset
574
000a5d4aa083 (rcirc-default-server): Rename from rcirc-server.
Eli Zaretskii <eliz@gnu.org>
parents: 69694
diff changeset
575 (defun rcirc-buffer-nick (&optional buffer)
000a5d4aa083 (rcirc-default-server): Rename from rcirc-server.
Eli Zaretskii <eliz@gnu.org>
parents: 69694
diff changeset
576 "Return the nick associated with BUFFER.
000a5d4aa083 (rcirc-default-server): Rename from rcirc-server.
Eli Zaretskii <eliz@gnu.org>
parents: 69694
diff changeset
577 With no argument or nil as argument, use the current buffer."
000a5d4aa083 (rcirc-default-server): Rename from rcirc-server.
Eli Zaretskii <eliz@gnu.org>
parents: 69694
diff changeset
578 (with-current-buffer (or buffer (current-buffer))
000a5d4aa083 (rcirc-default-server): Rename from rcirc-server.
Eli Zaretskii <eliz@gnu.org>
parents: 69694
diff changeset
579 (with-current-buffer rcirc-server-buffer
000a5d4aa083 (rcirc-default-server): Rename from rcirc-server.
Eli Zaretskii <eliz@gnu.org>
parents: 69694
diff changeset
580 (or rcirc-nick rcirc-default-nick))))
66248
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
581
70215
90d76f24753a Revision: emacs@sv.gnu.org/emacs--devo--0--patch-247
Miles Bader <miles@gnu.org>
parents: 69860
diff changeset
582 (defvar rcirc-max-message-length 420
66248
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
583 "Messages longer than this value will be split.")
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
584
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
585 (defun rcirc-send-message (process target message &optional noticep)
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
586 "Send TARGET associated with PROCESS a privmsg with text MESSAGE.
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
587 If NOTICEP is non-nil, send a notice instead of privmsg."
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
588 ;; max message length is 512 including CRLF
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
589 (let* ((response (if noticep "NOTICE" "PRIVMSG"))
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
590 (oversize (> (length message) rcirc-max-message-length))
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
591 (text (if oversize
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
592 (substring message 0 rcirc-max-message-length)
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
593 message))
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
594 (text (if (string= text "")
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
595 " "
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
596 text))
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
597 (more (if oversize
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
598 (substring message rcirc-max-message-length))))
68731
85be285e3494 (rcirc-startup-channels-alist): Add irc.freenode.net and #emacs as defaults.
Eli Zaretskii <eliz@gnu.org>
parents: 68648
diff changeset
599 (rcirc-get-buffer-create process target)
85be285e3494 (rcirc-startup-channels-alist): Add irc.freenode.net and #emacs as defaults.
Eli Zaretskii <eliz@gnu.org>
parents: 68648
diff changeset
600 (rcirc-print process (rcirc-nick process) response target text)
66248
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
601 (rcirc-send-string process (concat response " " target " :" text))
68731
85be285e3494 (rcirc-startup-channels-alist): Add irc.freenode.net and #emacs as defaults.
Eli Zaretskii <eliz@gnu.org>
parents: 68648
diff changeset
602 (when more (rcirc-send-message process target more noticep))))
66248
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
603
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
604 (defvar rcirc-input-ring nil)
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
605 (defvar rcirc-input-ring-index 0)
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
606 (defun rcirc-prev-input-string (arg)
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
607 (ring-ref rcirc-input-ring (+ rcirc-input-ring-index arg)))
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
608
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
609 (defun rcirc-insert-prev-input (arg)
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
610 (interactive "p")
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
611 (when (<= rcirc-prompt-end-marker (point))
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
612 (delete-region rcirc-prompt-end-marker (point-max))
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
613 (insert (rcirc-prev-input-string 0))
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
614 (setq rcirc-input-ring-index (1+ rcirc-input-ring-index))))
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
615
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
616 (defun rcirc-insert-next-input (arg)
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
617 (interactive "p")
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
618 (when (<= rcirc-prompt-end-marker (point))
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
619 (delete-region rcirc-prompt-end-marker (point-max))
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
620 (setq rcirc-input-ring-index (1- rcirc-input-ring-index))
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
621 (insert (rcirc-prev-input-string -1))))
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
622
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
623 (defvar rcirc-nick-completions nil)
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
624 (defvar rcirc-nick-completion-start-offset nil)
72468
5e47ca87ee3c Rcirc update from Ryan Yeske
Miles Bader <miles@gnu.org>
parents: 71442
diff changeset
625
66248
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
626 (defun rcirc-complete-nick ()
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
627 "Cycle through nick completions from list of nicks in channel."
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
628 (interactive)
72468
5e47ca87ee3c Rcirc update from Ryan Yeske
Miles Bader <miles@gnu.org>
parents: 71442
diff changeset
629 (if (eq last-command this-command)
66248
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
630 (setq rcirc-nick-completions
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
631 (append (cdr rcirc-nick-completions)
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
632 (list (car rcirc-nick-completions))))
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
633 (setq rcirc-nick-completion-start-offset
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
634 (- (save-excursion
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
635 (if (re-search-backward " " rcirc-prompt-end-marker t)
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
636 (1+ (point))
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
637 rcirc-prompt-end-marker))
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
638 rcirc-prompt-end-marker))
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
639 (setq rcirc-nick-completions
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
640 (let ((completion-ignore-case t))
66703
6cfb275aa300 Use split-string OMIT-NULLS argument.
Eli Zaretskii <eliz@gnu.org>
parents: 66272
diff changeset
641 (all-completions
6cfb275aa300 Use split-string OMIT-NULLS argument.
Eli Zaretskii <eliz@gnu.org>
parents: 66272
diff changeset
642 (buffer-substring
66248
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
643 (+ rcirc-prompt-end-marker
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
644 rcirc-nick-completion-start-offset)
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
645 (point))
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
646 (mapcar (lambda (x) (cons x nil))
69860
000a5d4aa083 (rcirc-default-server): Rename from rcirc-server.
Eli Zaretskii <eliz@gnu.org>
parents: 69694
diff changeset
647 (rcirc-channel-nicks (rcirc-buffer-process)
000a5d4aa083 (rcirc-default-server): Rename from rcirc-server.
Eli Zaretskii <eliz@gnu.org>
parents: 69694
diff changeset
648 rcirc-target))))))
66248
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
649 (let ((completion (car rcirc-nick-completions)))
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
650 (when completion
72468
5e47ca87ee3c Rcirc update from Ryan Yeske
Miles Bader <miles@gnu.org>
parents: 71442
diff changeset
651 (rcirc-put-nick-channel (rcirc-buffer-process) completion rcirc-target)
66703
6cfb275aa300 Use split-string OMIT-NULLS argument.
Eli Zaretskii <eliz@gnu.org>
parents: 66272
diff changeset
652 (delete-region (+ rcirc-prompt-end-marker
72468
5e47ca87ee3c Rcirc update from Ryan Yeske
Miles Bader <miles@gnu.org>
parents: 71442
diff changeset
653 rcirc-nick-completion-start-offset)
5e47ca87ee3c Rcirc update from Ryan Yeske
Miles Bader <miles@gnu.org>
parents: 71442
diff changeset
654 (point))
66248
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
655 (insert (concat completion
66703
6cfb275aa300 Use split-string OMIT-NULLS argument.
Eli Zaretskii <eliz@gnu.org>
parents: 66272
diff changeset
656 (if (= (+ rcirc-prompt-end-marker
66248
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
657 rcirc-nick-completion-start-offset)
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
658 rcirc-prompt-end-marker)
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
659 ": "))))))
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
660
69860
000a5d4aa083 (rcirc-default-server): Rename from rcirc-server.
Eli Zaretskii <eliz@gnu.org>
parents: 69694
diff changeset
661 (defun set-rcirc-decode-coding-system (coding-system)
000a5d4aa083 (rcirc-default-server): Rename from rcirc-server.
Eli Zaretskii <eliz@gnu.org>
parents: 69694
diff changeset
662 "Set the decode coding system used in this channel."
000a5d4aa083 (rcirc-default-server): Rename from rcirc-server.
Eli Zaretskii <eliz@gnu.org>
parents: 69694
diff changeset
663 (interactive "zCoding system for incoming messages: ")
000a5d4aa083 (rcirc-default-server): Rename from rcirc-server.
Eli Zaretskii <eliz@gnu.org>
parents: 69694
diff changeset
664 (setq rcirc-decode-coding-system coding-system))
000a5d4aa083 (rcirc-default-server): Rename from rcirc-server.
Eli Zaretskii <eliz@gnu.org>
parents: 69694
diff changeset
665
000a5d4aa083 (rcirc-default-server): Rename from rcirc-server.
Eli Zaretskii <eliz@gnu.org>
parents: 69694
diff changeset
666 (defun set-rcirc-encode-coding-system (coding-system)
000a5d4aa083 (rcirc-default-server): Rename from rcirc-server.
Eli Zaretskii <eliz@gnu.org>
parents: 69694
diff changeset
667 "Set the encode coding system used in this channel."
000a5d4aa083 (rcirc-default-server): Rename from rcirc-server.
Eli Zaretskii <eliz@gnu.org>
parents: 69694
diff changeset
668 (interactive "zCoding system for outgoing messages: ")
000a5d4aa083 (rcirc-default-server): Rename from rcirc-server.
Eli Zaretskii <eliz@gnu.org>
parents: 69694
diff changeset
669 (setq rcirc-encode-coding-system coding-system))
66248
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
670
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
671 (defvar rcirc-mode-map (make-sparse-keymap)
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
672 "Keymap for rcirc mode.")
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
673
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
674 (define-key rcirc-mode-map (kbd "RET") 'rcirc-send-input)
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
675 (define-key rcirc-mode-map (kbd "M-p") 'rcirc-insert-prev-input)
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
676 (define-key rcirc-mode-map (kbd "M-n") 'rcirc-insert-next-input)
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
677 (define-key rcirc-mode-map (kbd "TAB") 'rcirc-complete-nick)
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
678 (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
679 (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
680 (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
681 (define-key rcirc-mode-map (kbd "C-c C-k") 'rcirc-cmd-kick)
69860
000a5d4aa083 (rcirc-default-server): Rename from rcirc-server.
Eli Zaretskii <eliz@gnu.org>
parents: 69694
diff changeset
682 (define-key rcirc-mode-map (kbd "C-c C-l") 'rcirc-toggle-low-priority)
66248
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
683 (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
684 (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
685 (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
686 (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
687 (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
688 (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
689 (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
690 (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
691 (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
692 (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
693 (define-key rcirc-mode-map (kbd "C-c TAB") ; C-i
66703
6cfb275aa300 Use split-string OMIT-NULLS argument.
Eli Zaretskii <eliz@gnu.org>
parents: 66272
diff changeset
694 'rcirc-toggle-ignore-buffer-activity)
66248
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
695 (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
696 (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
697
66703
6cfb275aa300 Use split-string OMIT-NULLS argument.
Eli Zaretskii <eliz@gnu.org>
parents: 66272
diff changeset
698 (defvar rcirc-browse-url-map (make-sparse-keymap)
68563
979fba30166f (rcirc-debug): Fix docstring.
Juanma Barranquero <lekktu@gmail.com>
parents: 68079
diff changeset
699 "Keymap used for browsing URLs in `rcirc-mode'.")
66703
6cfb275aa300 Use split-string OMIT-NULLS argument.
Eli Zaretskii <eliz@gnu.org>
parents: 66272
diff changeset
700
6cfb275aa300 Use split-string OMIT-NULLS argument.
Eli Zaretskii <eliz@gnu.org>
parents: 66272
diff changeset
701 (define-key rcirc-browse-url-map (kbd "RET") 'rcirc-browse-url-at-point)
6cfb275aa300 Use split-string OMIT-NULLS argument.
Eli Zaretskii <eliz@gnu.org>
parents: 66272
diff changeset
702 (define-key rcirc-browse-url-map (kbd "<mouse-2>") 'rcirc-browse-url-at-mouse)
6cfb275aa300 Use split-string OMIT-NULLS argument.
Eli Zaretskii <eliz@gnu.org>
parents: 66272
diff changeset
703
6cfb275aa300 Use split-string OMIT-NULLS argument.
Eli Zaretskii <eliz@gnu.org>
parents: 66272
diff changeset
704 (defvar rcirc-short-buffer-name nil
6cfb275aa300 Use split-string OMIT-NULLS argument.
Eli Zaretskii <eliz@gnu.org>
parents: 66272
diff changeset
705 "Generated abbreviation to use to indicate buffer activity.")
6cfb275aa300 Use split-string OMIT-NULLS argument.
Eli Zaretskii <eliz@gnu.org>
parents: 66272
diff changeset
706
66248
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
707 (defvar rcirc-mode-hook nil
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
708 "Hook run when setting up rcirc buffer.")
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
709
69860
000a5d4aa083 (rcirc-default-server): Rename from rcirc-server.
Eli Zaretskii <eliz@gnu.org>
parents: 69694
diff changeset
710 (defvar rcirc-last-post-time nil)
000a5d4aa083 (rcirc-default-server): Rename from rcirc-server.
Eli Zaretskii <eliz@gnu.org>
parents: 69694
diff changeset
711
66248
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
712 (defun rcirc-mode (process target)
68563
979fba30166f (rcirc-debug): Fix docstring.
Juanma Barranquero <lekktu@gmail.com>
parents: 68079
diff changeset
713 "Major mode for IRC channel buffers.
66248
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
714
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
715 \\{rcirc-mode-map}"
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
716 (kill-all-local-variables)
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
717 (use-local-map rcirc-mode-map)
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
718 (setq mode-name "rcirc")
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
719 (setq major-mode 'rcirc-mode)
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
720
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
721 (make-local-variable 'rcirc-input-ring)
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
722 (setq rcirc-input-ring (make-ring rcirc-input-ring-size))
69860
000a5d4aa083 (rcirc-default-server): Rename from rcirc-server.
Eli Zaretskii <eliz@gnu.org>
parents: 69694
diff changeset
723 (make-local-variable 'rcirc-server-buffer)
000a5d4aa083 (rcirc-default-server): Rename from rcirc-server.
Eli Zaretskii <eliz@gnu.org>
parents: 69694
diff changeset
724 (setq rcirc-server-buffer (process-buffer process))
66248
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
725 (make-local-variable 'rcirc-target)
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
726 (setq rcirc-target target)
67014
d3d8e2bcfa98 (rcirc-mangle-text): Add bold face property without replacing existing
Eli Zaretskii <eliz@gnu.org>
parents: 66703
diff changeset
727 (make-local-variable 'rcirc-topic)
d3d8e2bcfa98 (rcirc-mangle-text): Add bold face property without replacing existing
Eli Zaretskii <eliz@gnu.org>
parents: 66703
diff changeset
728 (setq rcirc-topic nil)
69860
000a5d4aa083 (rcirc-default-server): Rename from rcirc-server.
Eli Zaretskii <eliz@gnu.org>
parents: 69694
diff changeset
729 (make-local-variable 'rcirc-last-post-time)
000a5d4aa083 (rcirc-default-server): Rename from rcirc-server.
Eli Zaretskii <eliz@gnu.org>
parents: 69694
diff changeset
730 (setq rcirc-last-post-time (current-time))
66703
6cfb275aa300 Use split-string OMIT-NULLS argument.
Eli Zaretskii <eliz@gnu.org>
parents: 66272
diff changeset
731
6cfb275aa300 Use split-string OMIT-NULLS argument.
Eli Zaretskii <eliz@gnu.org>
parents: 66272
diff changeset
732 (make-local-variable 'rcirc-short-buffer-name)
6cfb275aa300 Use split-string OMIT-NULLS argument.
Eli Zaretskii <eliz@gnu.org>
parents: 66272
diff changeset
733 (setq rcirc-short-buffer-name nil)
66248
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
734 (make-local-variable 'rcirc-urls)
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
735 (setq use-hard-newlines t)
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
736
69860
000a5d4aa083 (rcirc-default-server): Rename from rcirc-server.
Eli Zaretskii <eliz@gnu.org>
parents: 69694
diff changeset
737 (make-local-variable 'rcirc-decode-coding-system)
000a5d4aa083 (rcirc-default-server): Rename from rcirc-server.
Eli Zaretskii <eliz@gnu.org>
parents: 69694
diff changeset
738 (make-local-variable 'rcirc-encode-coding-system)
000a5d4aa083 (rcirc-default-server): Rename from rcirc-server.
Eli Zaretskii <eliz@gnu.org>
parents: 69694
diff changeset
739 (dolist (i rcirc-coding-system-alist)
000a5d4aa083 (rcirc-default-server): Rename from rcirc-server.
Eli Zaretskii <eliz@gnu.org>
parents: 69694
diff changeset
740 (let ((chan (if (consp (car i)) (caar i) (car i)))
000a5d4aa083 (rcirc-default-server): Rename from rcirc-server.
Eli Zaretskii <eliz@gnu.org>
parents: 69694
diff changeset
741 (serv (if (consp (car i)) (cdar i) "")))
000a5d4aa083 (rcirc-default-server): Rename from rcirc-server.
Eli Zaretskii <eliz@gnu.org>
parents: 69694
diff changeset
742 (when (and (string-match chan (or target ""))
000a5d4aa083 (rcirc-default-server): Rename from rcirc-server.
Eli Zaretskii <eliz@gnu.org>
parents: 69694
diff changeset
743 (string-match serv (rcirc-server-name process)))
71440
fd07cc034d56 (rcirc-mode): Fix initialization of coding systems based on
Eli Zaretskii <eliz@gnu.org>
parents: 70215
diff changeset
744 (setq rcirc-decode-coding-system (if (consp (cdr i)) (cadr i) (cdr i))
fd07cc034d56 (rcirc-mode): Fix initialization of coding systems based on
Eli Zaretskii <eliz@gnu.org>
parents: 70215
diff changeset
745 rcirc-encode-coding-system (if (consp (cdr i)) (cddr i) (cdr i))))))
69860
000a5d4aa083 (rcirc-default-server): Rename from rcirc-server.
Eli Zaretskii <eliz@gnu.org>
parents: 69694
diff changeset
746
66248
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
747 ;; setup the prompt and markers
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
748 (make-local-variable 'rcirc-prompt-start-marker)
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
749 (setq rcirc-prompt-start-marker (make-marker))
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
750 (set-marker rcirc-prompt-start-marker (point-max))
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
751 (make-local-variable 'rcirc-prompt-end-marker)
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
752 (setq rcirc-prompt-end-marker (make-marker))
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
753 (set-marker rcirc-prompt-end-marker (point-max))
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
754 (rcirc-update-prompt)
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
755 (goto-char rcirc-prompt-end-marker)
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
756 (make-local-variable 'overlay-arrow-position)
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
757 (setq overlay-arrow-position (make-marker))
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
758 (set-marker overlay-arrow-position nil)
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
759
69860
000a5d4aa083 (rcirc-default-server): Rename from rcirc-server.
Eli Zaretskii <eliz@gnu.org>
parents: 69694
diff changeset
760 ;; if the user changes the major mode or kills the buffer, there is
000a5d4aa083 (rcirc-default-server): Rename from rcirc-server.
Eli Zaretskii <eliz@gnu.org>
parents: 69694
diff changeset
761 ;; cleanup work to do
72616
1c7de7b9540b (rcirc-keywords): New variable.
Eli Zaretskii <eliz@gnu.org>
parents: 72468
diff changeset
762 (add-hook 'change-major-mode-hook 'rcirc-change-major-mode-hook nil t)
1c7de7b9540b (rcirc-keywords): New variable.
Eli Zaretskii <eliz@gnu.org>
parents: 72468
diff changeset
763 (add-hook 'kill-buffer-hook 'rcirc-kill-buffer-hook nil t)
69860
000a5d4aa083 (rcirc-default-server): Rename from rcirc-server.
Eli Zaretskii <eliz@gnu.org>
parents: 69694
diff changeset
764
72616
1c7de7b9540b (rcirc-keywords): New variable.
Eli Zaretskii <eliz@gnu.org>
parents: 72468
diff changeset
765 (add-hook 'window-scroll-functions 'rcirc-scroll-to-bottom nil t)
72468
5e47ca87ee3c Rcirc update from Ryan Yeske
Miles Bader <miles@gnu.org>
parents: 71442
diff changeset
766
66703
6cfb275aa300 Use split-string OMIT-NULLS argument.
Eli Zaretskii <eliz@gnu.org>
parents: 66272
diff changeset
767 ;; add to buffer list, and update buffer abbrevs
6cfb275aa300 Use split-string OMIT-NULLS argument.
Eli Zaretskii <eliz@gnu.org>
parents: 66272
diff changeset
768 (when target ; skip server buffer
6cfb275aa300 Use split-string OMIT-NULLS argument.
Eli Zaretskii <eliz@gnu.org>
parents: 66272
diff changeset
769 (let ((buffer (current-buffer)))
6cfb275aa300 Use split-string OMIT-NULLS argument.
Eli Zaretskii <eliz@gnu.org>
parents: 66272
diff changeset
770 (with-rcirc-process-buffer process
6cfb275aa300 Use split-string OMIT-NULLS argument.
Eli Zaretskii <eliz@gnu.org>
parents: 66272
diff changeset
771 (setq rcirc-buffer-alist (cons (cons target buffer)
6cfb275aa300 Use split-string OMIT-NULLS argument.
Eli Zaretskii <eliz@gnu.org>
parents: 66272
diff changeset
772 rcirc-buffer-alist))))
6cfb275aa300 Use split-string OMIT-NULLS argument.
Eli Zaretskii <eliz@gnu.org>
parents: 66272
diff changeset
773 (rcirc-update-short-buffer-names))
6cfb275aa300 Use split-string OMIT-NULLS argument.
Eli Zaretskii <eliz@gnu.org>
parents: 66272
diff changeset
774
66248
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
775 (run-hooks 'rcirc-mode-hook))
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
776
66703
6cfb275aa300 Use split-string OMIT-NULLS argument.
Eli Zaretskii <eliz@gnu.org>
parents: 66272
diff changeset
777 (defun rcirc-update-prompt (&optional all)
6cfb275aa300 Use split-string OMIT-NULLS argument.
Eli Zaretskii <eliz@gnu.org>
parents: 66272
diff changeset
778 "Reset the prompt string in the current buffer.
66252
684cec8133e3 (with-rcirc-process-buffer): Move above its first user.
Romain Francoise <romain@orebokech.com>
parents: 66250
diff changeset
779
66703
6cfb275aa300 Use split-string OMIT-NULLS argument.
Eli Zaretskii <eliz@gnu.org>
parents: 66272
diff changeset
780 If ALL is non-nil, update prompts in all IRC buffers."
6cfb275aa300 Use split-string OMIT-NULLS argument.
Eli Zaretskii <eliz@gnu.org>
parents: 66272
diff changeset
781 (if all
6cfb275aa300 Use split-string OMIT-NULLS argument.
Eli Zaretskii <eliz@gnu.org>
parents: 66272
diff changeset
782 (mapc (lambda (process)
6cfb275aa300 Use split-string OMIT-NULLS argument.
Eli Zaretskii <eliz@gnu.org>
parents: 66272
diff changeset
783 (mapc (lambda (buffer)
6cfb275aa300 Use split-string OMIT-NULLS argument.
Eli Zaretskii <eliz@gnu.org>
parents: 66272
diff changeset
784 (with-current-buffer buffer
6cfb275aa300 Use split-string OMIT-NULLS argument.
Eli Zaretskii <eliz@gnu.org>
parents: 66272
diff changeset
785 (rcirc-update-prompt)))
6cfb275aa300 Use split-string OMIT-NULLS argument.
Eli Zaretskii <eliz@gnu.org>
parents: 66272
diff changeset
786 (with-rcirc-process-buffer process
6cfb275aa300 Use split-string OMIT-NULLS argument.
Eli Zaretskii <eliz@gnu.org>
parents: 66272
diff changeset
787 (mapcar 'cdr rcirc-buffer-alist))))
6cfb275aa300 Use split-string OMIT-NULLS argument.
Eli Zaretskii <eliz@gnu.org>
parents: 66272
diff changeset
788 (rcirc-process-list))
6cfb275aa300 Use split-string OMIT-NULLS argument.
Eli Zaretskii <eliz@gnu.org>
parents: 66272
diff changeset
789 (let ((inhibit-read-only t)
6cfb275aa300 Use split-string OMIT-NULLS argument.
Eli Zaretskii <eliz@gnu.org>
parents: 66272
diff changeset
790 (prompt (or rcirc-prompt "")))
6cfb275aa300 Use split-string OMIT-NULLS argument.
Eli Zaretskii <eliz@gnu.org>
parents: 66272
diff changeset
791 (mapc (lambda (rep)
6cfb275aa300 Use split-string OMIT-NULLS argument.
Eli Zaretskii <eliz@gnu.org>
parents: 66272
diff changeset
792 (setq prompt
69860
000a5d4aa083 (rcirc-default-server): Rename from rcirc-server.
Eli Zaretskii <eliz@gnu.org>
parents: 69694
diff changeset
793 (replace-regexp-in-string (car rep) (cdr rep) prompt)))
000a5d4aa083 (rcirc-default-server): Rename from rcirc-server.
Eli Zaretskii <eliz@gnu.org>
parents: 69694
diff changeset
794 (list (cons "%n" (rcirc-buffer-nick))
000a5d4aa083 (rcirc-default-server): Rename from rcirc-server.
Eli Zaretskii <eliz@gnu.org>
parents: 69694
diff changeset
795 (cons "%s" (with-rcirc-server-buffer (or rcirc-server "")))
66703
6cfb275aa300 Use split-string OMIT-NULLS argument.
Eli Zaretskii <eliz@gnu.org>
parents: 66272
diff changeset
796 (cons "%t" (or rcirc-target ""))))
6cfb275aa300 Use split-string OMIT-NULLS argument.
Eli Zaretskii <eliz@gnu.org>
parents: 66272
diff changeset
797 (save-excursion
6cfb275aa300 Use split-string OMIT-NULLS argument.
Eli Zaretskii <eliz@gnu.org>
parents: 66272
diff changeset
798 (delete-region rcirc-prompt-start-marker rcirc-prompt-end-marker)
6cfb275aa300 Use split-string OMIT-NULLS argument.
Eli Zaretskii <eliz@gnu.org>
parents: 66272
diff changeset
799 (goto-char rcirc-prompt-start-marker)
6cfb275aa300 Use split-string OMIT-NULLS argument.
Eli Zaretskii <eliz@gnu.org>
parents: 66272
diff changeset
800 (let ((start (point)))
6cfb275aa300 Use split-string OMIT-NULLS argument.
Eli Zaretskii <eliz@gnu.org>
parents: 66272
diff changeset
801 (insert-before-markers prompt)
6cfb275aa300 Use split-string OMIT-NULLS argument.
Eli Zaretskii <eliz@gnu.org>
parents: 66272
diff changeset
802 (set-marker rcirc-prompt-start-marker start)
6cfb275aa300 Use split-string OMIT-NULLS argument.
Eli Zaretskii <eliz@gnu.org>
parents: 66272
diff changeset
803 (when (not (zerop (- rcirc-prompt-end-marker
6cfb275aa300 Use split-string OMIT-NULLS argument.
Eli Zaretskii <eliz@gnu.org>
parents: 66272
diff changeset
804 rcirc-prompt-start-marker)))
6cfb275aa300 Use split-string OMIT-NULLS argument.
Eli Zaretskii <eliz@gnu.org>
parents: 66272
diff changeset
805 (add-text-properties rcirc-prompt-start-marker
6cfb275aa300 Use split-string OMIT-NULLS argument.
Eli Zaretskii <eliz@gnu.org>
parents: 66272
diff changeset
806 rcirc-prompt-end-marker
6cfb275aa300 Use split-string OMIT-NULLS argument.
Eli Zaretskii <eliz@gnu.org>
parents: 66272
diff changeset
807 (list 'face 'rcirc-prompt
6cfb275aa300 Use split-string OMIT-NULLS argument.
Eli Zaretskii <eliz@gnu.org>
parents: 66272
diff changeset
808 'read-only t 'field t
6cfb275aa300 Use split-string OMIT-NULLS argument.
Eli Zaretskii <eliz@gnu.org>
parents: 66272
diff changeset
809 'front-sticky t 'rear-nonsticky t))))))))
6cfb275aa300 Use split-string OMIT-NULLS argument.
Eli Zaretskii <eliz@gnu.org>
parents: 66272
diff changeset
810
6cfb275aa300 Use split-string OMIT-NULLS argument.
Eli Zaretskii <eliz@gnu.org>
parents: 66272
diff changeset
811 (defun rcirc-set-changed (option value)
6cfb275aa300 Use split-string OMIT-NULLS argument.
Eli Zaretskii <eliz@gnu.org>
parents: 66272
diff changeset
812 "Set OPTION to VALUE and do updates after a customization change."
6cfb275aa300 Use split-string OMIT-NULLS argument.
Eli Zaretskii <eliz@gnu.org>
parents: 66272
diff changeset
813 (set-default option value)
6cfb275aa300 Use split-string OMIT-NULLS argument.
Eli Zaretskii <eliz@gnu.org>
parents: 66272
diff changeset
814 (cond ((eq option 'rcirc-prompt)
6cfb275aa300 Use split-string OMIT-NULLS argument.
Eli Zaretskii <eliz@gnu.org>
parents: 66272
diff changeset
815 (rcirc-update-prompt 'all))
6cfb275aa300 Use split-string OMIT-NULLS argument.
Eli Zaretskii <eliz@gnu.org>
parents: 66272
diff changeset
816 (t
6cfb275aa300 Use split-string OMIT-NULLS argument.
Eli Zaretskii <eliz@gnu.org>
parents: 66272
diff changeset
817 (error "Bad option %s" option))))
66248
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
818
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
819 (defun rcirc-channel-p (target)
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
820 "Return t if TARGET is a channel name."
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
821 (and target
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
822 (not (zerop (length target)))
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
823 (or (eq (aref target 0) ?#)
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
824 (eq (aref target 0) ?&))))
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
825
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
826 (defun rcirc-kill-buffer-hook ()
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
827 "Part the channel when killing an rcirc buffer."
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
828 (when (eq major-mode 'rcirc-mode)
69860
000a5d4aa083 (rcirc-default-server): Rename from rcirc-server.
Eli Zaretskii <eliz@gnu.org>
parents: 69694
diff changeset
829 (rcirc-clean-up-buffer "Killed buffer")))
000a5d4aa083 (rcirc-default-server): Rename from rcirc-server.
Eli Zaretskii <eliz@gnu.org>
parents: 69694
diff changeset
830
000a5d4aa083 (rcirc-default-server): Rename from rcirc-server.
Eli Zaretskii <eliz@gnu.org>
parents: 69694
diff changeset
831 (defun rcirc-change-major-mode-hook ()
000a5d4aa083 (rcirc-default-server): Rename from rcirc-server.
Eli Zaretskii <eliz@gnu.org>
parents: 69694
diff changeset
832 "Part the channel when changing the major-mode."
000a5d4aa083 (rcirc-default-server): Rename from rcirc-server.
Eli Zaretskii <eliz@gnu.org>
parents: 69694
diff changeset
833 (rcirc-clean-up-buffer "Changed major mode"))
000a5d4aa083 (rcirc-default-server): Rename from rcirc-server.
Eli Zaretskii <eliz@gnu.org>
parents: 69694
diff changeset
834
000a5d4aa083 (rcirc-default-server): Rename from rcirc-server.
Eli Zaretskii <eliz@gnu.org>
parents: 69694
diff changeset
835 (defun rcirc-clean-up-buffer (reason)
66703
6cfb275aa300 Use split-string OMIT-NULLS argument.
Eli Zaretskii <eliz@gnu.org>
parents: 66272
diff changeset
836 (let ((buffer (current-buffer)))
6cfb275aa300 Use split-string OMIT-NULLS argument.
Eli Zaretskii <eliz@gnu.org>
parents: 66272
diff changeset
837 (rcirc-clear-activity buffer)
69860
000a5d4aa083 (rcirc-default-server): Rename from rcirc-server.
Eli Zaretskii <eliz@gnu.org>
parents: 69694
diff changeset
838 (when (and (rcirc-buffer-process)
000a5d4aa083 (rcirc-default-server): Rename from rcirc-server.
Eli Zaretskii <eliz@gnu.org>
parents: 69694
diff changeset
839 (eq (process-status (rcirc-buffer-process)) 'open))
000a5d4aa083 (rcirc-default-server): Rename from rcirc-server.
Eli Zaretskii <eliz@gnu.org>
parents: 69694
diff changeset
840 (with-rcirc-server-buffer
000a5d4aa083 (rcirc-default-server): Rename from rcirc-server.
Eli Zaretskii <eliz@gnu.org>
parents: 69694
diff changeset
841 (setq rcirc-buffer-alist
000a5d4aa083 (rcirc-default-server): Rename from rcirc-server.
Eli Zaretskii <eliz@gnu.org>
parents: 69694
diff changeset
842 (rassq-delete-all buffer rcirc-buffer-alist)))
66703
6cfb275aa300 Use split-string OMIT-NULLS argument.
Eli Zaretskii <eliz@gnu.org>
parents: 66272
diff changeset
843 (rcirc-update-short-buffer-names)
66248
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
844 (if (rcirc-channel-p rcirc-target)
69860
000a5d4aa083 (rcirc-default-server): Rename from rcirc-server.
Eli Zaretskii <eliz@gnu.org>
parents: 69694
diff changeset
845 (rcirc-send-string (rcirc-buffer-process)
000a5d4aa083 (rcirc-default-server): Rename from rcirc-server.
Eli Zaretskii <eliz@gnu.org>
parents: 69694
diff changeset
846 (concat "PART " rcirc-target " :" reason))
66703
6cfb275aa300 Use split-string OMIT-NULLS argument.
Eli Zaretskii <eliz@gnu.org>
parents: 66272
diff changeset
847 (when rcirc-target
69860
000a5d4aa083 (rcirc-default-server): Rename from rcirc-server.
Eli Zaretskii <eliz@gnu.org>
parents: 69694
diff changeset
848 (rcirc-remove-nick-channel (rcirc-buffer-process)
000a5d4aa083 (rcirc-default-server): Rename from rcirc-server.
Eli Zaretskii <eliz@gnu.org>
parents: 69694
diff changeset
849 (rcirc-buffer-nick)
66703
6cfb275aa300 Use split-string OMIT-NULLS argument.
Eli Zaretskii <eliz@gnu.org>
parents: 66272
diff changeset
850 rcirc-target))))))
6cfb275aa300 Use split-string OMIT-NULLS argument.
Eli Zaretskii <eliz@gnu.org>
parents: 66272
diff changeset
851
6cfb275aa300 Use split-string OMIT-NULLS argument.
Eli Zaretskii <eliz@gnu.org>
parents: 66272
diff changeset
852 (defun rcirc-generate-new-buffer-name (process target)
6cfb275aa300 Use split-string OMIT-NULLS argument.
Eli Zaretskii <eliz@gnu.org>
parents: 66272
diff changeset
853 "Return a buffer name based on PROCESS and TARGET.
68563
979fba30166f (rcirc-debug): Fix docstring.
Juanma Barranquero <lekktu@gmail.com>
parents: 68079
diff changeset
854 This is used for the initial name given to IRC buffers."
66703
6cfb275aa300 Use split-string OMIT-NULLS argument.
Eli Zaretskii <eliz@gnu.org>
parents: 66272
diff changeset
855 (if target
6cfb275aa300 Use split-string OMIT-NULLS argument.
Eli Zaretskii <eliz@gnu.org>
parents: 66272
diff changeset
856 (concat target "@" (process-name process))
6cfb275aa300 Use split-string OMIT-NULLS argument.
Eli Zaretskii <eliz@gnu.org>
parents: 66272
diff changeset
857 (concat "*" (process-name process) "*")))
66248
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
858
66703
6cfb275aa300 Use split-string OMIT-NULLS argument.
Eli Zaretskii <eliz@gnu.org>
parents: 66272
diff changeset
859 (defun rcirc-get-buffer (process target &optional server)
66248
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
860 "Return the buffer associated with the PROCESS and TARGET.
66703
6cfb275aa300 Use split-string OMIT-NULLS argument.
Eli Zaretskii <eliz@gnu.org>
parents: 66272
diff changeset
861
6cfb275aa300 Use split-string OMIT-NULLS argument.
Eli Zaretskii <eliz@gnu.org>
parents: 66272
diff changeset
862 If optional argument SERVER is non-nil, return the server buffer
6cfb275aa300 Use split-string OMIT-NULLS argument.
Eli Zaretskii <eliz@gnu.org>
parents: 66272
diff changeset
863 if there is no existing buffer for TARGET, otherwise return nil."
6cfb275aa300 Use split-string OMIT-NULLS argument.
Eli Zaretskii <eliz@gnu.org>
parents: 66272
diff changeset
864 (with-rcirc-process-buffer process
6cfb275aa300 Use split-string OMIT-NULLS argument.
Eli Zaretskii <eliz@gnu.org>
parents: 66272
diff changeset
865 (if (null target)
6cfb275aa300 Use split-string OMIT-NULLS argument.
Eli Zaretskii <eliz@gnu.org>
parents: 66272
diff changeset
866 (current-buffer)
6cfb275aa300 Use split-string OMIT-NULLS argument.
Eli Zaretskii <eliz@gnu.org>
parents: 66272
diff changeset
867 (let ((buffer (cdr (assoc-string target rcirc-buffer-alist t))))
6cfb275aa300 Use split-string OMIT-NULLS argument.
Eli Zaretskii <eliz@gnu.org>
parents: 66272
diff changeset
868 (or buffer (when server (current-buffer)))))))
66248
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
869
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
870 (defun rcirc-get-buffer-create (process target)
66703
6cfb275aa300 Use split-string OMIT-NULLS argument.
Eli Zaretskii <eliz@gnu.org>
parents: 66272
diff changeset
871 "Return the buffer associated with the PROCESS and TARGET.
6cfb275aa300 Use split-string OMIT-NULLS argument.
Eli Zaretskii <eliz@gnu.org>
parents: 66272
diff changeset
872 Create the buffer if it doesn't exist."
6cfb275aa300 Use split-string OMIT-NULLS argument.
Eli Zaretskii <eliz@gnu.org>
parents: 66272
diff changeset
873 (let ((buffer (rcirc-get-buffer process target)))
69860
000a5d4aa083 (rcirc-default-server): Rename from rcirc-server.
Eli Zaretskii <eliz@gnu.org>
parents: 69694
diff changeset
874 (if (and buffer (buffer-live-p buffer))
68960
6e3160901812 (rcirc-connect): Make all arguments optional, and default to global variable
Eli Zaretskii <eliz@gnu.org>
parents: 68838
diff changeset
875 (with-current-buffer buffer
68731
85be285e3494 (rcirc-startup-channels-alist): Add irc.freenode.net and #emacs as defaults.
Eli Zaretskii <eliz@gnu.org>
parents: 68648
diff changeset
876 (when (not rcirc-target)
68960
6e3160901812 (rcirc-connect): Make all arguments optional, and default to global variable
Eli Zaretskii <eliz@gnu.org>
parents: 68838
diff changeset
877 (setq rcirc-target target))
68731
85be285e3494 (rcirc-startup-channels-alist): Add irc.freenode.net and #emacs as defaults.
Eli Zaretskii <eliz@gnu.org>
parents: 68648
diff changeset
878 buffer)
66703
6cfb275aa300 Use split-string OMIT-NULLS argument.
Eli Zaretskii <eliz@gnu.org>
parents: 66272
diff changeset
879 ;; create the buffer
6cfb275aa300 Use split-string OMIT-NULLS argument.
Eli Zaretskii <eliz@gnu.org>
parents: 66272
diff changeset
880 (with-rcirc-process-buffer process
6cfb275aa300 Use split-string OMIT-NULLS argument.
Eli Zaretskii <eliz@gnu.org>
parents: 66272
diff changeset
881 (let ((new-buffer (get-buffer-create
6cfb275aa300 Use split-string OMIT-NULLS argument.
Eli Zaretskii <eliz@gnu.org>
parents: 66272
diff changeset
882 (rcirc-generate-new-buffer-name process target))))
6cfb275aa300 Use split-string OMIT-NULLS argument.
Eli Zaretskii <eliz@gnu.org>
parents: 66272
diff changeset
883 (with-current-buffer new-buffer
6cfb275aa300 Use split-string OMIT-NULLS argument.
Eli Zaretskii <eliz@gnu.org>
parents: 66272
diff changeset
884 (rcirc-mode process target))
6cfb275aa300 Use split-string OMIT-NULLS argument.
Eli Zaretskii <eliz@gnu.org>
parents: 66272
diff changeset
885 (rcirc-put-nick-channel process (rcirc-nick process) target)
6cfb275aa300 Use split-string OMIT-NULLS argument.
Eli Zaretskii <eliz@gnu.org>
parents: 66272
diff changeset
886 new-buffer)))))
66248
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 (defun rcirc-send-input ()
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
889 "Send input to target associated with the current buffer."
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
890 (interactive)
68077
7e0fcbf84eb8 (rcirc-send-input): No longer check whether the
Alex Schroeder <alex@gnu.org>
parents: 67014
diff changeset
891 (if (< (point) rcirc-prompt-end-marker)
7e0fcbf84eb8 (rcirc-send-input): No longer check whether the
Alex Schroeder <alex@gnu.org>
parents: 67014
diff changeset
892 ;; copy the line down to the input area
7e0fcbf84eb8 (rcirc-send-input): No longer check whether the
Alex Schroeder <alex@gnu.org>
parents: 67014
diff changeset
893 (progn
7e0fcbf84eb8 (rcirc-send-input): No longer check whether the
Alex Schroeder <alex@gnu.org>
parents: 67014
diff changeset
894 (forward-line 0)
7e0fcbf84eb8 (rcirc-send-input): No longer check whether the
Alex Schroeder <alex@gnu.org>
parents: 67014
diff changeset
895 (let ((start (if (eq (point) (point-min))
7e0fcbf84eb8 (rcirc-send-input): No longer check whether the
Alex Schroeder <alex@gnu.org>
parents: 67014
diff changeset
896 (point)
7e0fcbf84eb8 (rcirc-send-input): No longer check whether the
Alex Schroeder <alex@gnu.org>
parents: 67014
diff changeset
897 (if (get-text-property (1- (point)) 'hard)
7e0fcbf84eb8 (rcirc-send-input): No longer check whether the
Alex Schroeder <alex@gnu.org>
parents: 67014
diff changeset
898 (point)
7e0fcbf84eb8 (rcirc-send-input): No longer check whether the
Alex Schroeder <alex@gnu.org>
parents: 67014
diff changeset
899 (previous-single-property-change (point) 'hard))))
7e0fcbf84eb8 (rcirc-send-input): No longer check whether the
Alex Schroeder <alex@gnu.org>
parents: 67014
diff changeset
900 (end (next-single-property-change (1+ (point)) 'hard)))
7e0fcbf84eb8 (rcirc-send-input): No longer check whether the
Alex Schroeder <alex@gnu.org>
parents: 67014
diff changeset
901 (goto-char (point-max))
7e0fcbf84eb8 (rcirc-send-input): No longer check whether the
Alex Schroeder <alex@gnu.org>
parents: 67014
diff changeset
902 (insert (replace-regexp-in-string
7e0fcbf84eb8 (rcirc-send-input): No longer check whether the
Alex Schroeder <alex@gnu.org>
parents: 67014
diff changeset
903 "\n\\s-+" " "
7e0fcbf84eb8 (rcirc-send-input): No longer check whether the
Alex Schroeder <alex@gnu.org>
parents: 67014
diff changeset
904 (buffer-substring-no-properties start end)))))
7e0fcbf84eb8 (rcirc-send-input): No longer check whether the
Alex Schroeder <alex@gnu.org>
parents: 67014
diff changeset
905 ;; process input
7e0fcbf84eb8 (rcirc-send-input): No longer check whether the
Alex Schroeder <alex@gnu.org>
parents: 67014
diff changeset
906 (goto-char (point-max))
69860
000a5d4aa083 (rcirc-default-server): Rename from rcirc-server.
Eli Zaretskii <eliz@gnu.org>
parents: 69694
diff changeset
907 (when (not (equal 0 (- (point) rcirc-prompt-end-marker)))
000a5d4aa083 (rcirc-default-server): Rename from rcirc-server.
Eli Zaretskii <eliz@gnu.org>
parents: 69694
diff changeset
908 ;; delete a trailing newline
000a5d4aa083 (rcirc-default-server): Rename from rcirc-server.
Eli Zaretskii <eliz@gnu.org>
parents: 69694
diff changeset
909 (when (eq (point) (point-at-bol))
000a5d4aa083 (rcirc-default-server): Rename from rcirc-server.
Eli Zaretskii <eliz@gnu.org>
parents: 69694
diff changeset
910 (delete-backward-char 1))
000a5d4aa083 (rcirc-default-server): Rename from rcirc-server.
Eli Zaretskii <eliz@gnu.org>
parents: 69694
diff changeset
911 (let ((input (buffer-substring-no-properties
000a5d4aa083 (rcirc-default-server): Rename from rcirc-server.
Eli Zaretskii <eliz@gnu.org>
parents: 69694
diff changeset
912 rcirc-prompt-end-marker (point))))
000a5d4aa083 (rcirc-default-server): Rename from rcirc-server.
Eli Zaretskii <eliz@gnu.org>
parents: 69694
diff changeset
913 (dolist (line (split-string input "\n"))
000a5d4aa083 (rcirc-default-server): Rename from rcirc-server.
Eli Zaretskii <eliz@gnu.org>
parents: 69694
diff changeset
914 (rcirc-process-input-line line))
000a5d4aa083 (rcirc-default-server): Rename from rcirc-server.
Eli Zaretskii <eliz@gnu.org>
parents: 69694
diff changeset
915 ;; add to input-ring
000a5d4aa083 (rcirc-default-server): Rename from rcirc-server.
Eli Zaretskii <eliz@gnu.org>
parents: 69694
diff changeset
916 (save-excursion
000a5d4aa083 (rcirc-default-server): Rename from rcirc-server.
Eli Zaretskii <eliz@gnu.org>
parents: 69694
diff changeset
917 (ring-insert rcirc-input-ring input)
000a5d4aa083 (rcirc-default-server): Rename from rcirc-server.
Eli Zaretskii <eliz@gnu.org>
parents: 69694
diff changeset
918 (setq rcirc-input-ring-index 0))))))
66248
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
919
69860
000a5d4aa083 (rcirc-default-server): Rename from rcirc-server.
Eli Zaretskii <eliz@gnu.org>
parents: 69694
diff changeset
920 (defun rcirc-process-input-line (line)
68731
85be285e3494 (rcirc-startup-channels-alist): Add irc.freenode.net and #emacs as defaults.
Eli Zaretskii <eliz@gnu.org>
parents: 68648
diff changeset
921 (if (string-match "^/\\([^ ]+\\) ?\\(.*\\)$" line)
85be285e3494 (rcirc-startup-channels-alist): Add irc.freenode.net and #emacs as defaults.
Eli Zaretskii <eliz@gnu.org>
parents: 68648
diff changeset
922 (rcirc-process-command (match-string 1 line)
85be285e3494 (rcirc-startup-channels-alist): Add irc.freenode.net and #emacs as defaults.
Eli Zaretskii <eliz@gnu.org>
parents: 68648
diff changeset
923 (match-string 2 line)
85be285e3494 (rcirc-startup-channels-alist): Add irc.freenode.net and #emacs as defaults.
Eli Zaretskii <eliz@gnu.org>
parents: 68648
diff changeset
924 line)
85be285e3494 (rcirc-startup-channels-alist): Add irc.freenode.net and #emacs as defaults.
Eli Zaretskii <eliz@gnu.org>
parents: 68648
diff changeset
925 (rcirc-process-message line)))
85be285e3494 (rcirc-startup-channels-alist): Add irc.freenode.net and #emacs as defaults.
Eli Zaretskii <eliz@gnu.org>
parents: 68648
diff changeset
926
85be285e3494 (rcirc-startup-channels-alist): Add irc.freenode.net and #emacs as defaults.
Eli Zaretskii <eliz@gnu.org>
parents: 68648
diff changeset
927 (defun rcirc-process-message (line)
85be285e3494 (rcirc-startup-channels-alist): Add irc.freenode.net and #emacs as defaults.
Eli Zaretskii <eliz@gnu.org>
parents: 68648
diff changeset
928 (if (not rcirc-target)
69860
000a5d4aa083 (rcirc-default-server): Rename from rcirc-server.
Eli Zaretskii <eliz@gnu.org>
parents: 69694
diff changeset
929 (message "Not joined (no target)")
68731
85be285e3494 (rcirc-startup-channels-alist): Add irc.freenode.net and #emacs as defaults.
Eli Zaretskii <eliz@gnu.org>
parents: 68648
diff changeset
930 (delete-region rcirc-prompt-end-marker (point))
69860
000a5d4aa083 (rcirc-default-server): Rename from rcirc-server.
Eli Zaretskii <eliz@gnu.org>
parents: 69694
diff changeset
931 (rcirc-send-message (rcirc-buffer-process) rcirc-target line)
000a5d4aa083 (rcirc-default-server): Rename from rcirc-server.
Eli Zaretskii <eliz@gnu.org>
parents: 69694
diff changeset
932 (setq rcirc-last-post-time (current-time))))
68731
85be285e3494 (rcirc-startup-channels-alist): Add irc.freenode.net and #emacs as defaults.
Eli Zaretskii <eliz@gnu.org>
parents: 68648
diff changeset
933
85be285e3494 (rcirc-startup-channels-alist): Add irc.freenode.net and #emacs as defaults.
Eli Zaretskii <eliz@gnu.org>
parents: 68648
diff changeset
934 (defun rcirc-process-command (command args line)
85be285e3494 (rcirc-startup-channels-alist): Add irc.freenode.net and #emacs as defaults.
Eli Zaretskii <eliz@gnu.org>
parents: 68648
diff changeset
935 (if (eq (aref command 0) ?/)
85be285e3494 (rcirc-startup-channels-alist): Add irc.freenode.net and #emacs as defaults.
Eli Zaretskii <eliz@gnu.org>
parents: 68648
diff changeset
936 ;; "//text" will send "/text" as a message
85be285e3494 (rcirc-startup-channels-alist): Add irc.freenode.net and #emacs as defaults.
Eli Zaretskii <eliz@gnu.org>
parents: 68648
diff changeset
937 (rcirc-process-message (substring line 1))
69860
000a5d4aa083 (rcirc-default-server): Rename from rcirc-server.
Eli Zaretskii <eliz@gnu.org>
parents: 69694
diff changeset
938 (let ((fun (intern-soft (concat "rcirc-cmd-" command)))
000a5d4aa083 (rcirc-default-server): Rename from rcirc-server.
Eli Zaretskii <eliz@gnu.org>
parents: 69694
diff changeset
939 (process (rcirc-buffer-process)))
68731
85be285e3494 (rcirc-startup-channels-alist): Add irc.freenode.net and #emacs as defaults.
Eli Zaretskii <eliz@gnu.org>
parents: 68648
diff changeset
940 (newline)
85be285e3494 (rcirc-startup-channels-alist): Add irc.freenode.net and #emacs as defaults.
Eli Zaretskii <eliz@gnu.org>
parents: 68648
diff changeset
941 (with-current-buffer (current-buffer)
85be285e3494 (rcirc-startup-channels-alist): Add irc.freenode.net and #emacs as defaults.
Eli Zaretskii <eliz@gnu.org>
parents: 68648
diff changeset
942 (delete-region rcirc-prompt-end-marker (point))
85be285e3494 (rcirc-startup-channels-alist): Add irc.freenode.net and #emacs as defaults.
Eli Zaretskii <eliz@gnu.org>
parents: 68648
diff changeset
943 (if (string= command "me")
69860
000a5d4aa083 (rcirc-default-server): Rename from rcirc-server.
Eli Zaretskii <eliz@gnu.org>
parents: 69694
diff changeset
944 (rcirc-print process (rcirc-buffer-nick)
68731
85be285e3494 (rcirc-startup-channels-alist): Add irc.freenode.net and #emacs as defaults.
Eli Zaretskii <eliz@gnu.org>
parents: 68648
diff changeset
945 "ACTION" rcirc-target args)
69860
000a5d4aa083 (rcirc-default-server): Rename from rcirc-server.
Eli Zaretskii <eliz@gnu.org>
parents: 69694
diff changeset
946 (rcirc-print process (rcirc-buffer-nick)
68731
85be285e3494 (rcirc-startup-channels-alist): Add irc.freenode.net and #emacs as defaults.
Eli Zaretskii <eliz@gnu.org>
parents: 68648
diff changeset
947 "COMMAND" rcirc-target line))
85be285e3494 (rcirc-startup-channels-alist): Add irc.freenode.net and #emacs as defaults.
Eli Zaretskii <eliz@gnu.org>
parents: 68648
diff changeset
948 (set-marker rcirc-prompt-end-marker (point))
85be285e3494 (rcirc-startup-channels-alist): Add irc.freenode.net and #emacs as defaults.
Eli Zaretskii <eliz@gnu.org>
parents: 68648
diff changeset
949 (if (fboundp fun)
69860
000a5d4aa083 (rcirc-default-server): Rename from rcirc-server.
Eli Zaretskii <eliz@gnu.org>
parents: 69694
diff changeset
950 (funcall fun args process rcirc-target)
000a5d4aa083 (rcirc-default-server): Rename from rcirc-server.
Eli Zaretskii <eliz@gnu.org>
parents: 69694
diff changeset
951 (rcirc-send-string process
72616
1c7de7b9540b (rcirc-keywords): New variable.
Eli Zaretskii <eliz@gnu.org>
parents: 72468
diff changeset
952 (concat command " :" args)))))))
68731
85be285e3494 (rcirc-startup-channels-alist): Add irc.freenode.net and #emacs as defaults.
Eli Zaretskii <eliz@gnu.org>
parents: 68648
diff changeset
953
66248
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
954 (defvar rcirc-parent-buffer nil)
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
955 (defvar rcirc-window-configuration nil)
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
956 (defun rcirc-edit-multiline ()
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
957 "Move current edit to a dedicated buffer."
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
958 (interactive)
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
959 (let ((pos (1+ (- (point) rcirc-prompt-end-marker))))
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
960 (goto-char (point-max))
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
961 (let ((text (buffer-substring rcirc-prompt-end-marker (point)))
69860
000a5d4aa083 (rcirc-default-server): Rename from rcirc-server.
Eli Zaretskii <eliz@gnu.org>
parents: 69694
diff changeset
962 (parent (buffer-name)))
66248
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
963 (delete-region rcirc-prompt-end-marker (point))
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
964 (setq rcirc-window-configuration (current-window-configuration))
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
965 (pop-to-buffer (concat "*multiline " parent "*"))
69860
000a5d4aa083 (rcirc-default-server): Rename from rcirc-server.
Eli Zaretskii <eliz@gnu.org>
parents: 69694
diff changeset
966 (funcall rcirc-multiline-major-mode)
000a5d4aa083 (rcirc-default-server): Rename from rcirc-server.
Eli Zaretskii <eliz@gnu.org>
parents: 69694
diff changeset
967 (rcirc-multiline-minor-mode 1)
66248
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
968 (setq rcirc-parent-buffer parent)
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
969 (insert text)
68731
85be285e3494 (rcirc-startup-channels-alist): Add irc.freenode.net and #emacs as defaults.
Eli Zaretskii <eliz@gnu.org>
parents: 68648
diff changeset
970 (and (> pos 0) (goto-char pos))
85be285e3494 (rcirc-startup-channels-alist): Add irc.freenode.net and #emacs as defaults.
Eli Zaretskii <eliz@gnu.org>
parents: 68648
diff changeset
971 (message "Type C-c C-c to return text to %s, or C-c C-k to cancel" parent))))
66248
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
972
69860
000a5d4aa083 (rcirc-default-server): Rename from rcirc-server.
Eli Zaretskii <eliz@gnu.org>
parents: 69694
diff changeset
973 (defvar rcirc-multiline-minor-mode-map (make-sparse-keymap)
000a5d4aa083 (rcirc-default-server): Rename from rcirc-server.
Eli Zaretskii <eliz@gnu.org>
parents: 69694
diff changeset
974 "Keymap for multiline mode in rcirc.")
000a5d4aa083 (rcirc-default-server): Rename from rcirc-server.
Eli Zaretskii <eliz@gnu.org>
parents: 69694
diff changeset
975 (define-key rcirc-multiline-minor-mode-map
000a5d4aa083 (rcirc-default-server): Rename from rcirc-server.
Eli Zaretskii <eliz@gnu.org>
parents: 69694
diff changeset
976 (kbd "C-c C-c") 'rcirc-multiline-minor-submit)
000a5d4aa083 (rcirc-default-server): Rename from rcirc-server.
Eli Zaretskii <eliz@gnu.org>
parents: 69694
diff changeset
977 (define-key rcirc-multiline-minor-mode-map
000a5d4aa083 (rcirc-default-server): Rename from rcirc-server.
Eli Zaretskii <eliz@gnu.org>
parents: 69694
diff changeset
978 (kbd "C-x C-s") 'rcirc-multiline-minor-submit)
000a5d4aa083 (rcirc-default-server): Rename from rcirc-server.
Eli Zaretskii <eliz@gnu.org>
parents: 69694
diff changeset
979 (define-key rcirc-multiline-minor-mode-map
000a5d4aa083 (rcirc-default-server): Rename from rcirc-server.
Eli Zaretskii <eliz@gnu.org>
parents: 69694
diff changeset
980 (kbd "C-c C-k") 'rcirc-multiline-minor-cancel)
000a5d4aa083 (rcirc-default-server): Rename from rcirc-server.
Eli Zaretskii <eliz@gnu.org>
parents: 69694
diff changeset
981 (define-key rcirc-multiline-minor-mode-map
000a5d4aa083 (rcirc-default-server): Rename from rcirc-server.
Eli Zaretskii <eliz@gnu.org>
parents: 69694
diff changeset
982 (kbd "ESC ESC ESC") 'rcirc-multiline-minor-cancel)
66248
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
983
69860
000a5d4aa083 (rcirc-default-server): Rename from rcirc-server.
Eli Zaretskii <eliz@gnu.org>
parents: 69694
diff changeset
984 (define-minor-mode rcirc-multiline-minor-mode
000a5d4aa083 (rcirc-default-server): Rename from rcirc-server.
Eli Zaretskii <eliz@gnu.org>
parents: 69694
diff changeset
985 "Minor mode for editing multiple lines in rcirc."
000a5d4aa083 (rcirc-default-server): Rename from rcirc-server.
Eli Zaretskii <eliz@gnu.org>
parents: 69694
diff changeset
986 :init-value nil
000a5d4aa083 (rcirc-default-server): Rename from rcirc-server.
Eli Zaretskii <eliz@gnu.org>
parents: 69694
diff changeset
987 :lighter " rcirc-mline"
000a5d4aa083 (rcirc-default-server): Rename from rcirc-server.
Eli Zaretskii <eliz@gnu.org>
parents: 69694
diff changeset
988 :keymap rcirc-multiline-minor-mode-map
000a5d4aa083 (rcirc-default-server): Rename from rcirc-server.
Eli Zaretskii <eliz@gnu.org>
parents: 69694
diff changeset
989 :global nil
000a5d4aa083 (rcirc-default-server): Rename from rcirc-server.
Eli Zaretskii <eliz@gnu.org>
parents: 69694
diff changeset
990 :group 'rcirc
000a5d4aa083 (rcirc-default-server): Rename from rcirc-server.
Eli Zaretskii <eliz@gnu.org>
parents: 69694
diff changeset
991 (make-local-variable 'rcirc-parent-buffer)
70215
90d76f24753a Revision: emacs@sv.gnu.org/emacs--devo--0--patch-247
Miles Bader <miles@gnu.org>
parents: 69860
diff changeset
992 (put 'rcirc-parent-buffer 'permanent-local t)
90d76f24753a Revision: emacs@sv.gnu.org/emacs--devo--0--patch-247
Miles Bader <miles@gnu.org>
parents: 69860
diff changeset
993 (setq fill-column rcirc-max-message-length))
66248
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
994
69860
000a5d4aa083 (rcirc-default-server): Rename from rcirc-server.
Eli Zaretskii <eliz@gnu.org>
parents: 69694
diff changeset
995 (defun rcirc-multiline-minor-submit ()
66248
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
996 "Send the text in buffer back to parent buffer."
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
997 (interactive)
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
998 (assert rcirc-parent-buffer)
66703
6cfb275aa300 Use split-string OMIT-NULLS argument.
Eli Zaretskii <eliz@gnu.org>
parents: 66272
diff changeset
999 (untabify (point-min) (point-max))
66248
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1000 (let ((text (buffer-substring (point-min) (point-max)))
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1001 (buffer (current-buffer))
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1002 (pos (point)))
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1003 (set-buffer rcirc-parent-buffer)
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1004 (goto-char (point-max))
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1005 (insert text)
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1006 (kill-buffer buffer)
66703
6cfb275aa300 Use split-string OMIT-NULLS argument.
Eli Zaretskii <eliz@gnu.org>
parents: 66272
diff changeset
1007 (set-window-configuration rcirc-window-configuration)
6cfb275aa300 Use split-string OMIT-NULLS argument.
Eli Zaretskii <eliz@gnu.org>
parents: 66272
diff changeset
1008 (goto-char (+ rcirc-prompt-end-marker (1- pos)))))
66248
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1009
69860
000a5d4aa083 (rcirc-default-server): Rename from rcirc-server.
Eli Zaretskii <eliz@gnu.org>
parents: 69694
diff changeset
1010 (defun rcirc-multiline-minor-cancel ()
66248
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1011 "Cancel the multiline edit."
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1012 (interactive)
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1013 (kill-buffer (current-buffer))
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1014 (set-window-configuration rcirc-window-configuration))
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1015
68960
6e3160901812 (rcirc-connect): Make all arguments optional, and default to global variable
Eli Zaretskii <eliz@gnu.org>
parents: 68838
diff changeset
1016 (defun rcirc-any-buffer (process)
66703
6cfb275aa300 Use split-string OMIT-NULLS argument.
Eli Zaretskii <eliz@gnu.org>
parents: 66272
diff changeset
1017 "Return a buffer for PROCESS, either the one selected or the process buffer."
68960
6e3160901812 (rcirc-connect): Make all arguments optional, and default to global variable
Eli Zaretskii <eliz@gnu.org>
parents: 68838
diff changeset
1018 (if rcirc-always-use-server-buffer-flag
6e3160901812 (rcirc-connect): Make all arguments optional, and default to global variable
Eli Zaretskii <eliz@gnu.org>
parents: 68838
diff changeset
1019 (process-buffer process)
6e3160901812 (rcirc-connect): Make all arguments optional, and default to global variable
Eli Zaretskii <eliz@gnu.org>
parents: 68838
diff changeset
1020 (let ((buffer (window-buffer (selected-window))))
6e3160901812 (rcirc-connect): Make all arguments optional, and default to global variable
Eli Zaretskii <eliz@gnu.org>
parents: 68838
diff changeset
1021 (if (and buffer
6e3160901812 (rcirc-connect): Make all arguments optional, and default to global variable
Eli Zaretskii <eliz@gnu.org>
parents: 68838
diff changeset
1022 (with-current-buffer buffer
6e3160901812 (rcirc-connect): Make all arguments optional, and default to global variable
Eli Zaretskii <eliz@gnu.org>
parents: 68838
diff changeset
1023 (and (eq major-mode 'rcirc-mode)
69860
000a5d4aa083 (rcirc-default-server): Rename from rcirc-server.
Eli Zaretskii <eliz@gnu.org>
parents: 69694
diff changeset
1024 (eq (rcirc-buffer-process) process))))
68960
6e3160901812 (rcirc-connect): Make all arguments optional, and default to global variable
Eli Zaretskii <eliz@gnu.org>
parents: 68838
diff changeset
1025 buffer
6e3160901812 (rcirc-connect): Make all arguments optional, and default to global variable
Eli Zaretskii <eliz@gnu.org>
parents: 68838
diff changeset
1026 (process-buffer process)))))
66248
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1027
68807
7ba97c461db7 Revision: emacs@sv.gnu.org/emacs--devo--0--patch-69
Miles Bader <miles@gnu.org>
parents: 68731
diff changeset
1028 (defcustom rcirc-response-formats
68960
6e3160901812 (rcirc-connect): Make all arguments optional, and default to global variable
Eli Zaretskii <eliz@gnu.org>
parents: 68838
diff changeset
1029 '(("PRIVMSG" . "%T<%N> %m")
6e3160901812 (rcirc-connect): Make all arguments optional, and default to global variable
Eli Zaretskii <eliz@gnu.org>
parents: 68838
diff changeset
1030 ("NOTICE" . "%T-%N- %m")
6e3160901812 (rcirc-connect): Make all arguments optional, and default to global variable
Eli Zaretskii <eliz@gnu.org>
parents: 68838
diff changeset
1031 ("ACTION" . "%T[%N %m]")
68807
7ba97c461db7 Revision: emacs@sv.gnu.org/emacs--devo--0--patch-69
Miles Bader <miles@gnu.org>
parents: 68731
diff changeset
1032 ("COMMAND" . "%T%m")
7ba97c461db7 Revision: emacs@sv.gnu.org/emacs--devo--0--patch-69
Miles Bader <miles@gnu.org>
parents: 68731
diff changeset
1033 ("ERROR" . "%T%fw!!! %m")
7ba97c461db7 Revision: emacs@sv.gnu.org/emacs--devo--0--patch-69
Miles Bader <miles@gnu.org>
parents: 68731
diff changeset
1034 (t . "%T%fp*** %fs%n %r %m"))
7ba97c461db7 Revision: emacs@sv.gnu.org/emacs--devo--0--patch-69
Miles Bader <miles@gnu.org>
parents: 68731
diff changeset
1035 "An alist of formats used for printing responses.
7ba97c461db7 Revision: emacs@sv.gnu.org/emacs--devo--0--patch-69
Miles Bader <miles@gnu.org>
parents: 68731
diff changeset
1036 The format is looked up using the response-type as a key;
7ba97c461db7 Revision: emacs@sv.gnu.org/emacs--devo--0--patch-69
Miles Bader <miles@gnu.org>
parents: 68731
diff changeset
1037 if no match is found, the default entry (with a key of `t') is used.
7ba97c461db7 Revision: emacs@sv.gnu.org/emacs--devo--0--patch-69
Miles Bader <miles@gnu.org>
parents: 68731
diff changeset
1038
7ba97c461db7 Revision: emacs@sv.gnu.org/emacs--devo--0--patch-69
Miles Bader <miles@gnu.org>
parents: 68731
diff changeset
1039 The entry's value part should be a string, which is inserted with
7ba97c461db7 Revision: emacs@sv.gnu.org/emacs--devo--0--patch-69
Miles Bader <miles@gnu.org>
parents: 68731
diff changeset
1040 the of the following escape sequences replaced by the described values:
7ba97c461db7 Revision: emacs@sv.gnu.org/emacs--devo--0--patch-69
Miles Bader <miles@gnu.org>
parents: 68731
diff changeset
1041
7ba97c461db7 Revision: emacs@sv.gnu.org/emacs--devo--0--patch-69
Miles Bader <miles@gnu.org>
parents: 68731
diff changeset
1042 %m The message text
68960
6e3160901812 (rcirc-connect): Make all arguments optional, and default to global variable
Eli Zaretskii <eliz@gnu.org>
parents: 68838
diff changeset
1043 %n The sender's nick
6e3160901812 (rcirc-connect): Make all arguments optional, and default to global variable
Eli Zaretskii <eliz@gnu.org>
parents: 68838
diff changeset
1044 %N The sender's nick (with face `rcirc-my-nick' or `rcirc-other-nick')
68807
7ba97c461db7 Revision: emacs@sv.gnu.org/emacs--devo--0--patch-69
Miles Bader <miles@gnu.org>
parents: 68731
diff changeset
1045 %r The response-type
7ba97c461db7 Revision: emacs@sv.gnu.org/emacs--devo--0--patch-69
Miles Bader <miles@gnu.org>
parents: 68731
diff changeset
1046 %T The timestamp (with face `rcirc-timestamp')
7ba97c461db7 Revision: emacs@sv.gnu.org/emacs--devo--0--patch-69
Miles Bader <miles@gnu.org>
parents: 68731
diff changeset
1047 %t The target
7ba97c461db7 Revision: emacs@sv.gnu.org/emacs--devo--0--patch-69
Miles Bader <miles@gnu.org>
parents: 68731
diff changeset
1048 %fw Following text uses the face `font-lock-warning-face'
7ba97c461db7 Revision: emacs@sv.gnu.org/emacs--devo--0--patch-69
Miles Bader <miles@gnu.org>
parents: 68731
diff changeset
1049 %fp Following text uses the face `rcirc-server-prefix'
7ba97c461db7 Revision: emacs@sv.gnu.org/emacs--devo--0--patch-69
Miles Bader <miles@gnu.org>
parents: 68731
diff changeset
1050 %fs Following text uses the face `rcirc-server'
7ba97c461db7 Revision: emacs@sv.gnu.org/emacs--devo--0--patch-69
Miles Bader <miles@gnu.org>
parents: 68731
diff changeset
1051 %f[FACE] Following text uses the face FACE
68838
6a3bf61d8473 Revision: emacs@sv.gnu.org/emacs--devo--0--patch-79
Miles Bader <miles@gnu.org>
parents: 68807
diff changeset
1052 %f- Following text uses the default face
69860
000a5d4aa083 (rcirc-default-server): Rename from rcirc-server.
Eli Zaretskii <eliz@gnu.org>
parents: 69694
diff changeset
1053 %% A literal `%' character"
68807
7ba97c461db7 Revision: emacs@sv.gnu.org/emacs--devo--0--patch-69
Miles Bader <miles@gnu.org>
parents: 68731
diff changeset
1054 :type '(alist :key-type (choice (string :tag "Type")
7ba97c461db7 Revision: emacs@sv.gnu.org/emacs--devo--0--patch-69
Miles Bader <miles@gnu.org>
parents: 68731
diff changeset
1055 (const :tag "Default" t))
7ba97c461db7 Revision: emacs@sv.gnu.org/emacs--devo--0--patch-69
Miles Bader <miles@gnu.org>
parents: 68731
diff changeset
1056 :value-type string)
7ba97c461db7 Revision: emacs@sv.gnu.org/emacs--devo--0--patch-69
Miles Bader <miles@gnu.org>
parents: 68731
diff changeset
1057 :group 'rcirc)
7ba97c461db7 Revision: emacs@sv.gnu.org/emacs--devo--0--patch-69
Miles Bader <miles@gnu.org>
parents: 68731
diff changeset
1058
66248
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1059 (defun rcirc-format-response-string (process sender response target text)
68807
7ba97c461db7 Revision: emacs@sv.gnu.org/emacs--devo--0--patch-69
Miles Bader <miles@gnu.org>
parents: 68731
diff changeset
1060 "Return a nicely-formatted response string, incorporating TEXT
7ba97c461db7 Revision: emacs@sv.gnu.org/emacs--devo--0--patch-69
Miles Bader <miles@gnu.org>
parents: 68731
diff changeset
1061 \(and perhaps other arguments). The specific formatting used
7ba97c461db7 Revision: emacs@sv.gnu.org/emacs--devo--0--patch-69
Miles Bader <miles@gnu.org>
parents: 68731
diff changeset
1062 is found by looking up RESPONSE in `rcirc-response-formats'."
7ba97c461db7 Revision: emacs@sv.gnu.org/emacs--devo--0--patch-69
Miles Bader <miles@gnu.org>
parents: 68731
diff changeset
1063 (let ((chunks
7ba97c461db7 Revision: emacs@sv.gnu.org/emacs--devo--0--patch-69
Miles Bader <miles@gnu.org>
parents: 68731
diff changeset
1064 (split-string (or (cdr (assoc response rcirc-response-formats))
7ba97c461db7 Revision: emacs@sv.gnu.org/emacs--devo--0--patch-69
Miles Bader <miles@gnu.org>
parents: 68731
diff changeset
1065 (cdr (assq t rcirc-response-formats)))
7ba97c461db7 Revision: emacs@sv.gnu.org/emacs--devo--0--patch-69
Miles Bader <miles@gnu.org>
parents: 68731
diff changeset
1066 "%"))
70215
90d76f24753a Revision: emacs@sv.gnu.org/emacs--devo--0--patch-247
Miles Bader <miles@gnu.org>
parents: 69860
diff changeset
1067 (sender (or sender ""))
68807
7ba97c461db7 Revision: emacs@sv.gnu.org/emacs--devo--0--patch-69
Miles Bader <miles@gnu.org>
parents: 68731
diff changeset
1068 (result "")
7ba97c461db7 Revision: emacs@sv.gnu.org/emacs--devo--0--patch-69
Miles Bader <miles@gnu.org>
parents: 68731
diff changeset
1069 (face nil)
7ba97c461db7 Revision: emacs@sv.gnu.org/emacs--devo--0--patch-69
Miles Bader <miles@gnu.org>
parents: 68731
diff changeset
1070 key face-key repl)
7ba97c461db7 Revision: emacs@sv.gnu.org/emacs--devo--0--patch-69
Miles Bader <miles@gnu.org>
parents: 68731
diff changeset
1071 (when (equal (car chunks) "")
7ba97c461db7 Revision: emacs@sv.gnu.org/emacs--devo--0--patch-69
Miles Bader <miles@gnu.org>
parents: 68731
diff changeset
1072 (pop chunks))
7ba97c461db7 Revision: emacs@sv.gnu.org/emacs--devo--0--patch-69
Miles Bader <miles@gnu.org>
parents: 68731
diff changeset
1073 (dolist (chunk chunks)
7ba97c461db7 Revision: emacs@sv.gnu.org/emacs--devo--0--patch-69
Miles Bader <miles@gnu.org>
parents: 68731
diff changeset
1074 (if (equal chunk "")
7ba97c461db7 Revision: emacs@sv.gnu.org/emacs--devo--0--patch-69
Miles Bader <miles@gnu.org>
parents: 68731
diff changeset
1075 (setq key ?%)
7ba97c461db7 Revision: emacs@sv.gnu.org/emacs--devo--0--patch-69
Miles Bader <miles@gnu.org>
parents: 68731
diff changeset
1076 (setq key (aref chunk 0))
7ba97c461db7 Revision: emacs@sv.gnu.org/emacs--devo--0--patch-69
Miles Bader <miles@gnu.org>
parents: 68731
diff changeset
1077 (setq chunk (substring chunk 1)))
7ba97c461db7 Revision: emacs@sv.gnu.org/emacs--devo--0--patch-69
Miles Bader <miles@gnu.org>
parents: 68731
diff changeset
1078 (setq repl
7ba97c461db7 Revision: emacs@sv.gnu.org/emacs--devo--0--patch-69
Miles Bader <miles@gnu.org>
parents: 68731
diff changeset
1079 (cond ((eq key ?%)
68838
6a3bf61d8473 Revision: emacs@sv.gnu.org/emacs--devo--0--patch-79
Miles Bader <miles@gnu.org>
parents: 68807
diff changeset
1080 ;; %% -- literal % character
68807
7ba97c461db7 Revision: emacs@sv.gnu.org/emacs--devo--0--patch-69
Miles Bader <miles@gnu.org>
parents: 68731
diff changeset
1081 "%")
68960
6e3160901812 (rcirc-connect): Make all arguments optional, and default to global variable
Eli Zaretskii <eliz@gnu.org>
parents: 68838
diff changeset
1082 ((or (eq key ?n) (eq key ?N))
6e3160901812 (rcirc-connect): Make all arguments optional, and default to global variable
Eli Zaretskii <eliz@gnu.org>
parents: 68838
diff changeset
1083 ;; %n/%N -- nick
72616
1c7de7b9540b (rcirc-keywords): New variable.
Eli Zaretskii <eliz@gnu.org>
parents: 72468
diff changeset
1084 (let ((nick (concat (if (string= (with-rcirc-process-buffer
1c7de7b9540b (rcirc-keywords): New variable.
Eli Zaretskii <eliz@gnu.org>
parents: 72468
diff changeset
1085 process
69860
000a5d4aa083 (rcirc-default-server): Rename from rcirc-server.
Eli Zaretskii <eliz@gnu.org>
parents: 69694
diff changeset
1086 rcirc-server)
68960
6e3160901812 (rcirc-connect): Make all arguments optional, and default to global variable
Eli Zaretskii <eliz@gnu.org>
parents: 68838
diff changeset
1087 sender)
6e3160901812 (rcirc-connect): Make all arguments optional, and default to global variable
Eli Zaretskii <eliz@gnu.org>
parents: 68838
diff changeset
1088 ""
69460
df75d16d140e Revision: emacs@sv.gnu.org/emacs--devo--0--patch-155
Miles Bader <miles@gnu.org>
parents: 69252
diff changeset
1089 sender)
68960
6e3160901812 (rcirc-connect): Make all arguments optional, and default to global variable
Eli Zaretskii <eliz@gnu.org>
parents: 68838
diff changeset
1090 (and target (concat "," target)))))
6e3160901812 (rcirc-connect): Make all arguments optional, and default to global variable
Eli Zaretskii <eliz@gnu.org>
parents: 68838
diff changeset
1091 (rcirc-facify nick
6e3160901812 (rcirc-connect): Make all arguments optional, and default to global variable
Eli Zaretskii <eliz@gnu.org>
parents: 68838
diff changeset
1092 (if (eq key ?n)
6e3160901812 (rcirc-connect): Make all arguments optional, and default to global variable
Eli Zaretskii <eliz@gnu.org>
parents: 68838
diff changeset
1093 face
70215
90d76f24753a Revision: emacs@sv.gnu.org/emacs--devo--0--patch-247
Miles Bader <miles@gnu.org>
parents: 69860
diff changeset
1094 (cond ((string= sender (rcirc-nick process))
90d76f24753a Revision: emacs@sv.gnu.org/emacs--devo--0--patch-247
Miles Bader <miles@gnu.org>
parents: 69860
diff changeset
1095 'rcirc-my-nick)
72616
1c7de7b9540b (rcirc-keywords): New variable.
Eli Zaretskii <eliz@gnu.org>
parents: 72468
diff changeset
1096 ((and rcirc-bright-nicks
1c7de7b9540b (rcirc-keywords): New variable.
Eli Zaretskii <eliz@gnu.org>
parents: 72468
diff changeset
1097 (string-match
1c7de7b9540b (rcirc-keywords): New variable.
Eli Zaretskii <eliz@gnu.org>
parents: 72468
diff changeset
1098 (regexp-opt rcirc-bright-nicks)
1c7de7b9540b (rcirc-keywords): New variable.
Eli Zaretskii <eliz@gnu.org>
parents: 72468
diff changeset
1099 sender))
70215
90d76f24753a Revision: emacs@sv.gnu.org/emacs--devo--0--patch-247
Miles Bader <miles@gnu.org>
parents: 69860
diff changeset
1100 'rcirc-bright-nick)
72616
1c7de7b9540b (rcirc-keywords): New variable.
Eli Zaretskii <eliz@gnu.org>
parents: 72468
diff changeset
1101 ((and rcirc-dim-nicks
1c7de7b9540b (rcirc-keywords): New variable.
Eli Zaretskii <eliz@gnu.org>
parents: 72468
diff changeset
1102 (string-match
1c7de7b9540b (rcirc-keywords): New variable.
Eli Zaretskii <eliz@gnu.org>
parents: 72468
diff changeset
1103 (regexp-opt rcirc-dim-nicks)
1c7de7b9540b (rcirc-keywords): New variable.
Eli Zaretskii <eliz@gnu.org>
parents: 72468
diff changeset
1104 sender))
70215
90d76f24753a Revision: emacs@sv.gnu.org/emacs--devo--0--patch-247
Miles Bader <miles@gnu.org>
parents: 69860
diff changeset
1105 'rcirc-dim-nick)
90d76f24753a Revision: emacs@sv.gnu.org/emacs--devo--0--patch-247
Miles Bader <miles@gnu.org>
parents: 69860
diff changeset
1106 (t
90d76f24753a Revision: emacs@sv.gnu.org/emacs--devo--0--patch-247
Miles Bader <miles@gnu.org>
parents: 69860
diff changeset
1107 'rcirc-other-nick))))))
72616
1c7de7b9540b (rcirc-keywords): New variable.
Eli Zaretskii <eliz@gnu.org>
parents: 72468
diff changeset
1108 ((eq key ?T)
68838
6a3bf61d8473 Revision: emacs@sv.gnu.org/emacs--devo--0--patch-79
Miles Bader <miles@gnu.org>
parents: 68807
diff changeset
1109 ;; %T -- timestamp
68807
7ba97c461db7 Revision: emacs@sv.gnu.org/emacs--devo--0--patch-69
Miles Bader <miles@gnu.org>
parents: 68731
diff changeset
1110 (rcirc-facify
7ba97c461db7 Revision: emacs@sv.gnu.org/emacs--devo--0--patch-69
Miles Bader <miles@gnu.org>
parents: 68731
diff changeset
1111 (format-time-string rcirc-time-format (current-time))
7ba97c461db7 Revision: emacs@sv.gnu.org/emacs--devo--0--patch-69
Miles Bader <miles@gnu.org>
parents: 68731
diff changeset
1112 'rcirc-timestamp))
7ba97c461db7 Revision: emacs@sv.gnu.org/emacs--devo--0--patch-69
Miles Bader <miles@gnu.org>
parents: 68731
diff changeset
1113 ((eq key ?m)
68838
6a3bf61d8473 Revision: emacs@sv.gnu.org/emacs--devo--0--patch-79
Miles Bader <miles@gnu.org>
parents: 68807
diff changeset
1114 ;; %m -- message text
72616
1c7de7b9540b (rcirc-keywords): New variable.
Eli Zaretskii <eliz@gnu.org>
parents: 72468
diff changeset
1115 (rcirc-markup-text process sender response (rcirc-facify text face)))
68807
7ba97c461db7 Revision: emacs@sv.gnu.org/emacs--devo--0--patch-69
Miles Bader <miles@gnu.org>
parents: 68731
diff changeset
1116 ((eq key ?t)
68838
6a3bf61d8473 Revision: emacs@sv.gnu.org/emacs--devo--0--patch-79
Miles Bader <miles@gnu.org>
parents: 68807
diff changeset
1117 ;; %t -- target
68807
7ba97c461db7 Revision: emacs@sv.gnu.org/emacs--devo--0--patch-69
Miles Bader <miles@gnu.org>
parents: 68731
diff changeset
1118 (rcirc-facify (or rcirc-target "") face))
7ba97c461db7 Revision: emacs@sv.gnu.org/emacs--devo--0--patch-69
Miles Bader <miles@gnu.org>
parents: 68731
diff changeset
1119 ((eq key ?r)
68838
6a3bf61d8473 Revision: emacs@sv.gnu.org/emacs--devo--0--patch-79
Miles Bader <miles@gnu.org>
parents: 68807
diff changeset
1120 ;; %r -- response
68807
7ba97c461db7 Revision: emacs@sv.gnu.org/emacs--devo--0--patch-69
Miles Bader <miles@gnu.org>
parents: 68731
diff changeset
1121 (rcirc-facify response face))
7ba97c461db7 Revision: emacs@sv.gnu.org/emacs--devo--0--patch-69
Miles Bader <miles@gnu.org>
parents: 68731
diff changeset
1122 ((eq key ?f)
68838
6a3bf61d8473 Revision: emacs@sv.gnu.org/emacs--devo--0--patch-79
Miles Bader <miles@gnu.org>
parents: 68807
diff changeset
1123 ;; %f -- change face
68807
7ba97c461db7 Revision: emacs@sv.gnu.org/emacs--devo--0--patch-69
Miles Bader <miles@gnu.org>
parents: 68731
diff changeset
1124 (setq face-key (aref chunk 0))
68838
6a3bf61d8473 Revision: emacs@sv.gnu.org/emacs--devo--0--patch-79
Miles Bader <miles@gnu.org>
parents: 68807
diff changeset
1125 (setq chunk (substring chunk 1))
68807
7ba97c461db7 Revision: emacs@sv.gnu.org/emacs--devo--0--patch-69
Miles Bader <miles@gnu.org>
parents: 68731
diff changeset
1126 (cond ((eq face-key ?w)
68838
6a3bf61d8473 Revision: emacs@sv.gnu.org/emacs--devo--0--patch-79
Miles Bader <miles@gnu.org>
parents: 68807
diff changeset
1127 ;; %fw -- warning face
68807
7ba97c461db7 Revision: emacs@sv.gnu.org/emacs--devo--0--patch-69
Miles Bader <miles@gnu.org>
parents: 68731
diff changeset
1128 (setq face 'font-lock-warning-face))
7ba97c461db7 Revision: emacs@sv.gnu.org/emacs--devo--0--patch-69
Miles Bader <miles@gnu.org>
parents: 68731
diff changeset
1129 ((eq face-key ?p)
68838
6a3bf61d8473 Revision: emacs@sv.gnu.org/emacs--devo--0--patch-79
Miles Bader <miles@gnu.org>
parents: 68807
diff changeset
1130 ;; %fp -- server-prefix face
68807
7ba97c461db7 Revision: emacs@sv.gnu.org/emacs--devo--0--patch-69
Miles Bader <miles@gnu.org>
parents: 68731
diff changeset
1131 (setq face 'rcirc-server-prefix))
7ba97c461db7 Revision: emacs@sv.gnu.org/emacs--devo--0--patch-69
Miles Bader <miles@gnu.org>
parents: 68731
diff changeset
1132 ((eq face-key ?s)
68838
6a3bf61d8473 Revision: emacs@sv.gnu.org/emacs--devo--0--patch-79
Miles Bader <miles@gnu.org>
parents: 68807
diff changeset
1133 ;; %fs -- warning face
68807
7ba97c461db7 Revision: emacs@sv.gnu.org/emacs--devo--0--patch-69
Miles Bader <miles@gnu.org>
parents: 68731
diff changeset
1134 (setq face 'rcirc-server))
7ba97c461db7 Revision: emacs@sv.gnu.org/emacs--devo--0--patch-69
Miles Bader <miles@gnu.org>
parents: 68731
diff changeset
1135 ((eq face-key ?-)
68838
6a3bf61d8473 Revision: emacs@sv.gnu.org/emacs--devo--0--patch-79
Miles Bader <miles@gnu.org>
parents: 68807
diff changeset
1136 ;; %fs -- warning face
68807
7ba97c461db7 Revision: emacs@sv.gnu.org/emacs--devo--0--patch-69
Miles Bader <miles@gnu.org>
parents: 68731
diff changeset
1137 (setq face nil))
7ba97c461db7 Revision: emacs@sv.gnu.org/emacs--devo--0--patch-69
Miles Bader <miles@gnu.org>
parents: 68731
diff changeset
1138 ((and (eq face-key ?\[)
68838
6a3bf61d8473 Revision: emacs@sv.gnu.org/emacs--devo--0--patch-79
Miles Bader <miles@gnu.org>
parents: 68807
diff changeset
1139 (string-match "^\\([^]]*\\)[]]" chunk)
68807
7ba97c461db7 Revision: emacs@sv.gnu.org/emacs--devo--0--patch-69
Miles Bader <miles@gnu.org>
parents: 68731
diff changeset
1140 (facep (match-string 1 chunk)))
68838
6a3bf61d8473 Revision: emacs@sv.gnu.org/emacs--devo--0--patch-79
Miles Bader <miles@gnu.org>
parents: 68807
diff changeset
1141 ;; %f[...] -- named face
68807
7ba97c461db7 Revision: emacs@sv.gnu.org/emacs--devo--0--patch-69
Miles Bader <miles@gnu.org>
parents: 68731
diff changeset
1142 (setq face (intern (match-string 1 chunk)))
68838
6a3bf61d8473 Revision: emacs@sv.gnu.org/emacs--devo--0--patch-79
Miles Bader <miles@gnu.org>
parents: 68807
diff changeset
1143 (setq chunk (substring chunk (match-end 0)))))
6a3bf61d8473 Revision: emacs@sv.gnu.org/emacs--devo--0--patch-79
Miles Bader <miles@gnu.org>
parents: 68807
diff changeset
1144 "")))
68807
7ba97c461db7 Revision: emacs@sv.gnu.org/emacs--devo--0--patch-69
Miles Bader <miles@gnu.org>
parents: 68731
diff changeset
1145 (setq result (concat result repl (rcirc-facify chunk face))))
7ba97c461db7 Revision: emacs@sv.gnu.org/emacs--devo--0--patch-69
Miles Bader <miles@gnu.org>
parents: 68731
diff changeset
1146 result))
66248
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1147
68731
85be285e3494 (rcirc-startup-channels-alist): Add irc.freenode.net and #emacs as defaults.
Eli Zaretskii <eliz@gnu.org>
parents: 68648
diff changeset
1148 (defun rcirc-target-buffer (process sender response target text)
85be285e3494 (rcirc-startup-channels-alist): Add irc.freenode.net and #emacs as defaults.
Eli Zaretskii <eliz@gnu.org>
parents: 68648
diff changeset
1149 "Return a buffer to print the server response."
85be285e3494 (rcirc-startup-channels-alist): Add irc.freenode.net and #emacs as defaults.
Eli Zaretskii <eliz@gnu.org>
parents: 68648
diff changeset
1150 (assert (not (bufferp target)))
85be285e3494 (rcirc-startup-channels-alist): Add irc.freenode.net and #emacs as defaults.
Eli Zaretskii <eliz@gnu.org>
parents: 68648
diff changeset
1151 (with-rcirc-process-buffer process
85be285e3494 (rcirc-startup-channels-alist): Add irc.freenode.net and #emacs as defaults.
Eli Zaretskii <eliz@gnu.org>
parents: 68648
diff changeset
1152 (cond ((not target)
68960
6e3160901812 (rcirc-connect): Make all arguments optional, and default to global variable
Eli Zaretskii <eliz@gnu.org>
parents: 68838
diff changeset
1153 (rcirc-any-buffer process))
68731
85be285e3494 (rcirc-startup-channels-alist): Add irc.freenode.net and #emacs as defaults.
Eli Zaretskii <eliz@gnu.org>
parents: 68648
diff changeset
1154 ((not (rcirc-channel-p target))
85be285e3494 (rcirc-startup-channels-alist): Add irc.freenode.net and #emacs as defaults.
Eli Zaretskii <eliz@gnu.org>
parents: 68648
diff changeset
1155 ;; message from another user
85be285e3494 (rcirc-startup-channels-alist): Add irc.freenode.net and #emacs as defaults.
Eli Zaretskii <eliz@gnu.org>
parents: 68648
diff changeset
1156 (if (string= response "PRIVMSG")
85be285e3494 (rcirc-startup-channels-alist): Add irc.freenode.net and #emacs as defaults.
Eli Zaretskii <eliz@gnu.org>
parents: 68648
diff changeset
1157 (rcirc-get-buffer-create process (if (string= sender rcirc-nick)
85be285e3494 (rcirc-startup-channels-alist): Add irc.freenode.net and #emacs as defaults.
Eli Zaretskii <eliz@gnu.org>
parents: 68648
diff changeset
1158 target
85be285e3494 (rcirc-startup-channels-alist): Add irc.freenode.net and #emacs as defaults.
Eli Zaretskii <eliz@gnu.org>
parents: 68648
diff changeset
1159 sender))
85be285e3494 (rcirc-startup-channels-alist): Add irc.freenode.net and #emacs as defaults.
Eli Zaretskii <eliz@gnu.org>
parents: 68648
diff changeset
1160 (rcirc-get-buffer process target t)))
85be285e3494 (rcirc-startup-channels-alist): Add irc.freenode.net and #emacs as defaults.
Eli Zaretskii <eliz@gnu.org>
parents: 68648
diff changeset
1161 ((or (rcirc-get-buffer process target)
68960
6e3160901812 (rcirc-connect): Make all arguments optional, and default to global variable
Eli Zaretskii <eliz@gnu.org>
parents: 68838
diff changeset
1162 (rcirc-any-buffer process))))))
68731
85be285e3494 (rcirc-startup-channels-alist): Add irc.freenode.net and #emacs as defaults.
Eli Zaretskii <eliz@gnu.org>
parents: 68648
diff changeset
1163
72616
1c7de7b9540b (rcirc-keywords): New variable.
Eli Zaretskii <eliz@gnu.org>
parents: 72468
diff changeset
1164 (defvar rcirc-activity-types nil)
1c7de7b9540b (rcirc-keywords): New variable.
Eli Zaretskii <eliz@gnu.org>
parents: 72468
diff changeset
1165 (make-variable-buffer-local 'rcirc-activity-types)
69860
000a5d4aa083 (rcirc-default-server): Rename from rcirc-server.
Eli Zaretskii <eliz@gnu.org>
parents: 69694
diff changeset
1166 (defvar rcirc-last-sender nil)
000a5d4aa083 (rcirc-default-server): Rename from rcirc-server.
Eli Zaretskii <eliz@gnu.org>
parents: 69694
diff changeset
1167 (make-variable-buffer-local 'rcirc-last-sender)
72468
5e47ca87ee3c Rcirc update from Ryan Yeske
Miles Bader <miles@gnu.org>
parents: 71442
diff changeset
1168
5e47ca87ee3c Rcirc update from Ryan Yeske
Miles Bader <miles@gnu.org>
parents: 71442
diff changeset
1169 (defun rcirc-scroll-to-bottom (window display-start)
5e47ca87ee3c Rcirc update from Ryan Yeske
Miles Bader <miles@gnu.org>
parents: 71442
diff changeset
1170 "Scroll window to show maximum output if `rcirc-show-maximum-output' is
5e47ca87ee3c Rcirc update from Ryan Yeske
Miles Bader <miles@gnu.org>
parents: 71442
diff changeset
1171 non-nil."
5e47ca87ee3c Rcirc update from Ryan Yeske
Miles Bader <miles@gnu.org>
parents: 71442
diff changeset
1172 (when rcirc-show-maximum-output
5e47ca87ee3c Rcirc update from Ryan Yeske
Miles Bader <miles@gnu.org>
parents: 71442
diff changeset
1173 (with-selected-window window
5e47ca87ee3c Rcirc update from Ryan Yeske
Miles Bader <miles@gnu.org>
parents: 71442
diff changeset
1174 (when (>= (window-point) rcirc-prompt-end-marker)
5e47ca87ee3c Rcirc update from Ryan Yeske
Miles Bader <miles@gnu.org>
parents: 71442
diff changeset
1175 (recenter -1)))))
5e47ca87ee3c Rcirc update from Ryan Yeske
Miles Bader <miles@gnu.org>
parents: 71442
diff changeset
1176
66248
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1177 (defun rcirc-print (process sender response target text &optional activity)
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1178 "Print TEXT in the buffer associated with TARGET.
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1179 Format based on SENDER and RESPONSE. If ACTIVITY is non-nil,
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1180 record activity."
69860
000a5d4aa083 (rcirc-default-server): Rename from rcirc-server.
Eli Zaretskii <eliz@gnu.org>
parents: 69694
diff changeset
1181 (or text (setq text ""))
68731
85be285e3494 (rcirc-startup-channels-alist): Add irc.freenode.net and #emacs as defaults.
Eli Zaretskii <eliz@gnu.org>
parents: 68648
diff changeset
1182 (unless (or (member sender rcirc-ignore-list)
68079
61e9ea461d3c (rcirc-ignore-list): New option.
Alex Schroeder <alex@gnu.org>
parents: 68077
diff changeset
1183 (member (with-syntax-table rcirc-nick-syntax-table
70215
90d76f24753a Revision: emacs@sv.gnu.org/emacs--devo--0--patch-247
Miles Bader <miles@gnu.org>
parents: 69860
diff changeset
1184 (when (string-match "^\\([^/]\\w*\\)[:,]" text)
90d76f24753a Revision: emacs@sv.gnu.org/emacs--devo--0--patch-247
Miles Bader <miles@gnu.org>
parents: 69860
diff changeset
1185 (match-string 1 text)))
90d76f24753a Revision: emacs@sv.gnu.org/emacs--devo--0--patch-247
Miles Bader <miles@gnu.org>
parents: 69860
diff changeset
1186 rcirc-ignore-list))
68731
85be285e3494 (rcirc-startup-channels-alist): Add irc.freenode.net and #emacs as defaults.
Eli Zaretskii <eliz@gnu.org>
parents: 68648
diff changeset
1187 (let* ((buffer (rcirc-target-buffer process sender response target text))
68079
61e9ea461d3c (rcirc-ignore-list): New option.
Alex Schroeder <alex@gnu.org>
parents: 68077
diff changeset
1188 (inhibit-read-only t))
61e9ea461d3c (rcirc-ignore-list): New option.
Alex Schroeder <alex@gnu.org>
parents: 68077
diff changeset
1189 (with-current-buffer buffer
61e9ea461d3c (rcirc-ignore-list): New option.
Alex Schroeder <alex@gnu.org>
parents: 68077
diff changeset
1190 (let ((moving (= (point) rcirc-prompt-end-marker))
61e9ea461d3c (rcirc-ignore-list): New option.
Alex Schroeder <alex@gnu.org>
parents: 68077
diff changeset
1191 (old-point (point-marker))
61e9ea461d3c (rcirc-ignore-list): New option.
Alex Schroeder <alex@gnu.org>
parents: 68077
diff changeset
1192 (fill-start (marker-position rcirc-prompt-start-marker)))
66248
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1193
68079
61e9ea461d3c (rcirc-ignore-list): New option.
Alex Schroeder <alex@gnu.org>
parents: 68077
diff changeset
1194 (unless (string= sender (rcirc-nick process))
61e9ea461d3c (rcirc-ignore-list): New option.
Alex Schroeder <alex@gnu.org>
parents: 68077
diff changeset
1195 ;; only decode text from other senders, not ours
69860
000a5d4aa083 (rcirc-default-server): Rename from rcirc-server.
Eli Zaretskii <eliz@gnu.org>
parents: 69694
diff changeset
1196 (setq text (decode-coding-string text rcirc-decode-coding-system))
68079
61e9ea461d3c (rcirc-ignore-list): New option.
Alex Schroeder <alex@gnu.org>
parents: 68077
diff changeset
1197 ;; mark the line with overlay arrow
61e9ea461d3c (rcirc-ignore-list): New option.
Alex Schroeder <alex@gnu.org>
parents: 68077
diff changeset
1198 (unless (or (marker-position overlay-arrow-position)
61e9ea461d3c (rcirc-ignore-list): New option.
Alex Schroeder <alex@gnu.org>
parents: 68077
diff changeset
1199 (get-buffer-window (current-buffer)))
61e9ea461d3c (rcirc-ignore-list): New option.
Alex Schroeder <alex@gnu.org>
parents: 68077
diff changeset
1200 (set-marker overlay-arrow-position
61e9ea461d3c (rcirc-ignore-list): New option.
Alex Schroeder <alex@gnu.org>
parents: 68077
diff changeset
1201 (marker-position rcirc-prompt-start-marker))))
66248
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1202
68079
61e9ea461d3c (rcirc-ignore-list): New option.
Alex Schroeder <alex@gnu.org>
parents: 68077
diff changeset
1203 ;; temporarily set the marker insertion-type because
61e9ea461d3c (rcirc-ignore-list): New option.
Alex Schroeder <alex@gnu.org>
parents: 68077
diff changeset
1204 ;; insert-before-markers results in hidden text in new buffers
61e9ea461d3c (rcirc-ignore-list): New option.
Alex Schroeder <alex@gnu.org>
parents: 68077
diff changeset
1205 (goto-char rcirc-prompt-start-marker)
61e9ea461d3c (rcirc-ignore-list): New option.
Alex Schroeder <alex@gnu.org>
parents: 68077
diff changeset
1206 (set-marker-insertion-type rcirc-prompt-start-marker t)
61e9ea461d3c (rcirc-ignore-list): New option.
Alex Schroeder <alex@gnu.org>
parents: 68077
diff changeset
1207 (set-marker-insertion-type rcirc-prompt-end-marker t)
68807
7ba97c461db7 Revision: emacs@sv.gnu.org/emacs--devo--0--patch-69
Miles Bader <miles@gnu.org>
parents: 68731
diff changeset
1208
7ba97c461db7 Revision: emacs@sv.gnu.org/emacs--devo--0--patch-69
Miles Bader <miles@gnu.org>
parents: 68731
diff changeset
1209 (let ((fmted-text
7ba97c461db7 Revision: emacs@sv.gnu.org/emacs--devo--0--patch-69
Miles Bader <miles@gnu.org>
parents: 68731
diff changeset
1210 (rcirc-format-response-string process sender response nil
7ba97c461db7 Revision: emacs@sv.gnu.org/emacs--devo--0--patch-69
Miles Bader <miles@gnu.org>
parents: 68731
diff changeset
1211 text)))
7ba97c461db7 Revision: emacs@sv.gnu.org/emacs--devo--0--patch-69
Miles Bader <miles@gnu.org>
parents: 68731
diff changeset
1212
7ba97c461db7 Revision: emacs@sv.gnu.org/emacs--devo--0--patch-69
Miles Bader <miles@gnu.org>
parents: 68731
diff changeset
1213 (insert fmted-text (propertize "\n" 'hard t))
7ba97c461db7 Revision: emacs@sv.gnu.org/emacs--devo--0--patch-69
Miles Bader <miles@gnu.org>
parents: 68731
diff changeset
1214 (set-marker-insertion-type rcirc-prompt-start-marker nil)
7ba97c461db7 Revision: emacs@sv.gnu.org/emacs--devo--0--patch-69
Miles Bader <miles@gnu.org>
parents: 68731
diff changeset
1215 (set-marker-insertion-type rcirc-prompt-end-marker nil)
66248
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1216
68960
6e3160901812 (rcirc-connect): Make all arguments optional, and default to global variable
Eli Zaretskii <eliz@gnu.org>
parents: 68838
diff changeset
1217 (let ((text-start (make-marker)))
6e3160901812 (rcirc-connect): Make all arguments optional, and default to global variable
Eli Zaretskii <eliz@gnu.org>
parents: 68838
diff changeset
1218 (set-marker text-start
6e3160901812 (rcirc-connect): Make all arguments optional, and default to global variable
Eli Zaretskii <eliz@gnu.org>
parents: 68838
diff changeset
1219 (or (next-single-property-change fill-start
6e3160901812 (rcirc-connect): Make all arguments optional, and default to global variable
Eli Zaretskii <eliz@gnu.org>
parents: 68838
diff changeset
1220 'rcirc-text)
69461
1527bb09ec30 Revision: emacs@sv.gnu.org/emacs--devo--0--patch-156
Miles Bader <miles@gnu.org>
parents: 69460
diff changeset
1221 rcirc-prompt-end-marker))
68960
6e3160901812 (rcirc-connect): Make all arguments optional, and default to global variable
Eli Zaretskii <eliz@gnu.org>
parents: 68838
diff changeset
1222 ;; squeeze spaces out of text before rcirc-text
6e3160901812 (rcirc-connect): Make all arguments optional, and default to global variable
Eli Zaretskii <eliz@gnu.org>
parents: 68838
diff changeset
1223 (fill-region fill-start (1- text-start))
6e3160901812 (rcirc-connect): Make all arguments optional, and default to global variable
Eli Zaretskii <eliz@gnu.org>
parents: 68838
diff changeset
1224
6e3160901812 (rcirc-connect): Make all arguments optional, and default to global variable
Eli Zaretskii <eliz@gnu.org>
parents: 68838
diff changeset
1225 ;; fill the text we just inserted, maybe
6e3160901812 (rcirc-connect): Make all arguments optional, and default to global variable
Eli Zaretskii <eliz@gnu.org>
parents: 68838
diff changeset
1226 (when (and rcirc-fill-flag
6e3160901812 (rcirc-connect): Make all arguments optional, and default to global variable
Eli Zaretskii <eliz@gnu.org>
parents: 68838
diff changeset
1227 (not (string= response "372"))) ;/motd
6e3160901812 (rcirc-connect): Make all arguments optional, and default to global variable
Eli Zaretskii <eliz@gnu.org>
parents: 68838
diff changeset
1228 (let ((fill-prefix
6e3160901812 (rcirc-connect): Make all arguments optional, and default to global variable
Eli Zaretskii <eliz@gnu.org>
parents: 68838
diff changeset
1229 (or rcirc-fill-prefix
6e3160901812 (rcirc-connect): Make all arguments optional, and default to global variable
Eli Zaretskii <eliz@gnu.org>
parents: 68838
diff changeset
1230 (make-string (- text-start fill-start) ?\s)))
6e3160901812 (rcirc-connect): Make all arguments optional, and default to global variable
Eli Zaretskii <eliz@gnu.org>
parents: 68838
diff changeset
1231 (fill-column (cond ((eq rcirc-fill-column 'frame-width)
6e3160901812 (rcirc-connect): Make all arguments optional, and default to global variable
Eli Zaretskii <eliz@gnu.org>
parents: 68838
diff changeset
1232 (1- (frame-width)))
6e3160901812 (rcirc-connect): Make all arguments optional, and default to global variable
Eli Zaretskii <eliz@gnu.org>
parents: 68838
diff changeset
1233 (rcirc-fill-column
6e3160901812 (rcirc-connect): Make all arguments optional, and default to global variable
Eli Zaretskii <eliz@gnu.org>
parents: 68838
diff changeset
1234 rcirc-fill-column)
6e3160901812 (rcirc-connect): Make all arguments optional, and default to global variable
Eli Zaretskii <eliz@gnu.org>
parents: 68838
diff changeset
1235 (t fill-column))))
6e3160901812 (rcirc-connect): Make all arguments optional, and default to global variable
Eli Zaretskii <eliz@gnu.org>
parents: 68838
diff changeset
1236 (fill-region fill-start rcirc-prompt-start-marker 'left t)))))
66248
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1237
68079
61e9ea461d3c (rcirc-ignore-list): New option.
Alex Schroeder <alex@gnu.org>
parents: 68077
diff changeset
1238 ;; set inserted text to be read-only
61e9ea461d3c (rcirc-ignore-list): New option.
Alex Schroeder <alex@gnu.org>
parents: 68077
diff changeset
1239 (when rcirc-read-only-flag
61e9ea461d3c (rcirc-ignore-list): New option.
Alex Schroeder <alex@gnu.org>
parents: 68077
diff changeset
1240 (put-text-property rcirc-prompt-start-marker fill-start 'read-only t)
61e9ea461d3c (rcirc-ignore-list): New option.
Alex Schroeder <alex@gnu.org>
parents: 68077
diff changeset
1241 (let ((inhibit-read-only t))
61e9ea461d3c (rcirc-ignore-list): New option.
Alex Schroeder <alex@gnu.org>
parents: 68077
diff changeset
1242 (put-text-property rcirc-prompt-start-marker fill-start
61e9ea461d3c (rcirc-ignore-list): New option.
Alex Schroeder <alex@gnu.org>
parents: 68077
diff changeset
1243 'front-sticky t)
61e9ea461d3c (rcirc-ignore-list): New option.
Alex Schroeder <alex@gnu.org>
parents: 68077
diff changeset
1244 (put-text-property (1- (point)) (point) 'rear-nonsticky t)))
66703
6cfb275aa300 Use split-string OMIT-NULLS argument.
Eli Zaretskii <eliz@gnu.org>
parents: 66272
diff changeset
1245
68079
61e9ea461d3c (rcirc-ignore-list): New option.
Alex Schroeder <alex@gnu.org>
parents: 68077
diff changeset
1246 ;; truncate buffer if it is very long
61e9ea461d3c (rcirc-ignore-list): New option.
Alex Schroeder <alex@gnu.org>
parents: 68077
diff changeset
1247 (save-excursion
61e9ea461d3c (rcirc-ignore-list): New option.
Alex Schroeder <alex@gnu.org>
parents: 68077
diff changeset
1248 (when (and rcirc-buffer-maximum-lines
61e9ea461d3c (rcirc-ignore-list): New option.
Alex Schroeder <alex@gnu.org>
parents: 68077
diff changeset
1249 (> rcirc-buffer-maximum-lines 0)
61e9ea461d3c (rcirc-ignore-list): New option.
Alex Schroeder <alex@gnu.org>
parents: 68077
diff changeset
1250 (= (forward-line (- rcirc-buffer-maximum-lines)) 0))
61e9ea461d3c (rcirc-ignore-list): New option.
Alex Schroeder <alex@gnu.org>
parents: 68077
diff changeset
1251 (delete-region (point-min) (point))))
66248
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1252
68079
61e9ea461d3c (rcirc-ignore-list): New option.
Alex Schroeder <alex@gnu.org>
parents: 68077
diff changeset
1253 ;; set the window point for buffers show in windows
61e9ea461d3c (rcirc-ignore-list): New option.
Alex Schroeder <alex@gnu.org>
parents: 68077
diff changeset
1254 (walk-windows (lambda (w)
61e9ea461d3c (rcirc-ignore-list): New option.
Alex Schroeder <alex@gnu.org>
parents: 68077
diff changeset
1255 (unless (eq (selected-window) w)
61e9ea461d3c (rcirc-ignore-list): New option.
Alex Schroeder <alex@gnu.org>
parents: 68077
diff changeset
1256 (when (and (eq (current-buffer)
61e9ea461d3c (rcirc-ignore-list): New option.
Alex Schroeder <alex@gnu.org>
parents: 68077
diff changeset
1257 (window-buffer w))
61e9ea461d3c (rcirc-ignore-list): New option.
Alex Schroeder <alex@gnu.org>
parents: 68077
diff changeset
1258 (>= (window-point w)
61e9ea461d3c (rcirc-ignore-list): New option.
Alex Schroeder <alex@gnu.org>
parents: 68077
diff changeset
1259 rcirc-prompt-end-marker))
61e9ea461d3c (rcirc-ignore-list): New option.
Alex Schroeder <alex@gnu.org>
parents: 68077
diff changeset
1260 (set-window-point w (point-max)))))
61e9ea461d3c (rcirc-ignore-list): New option.
Alex Schroeder <alex@gnu.org>
parents: 68077
diff changeset
1261 nil t)
66248
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1262
68079
61e9ea461d3c (rcirc-ignore-list): New option.
Alex Schroeder <alex@gnu.org>
parents: 68077
diff changeset
1263 ;; restore the point
61e9ea461d3c (rcirc-ignore-list): New option.
Alex Schroeder <alex@gnu.org>
parents: 68077
diff changeset
1264 (goto-char (if moving rcirc-prompt-end-marker old-point))
66248
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1265
68079
61e9ea461d3c (rcirc-ignore-list): New option.
Alex Schroeder <alex@gnu.org>
parents: 68077
diff changeset
1266 ;; flush undo (can we do something smarter here?)
61e9ea461d3c (rcirc-ignore-list): New option.
Alex Schroeder <alex@gnu.org>
parents: 68077
diff changeset
1267 (buffer-disable-undo)
61e9ea461d3c (rcirc-ignore-list): New option.
Alex Schroeder <alex@gnu.org>
parents: 68077
diff changeset
1268 (buffer-enable-undo))
66248
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1269
68079
61e9ea461d3c (rcirc-ignore-list): New option.
Alex Schroeder <alex@gnu.org>
parents: 68077
diff changeset
1270 ;; record modeline activity
72616
1c7de7b9540b (rcirc-keywords): New variable.
Eli Zaretskii <eliz@gnu.org>
parents: 72468
diff changeset
1271 (when (and activity
1c7de7b9540b (rcirc-keywords): New variable.
Eli Zaretskii <eliz@gnu.org>
parents: 72468
diff changeset
1272 (not rcirc-ignore-buffer-activity-flag)
1c7de7b9540b (rcirc-keywords): New variable.
Eli Zaretskii <eliz@gnu.org>
parents: 72468
diff changeset
1273 (not (and rcirc-dim-nicks sender
1c7de7b9540b (rcirc-keywords): New variable.
Eli Zaretskii <eliz@gnu.org>
parents: 72468
diff changeset
1274 (string-match (regexp-opt rcirc-dim-nicks) sender))))
1c7de7b9540b (rcirc-keywords): New variable.
Eli Zaretskii <eliz@gnu.org>
parents: 72468
diff changeset
1275 (rcirc-record-activity (current-buffer)
1c7de7b9540b (rcirc-keywords): New variable.
Eli Zaretskii <eliz@gnu.org>
parents: 72468
diff changeset
1276 (when (not (rcirc-channel-p rcirc-target))
1c7de7b9540b (rcirc-keywords): New variable.
Eli Zaretskii <eliz@gnu.org>
parents: 72468
diff changeset
1277 'nick)))
66248
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1278
68079
61e9ea461d3c (rcirc-ignore-list): New option.
Alex Schroeder <alex@gnu.org>
parents: 68077
diff changeset
1279 (sit-for 0) ; displayed text before hook
61e9ea461d3c (rcirc-ignore-list): New option.
Alex Schroeder <alex@gnu.org>
parents: 68077
diff changeset
1280 (run-hook-with-args 'rcirc-print-hooks
61e9ea461d3c (rcirc-ignore-list): New option.
Alex Schroeder <alex@gnu.org>
parents: 68077
diff changeset
1281 process sender response target text)))))
66248
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-startup-channels (server)
68563
979fba30166f (rcirc-debug): Fix docstring.
Juanma Barranquero <lekktu@gmail.com>
parents: 68079
diff changeset
1284 "Return the list of startup channels for SERVER."
66248
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1285 (let (channels)
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1286 (dolist (i rcirc-startup-channels-alist)
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1287 (if (string-match (car i) server)
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1288 (setq channels (append channels (cdr i)))))
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1289 channels))
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-join-channels (process channels)
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1292 "Join CHANNELS."
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1293 (save-window-excursion
68731
85be285e3494 (rcirc-startup-channels-alist): Add irc.freenode.net and #emacs as defaults.
Eli Zaretskii <eliz@gnu.org>
parents: 68648
diff changeset
1294 (dolist (channel channels)
85be285e3494 (rcirc-startup-channels-alist): Add irc.freenode.net and #emacs as defaults.
Eli Zaretskii <eliz@gnu.org>
parents: 68648
diff changeset
1295 (with-rcirc-process-buffer process
85be285e3494 (rcirc-startup-channels-alist): Add irc.freenode.net and #emacs as defaults.
Eli Zaretskii <eliz@gnu.org>
parents: 68648
diff changeset
1296 (rcirc-cmd-join channel process)))))
66248
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1297
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1298 ;;; nick management
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1299 (defun rcirc-user-nick (user)
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1300 "Return the nick from USER. Remove any non-nick junk."
68731
85be285e3494 (rcirc-startup-channels-alist): Add irc.freenode.net and #emacs as defaults.
Eli Zaretskii <eliz@gnu.org>
parents: 68648
diff changeset
1301 (save-match-data
85be285e3494 (rcirc-startup-channels-alist): Add irc.freenode.net and #emacs as defaults.
Eli Zaretskii <eliz@gnu.org>
parents: 68648
diff changeset
1302 (if (string-match "^[@%+]?\\([^! ]+\\)!?" (or user ""))
85be285e3494 (rcirc-startup-channels-alist): Add irc.freenode.net and #emacs as defaults.
Eli Zaretskii <eliz@gnu.org>
parents: 68648
diff changeset
1303 (match-string 1 user)
85be285e3494 (rcirc-startup-channels-alist): Add irc.freenode.net and #emacs as defaults.
Eli Zaretskii <eliz@gnu.org>
parents: 68648
diff changeset
1304 user)))
66248
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1305
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1306 (defun rcirc-user-non-nick (user)
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1307 "Return the non-nick portion of USER."
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1308 (if (string-match "^[@+]?[^! ]+!?\\(.*\\)" (or user ""))
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1309 (match-string 1 user)
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1310 user))
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-nick-channels (process nick)
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1313 "Return list of channels for NICK."
68731
85be285e3494 (rcirc-startup-channels-alist): Add irc.freenode.net and #emacs as defaults.
Eli Zaretskii <eliz@gnu.org>
parents: 68648
diff changeset
1314 (with-rcirc-process-buffer process
85be285e3494 (rcirc-startup-channels-alist): Add irc.freenode.net and #emacs as defaults.
Eli Zaretskii <eliz@gnu.org>
parents: 68648
diff changeset
1315 (mapcar (lambda (x) (car x))
85be285e3494 (rcirc-startup-channels-alist): Add irc.freenode.net and #emacs as defaults.
Eli Zaretskii <eliz@gnu.org>
parents: 68648
diff changeset
1316 (gethash nick rcirc-nick-table))))
66248
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1317
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1318 (defun rcirc-put-nick-channel (process nick channel)
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1319 "Add CHANNEL to list associated with NICK."
68960
6e3160901812 (rcirc-connect): Make all arguments optional, and default to global variable
Eli Zaretskii <eliz@gnu.org>
parents: 68838
diff changeset
1320 (let ((nick (rcirc-user-nick nick)))
6e3160901812 (rcirc-connect): Make all arguments optional, and default to global variable
Eli Zaretskii <eliz@gnu.org>
parents: 68838
diff changeset
1321 (with-rcirc-process-buffer process
6e3160901812 (rcirc-connect): Make all arguments optional, and default to global variable
Eli Zaretskii <eliz@gnu.org>
parents: 68838
diff changeset
1322 (let* ((chans (gethash nick rcirc-nick-table))
6e3160901812 (rcirc-connect): Make all arguments optional, and default to global variable
Eli Zaretskii <eliz@gnu.org>
parents: 68838
diff changeset
1323 (record (assoc-string channel chans t)))
6e3160901812 (rcirc-connect): Make all arguments optional, and default to global variable
Eli Zaretskii <eliz@gnu.org>
parents: 68838
diff changeset
1324 (if record
6e3160901812 (rcirc-connect): Make all arguments optional, and default to global variable
Eli Zaretskii <eliz@gnu.org>
parents: 68838
diff changeset
1325 (setcdr record (current-time))
6e3160901812 (rcirc-connect): Make all arguments optional, and default to global variable
Eli Zaretskii <eliz@gnu.org>
parents: 68838
diff changeset
1326 (puthash nick (cons (cons channel (current-time))
6e3160901812 (rcirc-connect): Make all arguments optional, and default to global variable
Eli Zaretskii <eliz@gnu.org>
parents: 68838
diff changeset
1327 chans)
6e3160901812 (rcirc-connect): Make all arguments optional, and default to global variable
Eli Zaretskii <eliz@gnu.org>
parents: 68838
diff changeset
1328 rcirc-nick-table))))))
66248
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1329
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1330 (defun rcirc-nick-remove (process nick)
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1331 "Remove NICK from table."
66703
6cfb275aa300 Use split-string OMIT-NULLS argument.
Eli Zaretskii <eliz@gnu.org>
parents: 66272
diff changeset
1332 (with-rcirc-process-buffer process
66248
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1333 (remhash nick rcirc-nick-table)))
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1334
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1335 (defun rcirc-remove-nick-channel (process nick channel)
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1336 "Remove the CHANNEL from list associated with NICK."
66703
6cfb275aa300 Use split-string OMIT-NULLS argument.
Eli Zaretskii <eliz@gnu.org>
parents: 66272
diff changeset
1337 (with-rcirc-process-buffer process
68731
85be285e3494 (rcirc-startup-channels-alist): Add irc.freenode.net and #emacs as defaults.
Eli Zaretskii <eliz@gnu.org>
parents: 68648
diff changeset
1338 (let* ((chans (gethash nick rcirc-nick-table))
66703
6cfb275aa300 Use split-string OMIT-NULLS argument.
Eli Zaretskii <eliz@gnu.org>
parents: 66272
diff changeset
1339 (newchans
6cfb275aa300 Use split-string OMIT-NULLS argument.
Eli Zaretskii <eliz@gnu.org>
parents: 66272
diff changeset
1340 ;; instead of assoc-string-delete-all:
6cfb275aa300 Use split-string OMIT-NULLS argument.
Eli Zaretskii <eliz@gnu.org>
parents: 66272
diff changeset
1341 (let ((record (assoc-string channel chans t)))
6cfb275aa300 Use split-string OMIT-NULLS argument.
Eli Zaretskii <eliz@gnu.org>
parents: 66272
diff changeset
1342 (when record
6cfb275aa300 Use split-string OMIT-NULLS argument.
Eli Zaretskii <eliz@gnu.org>
parents: 66272
diff changeset
1343 (setcar record 'delete)
6cfb275aa300 Use split-string OMIT-NULLS argument.
Eli Zaretskii <eliz@gnu.org>
parents: 66272
diff changeset
1344 (assq-delete-all 'delete chans)))))
66248
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1345 (if newchans
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1346 (puthash nick newchans rcirc-nick-table)
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1347 (remhash nick rcirc-nick-table)))))
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1348
69860
000a5d4aa083 (rcirc-default-server): Rename from rcirc-server.
Eli Zaretskii <eliz@gnu.org>
parents: 69694
diff changeset
1349 (defun rcirc-channel-nicks (process target)
000a5d4aa083 (rcirc-default-server): Rename from rcirc-server.
Eli Zaretskii <eliz@gnu.org>
parents: 69694
diff changeset
1350 "Return the list of nicks associated with TARGET sorted by last activity."
000a5d4aa083 (rcirc-default-server): Rename from rcirc-server.
Eli Zaretskii <eliz@gnu.org>
parents: 69694
diff changeset
1351 (when target
000a5d4aa083 (rcirc-default-server): Rename from rcirc-server.
Eli Zaretskii <eliz@gnu.org>
parents: 69694
diff changeset
1352 (if (rcirc-channel-p target)
000a5d4aa083 (rcirc-default-server): Rename from rcirc-server.
Eli Zaretskii <eliz@gnu.org>
parents: 69694
diff changeset
1353 (with-rcirc-process-buffer process
000a5d4aa083 (rcirc-default-server): Rename from rcirc-server.
Eli Zaretskii <eliz@gnu.org>
parents: 69694
diff changeset
1354 (let (nicks)
000a5d4aa083 (rcirc-default-server): Rename from rcirc-server.
Eli Zaretskii <eliz@gnu.org>
parents: 69694
diff changeset
1355 (maphash
000a5d4aa083 (rcirc-default-server): Rename from rcirc-server.
Eli Zaretskii <eliz@gnu.org>
parents: 69694
diff changeset
1356 (lambda (k v)
000a5d4aa083 (rcirc-default-server): Rename from rcirc-server.
Eli Zaretskii <eliz@gnu.org>
parents: 69694
diff changeset
1357 (let ((record (assoc-string target v t)))
000a5d4aa083 (rcirc-default-server): Rename from rcirc-server.
Eli Zaretskii <eliz@gnu.org>
parents: 69694
diff changeset
1358 (if record
000a5d4aa083 (rcirc-default-server): Rename from rcirc-server.
Eli Zaretskii <eliz@gnu.org>
parents: 69694
diff changeset
1359 (setq nicks (cons (cons k (cdr record)) nicks)))))
000a5d4aa083 (rcirc-default-server): Rename from rcirc-server.
Eli Zaretskii <eliz@gnu.org>
parents: 69694
diff changeset
1360 rcirc-nick-table)
000a5d4aa083 (rcirc-default-server): Rename from rcirc-server.
Eli Zaretskii <eliz@gnu.org>
parents: 69694
diff changeset
1361 (mapcar (lambda (x) (car x))
000a5d4aa083 (rcirc-default-server): Rename from rcirc-server.
Eli Zaretskii <eliz@gnu.org>
parents: 69694
diff changeset
1362 (sort nicks (lambda (x y) (time-less-p (cdr y) (cdr x)))))))
000a5d4aa083 (rcirc-default-server): Rename from rcirc-server.
Eli Zaretskii <eliz@gnu.org>
parents: 69694
diff changeset
1363 (list target))))
68079
61e9ea461d3c (rcirc-ignore-list): New option.
Alex Schroeder <alex@gnu.org>
parents: 68077
diff changeset
1364
61e9ea461d3c (rcirc-ignore-list): New option.
Alex Schroeder <alex@gnu.org>
parents: 68077
diff changeset
1365 (defun rcirc-ignore-update-automatic (nick)
68563
979fba30166f (rcirc-debug): Fix docstring.
Juanma Barranquero <lekktu@gmail.com>
parents: 68079
diff changeset
1366 "Remove NICK from `rcirc-ignore-list'
979fba30166f (rcirc-debug): Fix docstring.
Juanma Barranquero <lekktu@gmail.com>
parents: 68079
diff changeset
1367 if NICK is also on `rcirc-ignore-list-automatic'."
68079
61e9ea461d3c (rcirc-ignore-list): New option.
Alex Schroeder <alex@gnu.org>
parents: 68077
diff changeset
1368 (when (member nick rcirc-ignore-list-automatic)
61e9ea461d3c (rcirc-ignore-list): New option.
Alex Schroeder <alex@gnu.org>
parents: 68077
diff changeset
1369 (setq rcirc-ignore-list-automatic
61e9ea461d3c (rcirc-ignore-list): New option.
Alex Schroeder <alex@gnu.org>
parents: 68077
diff changeset
1370 (delete nick rcirc-ignore-list-automatic)
61e9ea461d3c (rcirc-ignore-list): New option.
Alex Schroeder <alex@gnu.org>
parents: 68077
diff changeset
1371 rcirc-ignore-list
61e9ea461d3c (rcirc-ignore-list): New option.
Alex Schroeder <alex@gnu.org>
parents: 68077
diff changeset
1372 (delete nick rcirc-ignore-list))))
66248
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1373
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1374 ;;; activity tracking
68731
85be285e3494 (rcirc-startup-channels-alist): Add irc.freenode.net and #emacs as defaults.
Eli Zaretskii <eliz@gnu.org>
parents: 68648
diff changeset
1375 (defvar rcirc-track-minor-mode-map (make-sparse-keymap)
85be285e3494 (rcirc-startup-channels-alist): Add irc.freenode.net and #emacs as defaults.
Eli Zaretskii <eliz@gnu.org>
parents: 68648
diff changeset
1376 "Keymap for rcirc track minor mode.")
85be285e3494 (rcirc-startup-channels-alist): Add irc.freenode.net and #emacs as defaults.
Eli Zaretskii <eliz@gnu.org>
parents: 68648
diff changeset
1377
85be285e3494 (rcirc-startup-channels-alist): Add irc.freenode.net and #emacs as defaults.
Eli Zaretskii <eliz@gnu.org>
parents: 68648
diff changeset
1378 (define-key rcirc-track-minor-mode-map (kbd "C-c `") 'rcirc-next-active-buffer)
85be285e3494 (rcirc-startup-channels-alist): Add irc.freenode.net and #emacs as defaults.
Eli Zaretskii <eliz@gnu.org>
parents: 68648
diff changeset
1379 (define-key rcirc-track-minor-mode-map (kbd "C-c C-@") 'rcirc-next-active-buffer)
85be285e3494 (rcirc-startup-channels-alist): Add irc.freenode.net and #emacs as defaults.
Eli Zaretskii <eliz@gnu.org>
parents: 68648
diff changeset
1380 (define-key rcirc-track-minor-mode-map (kbd "C-c C-SPC") 'rcirc-next-active-buffer)
85be285e3494 (rcirc-startup-channels-alist): Add irc.freenode.net and #emacs as defaults.
Eli Zaretskii <eliz@gnu.org>
parents: 68648
diff changeset
1381
69461
1527bb09ec30 Revision: emacs@sv.gnu.org/emacs--devo--0--patch-156
Miles Bader <miles@gnu.org>
parents: 69460
diff changeset
1382 ;;;###autoload
68731
85be285e3494 (rcirc-startup-channels-alist): Add irc.freenode.net and #emacs as defaults.
Eli Zaretskii <eliz@gnu.org>
parents: 68648
diff changeset
1383 (define-minor-mode rcirc-track-minor-mode
85be285e3494 (rcirc-startup-channels-alist): Add irc.freenode.net and #emacs as defaults.
Eli Zaretskii <eliz@gnu.org>
parents: 68648
diff changeset
1384 "Global minor mode for tracking activity in rcirc buffers."
85be285e3494 (rcirc-startup-channels-alist): Add irc.freenode.net and #emacs as defaults.
Eli Zaretskii <eliz@gnu.org>
parents: 68648
diff changeset
1385 :init-value nil
85be285e3494 (rcirc-startup-channels-alist): Add irc.freenode.net and #emacs as defaults.
Eli Zaretskii <eliz@gnu.org>
parents: 68648
diff changeset
1386 :lighter ""
85be285e3494 (rcirc-startup-channels-alist): Add irc.freenode.net and #emacs as defaults.
Eli Zaretskii <eliz@gnu.org>
parents: 68648
diff changeset
1387 :keymap rcirc-track-minor-mode-map
85be285e3494 (rcirc-startup-channels-alist): Add irc.freenode.net and #emacs as defaults.
Eli Zaretskii <eliz@gnu.org>
parents: 68648
diff changeset
1388 :global t
85be285e3494 (rcirc-startup-channels-alist): Add irc.freenode.net and #emacs as defaults.
Eli Zaretskii <eliz@gnu.org>
parents: 68648
diff changeset
1389 :group 'rcirc
85be285e3494 (rcirc-startup-channels-alist): Add irc.freenode.net and #emacs as defaults.
Eli Zaretskii <eliz@gnu.org>
parents: 68648
diff changeset
1390 (or global-mode-string (setq global-mode-string '("")))
85be285e3494 (rcirc-startup-channels-alist): Add irc.freenode.net and #emacs as defaults.
Eli Zaretskii <eliz@gnu.org>
parents: 68648
diff changeset
1391 ;; toggle the mode-line channel indicator
85be285e3494 (rcirc-startup-channels-alist): Add irc.freenode.net and #emacs as defaults.
Eli Zaretskii <eliz@gnu.org>
parents: 68648
diff changeset
1392 (if rcirc-track-minor-mode
69860
000a5d4aa083 (rcirc-default-server): Rename from rcirc-server.
Eli Zaretskii <eliz@gnu.org>
parents: 69694
diff changeset
1393 (progn
000a5d4aa083 (rcirc-default-server): Rename from rcirc-server.
Eli Zaretskii <eliz@gnu.org>
parents: 69694
diff changeset
1394 (and (not (memq 'rcirc-activity-string global-mode-string))
000a5d4aa083 (rcirc-default-server): Rename from rcirc-server.
Eli Zaretskii <eliz@gnu.org>
parents: 69694
diff changeset
1395 (setq global-mode-string
000a5d4aa083 (rcirc-default-server): Rename from rcirc-server.
Eli Zaretskii <eliz@gnu.org>
parents: 69694
diff changeset
1396 (append global-mode-string '(rcirc-activity-string))))
000a5d4aa083 (rcirc-default-server): Rename from rcirc-server.
Eli Zaretskii <eliz@gnu.org>
parents: 69694
diff changeset
1397 (add-hook 'window-configuration-change-hook
000a5d4aa083 (rcirc-default-server): Rename from rcirc-server.
Eli Zaretskii <eliz@gnu.org>
parents: 69694
diff changeset
1398 'rcirc-window-configuration-change))
68731
85be285e3494 (rcirc-startup-channels-alist): Add irc.freenode.net and #emacs as defaults.
Eli Zaretskii <eliz@gnu.org>
parents: 68648
diff changeset
1399 (setq global-mode-string
69860
000a5d4aa083 (rcirc-default-server): Rename from rcirc-server.
Eli Zaretskii <eliz@gnu.org>
parents: 69694
diff changeset
1400 (delete 'rcirc-activity-string global-mode-string))
000a5d4aa083 (rcirc-default-server): Rename from rcirc-server.
Eli Zaretskii <eliz@gnu.org>
parents: 69694
diff changeset
1401 (remove-hook 'window-configuration-change-hook
000a5d4aa083 (rcirc-default-server): Rename from rcirc-server.
Eli Zaretskii <eliz@gnu.org>
parents: 69694
diff changeset
1402 'rcirc-window-configuration-change)))
68731
85be285e3494 (rcirc-startup-channels-alist): Add irc.freenode.net and #emacs as defaults.
Eli Zaretskii <eliz@gnu.org>
parents: 68648
diff changeset
1403
66703
6cfb275aa300 Use split-string OMIT-NULLS argument.
Eli Zaretskii <eliz@gnu.org>
parents: 66272
diff changeset
1404 (or (assq 'rcirc-ignore-buffer-activity-flag minor-mode-alist)
66248
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1405 (setq minor-mode-alist
66703
6cfb275aa300 Use split-string OMIT-NULLS argument.
Eli Zaretskii <eliz@gnu.org>
parents: 66272
diff changeset
1406 (cons '(rcirc-ignore-buffer-activity-flag " Ignore") minor-mode-alist)))
69860
000a5d4aa083 (rcirc-default-server): Rename from rcirc-server.
Eli Zaretskii <eliz@gnu.org>
parents: 69694
diff changeset
1407 (or (assq 'rcirc-low-priority-flag minor-mode-alist)
000a5d4aa083 (rcirc-default-server): Rename from rcirc-server.
Eli Zaretskii <eliz@gnu.org>
parents: 69694
diff changeset
1408 (setq minor-mode-alist
000a5d4aa083 (rcirc-default-server): Rename from rcirc-server.
Eli Zaretskii <eliz@gnu.org>
parents: 69694
diff changeset
1409 (cons '(rcirc-low-priority-flag " LowPri") minor-mode-alist)))
66248
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1410
68731
85be285e3494 (rcirc-startup-channels-alist): Add irc.freenode.net and #emacs as defaults.
Eli Zaretskii <eliz@gnu.org>
parents: 68648
diff changeset
1411 (defun rcirc-toggle-ignore-buffer-activity ()
85be285e3494 (rcirc-startup-channels-alist): Add irc.freenode.net and #emacs as defaults.
Eli Zaretskii <eliz@gnu.org>
parents: 68648
diff changeset
1412 "Toggle the value of `rcirc-ignore-buffer-activity-flag'."
85be285e3494 (rcirc-startup-channels-alist): Add irc.freenode.net and #emacs as defaults.
Eli Zaretskii <eliz@gnu.org>
parents: 68648
diff changeset
1413 (interactive)
85be285e3494 (rcirc-startup-channels-alist): Add irc.freenode.net and #emacs as defaults.
Eli Zaretskii <eliz@gnu.org>
parents: 68648
diff changeset
1414 (setq rcirc-ignore-buffer-activity-flag
85be285e3494 (rcirc-startup-channels-alist): Add irc.freenode.net and #emacs as defaults.
Eli Zaretskii <eliz@gnu.org>
parents: 68648
diff changeset
1415 (not rcirc-ignore-buffer-activity-flag))
85be285e3494 (rcirc-startup-channels-alist): Add irc.freenode.net and #emacs as defaults.
Eli Zaretskii <eliz@gnu.org>
parents: 68648
diff changeset
1416 (message (if rcirc-ignore-buffer-activity-flag
85be285e3494 (rcirc-startup-channels-alist): Add irc.freenode.net and #emacs as defaults.
Eli Zaretskii <eliz@gnu.org>
parents: 68648
diff changeset
1417 "Ignore activity in this buffer"
85be285e3494 (rcirc-startup-channels-alist): Add irc.freenode.net and #emacs as defaults.
Eli Zaretskii <eliz@gnu.org>
parents: 68648
diff changeset
1418 "Notice activity in this buffer"))
66248
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1419 (force-mode-line-update))
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1420
69860
000a5d4aa083 (rcirc-default-server): Rename from rcirc-server.
Eli Zaretskii <eliz@gnu.org>
parents: 69694
diff changeset
1421 (defun rcirc-toggle-low-priority ()
70215
90d76f24753a Revision: emacs@sv.gnu.org/emacs--devo--0--patch-247
Miles Bader <miles@gnu.org>
parents: 69860
diff changeset
1422 "Toggle the value of `rcirc-low-priority-flag'."
69860
000a5d4aa083 (rcirc-default-server): Rename from rcirc-server.
Eli Zaretskii <eliz@gnu.org>
parents: 69694
diff changeset
1423 (interactive)
000a5d4aa083 (rcirc-default-server): Rename from rcirc-server.
Eli Zaretskii <eliz@gnu.org>
parents: 69694
diff changeset
1424 (setq rcirc-low-priority-flag
000a5d4aa083 (rcirc-default-server): Rename from rcirc-server.
Eli Zaretskii <eliz@gnu.org>
parents: 69694
diff changeset
1425 (not rcirc-low-priority-flag))
000a5d4aa083 (rcirc-default-server): Rename from rcirc-server.
Eli Zaretskii <eliz@gnu.org>
parents: 69694
diff changeset
1426 (message (if rcirc-low-priority-flag
000a5d4aa083 (rcirc-default-server): Rename from rcirc-server.
Eli Zaretskii <eliz@gnu.org>
parents: 69694
diff changeset
1427 "Activity in this buffer is low priority"
000a5d4aa083 (rcirc-default-server): Rename from rcirc-server.
Eli Zaretskii <eliz@gnu.org>
parents: 69694
diff changeset
1428 "Activity in this buffer is normal priority"))
000a5d4aa083 (rcirc-default-server): Rename from rcirc-server.
Eli Zaretskii <eliz@gnu.org>
parents: 69694
diff changeset
1429 (force-mode-line-update))
000a5d4aa083 (rcirc-default-server): Rename from rcirc-server.
Eli Zaretskii <eliz@gnu.org>
parents: 69694
diff changeset
1430
66248
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1431 (defvar rcirc-switch-to-buffer-function 'switch-to-buffer
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1432 "Function to use when switching buffers.
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1433 Possible values are `switch-to-buffer', `pop-to-buffer', and
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1434 `display-buffer'.")
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1435
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1436 (defun rcirc-switch-to-server-buffer ()
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1437 "Switch to the server buffer associated with current channel buffer."
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1438 (interactive)
69860
000a5d4aa083 (rcirc-default-server): Rename from rcirc-server.
Eli Zaretskii <eliz@gnu.org>
parents: 69694
diff changeset
1439 (funcall rcirc-switch-to-buffer-function rcirc-server-buffer))
66248
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1440
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1441 (defun rcirc-jump-to-first-unread-line ()
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1442 "Move the point to the first unread line in this buffer."
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1443 (interactive)
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1444 (when (marker-position overlay-arrow-position)
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1445 (goto-char overlay-arrow-position)))
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1446
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1447 (defvar rcirc-last-non-irc-buffer nil
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1448 "The buffer to switch to when there is no more activity.")
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1449
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1450 (defun rcirc-next-active-buffer (arg)
69860
000a5d4aa083 (rcirc-default-server): Rename from rcirc-server.
Eli Zaretskii <eliz@gnu.org>
parents: 69694
diff changeset
1451 "Go to the next rcirc buffer with activity.
000a5d4aa083 (rcirc-default-server): Rename from rcirc-server.
Eli Zaretskii <eliz@gnu.org>
parents: 69694
diff changeset
1452 With prefix ARG, go to the next low priority buffer with activity.
66248
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1453 The function given by `rcirc-switch-to-buffer-function' is used to
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1454 show the buffer."
69860
000a5d4aa083 (rcirc-default-server): Rename from rcirc-server.
Eli Zaretskii <eliz@gnu.org>
parents: 69694
diff changeset
1455 (interactive "P")
000a5d4aa083 (rcirc-default-server): Rename from rcirc-server.
Eli Zaretskii <eliz@gnu.org>
parents: 69694
diff changeset
1456 (let* ((pair (rcirc-split-activity rcirc-activity))
000a5d4aa083 (rcirc-default-server): Rename from rcirc-server.
Eli Zaretskii <eliz@gnu.org>
parents: 69694
diff changeset
1457 (lopri (car pair))
000a5d4aa083 (rcirc-default-server): Rename from rcirc-server.
Eli Zaretskii <eliz@gnu.org>
parents: 69694
diff changeset
1458 (hipri (cdr pair)))
000a5d4aa083 (rcirc-default-server): Rename from rcirc-server.
Eli Zaretskii <eliz@gnu.org>
parents: 69694
diff changeset
1459 (if (or (and (not arg) hipri)
000a5d4aa083 (rcirc-default-server): Rename from rcirc-server.
Eli Zaretskii <eliz@gnu.org>
parents: 69694
diff changeset
1460 (and arg lopri))
000a5d4aa083 (rcirc-default-server): Rename from rcirc-server.
Eli Zaretskii <eliz@gnu.org>
parents: 69694
diff changeset
1461 (progn
000a5d4aa083 (rcirc-default-server): Rename from rcirc-server.
Eli Zaretskii <eliz@gnu.org>
parents: 69694
diff changeset
1462 (unless (eq major-mode 'rcirc-mode)
000a5d4aa083 (rcirc-default-server): Rename from rcirc-server.
Eli Zaretskii <eliz@gnu.org>
parents: 69694
diff changeset
1463 (setq rcirc-last-non-irc-buffer (current-buffer)))
000a5d4aa083 (rcirc-default-server): Rename from rcirc-server.
Eli Zaretskii <eliz@gnu.org>
parents: 69694
diff changeset
1464 (funcall rcirc-switch-to-buffer-function
000a5d4aa083 (rcirc-default-server): Rename from rcirc-server.
Eli Zaretskii <eliz@gnu.org>
parents: 69694
diff changeset
1465 (car (if arg lopri hipri))))
000a5d4aa083 (rcirc-default-server): Rename from rcirc-server.
Eli Zaretskii <eliz@gnu.org>
parents: 69694
diff changeset
1466 (if (eq major-mode 'rcirc-mode)
000a5d4aa083 (rcirc-default-server): Rename from rcirc-server.
Eli Zaretskii <eliz@gnu.org>
parents: 69694
diff changeset
1467 (if (not (and rcirc-last-non-irc-buffer
000a5d4aa083 (rcirc-default-server): Rename from rcirc-server.
Eli Zaretskii <eliz@gnu.org>
parents: 69694
diff changeset
1468 (buffer-live-p rcirc-last-non-irc-buffer)))
000a5d4aa083 (rcirc-default-server): Rename from rcirc-server.
Eli Zaretskii <eliz@gnu.org>
parents: 69694
diff changeset
1469 (message "No IRC activity. Start something.")
000a5d4aa083 (rcirc-default-server): Rename from rcirc-server.
Eli Zaretskii <eliz@gnu.org>
parents: 69694
diff changeset
1470 (message "No more IRC activity. Go back to work.")
000a5d4aa083 (rcirc-default-server): Rename from rcirc-server.
Eli Zaretskii <eliz@gnu.org>
parents: 69694
diff changeset
1471 (funcall rcirc-switch-to-buffer-function rcirc-last-non-irc-buffer)
000a5d4aa083 (rcirc-default-server): Rename from rcirc-server.
Eli Zaretskii <eliz@gnu.org>
parents: 69694
diff changeset
1472 (setq rcirc-last-non-irc-buffer nil))
000a5d4aa083 (rcirc-default-server): Rename from rcirc-server.
Eli Zaretskii <eliz@gnu.org>
parents: 69694
diff changeset
1473 (message (concat
000a5d4aa083 (rcirc-default-server): Rename from rcirc-server.
Eli Zaretskii <eliz@gnu.org>
parents: 69694
diff changeset
1474 "No IRC activity."
000a5d4aa083 (rcirc-default-server): Rename from rcirc-server.
Eli Zaretskii <eliz@gnu.org>
parents: 69694
diff changeset
1475 (when lopri
000a5d4aa083 (rcirc-default-server): Rename from rcirc-server.
Eli Zaretskii <eliz@gnu.org>
parents: 69694
diff changeset
1476 (concat
000a5d4aa083 (rcirc-default-server): Rename from rcirc-server.
Eli Zaretskii <eliz@gnu.org>
parents: 69694
diff changeset
1477 " Type C-u "
000a5d4aa083 (rcirc-default-server): Rename from rcirc-server.
Eli Zaretskii <eliz@gnu.org>
parents: 69694
diff changeset
1478 (key-description (this-command-keys))
000a5d4aa083 (rcirc-default-server): Rename from rcirc-server.
Eli Zaretskii <eliz@gnu.org>
parents: 69694
diff changeset
1479 " for low priority activity."))))))))
66248
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1480
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1481 (defvar rcirc-activity-hooks nil
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1482 "Hook to be run when there is channel activity.
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1483
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1484 Functions are called with a single argument, the buffer with the
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1485 activity. Only run if the buffer is not visible and
66703
6cfb275aa300 Use split-string OMIT-NULLS argument.
Eli Zaretskii <eliz@gnu.org>
parents: 66272
diff changeset
1486 `rcirc-ignore-buffer-activity-flag' is non-nil.")
66248
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1487
69860
000a5d4aa083 (rcirc-default-server): Rename from rcirc-server.
Eli Zaretskii <eliz@gnu.org>
parents: 69694
diff changeset
1488 (defun rcirc-record-activity (buffer &optional type)
66248
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1489 "Record BUFFER activity with TYPE."
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1490 (with-current-buffer buffer
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1491 (when (not (get-buffer-window (current-buffer) t))
69860
000a5d4aa083 (rcirc-default-server): Rename from rcirc-server.
Eli Zaretskii <eliz@gnu.org>
parents: 69694
diff changeset
1492 (setq rcirc-activity
000a5d4aa083 (rcirc-default-server): Rename from rcirc-server.
Eli Zaretskii <eliz@gnu.org>
parents: 69694
diff changeset
1493 (sort (add-to-list 'rcirc-activity (current-buffer))
000a5d4aa083 (rcirc-default-server): Rename from rcirc-server.
Eli Zaretskii <eliz@gnu.org>
parents: 69694
diff changeset
1494 (lambda (b1 b2)
000a5d4aa083 (rcirc-default-server): Rename from rcirc-server.
Eli Zaretskii <eliz@gnu.org>
parents: 69694
diff changeset
1495 (let ((t1 (with-current-buffer b1 rcirc-last-post-time))
000a5d4aa083 (rcirc-default-server): Rename from rcirc-server.
Eli Zaretskii <eliz@gnu.org>
parents: 69694
diff changeset
1496 (t2 (with-current-buffer b2 rcirc-last-post-time)))
000a5d4aa083 (rcirc-default-server): Rename from rcirc-server.
Eli Zaretskii <eliz@gnu.org>
parents: 69694
diff changeset
1497 (time-less-p t2 t1)))))
72616
1c7de7b9540b (rcirc-keywords): New variable.
Eli Zaretskii <eliz@gnu.org>
parents: 72468
diff changeset
1498 (pushnew type rcirc-activity-types)
66248
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1499 (rcirc-update-activity-string)))
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1500 (run-hook-with-args 'rcirc-activity-hooks buffer))
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1501
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1502 (defun rcirc-clear-activity (buffer)
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1503 "Clear the BUFFER activity."
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1504 (setq rcirc-activity (delete buffer rcirc-activity))
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1505 (with-current-buffer buffer
72616
1c7de7b9540b (rcirc-keywords): New variable.
Eli Zaretskii <eliz@gnu.org>
parents: 72468
diff changeset
1506 (setq rcirc-activity-types nil)))
66248
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1507
69860
000a5d4aa083 (rcirc-default-server): Rename from rcirc-server.
Eli Zaretskii <eliz@gnu.org>
parents: 69694
diff changeset
1508 (defun rcirc-split-activity (activity)
000a5d4aa083 (rcirc-default-server): Rename from rcirc-server.
Eli Zaretskii <eliz@gnu.org>
parents: 69694
diff changeset
1509 "Return a cons cell with ACTIVITY split into (lopri . hipri)."
000a5d4aa083 (rcirc-default-server): Rename from rcirc-server.
Eli Zaretskii <eliz@gnu.org>
parents: 69694
diff changeset
1510 (let (lopri hipri)
000a5d4aa083 (rcirc-default-server): Rename from rcirc-server.
Eli Zaretskii <eliz@gnu.org>
parents: 69694
diff changeset
1511 (dolist (buf rcirc-activity)
000a5d4aa083 (rcirc-default-server): Rename from rcirc-server.
Eli Zaretskii <eliz@gnu.org>
parents: 69694
diff changeset
1512 (with-current-buffer buf
000a5d4aa083 (rcirc-default-server): Rename from rcirc-server.
Eli Zaretskii <eliz@gnu.org>
parents: 69694
diff changeset
1513 (if (and rcirc-low-priority-flag
72616
1c7de7b9540b (rcirc-keywords): New variable.
Eli Zaretskii <eliz@gnu.org>
parents: 72468
diff changeset
1514 (not (member 'nick rcirc-activity-types)))
69860
000a5d4aa083 (rcirc-default-server): Rename from rcirc-server.
Eli Zaretskii <eliz@gnu.org>
parents: 69694
diff changeset
1515 (add-to-list 'lopri buf t)
000a5d4aa083 (rcirc-default-server): Rename from rcirc-server.
Eli Zaretskii <eliz@gnu.org>
parents: 69694
diff changeset
1516 (add-to-list 'hipri buf t))))
000a5d4aa083 (rcirc-default-server): Rename from rcirc-server.
Eli Zaretskii <eliz@gnu.org>
parents: 69694
diff changeset
1517 (cons lopri hipri)))
000a5d4aa083 (rcirc-default-server): Rename from rcirc-server.
Eli Zaretskii <eliz@gnu.org>
parents: 69694
diff changeset
1518
66703
6cfb275aa300 Use split-string OMIT-NULLS argument.
Eli Zaretskii <eliz@gnu.org>
parents: 66272
diff changeset
1519 ;; TODO: add mouse properties
66248
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1520 (defun rcirc-update-activity-string ()
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1521 "Update mode-line string."
69860
000a5d4aa083 (rcirc-default-server): Rename from rcirc-server.
Eli Zaretskii <eliz@gnu.org>
parents: 69694
diff changeset
1522 (let* ((pair (rcirc-split-activity rcirc-activity))
000a5d4aa083 (rcirc-default-server): Rename from rcirc-server.
Eli Zaretskii <eliz@gnu.org>
parents: 69694
diff changeset
1523 (lopri (car pair))
000a5d4aa083 (rcirc-default-server): Rename from rcirc-server.
Eli Zaretskii <eliz@gnu.org>
parents: 69694
diff changeset
1524 (hipri (cdr pair)))
000a5d4aa083 (rcirc-default-server): Rename from rcirc-server.
Eli Zaretskii <eliz@gnu.org>
parents: 69694
diff changeset
1525 (setq rcirc-activity-string
72468
5e47ca87ee3c Rcirc update from Ryan Yeske
Miles Bader <miles@gnu.org>
parents: 71442
diff changeset
1526 (cond ((or hipri lopri)
5e47ca87ee3c Rcirc update from Ryan Yeske
Miles Bader <miles@gnu.org>
parents: 71442
diff changeset
1527 (concat "-"
5e47ca87ee3c Rcirc update from Ryan Yeske
Miles Bader <miles@gnu.org>
parents: 71442
diff changeset
1528 (and hipri "[")
5e47ca87ee3c Rcirc update from Ryan Yeske
Miles Bader <miles@gnu.org>
parents: 71442
diff changeset
1529 (rcirc-activity-string hipri)
5e47ca87ee3c Rcirc update from Ryan Yeske
Miles Bader <miles@gnu.org>
parents: 71442
diff changeset
1530 (and hipri lopri ",")
5e47ca87ee3c Rcirc update from Ryan Yeske
Miles Bader <miles@gnu.org>
parents: 71442
diff changeset
1531 (and lopri
5e47ca87ee3c Rcirc update from Ryan Yeske
Miles Bader <miles@gnu.org>
parents: 71442
diff changeset
1532 (concat "("
5e47ca87ee3c Rcirc update from Ryan Yeske
Miles Bader <miles@gnu.org>
parents: 71442
diff changeset
1533 (rcirc-activity-string lopri)
5e47ca87ee3c Rcirc update from Ryan Yeske
Miles Bader <miles@gnu.org>
parents: 71442
diff changeset
1534 ")"))
5e47ca87ee3c Rcirc update from Ryan Yeske
Miles Bader <miles@gnu.org>
parents: 71442
diff changeset
1535 (and hipri "]")
5e47ca87ee3c Rcirc update from Ryan Yeske
Miles Bader <miles@gnu.org>
parents: 71442
diff changeset
1536 "-"))
5e47ca87ee3c Rcirc update from Ryan Yeske
Miles Bader <miles@gnu.org>
parents: 71442
diff changeset
1537 ((not (null (rcirc-process-list)))
5e47ca87ee3c Rcirc update from Ryan Yeske
Miles Bader <miles@gnu.org>
parents: 71442
diff changeset
1538 "-[]-")
5e47ca87ee3c Rcirc update from Ryan Yeske
Miles Bader <miles@gnu.org>
parents: 71442
diff changeset
1539 (t "")))))
69860
000a5d4aa083 (rcirc-default-server): Rename from rcirc-server.
Eli Zaretskii <eliz@gnu.org>
parents: 69694
diff changeset
1540
000a5d4aa083 (rcirc-default-server): Rename from rcirc-server.
Eli Zaretskii <eliz@gnu.org>
parents: 69694
diff changeset
1541 (defun rcirc-activity-string (buffers)
000a5d4aa083 (rcirc-default-server): Rename from rcirc-server.
Eli Zaretskii <eliz@gnu.org>
parents: 69694
diff changeset
1542 (mapconcat (lambda (b)
72616
1c7de7b9540b (rcirc-keywords): New variable.
Eli Zaretskii <eliz@gnu.org>
parents: 72468
diff changeset
1543 (let ((s (substring-no-properties (rcirc-short-buffer-name b))))
69860
000a5d4aa083 (rcirc-default-server): Rename from rcirc-server.
Eli Zaretskii <eliz@gnu.org>
parents: 69694
diff changeset
1544 (with-current-buffer b
72616
1c7de7b9540b (rcirc-keywords): New variable.
Eli Zaretskii <eliz@gnu.org>
parents: 72468
diff changeset
1545 (dolist (type rcirc-activity-types)
1c7de7b9540b (rcirc-keywords): New variable.
Eli Zaretskii <eliz@gnu.org>
parents: 72468
diff changeset
1546 (rcirc-add-face 0 (length s)
1c7de7b9540b (rcirc-keywords): New variable.
Eli Zaretskii <eliz@gnu.org>
parents: 72468
diff changeset
1547 (case type
72699
249ed2e06deb * net/rcirc.el (rcirc-activity-string): Don't quote value in case
Chong Yidong <cyd@stupidchicken.com>
parents: 72616
diff changeset
1548 (nick 'rcirc-track-nick)
249ed2e06deb * net/rcirc.el (rcirc-activity-string): Don't quote value in case
Chong Yidong <cyd@stupidchicken.com>
parents: 72616
diff changeset
1549 (keyword 'rcirc-track-keyword))
72616
1c7de7b9540b (rcirc-keywords): New variable.
Eli Zaretskii <eliz@gnu.org>
parents: 72468
diff changeset
1550 s)))
1c7de7b9540b (rcirc-keywords): New variable.
Eli Zaretskii <eliz@gnu.org>
parents: 72468
diff changeset
1551 s))
69860
000a5d4aa083 (rcirc-default-server): Rename from rcirc-server.
Eli Zaretskii <eliz@gnu.org>
parents: 69694
diff changeset
1552 buffers ","))
66248
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1553
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1554 (defun rcirc-short-buffer-name (buffer)
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1555 "Return a short name for BUFFER to use in the modeline indicator."
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1556 (with-current-buffer buffer
66703
6cfb275aa300 Use split-string OMIT-NULLS argument.
Eli Zaretskii <eliz@gnu.org>
parents: 66272
diff changeset
1557 (or rcirc-short-buffer-name (buffer-name))))
6cfb275aa300 Use split-string OMIT-NULLS argument.
Eli Zaretskii <eliz@gnu.org>
parents: 66272
diff changeset
1558
6cfb275aa300 Use split-string OMIT-NULLS argument.
Eli Zaretskii <eliz@gnu.org>
parents: 66272
diff changeset
1559 (defvar rcirc-current-buffer nil)
6cfb275aa300 Use split-string OMIT-NULLS argument.
Eli Zaretskii <eliz@gnu.org>
parents: 66272
diff changeset
1560 (defun rcirc-window-configuration-change ()
6cfb275aa300 Use split-string OMIT-NULLS argument.
Eli Zaretskii <eliz@gnu.org>
parents: 66272
diff changeset
1561 "Go through visible windows and remove buffers from activity list.
6cfb275aa300 Use split-string OMIT-NULLS argument.
Eli Zaretskii <eliz@gnu.org>
parents: 66272
diff changeset
1562 Also, clear the overlay arrow if the current buffer is now hidden."
6cfb275aa300 Use split-string OMIT-NULLS argument.
Eli Zaretskii <eliz@gnu.org>
parents: 66272
diff changeset
1563 (let ((current-now-hidden t))
6cfb275aa300 Use split-string OMIT-NULLS argument.
Eli Zaretskii <eliz@gnu.org>
parents: 66272
diff changeset
1564 (walk-windows (lambda (w)
6cfb275aa300 Use split-string OMIT-NULLS argument.
Eli Zaretskii <eliz@gnu.org>
parents: 66272
diff changeset
1565 (let ((buf (window-buffer w)))
72616
1c7de7b9540b (rcirc-keywords): New variable.
Eli Zaretskii <eliz@gnu.org>
parents: 72468
diff changeset
1566 (with-current-buffer buf
1c7de7b9540b (rcirc-keywords): New variable.
Eli Zaretskii <eliz@gnu.org>
parents: 72468
diff changeset
1567 (when (eq major-mode 'rcirc-mode)
1c7de7b9540b (rcirc-keywords): New variable.
Eli Zaretskii <eliz@gnu.org>
parents: 72468
diff changeset
1568 (rcirc-clear-activity buf)))
69860
000a5d4aa083 (rcirc-default-server): Rename from rcirc-server.
Eli Zaretskii <eliz@gnu.org>
parents: 69694
diff changeset
1569 (when (eq buf rcirc-current-buffer)
72616
1c7de7b9540b (rcirc-keywords): New variable.
Eli Zaretskii <eliz@gnu.org>
parents: 72468
diff changeset
1570 (setq current-now-hidden nil)))))
69860
000a5d4aa083 (rcirc-default-server): Rename from rcirc-server.
Eli Zaretskii <eliz@gnu.org>
parents: 69694
diff changeset
1571 ;; add overlay arrow if the buffer isn't displayed
72616
1c7de7b9540b (rcirc-keywords): New variable.
Eli Zaretskii <eliz@gnu.org>
parents: 72468
diff changeset
1572 (when (and current-now-hidden
1c7de7b9540b (rcirc-keywords): New variable.
Eli Zaretskii <eliz@gnu.org>
parents: 72468
diff changeset
1573 rcirc-current-buffer
1c7de7b9540b (rcirc-keywords): New variable.
Eli Zaretskii <eliz@gnu.org>
parents: 72468
diff changeset
1574 (buffer-live-p rcirc-current-buffer))
66703
6cfb275aa300 Use split-string OMIT-NULLS argument.
Eli Zaretskii <eliz@gnu.org>
parents: 66272
diff changeset
1575 (with-current-buffer rcirc-current-buffer
72616
1c7de7b9540b (rcirc-keywords): New variable.
Eli Zaretskii <eliz@gnu.org>
parents: 72468
diff changeset
1576 (when (and (eq major-mode 'rcirc-mode)
1c7de7b9540b (rcirc-keywords): New variable.
Eli Zaretskii <eliz@gnu.org>
parents: 72468
diff changeset
1577 (marker-position overlay-arrow-position))
66703
6cfb275aa300 Use split-string OMIT-NULLS argument.
Eli Zaretskii <eliz@gnu.org>
parents: 66272
diff changeset
1578 (set-marker overlay-arrow-position nil)))))
6cfb275aa300 Use split-string OMIT-NULLS argument.
Eli Zaretskii <eliz@gnu.org>
parents: 66272
diff changeset
1579
6cfb275aa300 Use split-string OMIT-NULLS argument.
Eli Zaretskii <eliz@gnu.org>
parents: 66272
diff changeset
1580 ;; remove any killed buffers from list
6cfb275aa300 Use split-string OMIT-NULLS argument.
Eli Zaretskii <eliz@gnu.org>
parents: 66272
diff changeset
1581 (setq rcirc-activity
6cfb275aa300 Use split-string OMIT-NULLS argument.
Eli Zaretskii <eliz@gnu.org>
parents: 66272
diff changeset
1582 (delq nil (mapcar (lambda (buf) (when (buffer-live-p buf) buf))
6cfb275aa300 Use split-string OMIT-NULLS argument.
Eli Zaretskii <eliz@gnu.org>
parents: 66272
diff changeset
1583 rcirc-activity)))
6cfb275aa300 Use split-string OMIT-NULLS argument.
Eli Zaretskii <eliz@gnu.org>
parents: 66272
diff changeset
1584 (rcirc-update-activity-string)
6cfb275aa300 Use split-string OMIT-NULLS argument.
Eli Zaretskii <eliz@gnu.org>
parents: 66272
diff changeset
1585 (setq rcirc-current-buffer (current-buffer)))
6cfb275aa300 Use split-string OMIT-NULLS argument.
Eli Zaretskii <eliz@gnu.org>
parents: 66272
diff changeset
1586
6cfb275aa300 Use split-string OMIT-NULLS argument.
Eli Zaretskii <eliz@gnu.org>
parents: 66272
diff changeset
1587
6cfb275aa300 Use split-string OMIT-NULLS argument.
Eli Zaretskii <eliz@gnu.org>
parents: 66272
diff changeset
1588 ;;; buffer name abbreviation
6cfb275aa300 Use split-string OMIT-NULLS argument.
Eli Zaretskii <eliz@gnu.org>
parents: 66272
diff changeset
1589 (defun rcirc-update-short-buffer-names ()
6cfb275aa300 Use split-string OMIT-NULLS argument.
Eli Zaretskii <eliz@gnu.org>
parents: 66272
diff changeset
1590 (let ((bufalist
6cfb275aa300 Use split-string OMIT-NULLS argument.
Eli Zaretskii <eliz@gnu.org>
parents: 66272
diff changeset
1591 (apply 'append (mapcar (lambda (process)
6cfb275aa300 Use split-string OMIT-NULLS argument.
Eli Zaretskii <eliz@gnu.org>
parents: 66272
diff changeset
1592 (with-rcirc-process-buffer process
6cfb275aa300 Use split-string OMIT-NULLS argument.
Eli Zaretskii <eliz@gnu.org>
parents: 66272
diff changeset
1593 rcirc-buffer-alist))
6cfb275aa300 Use split-string OMIT-NULLS argument.
Eli Zaretskii <eliz@gnu.org>
parents: 66272
diff changeset
1594 (rcirc-process-list)))))
6cfb275aa300 Use split-string OMIT-NULLS argument.
Eli Zaretskii <eliz@gnu.org>
parents: 66272
diff changeset
1595 (dolist (i (rcirc-abbreviate bufalist))
69860
000a5d4aa083 (rcirc-default-server): Rename from rcirc-server.
Eli Zaretskii <eliz@gnu.org>
parents: 69694
diff changeset
1596 (when (buffer-live-p (cdr i))
000a5d4aa083 (rcirc-default-server): Rename from rcirc-server.
Eli Zaretskii <eliz@gnu.org>
parents: 69694
diff changeset
1597 (with-current-buffer (cdr i)
000a5d4aa083 (rcirc-default-server): Rename from rcirc-server.
Eli Zaretskii <eliz@gnu.org>
parents: 69694
diff changeset
1598 (setq rcirc-short-buffer-name (car i)))))))
66703
6cfb275aa300 Use split-string OMIT-NULLS argument.
Eli Zaretskii <eliz@gnu.org>
parents: 66272
diff changeset
1599
6cfb275aa300 Use split-string OMIT-NULLS argument.
Eli Zaretskii <eliz@gnu.org>
parents: 66272
diff changeset
1600 (defun rcirc-abbreviate (pairs)
6cfb275aa300 Use split-string OMIT-NULLS argument.
Eli Zaretskii <eliz@gnu.org>
parents: 66272
diff changeset
1601 (apply 'append (mapcar 'rcirc-rebuild-tree (rcirc-make-trees pairs))))
66248
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1602
66703
6cfb275aa300 Use split-string OMIT-NULLS argument.
Eli Zaretskii <eliz@gnu.org>
parents: 66272
diff changeset
1603 (defun rcirc-rebuild-tree (tree &optional acc)
6cfb275aa300 Use split-string OMIT-NULLS argument.
Eli Zaretskii <eliz@gnu.org>
parents: 66272
diff changeset
1604 (let ((ch (char-to-string (car tree))))
6cfb275aa300 Use split-string OMIT-NULLS argument.
Eli Zaretskii <eliz@gnu.org>
parents: 66272
diff changeset
1605 (dolist (x (cdr tree))
6cfb275aa300 Use split-string OMIT-NULLS argument.
Eli Zaretskii <eliz@gnu.org>
parents: 66272
diff changeset
1606 (if (listp x)
6cfb275aa300 Use split-string OMIT-NULLS argument.
Eli Zaretskii <eliz@gnu.org>
parents: 66272
diff changeset
1607 (setq acc (append acc
6cfb275aa300 Use split-string OMIT-NULLS argument.
Eli Zaretskii <eliz@gnu.org>
parents: 66272
diff changeset
1608 (mapcar (lambda (y)
6cfb275aa300 Use split-string OMIT-NULLS argument.
Eli Zaretskii <eliz@gnu.org>
parents: 66272
diff changeset
1609 (cons (concat ch (car y))
6cfb275aa300 Use split-string OMIT-NULLS argument.
Eli Zaretskii <eliz@gnu.org>
parents: 66272
diff changeset
1610 (cdr y)))
6cfb275aa300 Use split-string OMIT-NULLS argument.
Eli Zaretskii <eliz@gnu.org>
parents: 66272
diff changeset
1611 (rcirc-rebuild-tree x))))
6cfb275aa300 Use split-string OMIT-NULLS argument.
Eli Zaretskii <eliz@gnu.org>
parents: 66272
diff changeset
1612 (setq acc (cons (cons ch x) acc))))
6cfb275aa300 Use split-string OMIT-NULLS argument.
Eli Zaretskii <eliz@gnu.org>
parents: 66272
diff changeset
1613 acc))
66248
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1614
66703
6cfb275aa300 Use split-string OMIT-NULLS argument.
Eli Zaretskii <eliz@gnu.org>
parents: 66272
diff changeset
1615 (defun rcirc-make-trees (pairs)
6cfb275aa300 Use split-string OMIT-NULLS argument.
Eli Zaretskii <eliz@gnu.org>
parents: 66272
diff changeset
1616 (let (alist)
6cfb275aa300 Use split-string OMIT-NULLS argument.
Eli Zaretskii <eliz@gnu.org>
parents: 66272
diff changeset
1617 (mapc (lambda (pair)
6cfb275aa300 Use split-string OMIT-NULLS argument.
Eli Zaretskii <eliz@gnu.org>
parents: 66272
diff changeset
1618 (if (consp pair)
6cfb275aa300 Use split-string OMIT-NULLS argument.
Eli Zaretskii <eliz@gnu.org>
parents: 66272
diff changeset
1619 (let* ((str (car pair))
6cfb275aa300 Use split-string OMIT-NULLS argument.
Eli Zaretskii <eliz@gnu.org>
parents: 66272
diff changeset
1620 (data (cdr pair))
6cfb275aa300 Use split-string OMIT-NULLS argument.
Eli Zaretskii <eliz@gnu.org>
parents: 66272
diff changeset
1621 (char (unless (zerop (length str))
6cfb275aa300 Use split-string OMIT-NULLS argument.
Eli Zaretskii <eliz@gnu.org>
parents: 66272
diff changeset
1622 (aref str 0)))
6cfb275aa300 Use split-string OMIT-NULLS argument.
Eli Zaretskii <eliz@gnu.org>
parents: 66272
diff changeset
1623 (rest (unless (zerop (length str))
6cfb275aa300 Use split-string OMIT-NULLS argument.
Eli Zaretskii <eliz@gnu.org>
parents: 66272
diff changeset
1624 (substring str 1)))
6cfb275aa300 Use split-string OMIT-NULLS argument.
Eli Zaretskii <eliz@gnu.org>
parents: 66272
diff changeset
1625 (part (if char (assq char alist))))
6cfb275aa300 Use split-string OMIT-NULLS argument.
Eli Zaretskii <eliz@gnu.org>
parents: 66272
diff changeset
1626 (if part
6cfb275aa300 Use split-string OMIT-NULLS argument.
Eli Zaretskii <eliz@gnu.org>
parents: 66272
diff changeset
1627 ;; existing partition
6cfb275aa300 Use split-string OMIT-NULLS argument.
Eli Zaretskii <eliz@gnu.org>
parents: 66272
diff changeset
1628 (setcdr part (cons (cons rest data) (cdr part)))
6cfb275aa300 Use split-string OMIT-NULLS argument.
Eli Zaretskii <eliz@gnu.org>
parents: 66272
diff changeset
1629 ;; new partition
6cfb275aa300 Use split-string OMIT-NULLS argument.
Eli Zaretskii <eliz@gnu.org>
parents: 66272
diff changeset
1630 (setq alist (cons (if char
6cfb275aa300 Use split-string OMIT-NULLS argument.
Eli Zaretskii <eliz@gnu.org>
parents: 66272
diff changeset
1631 (list char (cons rest data))
6cfb275aa300 Use split-string OMIT-NULLS argument.
Eli Zaretskii <eliz@gnu.org>
parents: 66272
diff changeset
1632 data)
6cfb275aa300 Use split-string OMIT-NULLS argument.
Eli Zaretskii <eliz@gnu.org>
parents: 66272
diff changeset
1633 alist))))
6cfb275aa300 Use split-string OMIT-NULLS argument.
Eli Zaretskii <eliz@gnu.org>
parents: 66272
diff changeset
1634 (setq alist (cons pair alist))))
6cfb275aa300 Use split-string OMIT-NULLS argument.
Eli Zaretskii <eliz@gnu.org>
parents: 66272
diff changeset
1635 pairs)
6cfb275aa300 Use split-string OMIT-NULLS argument.
Eli Zaretskii <eliz@gnu.org>
parents: 66272
diff changeset
1636 ;; recurse into cdrs of alist
6cfb275aa300 Use split-string OMIT-NULLS argument.
Eli Zaretskii <eliz@gnu.org>
parents: 66272
diff changeset
1637 (mapc (lambda (x)
6cfb275aa300 Use split-string OMIT-NULLS argument.
Eli Zaretskii <eliz@gnu.org>
parents: 66272
diff changeset
1638 (when (and (listp x) (listp (cadr x)))
6cfb275aa300 Use split-string OMIT-NULLS argument.
Eli Zaretskii <eliz@gnu.org>
parents: 66272
diff changeset
1639 (setcdr x (if (> (length (cdr x)) 1)
6cfb275aa300 Use split-string OMIT-NULLS argument.
Eli Zaretskii <eliz@gnu.org>
parents: 66272
diff changeset
1640 (rcirc-make-trees (cdr x))
6cfb275aa300 Use split-string OMIT-NULLS argument.
Eli Zaretskii <eliz@gnu.org>
parents: 66272
diff changeset
1641 (setcdr x (list (cdadr x)))))))
6cfb275aa300 Use split-string OMIT-NULLS argument.
Eli Zaretskii <eliz@gnu.org>
parents: 66272
diff changeset
1642 alist)))
66248
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1643
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1644 ;;; /commands these are called with 3 args: PROCESS, TARGET, which is
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1645 ;; the current buffer/channel/user, and ARGS, which is a string
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1646 ;; containing the text following the /cmd.
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1647
66703
6cfb275aa300 Use split-string OMIT-NULLS argument.
Eli Zaretskii <eliz@gnu.org>
parents: 66272
diff changeset
1648 (defmacro defun-rcirc-command (command argument docstring interactive-form
66248
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1649 &rest body)
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1650 "Define a command."
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1651 `(defun ,(intern (concat "rcirc-cmd-" (symbol-name command)))
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1652 (,@argument &optional process target)
69860
000a5d4aa083 (rcirc-default-server): Rename from rcirc-server.
Eli Zaretskii <eliz@gnu.org>
parents: 69694
diff changeset
1653 ,(concat docstring "\n\nNote: If PROCESS or TARGET are nil, the values given"
000a5d4aa083 (rcirc-default-server): Rename from rcirc-server.
Eli Zaretskii <eliz@gnu.org>
parents: 69694
diff changeset
1654 "\nby `rcirc-buffer-process' and `rcirc-target' will be used.")
66248
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1655 ,interactive-form
69860
000a5d4aa083 (rcirc-default-server): Rename from rcirc-server.
Eli Zaretskii <eliz@gnu.org>
parents: 69694
diff changeset
1656 (let ((process (or process (rcirc-buffer-process)))
66248
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1657 (target (or target rcirc-target)))
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1658 ,@body)))
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1659
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1660 (defun-rcirc-command msg (message)
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1661 "Send private MESSAGE to TARGET."
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1662 (interactive "i")
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1663 (if (null message)
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1664 (progn
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1665 (setq target (completing-read "Message nick: "
69860
000a5d4aa083 (rcirc-default-server): Rename from rcirc-server.
Eli Zaretskii <eliz@gnu.org>
parents: 69694
diff changeset
1666 (with-rcirc-server-buffer
000a5d4aa083 (rcirc-default-server): Rename from rcirc-server.
Eli Zaretskii <eliz@gnu.org>
parents: 69694
diff changeset
1667 rcirc-nick-table)))
66248
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1668 (when (> (length target) 0)
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1669 (setq message (read-string (format "Message %s: " target)))
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1670 (when (> (length message) 0)
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1671 (rcirc-send-message process target message))))
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1672 (if (not (string-match "\\([^ ]+\\) \\(.+\\)" message))
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1673 (message "Not enough args, or something.")
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1674 (setq target (match-string 1 message)
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1675 message (match-string 2 message))
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1676 (rcirc-send-message process target message))))
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1677
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1678 (defun-rcirc-command query (nick)
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1679 "Open a private chat buffer to NICK."
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1680 (interactive (list (completing-read "Query nick: "
69860
000a5d4aa083 (rcirc-default-server): Rename from rcirc-server.
Eli Zaretskii <eliz@gnu.org>
parents: 69694
diff changeset
1681 (with-rcirc-server-buffer rcirc-nick-table))))
66703
6cfb275aa300 Use split-string OMIT-NULLS argument.
Eli Zaretskii <eliz@gnu.org>
parents: 66272
diff changeset
1682 (let ((existing-buffer (rcirc-get-buffer process nick)))
6cfb275aa300 Use split-string OMIT-NULLS argument.
Eli Zaretskii <eliz@gnu.org>
parents: 66272
diff changeset
1683 (switch-to-buffer (or existing-buffer
6cfb275aa300 Use split-string OMIT-NULLS argument.
Eli Zaretskii <eliz@gnu.org>
parents: 66272
diff changeset
1684 (rcirc-get-buffer-create process nick)))
6cfb275aa300 Use split-string OMIT-NULLS argument.
Eli Zaretskii <eliz@gnu.org>
parents: 66272
diff changeset
1685 (when (not existing-buffer)
66248
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1686 (rcirc-cmd-whois nick))))
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1687
68578
2b5f6787aa4f (rcirc-cmd-join): Improve argument/docstring consistency.
Juanma Barranquero <lekktu@gmail.com>
parents: 68563
diff changeset
1688 (defun-rcirc-command join (channel)
66248
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1689 "Join CHANNEL."
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1690 (interactive "sJoin channel: ")
68578
2b5f6787aa4f (rcirc-cmd-join): Improve argument/docstring consistency.
Juanma Barranquero <lekktu@gmail.com>
parents: 68563
diff changeset
1691 (let ((buffer (rcirc-get-buffer-create process
2b5f6787aa4f (rcirc-cmd-join): Improve argument/docstring consistency.
Juanma Barranquero <lekktu@gmail.com>
parents: 68563
diff changeset
1692 (car (split-string channel)))))
69860
000a5d4aa083 (rcirc-default-server): Rename from rcirc-server.
Eli Zaretskii <eliz@gnu.org>
parents: 69694
diff changeset
1693 (rcirc-send-string process (concat "JOIN " channel))
66248
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1694 (when (not (eq (selected-window) (minibuffer-window)))
69860
000a5d4aa083 (rcirc-default-server): Rename from rcirc-server.
Eli Zaretskii <eliz@gnu.org>
parents: 69694
diff changeset
1695 (funcall rcirc-switch-to-buffer-function buffer))))
66248
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1696
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1697 (defun-rcirc-command part (channel)
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1698 "Part CHANNEL."
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1699 (interactive "sPart channel: ")
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1700 (let ((channel (if (> (length channel) 0) channel target)))
66703
6cfb275aa300 Use split-string OMIT-NULLS argument.
Eli Zaretskii <eliz@gnu.org>
parents: 66272
diff changeset
1701 (rcirc-send-string process (concat "PART " channel " :" rcirc-id-string))))
66248
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1702
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1703 (defun-rcirc-command quit (reason)
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1704 "Send a quit message to server with REASON."
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1705 (interactive "sQuit reason: ")
66703
6cfb275aa300 Use split-string OMIT-NULLS argument.
Eli Zaretskii <eliz@gnu.org>
parents: 66272
diff changeset
1706 (rcirc-send-string process (concat "QUIT :"
6cfb275aa300 Use split-string OMIT-NULLS argument.
Eli Zaretskii <eliz@gnu.org>
parents: 66272
diff changeset
1707 (if (not (zerop (length reason)))
6cfb275aa300 Use split-string OMIT-NULLS argument.
Eli Zaretskii <eliz@gnu.org>
parents: 66272
diff changeset
1708 reason
6cfb275aa300 Use split-string OMIT-NULLS argument.
Eli Zaretskii <eliz@gnu.org>
parents: 66272
diff changeset
1709 rcirc-id-string))))
66248
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1710
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1711 (defun-rcirc-command nick (nick)
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1712 "Change nick to NICK."
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1713 (interactive "i")
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1714 (when (null nick)
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1715 (setq nick (read-string "New nick: " (rcirc-nick process))))
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1716 (rcirc-send-string process (concat "NICK " nick)))
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1717
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1718 (defun-rcirc-command names (channel)
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1719 "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
1720 If called interactively, prompt for a channel when prefix arg is supplied."
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1721 (interactive "P")
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1722 (if (interactive-p)
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1723 (if channel
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1724 (setq channel (read-string "List names in channel: " target))))
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1725 (let ((channel (if (> (length channel) 0)
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1726 channel
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1727 target)))
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1728 (rcirc-send-string process (concat "NAMES " channel))))
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1729
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1730 (defun-rcirc-command topic (topic)
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1731 "List TOPIC for the TARGET channel.
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1732 With a prefix arg, prompt for new topic."
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1733 (interactive "P")
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1734 (if (and (interactive-p) topic)
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1735 (setq topic (read-string "New Topic: " rcirc-topic)))
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1736 (rcirc-send-string process (concat "TOPIC " target
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1737 (when (> (length topic) 0)
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1738 (concat " :" topic)))))
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1739
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1740 (defun-rcirc-command whois (nick)
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1741 "Request information from server about NICK."
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1742 (interactive (list
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1743 (completing-read "Whois: "
69860
000a5d4aa083 (rcirc-default-server): Rename from rcirc-server.
Eli Zaretskii <eliz@gnu.org>
parents: 69694
diff changeset
1744 (with-rcirc-server-buffer rcirc-nick-table))))
66248
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1745 (rcirc-send-string process (concat "WHOIS " nick)))
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1746
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1747 (defun-rcirc-command mode (args)
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1748 "Set mode with ARGS."
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1749 (interactive (list (concat (read-string "Mode nick or channel: ")
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1750 " " (read-string "Mode: "))))
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1751 (rcirc-send-string process (concat "MODE " args)))
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1752
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1753 (defun-rcirc-command list (channels)
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1754 "Request information on CHANNELS from server."
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1755 (interactive "sList Channels: ")
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1756 (rcirc-send-string process (concat "LIST " channels)))
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1757
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1758 (defun-rcirc-command oper (args)
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1759 "Send operator command to server."
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1760 (interactive "sOper args: ")
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1761 (rcirc-send-string process (concat "OPER " args)))
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1762
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1763 (defun-rcirc-command quote (message)
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1764 "Send MESSAGE literally to server."
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1765 (interactive "sServer message: ")
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1766 (rcirc-send-string process message))
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1767
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1768 (defun-rcirc-command kick (arg)
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1769 "Kick NICK from current channel."
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1770 (interactive (list
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1771 (concat (completing-read "Kick nick: "
69860
000a5d4aa083 (rcirc-default-server): Rename from rcirc-server.
Eli Zaretskii <eliz@gnu.org>
parents: 69694
diff changeset
1772 (rcirc-channel-nicks
000a5d4aa083 (rcirc-default-server): Rename from rcirc-server.
Eli Zaretskii <eliz@gnu.org>
parents: 69694
diff changeset
1773 (rcirc-buffer-process)
000a5d4aa083 (rcirc-default-server): Rename from rcirc-server.
Eli Zaretskii <eliz@gnu.org>
parents: 69694
diff changeset
1774 rcirc-target))
66248
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1775 (read-from-minibuffer "Kick reason: "))))
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1776 (let* ((arglist (split-string arg))
66703
6cfb275aa300 Use split-string OMIT-NULLS argument.
Eli Zaretskii <eliz@gnu.org>
parents: 66272
diff changeset
1777 (argstring (concat (car arglist) " :"
66248
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1778 (mapconcat 'identity (cdr arglist) " "))))
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1779 (rcirc-send-string process (concat "KICK " target " " argstring))))
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1780
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1781 (defun rcirc-cmd-ctcp (args &optional process target)
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1782 (if (string-match "^\\([^ ]+\\)\\s-+\\(.+\\)$" args)
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1783 (let ((target (match-string 1 args))
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1784 (request (match-string 2 args)))
66703
6cfb275aa300 Use split-string OMIT-NULLS argument.
Eli Zaretskii <eliz@gnu.org>
parents: 66272
diff changeset
1785 (rcirc-send-string process
6cfb275aa300 Use split-string OMIT-NULLS argument.
Eli Zaretskii <eliz@gnu.org>
parents: 66272
diff changeset
1786 (format "PRIVMSG %s \C-a%s\C-a"
6cfb275aa300 Use split-string OMIT-NULLS argument.
Eli Zaretskii <eliz@gnu.org>
parents: 66272
diff changeset
1787 target (upcase request))))
6cfb275aa300 Use split-string OMIT-NULLS argument.
Eli Zaretskii <eliz@gnu.org>
parents: 66272
diff changeset
1788 (rcirc-print process (rcirc-nick process) "ERROR" nil
66248
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1789 "usage: /ctcp NICK REQUEST")))
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1790
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1791 (defun rcirc-cmd-me (args &optional process target)
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1792 (rcirc-send-string process (format "PRIVMSG %s :\C-aACTION %s\C-a"
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1793 target args)))
68079
61e9ea461d3c (rcirc-ignore-list): New option.
Alex Schroeder <alex@gnu.org>
parents: 68077
diff changeset
1794
72616
1c7de7b9540b (rcirc-keywords): New variable.
Eli Zaretskii <eliz@gnu.org>
parents: 72468
diff changeset
1795 (defun rcirc-add-or-remove (set &optional elt)
1c7de7b9540b (rcirc-keywords): New variable.
Eli Zaretskii <eliz@gnu.org>
parents: 72468
diff changeset
1796 (if (and elt (not (string= "" elt)))
1c7de7b9540b (rcirc-keywords): New variable.
Eli Zaretskii <eliz@gnu.org>
parents: 72468
diff changeset
1797 (if (member-ignore-case elt set)
1c7de7b9540b (rcirc-keywords): New variable.
Eli Zaretskii <eliz@gnu.org>
parents: 72468
diff changeset
1798 (delete elt set)
1c7de7b9540b (rcirc-keywords): New variable.
Eli Zaretskii <eliz@gnu.org>
parents: 72468
diff changeset
1799 (cons elt set))
1c7de7b9540b (rcirc-keywords): New variable.
Eli Zaretskii <eliz@gnu.org>
parents: 72468
diff changeset
1800 set))
1c7de7b9540b (rcirc-keywords): New variable.
Eli Zaretskii <eliz@gnu.org>
parents: 72468
diff changeset
1801
68079
61e9ea461d3c (rcirc-ignore-list): New option.
Alex Schroeder <alex@gnu.org>
parents: 68077
diff changeset
1802 (defun-rcirc-command ignore (nick)
61e9ea461d3c (rcirc-ignore-list): New option.
Alex Schroeder <alex@gnu.org>
parents: 68077
diff changeset
1803 "Manage the ignore list.
61e9ea461d3c (rcirc-ignore-list): New option.
Alex Schroeder <alex@gnu.org>
parents: 68077
diff changeset
1804 Ignore NICK, unignore NICK if already ignored, or list ignored
61e9ea461d3c (rcirc-ignore-list): New option.
Alex Schroeder <alex@gnu.org>
parents: 68077
diff changeset
1805 nicks when no NICK is given. When listing ignored nicks, the
68563
979fba30166f (rcirc-debug): Fix docstring.
Juanma Barranquero <lekktu@gmail.com>
parents: 68079
diff changeset
1806 ones added to the list automatically are marked with an asterisk."
68079
61e9ea461d3c (rcirc-ignore-list): New option.
Alex Schroeder <alex@gnu.org>
parents: 68077
diff changeset
1807 (interactive "sToggle ignoring of nick: ")
72616
1c7de7b9540b (rcirc-keywords): New variable.
Eli Zaretskii <eliz@gnu.org>
parents: 72468
diff changeset
1808 (setq rcirc-ignore-list (rcirc-add-or-remove rcirc-ignore-list nick))
1c7de7b9540b (rcirc-keywords): New variable.
Eli Zaretskii <eliz@gnu.org>
parents: 72468
diff changeset
1809 (rcirc-print process nil "IGNORE" target
68731
85be285e3494 (rcirc-startup-channels-alist): Add irc.freenode.net and #emacs as defaults.
Eli Zaretskii <eliz@gnu.org>
parents: 68648
diff changeset
1810 (mapconcat
85be285e3494 (rcirc-startup-channels-alist): Add irc.freenode.net and #emacs as defaults.
Eli Zaretskii <eliz@gnu.org>
parents: 68648
diff changeset
1811 (lambda (nick)
85be285e3494 (rcirc-startup-channels-alist): Add irc.freenode.net and #emacs as defaults.
Eli Zaretskii <eliz@gnu.org>
parents: 68648
diff changeset
1812 (concat nick
85be285e3494 (rcirc-startup-channels-alist): Add irc.freenode.net and #emacs as defaults.
Eli Zaretskii <eliz@gnu.org>
parents: 68648
diff changeset
1813 (if (member nick rcirc-ignore-list-automatic)
85be285e3494 (rcirc-startup-channels-alist): Add irc.freenode.net and #emacs as defaults.
Eli Zaretskii <eliz@gnu.org>
parents: 68648
diff changeset
1814 "*" "")))
85be285e3494 (rcirc-startup-channels-alist): Add irc.freenode.net and #emacs as defaults.
Eli Zaretskii <eliz@gnu.org>
parents: 68648
diff changeset
1815 rcirc-ignore-list " ")))
68079
61e9ea461d3c (rcirc-ignore-list): New option.
Alex Schroeder <alex@gnu.org>
parents: 68077
diff changeset
1816
72616
1c7de7b9540b (rcirc-keywords): New variable.
Eli Zaretskii <eliz@gnu.org>
parents: 72468
diff changeset
1817 (defun-rcirc-command bright (nick)
1c7de7b9540b (rcirc-keywords): New variable.
Eli Zaretskii <eliz@gnu.org>
parents: 72468
diff changeset
1818 "Manage the bright nick list."
1c7de7b9540b (rcirc-keywords): New variable.
Eli Zaretskii <eliz@gnu.org>
parents: 72468
diff changeset
1819 (interactive "sToggle emphasis of nick: ")
1c7de7b9540b (rcirc-keywords): New variable.
Eli Zaretskii <eliz@gnu.org>
parents: 72468
diff changeset
1820 (setq rcirc-bright-nicks (rcirc-add-or-remove rcirc-bright-nicks nick))
1c7de7b9540b (rcirc-keywords): New variable.
Eli Zaretskii <eliz@gnu.org>
parents: 72468
diff changeset
1821 (rcirc-print process nil "BRIGHT" target
1c7de7b9540b (rcirc-keywords): New variable.
Eli Zaretskii <eliz@gnu.org>
parents: 72468
diff changeset
1822 (mapconcat 'identity rcirc-bright-nicks " ")))
1c7de7b9540b (rcirc-keywords): New variable.
Eli Zaretskii <eliz@gnu.org>
parents: 72468
diff changeset
1823
1c7de7b9540b (rcirc-keywords): New variable.
Eli Zaretskii <eliz@gnu.org>
parents: 72468
diff changeset
1824 (defun-rcirc-command dim (nick)
1c7de7b9540b (rcirc-keywords): New variable.
Eli Zaretskii <eliz@gnu.org>
parents: 72468
diff changeset
1825 "Manage the dim nick list."
1c7de7b9540b (rcirc-keywords): New variable.
Eli Zaretskii <eliz@gnu.org>
parents: 72468
diff changeset
1826 (interactive "sToggle deemphasis of nick: ")
1c7de7b9540b (rcirc-keywords): New variable.
Eli Zaretskii <eliz@gnu.org>
parents: 72468
diff changeset
1827 (setq rcirc-dim-nicks (rcirc-add-or-remove rcirc-dim-nicks nick))
1c7de7b9540b (rcirc-keywords): New variable.
Eli Zaretskii <eliz@gnu.org>
parents: 72468
diff changeset
1828 (rcirc-print process nil "DIM" target
1c7de7b9540b (rcirc-keywords): New variable.
Eli Zaretskii <eliz@gnu.org>
parents: 72468
diff changeset
1829 (mapconcat 'identity rcirc-dim-nicks " ")))
1c7de7b9540b (rcirc-keywords): New variable.
Eli Zaretskii <eliz@gnu.org>
parents: 72468
diff changeset
1830
1c7de7b9540b (rcirc-keywords): New variable.
Eli Zaretskii <eliz@gnu.org>
parents: 72468
diff changeset
1831 (defun-rcirc-command keyword (keyword)
1c7de7b9540b (rcirc-keywords): New variable.
Eli Zaretskii <eliz@gnu.org>
parents: 72468
diff changeset
1832 "Manage the keyword list.
1c7de7b9540b (rcirc-keywords): New variable.
Eli Zaretskii <eliz@gnu.org>
parents: 72468
diff changeset
1833 Mark KEYWORD, unmark KEYWORD if already marked, or list marked
1c7de7b9540b (rcirc-keywords): New variable.
Eli Zaretskii <eliz@gnu.org>
parents: 72468
diff changeset
1834 keywords when no KEYWORD is given."
1c7de7b9540b (rcirc-keywords): New variable.
Eli Zaretskii <eliz@gnu.org>
parents: 72468
diff changeset
1835 (interactive "sToggle highlighting of keyword: ")
1c7de7b9540b (rcirc-keywords): New variable.
Eli Zaretskii <eliz@gnu.org>
parents: 72468
diff changeset
1836 (setq rcirc-keywords (rcirc-add-or-remove rcirc-keywords keyword))
1c7de7b9540b (rcirc-keywords): New variable.
Eli Zaretskii <eliz@gnu.org>
parents: 72468
diff changeset
1837 (rcirc-print process nil "KEYWORD" target
1c7de7b9540b (rcirc-keywords): New variable.
Eli Zaretskii <eliz@gnu.org>
parents: 72468
diff changeset
1838 (mapconcat 'identity rcirc-keywords " ")))
1c7de7b9540b (rcirc-keywords): New variable.
Eli Zaretskii <eliz@gnu.org>
parents: 72468
diff changeset
1839
66248
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1840
72616
1c7de7b9540b (rcirc-keywords): New variable.
Eli Zaretskii <eliz@gnu.org>
parents: 72468
diff changeset
1841 (defun rcirc-add-face (start end name &optional object)
1c7de7b9540b (rcirc-keywords): New variable.
Eli Zaretskii <eliz@gnu.org>
parents: 72468
diff changeset
1842 "Add face NAME to the face text property of the text from START to END."
1c7de7b9540b (rcirc-keywords): New variable.
Eli Zaretskii <eliz@gnu.org>
parents: 72468
diff changeset
1843 (when name
1c7de7b9540b (rcirc-keywords): New variable.
Eli Zaretskii <eliz@gnu.org>
parents: 72468
diff changeset
1844 (let ((pos start)
1c7de7b9540b (rcirc-keywords): New variable.
Eli Zaretskii <eliz@gnu.org>
parents: 72468
diff changeset
1845 next prop)
1c7de7b9540b (rcirc-keywords): New variable.
Eli Zaretskii <eliz@gnu.org>
parents: 72468
diff changeset
1846 (while (< pos end)
1c7de7b9540b (rcirc-keywords): New variable.
Eli Zaretskii <eliz@gnu.org>
parents: 72468
diff changeset
1847 (setq prop (get-text-property pos 'face object)
1c7de7b9540b (rcirc-keywords): New variable.
Eli Zaretskii <eliz@gnu.org>
parents: 72468
diff changeset
1848 next (next-single-property-change pos 'face object end))
1c7de7b9540b (rcirc-keywords): New variable.
Eli Zaretskii <eliz@gnu.org>
parents: 72468
diff changeset
1849 (unless (member name (get-text-property pos 'face object))
1c7de7b9540b (rcirc-keywords): New variable.
Eli Zaretskii <eliz@gnu.org>
parents: 72468
diff changeset
1850 (add-text-properties pos next (list 'face (cons name prop)) object))
1c7de7b9540b (rcirc-keywords): New variable.
Eli Zaretskii <eliz@gnu.org>
parents: 72468
diff changeset
1851 (setq pos next)))))
66703
6cfb275aa300 Use split-string OMIT-NULLS argument.
Eli Zaretskii <eliz@gnu.org>
parents: 66272
diff changeset
1852
66248
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1853 (defun rcirc-facify (string face)
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1854 "Return a copy of STRING with FACE property added."
72616
1c7de7b9540b (rcirc-keywords): New variable.
Eli Zaretskii <eliz@gnu.org>
parents: 72468
diff changeset
1855 (let ((string (or string "")))
1c7de7b9540b (rcirc-keywords): New variable.
Eli Zaretskii <eliz@gnu.org>
parents: 72468
diff changeset
1856 (rcirc-add-face 0 (length string) face string)
1c7de7b9540b (rcirc-keywords): New variable.
Eli Zaretskii <eliz@gnu.org>
parents: 72468
diff changeset
1857 string))
66248
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1858
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1859 (defvar rcirc-url-regexp
68960
6e3160901812 (rcirc-connect): Make all arguments optional, and default to global variable
Eli Zaretskii <eliz@gnu.org>
parents: 68838
diff changeset
1860 (rx-to-string
6e3160901812 (rcirc-connect): Make all arguments optional, and default to global variable
Eli Zaretskii <eliz@gnu.org>
parents: 68838
diff changeset
1861 `(and word-boundary
69252
45e1ec6f858b (rcirc-url-regexp): Match entire url when it starts with "www".
Eli Zaretskii <eliz@gnu.org>
parents: 68960
diff changeset
1862 (or (and
45e1ec6f858b (rcirc-url-regexp): Match entire url when it starts with "www".
Eli Zaretskii <eliz@gnu.org>
parents: 68960
diff changeset
1863 (or (and (or "http" "https" "ftp" "file" "gopher" "news"
45e1ec6f858b (rcirc-url-regexp): Match entire url when it starts with "www".
Eli Zaretskii <eliz@gnu.org>
parents: 68960
diff changeset
1864 "telnet" "wais" "mailto")
45e1ec6f858b (rcirc-url-regexp): Match entire url when it starts with "www".
Eli Zaretskii <eliz@gnu.org>
parents: 68960
diff changeset
1865 "://")
45e1ec6f858b (rcirc-url-regexp): Match entire url when it starts with "www".
Eli Zaretskii <eliz@gnu.org>
parents: 68960
diff changeset
1866 "www.")
45e1ec6f858b (rcirc-url-regexp): Match entire url when it starts with "www".
Eli Zaretskii <eliz@gnu.org>
parents: 68960
diff changeset
1867 (1+ (char "-a-zA-Z0-9_."))
72468
5e47ca87ee3c Rcirc update from Ryan Yeske
Miles Bader <miles@gnu.org>
parents: 71442
diff changeset
1868 (1+ (char "-a-zA-Z0-9_"))
69252
45e1ec6f858b (rcirc-url-regexp): Match entire url when it starts with "www".
Eli Zaretskii <eliz@gnu.org>
parents: 68960
diff changeset
1869 (optional ":" (1+ (char "0-9"))))
68960
6e3160901812 (rcirc-connect): Make all arguments optional, and default to global variable
Eli Zaretskii <eliz@gnu.org>
parents: 68838
diff changeset
1870 (and (1+ (char "-a-zA-Z0-9_."))
6e3160901812 (rcirc-connect): Make all arguments optional, and default to global variable
Eli Zaretskii <eliz@gnu.org>
parents: 68838
diff changeset
1871 (or ".com" ".net" ".org")
6e3160901812 (rcirc-connect): Make all arguments optional, and default to global variable
Eli Zaretskii <eliz@gnu.org>
parents: 68838
diff changeset
1872 word-boundary))
6e3160901812 (rcirc-connect): Make all arguments optional, and default to global variable
Eli Zaretskii <eliz@gnu.org>
parents: 68838
diff changeset
1873 (optional
6e3160901812 (rcirc-connect): Make all arguments optional, and default to global variable
Eli Zaretskii <eliz@gnu.org>
parents: 68838
diff changeset
1874 (and "/"
72616
1c7de7b9540b (rcirc-keywords): New variable.
Eli Zaretskii <eliz@gnu.org>
parents: 72468
diff changeset
1875 (1+ (char "-a-zA-Z0-9_=!?#$\@~`%&*+|\\/:;.,{}[]()"))
1c7de7b9540b (rcirc-keywords): New variable.
Eli Zaretskii <eliz@gnu.org>
parents: 72468
diff changeset
1876 (char "-a-zA-Z0-9_=#$\@~`%&*+|\\/:;{}[]()")))))
68563
979fba30166f (rcirc-debug): Fix docstring.
Juanma Barranquero <lekktu@gmail.com>
parents: 68079
diff changeset
1877 "Regexp matching URLs. Set to nil to disable URL features in rcirc.")
66248
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1878
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1879 (defun rcirc-browse-url (&optional arg)
68563
979fba30166f (rcirc-debug): Fix docstring.
Juanma Barranquero <lekktu@gmail.com>
parents: 68079
diff changeset
1880 "Prompt for URL to browse based on URLs in buffer."
70215
90d76f24753a Revision: emacs@sv.gnu.org/emacs--devo--0--patch-247
Miles Bader <miles@gnu.org>
parents: 69860
diff changeset
1881 (interactive "P")
66248
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1882 (let ((completions (mapcar (lambda (x) (cons x nil)) rcirc-urls))
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1883 (initial-input (car rcirc-urls))
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1884 (history (cdr rcirc-urls)))
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1885 (browse-url (completing-read "rcirc browse-url: "
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1886 completions nil nil initial-input 'history)
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1887 arg)))
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1888
66703
6cfb275aa300 Use split-string OMIT-NULLS argument.
Eli Zaretskii <eliz@gnu.org>
parents: 66272
diff changeset
1889 (defun rcirc-browse-url-at-point (point)
6cfb275aa300 Use split-string OMIT-NULLS argument.
Eli Zaretskii <eliz@gnu.org>
parents: 66272
diff changeset
1890 "Send URL at point to `browse-url'."
6cfb275aa300 Use split-string OMIT-NULLS argument.
Eli Zaretskii <eliz@gnu.org>
parents: 66272
diff changeset
1891 (interactive "d")
72468
5e47ca87ee3c Rcirc update from Ryan Yeske
Miles Bader <miles@gnu.org>
parents: 71442
diff changeset
1892 (let ((beg (previous-single-property-change (1+ point) 'mouse-face))
66703
6cfb275aa300 Use split-string OMIT-NULLS argument.
Eli Zaretskii <eliz@gnu.org>
parents: 66272
diff changeset
1893 (end (next-single-property-change point 'mouse-face)))
6cfb275aa300 Use split-string OMIT-NULLS argument.
Eli Zaretskii <eliz@gnu.org>
parents: 66272
diff changeset
1894 (browse-url (buffer-substring-no-properties beg end))))
6cfb275aa300 Use split-string OMIT-NULLS argument.
Eli Zaretskii <eliz@gnu.org>
parents: 66272
diff changeset
1895
6cfb275aa300 Use split-string OMIT-NULLS argument.
Eli Zaretskii <eliz@gnu.org>
parents: 66272
diff changeset
1896 (defun rcirc-browse-url-at-mouse (event)
6cfb275aa300 Use split-string OMIT-NULLS argument.
Eli Zaretskii <eliz@gnu.org>
parents: 66272
diff changeset
1897 "Send URL at mouse click to `browse-url'."
6cfb275aa300 Use split-string OMIT-NULLS argument.
Eli Zaretskii <eliz@gnu.org>
parents: 66272
diff changeset
1898 (interactive "e")
6cfb275aa300 Use split-string OMIT-NULLS argument.
Eli Zaretskii <eliz@gnu.org>
parents: 66272
diff changeset
1899 (let ((position (event-end event)))
6cfb275aa300 Use split-string OMIT-NULLS argument.
Eli Zaretskii <eliz@gnu.org>
parents: 66272
diff changeset
1900 (with-current-buffer (window-buffer (posn-window position))
6cfb275aa300 Use split-string OMIT-NULLS argument.
Eli Zaretskii <eliz@gnu.org>
parents: 66272
diff changeset
1901 (rcirc-browse-url-at-point (posn-point position)))))
6cfb275aa300 Use split-string OMIT-NULLS argument.
Eli Zaretskii <eliz@gnu.org>
parents: 66272
diff changeset
1902
72616
1c7de7b9540b (rcirc-keywords): New variable.
Eli Zaretskii <eliz@gnu.org>
parents: 72468
diff changeset
1903
1c7de7b9540b (rcirc-keywords): New variable.
Eli Zaretskii <eliz@gnu.org>
parents: 72468
diff changeset
1904 (defvar rcirc-markup-text-functions
1c7de7b9540b (rcirc-keywords): New variable.
Eli Zaretskii <eliz@gnu.org>
parents: 72468
diff changeset
1905 '(rcirc-markup-body-text
1c7de7b9540b (rcirc-keywords): New variable.
Eli Zaretskii <eliz@gnu.org>
parents: 72468
diff changeset
1906 rcirc-markup-attributes
1c7de7b9540b (rcirc-keywords): New variable.
Eli Zaretskii <eliz@gnu.org>
parents: 72468
diff changeset
1907 rcirc-markup-my-nick
1c7de7b9540b (rcirc-keywords): New variable.
Eli Zaretskii <eliz@gnu.org>
parents: 72468
diff changeset
1908 rcirc-markup-urls
1c7de7b9540b (rcirc-keywords): New variable.
Eli Zaretskii <eliz@gnu.org>
parents: 72468
diff changeset
1909 rcirc-markup-keywords
1c7de7b9540b (rcirc-keywords): New variable.
Eli Zaretskii <eliz@gnu.org>
parents: 72468
diff changeset
1910 rcirc-markup-bright-nicks)
1c7de7b9540b (rcirc-keywords): New variable.
Eli Zaretskii <eliz@gnu.org>
parents: 72468
diff changeset
1911 "List of functions used to manipulate text before it is printed.
66248
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1912
72616
1c7de7b9540b (rcirc-keywords): New variable.
Eli Zaretskii <eliz@gnu.org>
parents: 72468
diff changeset
1913 Each function takes three arguments, PROCESS, SENDER, RESPONSE
1c7de7b9540b (rcirc-keywords): New variable.
Eli Zaretskii <eliz@gnu.org>
parents: 72468
diff changeset
1914 and CHANNEL-BUFFER. The current buffer is temporary buffer that
1c7de7b9540b (rcirc-keywords): New variable.
Eli Zaretskii <eliz@gnu.org>
parents: 72468
diff changeset
1915 contains the text to manipulate. Each function works on the text
1c7de7b9540b (rcirc-keywords): New variable.
Eli Zaretskii <eliz@gnu.org>
parents: 72468
diff changeset
1916 in this buffer.")
1c7de7b9540b (rcirc-keywords): New variable.
Eli Zaretskii <eliz@gnu.org>
parents: 72468
diff changeset
1917
1c7de7b9540b (rcirc-keywords): New variable.
Eli Zaretskii <eliz@gnu.org>
parents: 72468
diff changeset
1918 (defun rcirc-markup-text (process sender response text)
66248
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1919 "Return TEXT with properties added based on various patterns."
72616
1c7de7b9540b (rcirc-keywords): New variable.
Eli Zaretskii <eliz@gnu.org>
parents: 72468
diff changeset
1920 (let ((channel-buffer (current-buffer)))
1c7de7b9540b (rcirc-keywords): New variable.
Eli Zaretskii <eliz@gnu.org>
parents: 72468
diff changeset
1921 (with-temp-buffer
1c7de7b9540b (rcirc-keywords): New variable.
Eli Zaretskii <eliz@gnu.org>
parents: 72468
diff changeset
1922 (insert text)
1c7de7b9540b (rcirc-keywords): New variable.
Eli Zaretskii <eliz@gnu.org>
parents: 72468
diff changeset
1923 (goto-char (point-min))
1c7de7b9540b (rcirc-keywords): New variable.
Eli Zaretskii <eliz@gnu.org>
parents: 72468
diff changeset
1924 (dolist (fn rcirc-markup-text-functions)
1c7de7b9540b (rcirc-keywords): New variable.
Eli Zaretskii <eliz@gnu.org>
parents: 72468
diff changeset
1925 (save-excursion
1c7de7b9540b (rcirc-keywords): New variable.
Eli Zaretskii <eliz@gnu.org>
parents: 72468
diff changeset
1926 (funcall fn process sender response channel-buffer)))
1c7de7b9540b (rcirc-keywords): New variable.
Eli Zaretskii <eliz@gnu.org>
parents: 72468
diff changeset
1927 (buffer-substring (point-min) (point-max)))))
1c7de7b9540b (rcirc-keywords): New variable.
Eli Zaretskii <eliz@gnu.org>
parents: 72468
diff changeset
1928
1c7de7b9540b (rcirc-keywords): New variable.
Eli Zaretskii <eliz@gnu.org>
parents: 72468
diff changeset
1929 (defun rcirc-markup-body-text (process sender response channel-buffer)
1c7de7b9540b (rcirc-keywords): New variable.
Eli Zaretskii <eliz@gnu.org>
parents: 72468
diff changeset
1930 ;; We add the text property `rcirc-text' to identify this as the
1c7de7b9540b (rcirc-keywords): New variable.
Eli Zaretskii <eliz@gnu.org>
parents: 72468
diff changeset
1931 ;; body text.
1c7de7b9540b (rcirc-keywords): New variable.
Eli Zaretskii <eliz@gnu.org>
parents: 72468
diff changeset
1932 (add-text-properties (point-min) (point-max)
1c7de7b9540b (rcirc-keywords): New variable.
Eli Zaretskii <eliz@gnu.org>
parents: 72468
diff changeset
1933 (list 'rcirc-text (buffer-substring-no-properties
1c7de7b9540b (rcirc-keywords): New variable.
Eli Zaretskii <eliz@gnu.org>
parents: 72468
diff changeset
1934 (point-min) (point-max)))))
1c7de7b9540b (rcirc-keywords): New variable.
Eli Zaretskii <eliz@gnu.org>
parents: 72468
diff changeset
1935
1c7de7b9540b (rcirc-keywords): New variable.
Eli Zaretskii <eliz@gnu.org>
parents: 72468
diff changeset
1936 (defun rcirc-markup-attributes (process sender response channel-buffer)
1c7de7b9540b (rcirc-keywords): New variable.
Eli Zaretskii <eliz@gnu.org>
parents: 72468
diff changeset
1937 (while (re-search-forward "\\([\C-b\C-_\C-v]\\).*?\\(\\1\\|\C-o\\)" nil t)
1c7de7b9540b (rcirc-keywords): New variable.
Eli Zaretskii <eliz@gnu.org>
parents: 72468
diff changeset
1938 (rcirc-add-face (match-beginning 0) (match-end 0)
1c7de7b9540b (rcirc-keywords): New variable.
Eli Zaretskii <eliz@gnu.org>
parents: 72468
diff changeset
1939 (case (char-after (match-beginning 1))
1c7de7b9540b (rcirc-keywords): New variable.
Eli Zaretskii <eliz@gnu.org>
parents: 72468
diff changeset
1940 (?\C-b 'bold)
1c7de7b9540b (rcirc-keywords): New variable.
Eli Zaretskii <eliz@gnu.org>
parents: 72468
diff changeset
1941 (?\C-v 'italic)
1c7de7b9540b (rcirc-keywords): New variable.
Eli Zaretskii <eliz@gnu.org>
parents: 72468
diff changeset
1942 (?\C-_ 'underline)))
1c7de7b9540b (rcirc-keywords): New variable.
Eli Zaretskii <eliz@gnu.org>
parents: 72468
diff changeset
1943 ;; keep the ^O since it could terminate other attributes
1c7de7b9540b (rcirc-keywords): New variable.
Eli Zaretskii <eliz@gnu.org>
parents: 72468
diff changeset
1944 (when (not (eq ?\C-o (char-before (match-end 2))))
1c7de7b9540b (rcirc-keywords): New variable.
Eli Zaretskii <eliz@gnu.org>
parents: 72468
diff changeset
1945 (delete-region (match-beginning 2) (match-end 2)))
1c7de7b9540b (rcirc-keywords): New variable.
Eli Zaretskii <eliz@gnu.org>
parents: 72468
diff changeset
1946 (delete-region (match-beginning 1) (match-end 1))
1c7de7b9540b (rcirc-keywords): New variable.
Eli Zaretskii <eliz@gnu.org>
parents: 72468
diff changeset
1947 (goto-char (1+ (match-beginning 1))))
1c7de7b9540b (rcirc-keywords): New variable.
Eli Zaretskii <eliz@gnu.org>
parents: 72468
diff changeset
1948 ;; remove the ^O characters now
1c7de7b9540b (rcirc-keywords): New variable.
Eli Zaretskii <eliz@gnu.org>
parents: 72468
diff changeset
1949 (while (re-search-forward "\C-o+" nil t)
1c7de7b9540b (rcirc-keywords): New variable.
Eli Zaretskii <eliz@gnu.org>
parents: 72468
diff changeset
1950 (delete-region (match-beginning 0) (match-end 0))))
66248
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1951
72616
1c7de7b9540b (rcirc-keywords): New variable.
Eli Zaretskii <eliz@gnu.org>
parents: 72468
diff changeset
1952 (defun rcirc-markup-my-nick (process sender response channel-buffer)
1c7de7b9540b (rcirc-keywords): New variable.
Eli Zaretskii <eliz@gnu.org>
parents: 72468
diff changeset
1953 (with-syntax-table rcirc-nick-syntax-table
1c7de7b9540b (rcirc-keywords): New variable.
Eli Zaretskii <eliz@gnu.org>
parents: 72468
diff changeset
1954 (while (re-search-forward (concat "\\b"
1c7de7b9540b (rcirc-keywords): New variable.
Eli Zaretskii <eliz@gnu.org>
parents: 72468
diff changeset
1955 (regexp-quote (rcirc-nick process))
1c7de7b9540b (rcirc-keywords): New variable.
Eli Zaretskii <eliz@gnu.org>
parents: 72468
diff changeset
1956 "\\b")
1c7de7b9540b (rcirc-keywords): New variable.
Eli Zaretskii <eliz@gnu.org>
parents: 72468
diff changeset
1957 nil t)
1c7de7b9540b (rcirc-keywords): New variable.
Eli Zaretskii <eliz@gnu.org>
parents: 72468
diff changeset
1958 (rcirc-add-face (match-beginning 0) (match-end 0)
1c7de7b9540b (rcirc-keywords): New variable.
Eli Zaretskii <eliz@gnu.org>
parents: 72468
diff changeset
1959 'rcirc-nick-in-message)
1c7de7b9540b (rcirc-keywords): New variable.
Eli Zaretskii <eliz@gnu.org>
parents: 72468
diff changeset
1960 (when (string= response "PRIVMSG")
1c7de7b9540b (rcirc-keywords): New variable.
Eli Zaretskii <eliz@gnu.org>
parents: 72468
diff changeset
1961 (rcirc-add-face (point-min) (point-max) 'rcirc-nick-in-message-full-line)
1c7de7b9540b (rcirc-keywords): New variable.
Eli Zaretskii <eliz@gnu.org>
parents: 72468
diff changeset
1962 (rcirc-record-activity channel-buffer 'nick)))))
1c7de7b9540b (rcirc-keywords): New variable.
Eli Zaretskii <eliz@gnu.org>
parents: 72468
diff changeset
1963
1c7de7b9540b (rcirc-keywords): New variable.
Eli Zaretskii <eliz@gnu.org>
parents: 72468
diff changeset
1964 (defun rcirc-markup-urls (process sender response channel-buffer)
1c7de7b9540b (rcirc-keywords): New variable.
Eli Zaretskii <eliz@gnu.org>
parents: 72468
diff changeset
1965 (while (re-search-forward rcirc-url-regexp nil t)
1c7de7b9540b (rcirc-keywords): New variable.
Eli Zaretskii <eliz@gnu.org>
parents: 72468
diff changeset
1966 (let ((start (match-beginning 0))
1c7de7b9540b (rcirc-keywords): New variable.
Eli Zaretskii <eliz@gnu.org>
parents: 72468
diff changeset
1967 (end (match-end 0)))
1c7de7b9540b (rcirc-keywords): New variable.
Eli Zaretskii <eliz@gnu.org>
parents: 72468
diff changeset
1968 (rcirc-add-face start end 'rcirc-url)
1c7de7b9540b (rcirc-keywords): New variable.
Eli Zaretskii <eliz@gnu.org>
parents: 72468
diff changeset
1969 (add-text-properties start end (list 'mouse-face 'highlight
1c7de7b9540b (rcirc-keywords): New variable.
Eli Zaretskii <eliz@gnu.org>
parents: 72468
diff changeset
1970 'keymap rcirc-browse-url-map))
1c7de7b9540b (rcirc-keywords): New variable.
Eli Zaretskii <eliz@gnu.org>
parents: 72468
diff changeset
1971 ;; record the url
1c7de7b9540b (rcirc-keywords): New variable.
Eli Zaretskii <eliz@gnu.org>
parents: 72468
diff changeset
1972 (let ((url (buffer-substring-no-properties start end)))
1c7de7b9540b (rcirc-keywords): New variable.
Eli Zaretskii <eliz@gnu.org>
parents: 72468
diff changeset
1973 (with-current-buffer channel-buffer
1c7de7b9540b (rcirc-keywords): New variable.
Eli Zaretskii <eliz@gnu.org>
parents: 72468
diff changeset
1974 (push url rcirc-urls))))))
1c7de7b9540b (rcirc-keywords): New variable.
Eli Zaretskii <eliz@gnu.org>
parents: 72468
diff changeset
1975
1c7de7b9540b (rcirc-keywords): New variable.
Eli Zaretskii <eliz@gnu.org>
parents: 72468
diff changeset
1976 (defun rcirc-markup-keywords (process sender response channel-buffer)
1c7de7b9540b (rcirc-keywords): New variable.
Eli Zaretskii <eliz@gnu.org>
parents: 72468
diff changeset
1977 (let* ((target (with-current-buffer channel-buffer (or rcirc-target "")))
1c7de7b9540b (rcirc-keywords): New variable.
Eli Zaretskii <eliz@gnu.org>
parents: 72468
diff changeset
1978 (keywords (delq nil (mapcar (lambda (keyword)
1c7de7b9540b (rcirc-keywords): New variable.
Eli Zaretskii <eliz@gnu.org>
parents: 72468
diff changeset
1979 (when (not (string-match keyword target))
1c7de7b9540b (rcirc-keywords): New variable.
Eli Zaretskii <eliz@gnu.org>
parents: 72468
diff changeset
1980 keyword))
1c7de7b9540b (rcirc-keywords): New variable.
Eli Zaretskii <eliz@gnu.org>
parents: 72468
diff changeset
1981 rcirc-keywords))))
1c7de7b9540b (rcirc-keywords): New variable.
Eli Zaretskii <eliz@gnu.org>
parents: 72468
diff changeset
1982 (when keywords
1c7de7b9540b (rcirc-keywords): New variable.
Eli Zaretskii <eliz@gnu.org>
parents: 72468
diff changeset
1983 (while (re-search-forward (regexp-opt keywords 'words) nil t)
1c7de7b9540b (rcirc-keywords): New variable.
Eli Zaretskii <eliz@gnu.org>
parents: 72468
diff changeset
1984 (rcirc-add-face (match-beginning 0) (match-end 0) 'rcirc-keyword)
1c7de7b9540b (rcirc-keywords): New variable.
Eli Zaretskii <eliz@gnu.org>
parents: 72468
diff changeset
1985 (when (and (string= response "PRIVMSG")
1c7de7b9540b (rcirc-keywords): New variable.
Eli Zaretskii <eliz@gnu.org>
parents: 72468
diff changeset
1986 (not (string= sender (rcirc-nick process))))
1c7de7b9540b (rcirc-keywords): New variable.
Eli Zaretskii <eliz@gnu.org>
parents: 72468
diff changeset
1987 (rcirc-record-activity channel-buffer 'keyword))))))
1c7de7b9540b (rcirc-keywords): New variable.
Eli Zaretskii <eliz@gnu.org>
parents: 72468
diff changeset
1988
1c7de7b9540b (rcirc-keywords): New variable.
Eli Zaretskii <eliz@gnu.org>
parents: 72468
diff changeset
1989 (defun rcirc-markup-bright-nicks (process sender response channel-buffer)
1c7de7b9540b (rcirc-keywords): New variable.
Eli Zaretskii <eliz@gnu.org>
parents: 72468
diff changeset
1990 (when (and rcirc-bright-nicks
1c7de7b9540b (rcirc-keywords): New variable.
Eli Zaretskii <eliz@gnu.org>
parents: 72468
diff changeset
1991 (string= response "NAMES"))
1c7de7b9540b (rcirc-keywords): New variable.
Eli Zaretskii <eliz@gnu.org>
parents: 72468
diff changeset
1992 (with-syntax-table rcirc-nick-syntax-table
1c7de7b9540b (rcirc-keywords): New variable.
Eli Zaretskii <eliz@gnu.org>
parents: 72468
diff changeset
1993 (while (re-search-forward (regexp-opt rcirc-bright-nicks 'words) nil t)
1c7de7b9540b (rcirc-keywords): New variable.
Eli Zaretskii <eliz@gnu.org>
parents: 72468
diff changeset
1994 (rcirc-add-face (match-beginning 0) (match-end 0)
1c7de7b9540b (rcirc-keywords): New variable.
Eli Zaretskii <eliz@gnu.org>
parents: 72468
diff changeset
1995 'rcirc-bright-nick)))))
66248
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1996
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1997 ;;; handlers
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1998 ;; these are called with the server PROCESS, the SENDER, which is a
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
1999 ;; 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
2000 ;; list of strings, and the TEXT, which is the original server text,
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
2001 ;; verbatim
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
2002 (defun rcirc-handler-001 (process sender args text)
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
2003 (rcirc-handler-generic process "001" sender args text)
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
2004 ;; set the real server name
66703
6cfb275aa300 Use split-string OMIT-NULLS argument.
Eli Zaretskii <eliz@gnu.org>
parents: 66272
diff changeset
2005 (with-rcirc-process-buffer process
66248
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
2006 (setq rcirc-server sender)
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
2007 (setq rcirc-nick (car args))
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
2008 (rcirc-update-prompt)
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
2009 (when rcirc-auto-authenticate-flag (rcirc-authenticate))
66703
6cfb275aa300 Use split-string OMIT-NULLS argument.
Eli Zaretskii <eliz@gnu.org>
parents: 66272
diff changeset
2010 (rcirc-join-channels process rcirc-startup-channels)))
66248
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
2011
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
2012 (defun rcirc-handler-PRIVMSG (process sender args text)
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
2013 (let ((target (if (rcirc-channel-p (car args))
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
2014 (car args)
68731
85be285e3494 (rcirc-startup-channels-alist): Add irc.freenode.net and #emacs as defaults.
Eli Zaretskii <eliz@gnu.org>
parents: 68648
diff changeset
2015 sender))
66248
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
2016 (message (or (cadr args) "")))
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
2017 (if (string-match "^\C-a\\(.*\\)\C-a$" message)
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
2018 (rcirc-handler-CTCP process target sender (match-string 1 message))
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
2019 (rcirc-print process sender "PRIVMSG" target message t))
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
2020 ;; update nick timestamp
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
2021 (if (member target (rcirc-nick-channels process sender))
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
2022 (rcirc-put-nick-channel process sender target))))
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
2023
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
2024 (defun rcirc-handler-NOTICE (process sender args text)
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
2025 (let ((target (car args))
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
2026 (message (cadr args)))
66703
6cfb275aa300 Use split-string OMIT-NULLS argument.
Eli Zaretskii <eliz@gnu.org>
parents: 66272
diff changeset
2027 (if (string-match "^\C-a\\(.*\\)\C-a$" message)
6cfb275aa300 Use split-string OMIT-NULLS argument.
Eli Zaretskii <eliz@gnu.org>
parents: 66272
diff changeset
2028 (rcirc-handler-CTCP-response process target sender
6cfb275aa300 Use split-string OMIT-NULLS argument.
Eli Zaretskii <eliz@gnu.org>
parents: 66272
diff changeset
2029 (match-string 1 message))
6cfb275aa300 Use split-string OMIT-NULLS argument.
Eli Zaretskii <eliz@gnu.org>
parents: 66272
diff changeset
2030 (rcirc-print process sender "NOTICE"
6cfb275aa300 Use split-string OMIT-NULLS argument.
Eli Zaretskii <eliz@gnu.org>
parents: 66272
diff changeset
2031 (cond ((rcirc-channel-p target)
6cfb275aa300 Use split-string OMIT-NULLS argument.
Eli Zaretskii <eliz@gnu.org>
parents: 66272
diff changeset
2032 target)
6cfb275aa300 Use split-string OMIT-NULLS argument.
Eli Zaretskii <eliz@gnu.org>
parents: 66272
diff changeset
2033 ;;; -ChanServ- [#gnu] Welcome...
70215
90d76f24753a Revision: emacs@sv.gnu.org/emacs--devo--0--patch-247
Miles Bader <miles@gnu.org>
parents: 69860
diff changeset
2034 ((string-match "\\[\\(#[^\] ]+\\)\\]" message)
66703
6cfb275aa300 Use split-string OMIT-NULLS argument.
Eli Zaretskii <eliz@gnu.org>
parents: 66272
diff changeset
2035 (match-string 1 message))
6cfb275aa300 Use split-string OMIT-NULLS argument.
Eli Zaretskii <eliz@gnu.org>
parents: 66272
diff changeset
2036 (sender
69860
000a5d4aa083 (rcirc-default-server): Rename from rcirc-server.
Eli Zaretskii <eliz@gnu.org>
parents: 69694
diff changeset
2037 (if (string= sender (rcirc-server-name process))
68731
85be285e3494 (rcirc-startup-channels-alist): Add irc.freenode.net and #emacs as defaults.
Eli Zaretskii <eliz@gnu.org>
parents: 68648
diff changeset
2038 nil ; server notice
85be285e3494 (rcirc-startup-channels-alist): Add irc.freenode.net and #emacs as defaults.
Eli Zaretskii <eliz@gnu.org>
parents: 68648
diff changeset
2039 sender)))
66703
6cfb275aa300 Use split-string OMIT-NULLS argument.
Eli Zaretskii <eliz@gnu.org>
parents: 66272
diff changeset
2040 message t))))
66248
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
2041
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
2042 (defun rcirc-handler-WALLOPS (process sender args text)
68731
85be285e3494 (rcirc-startup-channels-alist): Add irc.freenode.net and #emacs as defaults.
Eli Zaretskii <eliz@gnu.org>
parents: 68648
diff changeset
2043 (rcirc-print process sender "WALLOPS" sender (car args) t))
66248
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
2044
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
2045 (defun rcirc-handler-JOIN (process sender args text)
68731
85be285e3494 (rcirc-startup-channels-alist): Add irc.freenode.net and #emacs as defaults.
Eli Zaretskii <eliz@gnu.org>
parents: 68648
diff changeset
2046 (let ((channel (car args)))
66248
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
2047 (rcirc-get-buffer-create process channel)
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
2048 (rcirc-print process sender "JOIN" channel "")
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
2049
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
2050 ;; print in private chat buffer if it exists
69860
000a5d4aa083 (rcirc-default-server): Rename from rcirc-server.
Eli Zaretskii <eliz@gnu.org>
parents: 69694
diff changeset
2051 (when (rcirc-get-buffer (rcirc-buffer-process) sender)
68731
85be285e3494 (rcirc-startup-channels-alist): Add irc.freenode.net and #emacs as defaults.
Eli Zaretskii <eliz@gnu.org>
parents: 68648
diff changeset
2052 (rcirc-print process sender "JOIN" sender channel))
66248
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
2053
66703
6cfb275aa300 Use split-string OMIT-NULLS argument.
Eli Zaretskii <eliz@gnu.org>
parents: 66272
diff changeset
2054 (rcirc-put-nick-channel process sender channel)))
66248
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
2055
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
2056 ;; PART and KICK are handled the same way
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
2057 (defun rcirc-handler-PART-or-KICK (process response channel sender nick args)
69860
000a5d4aa083 (rcirc-default-server): Rename from rcirc-server.
Eli Zaretskii <eliz@gnu.org>
parents: 69694
diff changeset
2058 (rcirc-ignore-update-automatic nick)
66248
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
2059 (if (not (string= nick (rcirc-nick process)))
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
2060 ;; this is someone else leaving
66703
6cfb275aa300 Use split-string OMIT-NULLS argument.
Eli Zaretskii <eliz@gnu.org>
parents: 66272
diff changeset
2061 (rcirc-remove-nick-channel process nick channel)
6cfb275aa300 Use split-string OMIT-NULLS argument.
Eli Zaretskii <eliz@gnu.org>
parents: 66272
diff changeset
2062 ;; this is us leaving
6cfb275aa300 Use split-string OMIT-NULLS argument.
Eli Zaretskii <eliz@gnu.org>
parents: 66272
diff changeset
2063 (mapc (lambda (n)
6cfb275aa300 Use split-string OMIT-NULLS argument.
Eli Zaretskii <eliz@gnu.org>
parents: 66272
diff changeset
2064 (rcirc-remove-nick-channel process n channel))
6cfb275aa300 Use split-string OMIT-NULLS argument.
Eli Zaretskii <eliz@gnu.org>
parents: 66272
diff changeset
2065 (rcirc-channel-nicks process channel))
6cfb275aa300 Use split-string OMIT-NULLS argument.
Eli Zaretskii <eliz@gnu.org>
parents: 66272
diff changeset
2066
6cfb275aa300 Use split-string OMIT-NULLS argument.
Eli Zaretskii <eliz@gnu.org>
parents: 66272
diff changeset
2067 ;; if the buffer is still around, make it inactive
6cfb275aa300 Use split-string OMIT-NULLS argument.
Eli Zaretskii <eliz@gnu.org>
parents: 66272
diff changeset
2068 (let ((buffer (rcirc-get-buffer process channel)))
6cfb275aa300 Use split-string OMIT-NULLS argument.
Eli Zaretskii <eliz@gnu.org>
parents: 66272
diff changeset
2069 (when buffer
6cfb275aa300 Use split-string OMIT-NULLS argument.
Eli Zaretskii <eliz@gnu.org>
parents: 66272
diff changeset
2070 (with-current-buffer buffer
6cfb275aa300 Use split-string OMIT-NULLS argument.
Eli Zaretskii <eliz@gnu.org>
parents: 66272
diff changeset
2071 (setq rcirc-target nil))))))
66248
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
2072
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
2073 (defun rcirc-handler-PART (process sender args text)
69860
000a5d4aa083 (rcirc-default-server): Rename from rcirc-server.
Eli Zaretskii <eliz@gnu.org>
parents: 69694
diff changeset
2074 (let* ((channel (car args))
000a5d4aa083 (rcirc-default-server): Rename from rcirc-server.
Eli Zaretskii <eliz@gnu.org>
parents: 69694
diff changeset
2075 (reason (cadr args))
000a5d4aa083 (rcirc-default-server): Rename from rcirc-server.
Eli Zaretskii <eliz@gnu.org>
parents: 69694
diff changeset
2076 (message (concat channel " " reason)))
000a5d4aa083 (rcirc-default-server): Rename from rcirc-server.
Eli Zaretskii <eliz@gnu.org>
parents: 69694
diff changeset
2077 (rcirc-print process sender "PART" channel message)
000a5d4aa083 (rcirc-default-server): Rename from rcirc-server.
Eli Zaretskii <eliz@gnu.org>
parents: 69694
diff changeset
2078 ;; print in private chat buffer if it exists
000a5d4aa083 (rcirc-default-server): Rename from rcirc-server.
Eli Zaretskii <eliz@gnu.org>
parents: 69694
diff changeset
2079 (when (rcirc-get-buffer (rcirc-buffer-process) sender)
000a5d4aa083 (rcirc-default-server): Rename from rcirc-server.
Eli Zaretskii <eliz@gnu.org>
parents: 69694
diff changeset
2080 (rcirc-print process sender "PART" sender message))
000a5d4aa083 (rcirc-default-server): Rename from rcirc-server.
Eli Zaretskii <eliz@gnu.org>
parents: 69694
diff changeset
2081
000a5d4aa083 (rcirc-default-server): Rename from rcirc-server.
Eli Zaretskii <eliz@gnu.org>
parents: 69694
diff changeset
2082 (rcirc-handler-PART-or-KICK process "PART" channel sender sender reason)))
66248
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
2083
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
2084 (defun rcirc-handler-KICK (process sender args text)
69860
000a5d4aa083 (rcirc-default-server): Rename from rcirc-server.
Eli Zaretskii <eliz@gnu.org>
parents: 69694
diff changeset
2085 (let* ((channel (car args))
000a5d4aa083 (rcirc-default-server): Rename from rcirc-server.
Eli Zaretskii <eliz@gnu.org>
parents: 69694
diff changeset
2086 (nick (cadr args))
000a5d4aa083 (rcirc-default-server): Rename from rcirc-server.
Eli Zaretskii <eliz@gnu.org>
parents: 69694
diff changeset
2087 (reason (caddr args))
000a5d4aa083 (rcirc-default-server): Rename from rcirc-server.
Eli Zaretskii <eliz@gnu.org>
parents: 69694
diff changeset
2088 (message (concat nick " " channel " " reason)))
000a5d4aa083 (rcirc-default-server): Rename from rcirc-server.
Eli Zaretskii <eliz@gnu.org>
parents: 69694
diff changeset
2089 (rcirc-print process sender "KICK" channel message t)
000a5d4aa083 (rcirc-default-server): Rename from rcirc-server.
Eli Zaretskii <eliz@gnu.org>
parents: 69694
diff changeset
2090 ;; print in private chat buffer if it exists
000a5d4aa083 (rcirc-default-server): Rename from rcirc-server.
Eli Zaretskii <eliz@gnu.org>
parents: 69694
diff changeset
2091 (when (rcirc-get-buffer (rcirc-buffer-process) nick)
000a5d4aa083 (rcirc-default-server): Rename from rcirc-server.
Eli Zaretskii <eliz@gnu.org>
parents: 69694
diff changeset
2092 (rcirc-print process sender "KICK" nick message))
000a5d4aa083 (rcirc-default-server): Rename from rcirc-server.
Eli Zaretskii <eliz@gnu.org>
parents: 69694
diff changeset
2093
000a5d4aa083 (rcirc-default-server): Rename from rcirc-server.
Eli Zaretskii <eliz@gnu.org>
parents: 69694
diff changeset
2094 (rcirc-handler-PART-or-KICK process "KICK" channel sender nick reason)))
66248
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
2095
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
2096 (defun rcirc-handler-QUIT (process sender args text)
68731
85be285e3494 (rcirc-startup-channels-alist): Add irc.freenode.net and #emacs as defaults.
Eli Zaretskii <eliz@gnu.org>
parents: 68648
diff changeset
2097 (rcirc-ignore-update-automatic sender)
85be285e3494 (rcirc-startup-channels-alist): Add irc.freenode.net and #emacs as defaults.
Eli Zaretskii <eliz@gnu.org>
parents: 68648
diff changeset
2098 (mapc (lambda (channel)
85be285e3494 (rcirc-startup-channels-alist): Add irc.freenode.net and #emacs as defaults.
Eli Zaretskii <eliz@gnu.org>
parents: 68648
diff changeset
2099 (rcirc-print process sender "QUIT" channel (apply 'concat args)))
85be285e3494 (rcirc-startup-channels-alist): Add irc.freenode.net and #emacs as defaults.
Eli Zaretskii <eliz@gnu.org>
parents: 68648
diff changeset
2100 (rcirc-nick-channels process sender))
66248
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
2101
68731
85be285e3494 (rcirc-startup-channels-alist): Add irc.freenode.net and #emacs as defaults.
Eli Zaretskii <eliz@gnu.org>
parents: 68648
diff changeset
2102 ;; print in private chat buffer if it exists
69860
000a5d4aa083 (rcirc-default-server): Rename from rcirc-server.
Eli Zaretskii <eliz@gnu.org>
parents: 69694
diff changeset
2103 (when (rcirc-get-buffer (rcirc-buffer-process) sender)
68731
85be285e3494 (rcirc-startup-channels-alist): Add irc.freenode.net and #emacs as defaults.
Eli Zaretskii <eliz@gnu.org>
parents: 68648
diff changeset
2104 (rcirc-print process sender "QUIT" sender (apply 'concat args)))
66248
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
2105
68731
85be285e3494 (rcirc-startup-channels-alist): Add irc.freenode.net and #emacs as defaults.
Eli Zaretskii <eliz@gnu.org>
parents: 68648
diff changeset
2106 (rcirc-nick-remove process sender))
66248
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
2107
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
2108 (defun rcirc-handler-NICK (process sender args text)
68731
85be285e3494 (rcirc-startup-channels-alist): Add irc.freenode.net and #emacs as defaults.
Eli Zaretskii <eliz@gnu.org>
parents: 68648
diff changeset
2109 (let* ((old-nick sender)
66248
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
2110 (new-nick (car args))
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
2111 (channels (rcirc-nick-channels process old-nick)))
68079
61e9ea461d3c (rcirc-ignore-list): New option.
Alex Schroeder <alex@gnu.org>
parents: 68077
diff changeset
2112 ;; update list of ignored nicks
61e9ea461d3c (rcirc-ignore-list): New option.
Alex Schroeder <alex@gnu.org>
parents: 68077
diff changeset
2113 (rcirc-ignore-update-automatic old-nick)
61e9ea461d3c (rcirc-ignore-list): New option.
Alex Schroeder <alex@gnu.org>
parents: 68077
diff changeset
2114 (when (member old-nick rcirc-ignore-list)
61e9ea461d3c (rcirc-ignore-list): New option.
Alex Schroeder <alex@gnu.org>
parents: 68077
diff changeset
2115 (add-to-list 'rcirc-ignore-list new-nick)
61e9ea461d3c (rcirc-ignore-list): New option.
Alex Schroeder <alex@gnu.org>
parents: 68077
diff changeset
2116 (add-to-list 'rcirc-ignore-list-automatic new-nick))
66248
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
2117 ;; print message to nick's channels
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
2118 (dolist (target channels)
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
2119 (rcirc-print process sender "NICK" target new-nick))
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
2120 ;; update private chat buffer, if it exists
66703
6cfb275aa300 Use split-string OMIT-NULLS argument.
Eli Zaretskii <eliz@gnu.org>
parents: 66272
diff changeset
2121 (let ((chat-buffer (rcirc-get-buffer process old-nick)))
6cfb275aa300 Use split-string OMIT-NULLS argument.
Eli Zaretskii <eliz@gnu.org>
parents: 66272
diff changeset
2122 (when chat-buffer
6cfb275aa300 Use split-string OMIT-NULLS argument.
Eli Zaretskii <eliz@gnu.org>
parents: 66272
diff changeset
2123 (with-current-buffer chat-buffer
6cfb275aa300 Use split-string OMIT-NULLS argument.
Eli Zaretskii <eliz@gnu.org>
parents: 66272
diff changeset
2124 (rcirc-print process sender "NICK" old-nick new-nick)
6cfb275aa300 Use split-string OMIT-NULLS argument.
Eli Zaretskii <eliz@gnu.org>
parents: 66272
diff changeset
2125 (setq rcirc-target new-nick)
6cfb275aa300 Use split-string OMIT-NULLS argument.
Eli Zaretskii <eliz@gnu.org>
parents: 66272
diff changeset
2126 (rename-buffer (rcirc-generate-new-buffer-name process new-nick)))))
66248
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
2127 ;; remove old nick and add new one
66703
6cfb275aa300 Use split-string OMIT-NULLS argument.
Eli Zaretskii <eliz@gnu.org>
parents: 66272
diff changeset
2128 (with-rcirc-process-buffer process
66248
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
2129 (let ((v (gethash old-nick rcirc-nick-table)))
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
2130 (remhash old-nick rcirc-nick-table)
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
2131 (puthash new-nick v rcirc-nick-table))
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
2132 ;; if this is our nick...
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
2133 (when (string= old-nick rcirc-nick)
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
2134 (setq rcirc-nick new-nick)
66703
6cfb275aa300 Use split-string OMIT-NULLS argument.
Eli Zaretskii <eliz@gnu.org>
parents: 66272
diff changeset
2135 (rcirc-update-prompt t)
66248
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
2136 ;; reauthenticate
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
2137 (when rcirc-auto-authenticate-flag (rcirc-authenticate))))))
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
2138
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
2139 (defun rcirc-handler-PING (process sender args text)
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
2140 (rcirc-send-string process (concat "PONG " (car args))))
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
2141
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
2142 (defun rcirc-handler-PONG (process sender args text)
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
2143 ;; do nothing
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
2144 )
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
2145
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
2146 (defun rcirc-handler-TOPIC (process sender args text)
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
2147 (let ((topic (cadr args)))
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
2148 (rcirc-print process sender "TOPIC" (car args) topic)
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
2149 (with-current-buffer (rcirc-get-buffer process (car args))
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
2150 (setq rcirc-topic topic))))
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
2151
69860
000a5d4aa083 (rcirc-default-server): Rename from rcirc-server.
Eli Zaretskii <eliz@gnu.org>
parents: 69694
diff changeset
2152 (defvar rcirc-nick-away-alist nil)
000a5d4aa083 (rcirc-default-server): Rename from rcirc-server.
Eli Zaretskii <eliz@gnu.org>
parents: 69694
diff changeset
2153 (defun rcirc-handler-301 (process sender args text)
000a5d4aa083 (rcirc-default-server): Rename from rcirc-server.
Eli Zaretskii <eliz@gnu.org>
parents: 69694
diff changeset
2154 "RPL_AWAY"
000a5d4aa083 (rcirc-default-server): Rename from rcirc-server.
Eli Zaretskii <eliz@gnu.org>
parents: 69694
diff changeset
2155 (let* ((nick (cadr args))
000a5d4aa083 (rcirc-default-server): Rename from rcirc-server.
Eli Zaretskii <eliz@gnu.org>
parents: 69694
diff changeset
2156 (rec (assoc-string nick rcirc-nick-away-alist))
000a5d4aa083 (rcirc-default-server): Rename from rcirc-server.
Eli Zaretskii <eliz@gnu.org>
parents: 69694
diff changeset
2157 (away-message (caddr args)))
000a5d4aa083 (rcirc-default-server): Rename from rcirc-server.
Eli Zaretskii <eliz@gnu.org>
parents: 69694
diff changeset
2158 (when (or (not rec)
000a5d4aa083 (rcirc-default-server): Rename from rcirc-server.
Eli Zaretskii <eliz@gnu.org>
parents: 69694
diff changeset
2159 (not (string= (cdr rec) away-message)))
000a5d4aa083 (rcirc-default-server): Rename from rcirc-server.
Eli Zaretskii <eliz@gnu.org>
parents: 69694
diff changeset
2160 ;; away message has changed
000a5d4aa083 (rcirc-default-server): Rename from rcirc-server.
Eli Zaretskii <eliz@gnu.org>
parents: 69694
diff changeset
2161 (rcirc-handler-generic process "AWAY" nick (cdr args) text)
000a5d4aa083 (rcirc-default-server): Rename from rcirc-server.
Eli Zaretskii <eliz@gnu.org>
parents: 69694
diff changeset
2162 (if rec
000a5d4aa083 (rcirc-default-server): Rename from rcirc-server.
Eli Zaretskii <eliz@gnu.org>
parents: 69694
diff changeset
2163 (setcdr rec away-message)
000a5d4aa083 (rcirc-default-server): Rename from rcirc-server.
Eli Zaretskii <eliz@gnu.org>
parents: 69694
diff changeset
2164 (setq rcirc-nick-away-alist (cons (cons nick away-message)
000a5d4aa083 (rcirc-default-server): Rename from rcirc-server.
Eli Zaretskii <eliz@gnu.org>
parents: 69694
diff changeset
2165 rcirc-nick-away-alist))))))
000a5d4aa083 (rcirc-default-server): Rename from rcirc-server.
Eli Zaretskii <eliz@gnu.org>
parents: 69694
diff changeset
2166
66248
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
2167 (defun rcirc-handler-332 (process sender args text)
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
2168 "RPL_TOPIC"
66703
6cfb275aa300 Use split-string OMIT-NULLS argument.
Eli Zaretskii <eliz@gnu.org>
parents: 66272
diff changeset
2169 (let ((buffer (or (rcirc-get-buffer process (cadr args))
6cfb275aa300 Use split-string OMIT-NULLS argument.
Eli Zaretskii <eliz@gnu.org>
parents: 66272
diff changeset
2170 (rcirc-get-temp-buffer-create process (cadr args)))))
6cfb275aa300 Use split-string OMIT-NULLS argument.
Eli Zaretskii <eliz@gnu.org>
parents: 66272
diff changeset
2171 (with-current-buffer buffer
6cfb275aa300 Use split-string OMIT-NULLS argument.
Eli Zaretskii <eliz@gnu.org>
parents: 66272
diff changeset
2172 (setq rcirc-topic (caddr args)))))
66248
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
2173
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
2174 (defun rcirc-handler-333 (process sender args text)
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
2175 "Not in rfc1459.txt"
66703
6cfb275aa300 Use split-string OMIT-NULLS argument.
Eli Zaretskii <eliz@gnu.org>
parents: 66272
diff changeset
2176 (let ((buffer (or (rcirc-get-buffer process (cadr args))
6cfb275aa300 Use split-string OMIT-NULLS argument.
Eli Zaretskii <eliz@gnu.org>
parents: 66272
diff changeset
2177 (rcirc-get-temp-buffer-create process (cadr args)))))
6cfb275aa300 Use split-string OMIT-NULLS argument.
Eli Zaretskii <eliz@gnu.org>
parents: 66272
diff changeset
2178 (with-current-buffer buffer
6cfb275aa300 Use split-string OMIT-NULLS argument.
Eli Zaretskii <eliz@gnu.org>
parents: 66272
diff changeset
2179 (let ((setter (caddr args))
6cfb275aa300 Use split-string OMIT-NULLS argument.
Eli Zaretskii <eliz@gnu.org>
parents: 66272
diff changeset
2180 (time (current-time-string
6cfb275aa300 Use split-string OMIT-NULLS argument.
Eli Zaretskii <eliz@gnu.org>
parents: 66272
diff changeset
2181 (seconds-to-time
6cfb275aa300 Use split-string OMIT-NULLS argument.
Eli Zaretskii <eliz@gnu.org>
parents: 66272
diff changeset
2182 (string-to-number (cadddr args))))))
6cfb275aa300 Use split-string OMIT-NULLS argument.
Eli Zaretskii <eliz@gnu.org>
parents: 66272
diff changeset
2183 (rcirc-print process sender "TOPIC" (cadr args)
6cfb275aa300 Use split-string OMIT-NULLS argument.
Eli Zaretskii <eliz@gnu.org>
parents: 66272
diff changeset
2184 (format "%s (%s on %s)" rcirc-topic setter time))))))
66248
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
2185
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
2186 (defun rcirc-handler-477 (process sender args text)
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
2187 "ERR_NOCHANMODES"
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
2188 (rcirc-print process sender "477" (cadr args) (caddr args)))
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
2189
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
2190 (defun rcirc-handler-MODE (process sender args text)
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
2191 (let ((target (car args))
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
2192 (msg (mapconcat 'identity (cdr args) " ")))
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
2193 (rcirc-print process sender "MODE"
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
2194 (if (string= target (rcirc-nick process))
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
2195 nil
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
2196 target)
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
2197 msg)
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
2198
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
2199 ;; print in private chat buffers if they exist
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
2200 (mapc (lambda (nick)
68731
85be285e3494 (rcirc-startup-channels-alist): Add irc.freenode.net and #emacs as defaults.
Eli Zaretskii <eliz@gnu.org>
parents: 68648
diff changeset
2201 (when (rcirc-get-buffer process nick)
85be285e3494 (rcirc-startup-channels-alist): Add irc.freenode.net and #emacs as defaults.
Eli Zaretskii <eliz@gnu.org>
parents: 68648
diff changeset
2202 (rcirc-print process sender "MODE" nick msg)))
66703
6cfb275aa300 Use split-string OMIT-NULLS argument.
Eli Zaretskii <eliz@gnu.org>
parents: 66272
diff changeset
2203 (cddr args))))
66248
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
2204
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
2205 (defun rcirc-get-temp-buffer-create (process channel)
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
2206 "Return a buffer based on PROCESS and CHANNEL."
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
2207 (let ((tmpnam (concat " " (downcase channel) "TMP" (process-name process))))
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
2208 (get-buffer-create tmpnam)))
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
2209
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
2210 (defun rcirc-handler-353 (process sender args text)
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
2211 "RPL_NAMREPLY"
66703
6cfb275aa300 Use split-string OMIT-NULLS argument.
Eli Zaretskii <eliz@gnu.org>
parents: 66272
diff changeset
2212 (let ((channel (caddr args)))
66248
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
2213 (mapc (lambda (nick)
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
2214 (rcirc-put-nick-channel process nick channel))
66703
6cfb275aa300 Use split-string OMIT-NULLS argument.
Eli Zaretskii <eliz@gnu.org>
parents: 66272
diff changeset
2215 (split-string (cadddr args) " " t))
66248
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
2216 (with-current-buffer (rcirc-get-temp-buffer-create process channel)
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
2217 (goto-char (point-max))
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
2218 (insert (car (last args)) " "))))
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
2219
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
2220 (defun rcirc-handler-366 (process sender args text)
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
2221 "RPL_ENDOFNAMES"
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
2222 (let* ((channel (cadr args))
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
2223 (buffer (rcirc-get-temp-buffer-create process channel)))
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
2224 (with-current-buffer buffer
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
2225 (rcirc-print process sender "NAMES" channel
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
2226 (buffer-substring (point-min) (point-max))))
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
2227 (kill-buffer buffer)))
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
2228
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
2229 (defun rcirc-handler-433 (process sender args text)
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
2230 "ERR_NICKNAMEINUSE"
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
2231 (rcirc-handler-generic process "433" sender args text)
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
2232 (let* ((new-nick (concat (cadr args) "`")))
66703
6cfb275aa300 Use split-string OMIT-NULLS argument.
Eli Zaretskii <eliz@gnu.org>
parents: 66272
diff changeset
2233 (with-rcirc-process-buffer process
66248
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
2234 (rcirc-cmd-nick new-nick nil process))))
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
2235
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
2236 (defun rcirc-authenticate ()
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
2237 "Send authentication to process associated with current buffer.
68731
85be285e3494 (rcirc-startup-channels-alist): Add irc.freenode.net and #emacs as defaults.
Eli Zaretskii <eliz@gnu.org>
parents: 68648
diff changeset
2238 Passwords are stored in `rcirc-authinfo' (which see)."
66248
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
2239 (interactive)
69860
000a5d4aa083 (rcirc-default-server): Rename from rcirc-server.
Eli Zaretskii <eliz@gnu.org>
parents: 69694
diff changeset
2240 (with-rcirc-server-buffer
68731
85be285e3494 (rcirc-startup-channels-alist): Add irc.freenode.net and #emacs as defaults.
Eli Zaretskii <eliz@gnu.org>
parents: 68648
diff changeset
2241 (dolist (i rcirc-authinfo)
69860
000a5d4aa083 (rcirc-default-server): Rename from rcirc-server.
Eli Zaretskii <eliz@gnu.org>
parents: 69694
diff changeset
2242 (let ((process (rcirc-buffer-process))
000a5d4aa083 (rcirc-default-server): Rename from rcirc-server.
Eli Zaretskii <eliz@gnu.org>
parents: 69694
diff changeset
2243 (server (car i))
68731
85be285e3494 (rcirc-startup-channels-alist): Add irc.freenode.net and #emacs as defaults.
Eli Zaretskii <eliz@gnu.org>
parents: 68648
diff changeset
2244 (nick (caddr i))
85be285e3494 (rcirc-startup-channels-alist): Add irc.freenode.net and #emacs as defaults.
Eli Zaretskii <eliz@gnu.org>
parents: 68648
diff changeset
2245 (method (cadr i))
85be285e3494 (rcirc-startup-channels-alist): Add irc.freenode.net and #emacs as defaults.
Eli Zaretskii <eliz@gnu.org>
parents: 68648
diff changeset
2246 (args (cdddr i)))
85be285e3494 (rcirc-startup-channels-alist): Add irc.freenode.net and #emacs as defaults.
Eli Zaretskii <eliz@gnu.org>
parents: 68648
diff changeset
2247 (when (and (string-match server rcirc-server)
85be285e3494 (rcirc-startup-channels-alist): Add irc.freenode.net and #emacs as defaults.
Eli Zaretskii <eliz@gnu.org>
parents: 68648
diff changeset
2248 (string-match nick rcirc-nick))
85be285e3494 (rcirc-startup-channels-alist): Add irc.freenode.net and #emacs as defaults.
Eli Zaretskii <eliz@gnu.org>
parents: 68648
diff changeset
2249 (cond ((equal method 'nickserv)
85be285e3494 (rcirc-startup-channels-alist): Add irc.freenode.net and #emacs as defaults.
Eli Zaretskii <eliz@gnu.org>
parents: 68648
diff changeset
2250 (rcirc-send-string
69860
000a5d4aa083 (rcirc-default-server): Rename from rcirc-server.
Eli Zaretskii <eliz@gnu.org>
parents: 69694
diff changeset
2251 process
68731
85be285e3494 (rcirc-startup-channels-alist): Add irc.freenode.net and #emacs as defaults.
Eli Zaretskii <eliz@gnu.org>
parents: 68648
diff changeset
2252 (concat
85be285e3494 (rcirc-startup-channels-alist): Add irc.freenode.net and #emacs as defaults.
Eli Zaretskii <eliz@gnu.org>
parents: 68648
diff changeset
2253 "PRIVMSG nickserv :identify "
85be285e3494 (rcirc-startup-channels-alist): Add irc.freenode.net and #emacs as defaults.
Eli Zaretskii <eliz@gnu.org>
parents: 68648
diff changeset
2254 (car args))))
85be285e3494 (rcirc-startup-channels-alist): Add irc.freenode.net and #emacs as defaults.
Eli Zaretskii <eliz@gnu.org>
parents: 68648
diff changeset
2255 ((equal method 'chanserv)
85be285e3494 (rcirc-startup-channels-alist): Add irc.freenode.net and #emacs as defaults.
Eli Zaretskii <eliz@gnu.org>
parents: 68648
diff changeset
2256 (rcirc-send-string
69860
000a5d4aa083 (rcirc-default-server): Rename from rcirc-server.
Eli Zaretskii <eliz@gnu.org>
parents: 69694
diff changeset
2257 process
68731
85be285e3494 (rcirc-startup-channels-alist): Add irc.freenode.net and #emacs as defaults.
Eli Zaretskii <eliz@gnu.org>
parents: 68648
diff changeset
2258 (concat
85be285e3494 (rcirc-startup-channels-alist): Add irc.freenode.net and #emacs as defaults.
Eli Zaretskii <eliz@gnu.org>
parents: 68648
diff changeset
2259 "PRIVMSG chanserv :identify "
85be285e3494 (rcirc-startup-channels-alist): Add irc.freenode.net and #emacs as defaults.
Eli Zaretskii <eliz@gnu.org>
parents: 68648
diff changeset
2260 (cadr args) " " (car args))))
85be285e3494 (rcirc-startup-channels-alist): Add irc.freenode.net and #emacs as defaults.
Eli Zaretskii <eliz@gnu.org>
parents: 68648
diff changeset
2261 ((equal method 'bitlbee)
85be285e3494 (rcirc-startup-channels-alist): Add irc.freenode.net and #emacs as defaults.
Eli Zaretskii <eliz@gnu.org>
parents: 68648
diff changeset
2262 (rcirc-send-string
69860
000a5d4aa083 (rcirc-default-server): Rename from rcirc-server.
Eli Zaretskii <eliz@gnu.org>
parents: 69694
diff changeset
2263 process
68731
85be285e3494 (rcirc-startup-channels-alist): Add irc.freenode.net and #emacs as defaults.
Eli Zaretskii <eliz@gnu.org>
parents: 68648
diff changeset
2264 (concat "PRIVMSG &bitlbee :identify " (car args))))
85be285e3494 (rcirc-startup-channels-alist): Add irc.freenode.net and #emacs as defaults.
Eli Zaretskii <eliz@gnu.org>
parents: 68648
diff changeset
2265 (t
85be285e3494 (rcirc-startup-channels-alist): Add irc.freenode.net and #emacs as defaults.
Eli Zaretskii <eliz@gnu.org>
parents: 68648
diff changeset
2266 (message "No %S authentication method defined"
85be285e3494 (rcirc-startup-channels-alist): Add irc.freenode.net and #emacs as defaults.
Eli Zaretskii <eliz@gnu.org>
parents: 68648
diff changeset
2267 method))))))))
66703
6cfb275aa300 Use split-string OMIT-NULLS argument.
Eli Zaretskii <eliz@gnu.org>
parents: 66272
diff changeset
2268
66248
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
2269 (defun rcirc-handler-INVITE (process sender args text)
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
2270 (rcirc-print process sender "INVITE" nil (mapconcat 'identity args " ") t))
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
2271
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
2272 (defun rcirc-handler-ERROR (process sender args text)
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
2273 (rcirc-print process sender "ERROR" nil (mapconcat 'identity args " ")))
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
2274
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
2275 (defun rcirc-handler-CTCP (process target sender text)
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
2276 (if (string-match "^\\([^ ]+\\) *\\(.*\\)$" text)
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
2277 (let* ((request (upcase (match-string 1 text)))
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
2278 (args (match-string 2 text))
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
2279 (handler (intern-soft (concat "rcirc-handler-ctcp-" request))))
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
2280 (if (not (fboundp handler))
68731
85be285e3494 (rcirc-startup-channels-alist): Add irc.freenode.net and #emacs as defaults.
Eli Zaretskii <eliz@gnu.org>
parents: 68648
diff changeset
2281 (rcirc-print process sender "ERROR" target
85be285e3494 (rcirc-startup-channels-alist): Add irc.freenode.net and #emacs as defaults.
Eli Zaretskii <eliz@gnu.org>
parents: 68648
diff changeset
2282 (format "%s sent unsupported ctcp: %s" sender text)
66703
6cfb275aa300 Use split-string OMIT-NULLS argument.
Eli Zaretskii <eliz@gnu.org>
parents: 66272
diff changeset
2283 t)
66248
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
2284 (funcall handler process target sender args)
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
2285 (if (not (string= request "ACTION"))
68731
85be285e3494 (rcirc-startup-channels-alist): Add irc.freenode.net and #emacs as defaults.
Eli Zaretskii <eliz@gnu.org>
parents: 68648
diff changeset
2286 (rcirc-print process sender "CTCP" target
66703
6cfb275aa300 Use split-string OMIT-NULLS argument.
Eli Zaretskii <eliz@gnu.org>
parents: 66272
diff changeset
2287 (format "%s" text) t))))))
66248
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
2288
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
2289 (defun rcirc-handler-ctcp-VERSION (process target sender args)
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
2290 (rcirc-send-string process
68731
85be285e3494 (rcirc-startup-channels-alist): Add irc.freenode.net and #emacs as defaults.
Eli Zaretskii <eliz@gnu.org>
parents: 68648
diff changeset
2291 (concat "NOTICE " sender
66703
6cfb275aa300 Use split-string OMIT-NULLS argument.
Eli Zaretskii <eliz@gnu.org>
parents: 66272
diff changeset
2292 " :\C-aVERSION " rcirc-id-string
66248
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
2293 "\C-a")))
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
2294
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
2295 (defun rcirc-handler-ctcp-ACTION (process target sender args)
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
2296 (rcirc-print process sender "ACTION" target args t))
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
2297
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
2298 (defun rcirc-handler-ctcp-TIME (process target sender args)
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
2299 (rcirc-send-string process
68731
85be285e3494 (rcirc-startup-channels-alist): Add irc.freenode.net and #emacs as defaults.
Eli Zaretskii <eliz@gnu.org>
parents: 68648
diff changeset
2300 (concat "NOTICE " sender
66248
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
2301 " :\C-aTIME " (current-time-string) "\C-a")))
66703
6cfb275aa300 Use split-string OMIT-NULLS argument.
Eli Zaretskii <eliz@gnu.org>
parents: 66272
diff changeset
2302
6cfb275aa300 Use split-string OMIT-NULLS argument.
Eli Zaretskii <eliz@gnu.org>
parents: 66272
diff changeset
2303 (defun rcirc-handler-CTCP-response (process target sender message)
6cfb275aa300 Use split-string OMIT-NULLS argument.
Eli Zaretskii <eliz@gnu.org>
parents: 66272
diff changeset
2304 (rcirc-print process sender "CTCP" nil message t))
66248
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
2305
66703
6cfb275aa300 Use split-string OMIT-NULLS argument.
Eli Zaretskii <eliz@gnu.org>
parents: 66272
diff changeset
2306 (defgroup rcirc-faces nil
6cfb275aa300 Use split-string OMIT-NULLS argument.
Eli Zaretskii <eliz@gnu.org>
parents: 66272
diff changeset
2307 "Faces for rcirc."
6cfb275aa300 Use split-string OMIT-NULLS argument.
Eli Zaretskii <eliz@gnu.org>
parents: 66272
diff changeset
2308 :group 'rcirc
6cfb275aa300 Use split-string OMIT-NULLS argument.
Eli Zaretskii <eliz@gnu.org>
parents: 66272
diff changeset
2309 :group 'faces)
6cfb275aa300 Use split-string OMIT-NULLS argument.
Eli Zaretskii <eliz@gnu.org>
parents: 66272
diff changeset
2310
67014
d3d8e2bcfa98 (rcirc-mangle-text): Add bold face property without replacing existing
Eli Zaretskii <eliz@gnu.org>
parents: 66703
diff changeset
2311 (defface rcirc-my-nick ; font-lock-function-name-face
d3d8e2bcfa98 (rcirc-mangle-text): Add bold face property without replacing existing
Eli Zaretskii <eliz@gnu.org>
parents: 66703
diff changeset
2312 '((((class color) (min-colors 88) (background light)) (:foreground "Blue1"))
d3d8e2bcfa98 (rcirc-mangle-text): Add bold face property without replacing existing
Eli Zaretskii <eliz@gnu.org>
parents: 66703
diff changeset
2313 (((class color) (min-colors 88) (background dark)) (:foreground "LightSkyBlue"))
d3d8e2bcfa98 (rcirc-mangle-text): Add bold face property without replacing existing
Eli Zaretskii <eliz@gnu.org>
parents: 66703
diff changeset
2314 (((class color) (min-colors 16) (background light)) (:foreground "Blue"))
d3d8e2bcfa98 (rcirc-mangle-text): Add bold face property without replacing existing
Eli Zaretskii <eliz@gnu.org>
parents: 66703
diff changeset
2315 (((class color) (min-colors 16) (background dark)) (:foreground "LightSkyBlue"))
d3d8e2bcfa98 (rcirc-mangle-text): Add bold face property without replacing existing
Eli Zaretskii <eliz@gnu.org>
parents: 66703
diff changeset
2316 (((class color) (min-colors 8)) (:foreground "blue" :weight bold))
d3d8e2bcfa98 (rcirc-mangle-text): Add bold face property without replacing existing
Eli Zaretskii <eliz@gnu.org>
parents: 66703
diff changeset
2317 (t (:inverse-video t :weight bold)))
66703
6cfb275aa300 Use split-string OMIT-NULLS argument.
Eli Zaretskii <eliz@gnu.org>
parents: 66272
diff changeset
2318 "The face used to highlight my messages."
6cfb275aa300 Use split-string OMIT-NULLS argument.
Eli Zaretskii <eliz@gnu.org>
parents: 66272
diff changeset
2319 :group 'rcirc-faces)
66248
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
2320
67014
d3d8e2bcfa98 (rcirc-mangle-text): Add bold face property without replacing existing
Eli Zaretskii <eliz@gnu.org>
parents: 66703
diff changeset
2321 (defface rcirc-other-nick ; font-lock-variable-name-face
d3d8e2bcfa98 (rcirc-mangle-text): Add bold face property without replacing existing
Eli Zaretskii <eliz@gnu.org>
parents: 66703
diff changeset
2322 '((((class grayscale) (background light))
d3d8e2bcfa98 (rcirc-mangle-text): Add bold face property without replacing existing
Eli Zaretskii <eliz@gnu.org>
parents: 66703
diff changeset
2323 (:foreground "Gray90" :weight bold :slant italic))
66248
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
2324 (((class grayscale) (background dark))
67014
d3d8e2bcfa98 (rcirc-mangle-text): Add bold face property without replacing existing
Eli Zaretskii <eliz@gnu.org>
parents: 66703
diff changeset
2325 (:foreground "DimGray" :weight bold :slant italic))
d3d8e2bcfa98 (rcirc-mangle-text): Add bold face property without replacing existing
Eli Zaretskii <eliz@gnu.org>
parents: 66703
diff changeset
2326 (((class color) (min-colors 88) (background light)) (:foreground "DarkGoldenrod"))
d3d8e2bcfa98 (rcirc-mangle-text): Add bold face property without replacing existing
Eli Zaretskii <eliz@gnu.org>
parents: 66703
diff changeset
2327 (((class color) (min-colors 88) (background dark)) (:foreground "LightGoldenrod"))
d3d8e2bcfa98 (rcirc-mangle-text): Add bold face property without replacing existing
Eli Zaretskii <eliz@gnu.org>
parents: 66703
diff changeset
2328 (((class color) (min-colors 16) (background light)) (:foreground "DarkGoldenrod"))
d3d8e2bcfa98 (rcirc-mangle-text): Add bold face property without replacing existing
Eli Zaretskii <eliz@gnu.org>
parents: 66703
diff changeset
2329 (((class color) (min-colors 16) (background dark)) (:foreground "LightGoldenrod"))
d3d8e2bcfa98 (rcirc-mangle-text): Add bold face property without replacing existing
Eli Zaretskii <eliz@gnu.org>
parents: 66703
diff changeset
2330 (((class color) (min-colors 8)) (:foreground "yellow" :weight light))
d3d8e2bcfa98 (rcirc-mangle-text): Add bold face property without replacing existing
Eli Zaretskii <eliz@gnu.org>
parents: 66703
diff changeset
2331 (t (:weight bold :slant italic)))
66703
6cfb275aa300 Use split-string OMIT-NULLS argument.
Eli Zaretskii <eliz@gnu.org>
parents: 66272
diff changeset
2332 "The face used to highlight other messages."
6cfb275aa300 Use split-string OMIT-NULLS argument.
Eli Zaretskii <eliz@gnu.org>
parents: 66272
diff changeset
2333 :group 'rcirc-faces)
66248
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
2334
70215
90d76f24753a Revision: emacs@sv.gnu.org/emacs--devo--0--patch-247
Miles Bader <miles@gnu.org>
parents: 69860
diff changeset
2335 (defface rcirc-bright-nick
90d76f24753a Revision: emacs@sv.gnu.org/emacs--devo--0--patch-247
Miles Bader <miles@gnu.org>
parents: 69860
diff changeset
2336 '((((class grayscale) (background light))
90d76f24753a Revision: emacs@sv.gnu.org/emacs--devo--0--patch-247
Miles Bader <miles@gnu.org>
parents: 69860
diff changeset
2337 (:foreground "LightGray" :weight bold :underline t))
90d76f24753a Revision: emacs@sv.gnu.org/emacs--devo--0--patch-247
Miles Bader <miles@gnu.org>
parents: 69860
diff changeset
2338 (((class grayscale) (background dark))
90d76f24753a Revision: emacs@sv.gnu.org/emacs--devo--0--patch-247
Miles Bader <miles@gnu.org>
parents: 69860
diff changeset
2339 (:foreground "Gray50" :weight bold :underline t))
90d76f24753a Revision: emacs@sv.gnu.org/emacs--devo--0--patch-247
Miles Bader <miles@gnu.org>
parents: 69860
diff changeset
2340 (((class color) (min-colors 88) (background light)) (:foreground "CadetBlue"))
90d76f24753a Revision: emacs@sv.gnu.org/emacs--devo--0--patch-247
Miles Bader <miles@gnu.org>
parents: 69860
diff changeset
2341 (((class color) (min-colors 88) (background dark)) (:foreground "Aquamarine"))
90d76f24753a Revision: emacs@sv.gnu.org/emacs--devo--0--patch-247
Miles Bader <miles@gnu.org>
parents: 69860
diff changeset
2342 (((class color) (min-colors 16) (background light)) (:foreground "CadetBlue"))
90d76f24753a Revision: emacs@sv.gnu.org/emacs--devo--0--patch-247
Miles Bader <miles@gnu.org>
parents: 69860
diff changeset
2343 (((class color) (min-colors 16) (background dark)) (:foreground "Aquamarine"))
90d76f24753a Revision: emacs@sv.gnu.org/emacs--devo--0--patch-247
Miles Bader <miles@gnu.org>
parents: 69860
diff changeset
2344 (((class color) (min-colors 8)) (:foreground "magenta"))
90d76f24753a Revision: emacs@sv.gnu.org/emacs--devo--0--patch-247
Miles Bader <miles@gnu.org>
parents: 69860
diff changeset
2345 (t (:weight bold :underline t)))
72616
1c7de7b9540b (rcirc-keywords): New variable.
Eli Zaretskii <eliz@gnu.org>
parents: 72468
diff changeset
2346 "Face used for nicks matched by `rcirc-bright-nicks'."
70215
90d76f24753a Revision: emacs@sv.gnu.org/emacs--devo--0--patch-247
Miles Bader <miles@gnu.org>
parents: 69860
diff changeset
2347 :group 'rcirc-faces)
90d76f24753a Revision: emacs@sv.gnu.org/emacs--devo--0--patch-247
Miles Bader <miles@gnu.org>
parents: 69860
diff changeset
2348
90d76f24753a Revision: emacs@sv.gnu.org/emacs--devo--0--patch-247
Miles Bader <miles@gnu.org>
parents: 69860
diff changeset
2349 (defface rcirc-dim-nick
90d76f24753a Revision: emacs@sv.gnu.org/emacs--devo--0--patch-247
Miles Bader <miles@gnu.org>
parents: 69860
diff changeset
2350 '((t :inherit default))
72616
1c7de7b9540b (rcirc-keywords): New variable.
Eli Zaretskii <eliz@gnu.org>
parents: 72468
diff changeset
2351 "Face used for nicks in `rcirc-dim-nicks'."
70215
90d76f24753a Revision: emacs@sv.gnu.org/emacs--devo--0--patch-247
Miles Bader <miles@gnu.org>
parents: 69860
diff changeset
2352 :group 'rcirc-faces)
90d76f24753a Revision: emacs@sv.gnu.org/emacs--devo--0--patch-247
Miles Bader <miles@gnu.org>
parents: 69860
diff changeset
2353
67014
d3d8e2bcfa98 (rcirc-mangle-text): Add bold face property without replacing existing
Eli Zaretskii <eliz@gnu.org>
parents: 66703
diff changeset
2354 (defface rcirc-server ; font-lock-comment-face
d3d8e2bcfa98 (rcirc-mangle-text): Add bold face property without replacing existing
Eli Zaretskii <eliz@gnu.org>
parents: 66703
diff changeset
2355 '((((class grayscale) (background light))
d3d8e2bcfa98 (rcirc-mangle-text): Add bold face property without replacing existing
Eli Zaretskii <eliz@gnu.org>
parents: 66703
diff changeset
2356 (:foreground "DimGray" :weight bold :slant italic))
66248
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
2357 (((class grayscale) (background dark))
67014
d3d8e2bcfa98 (rcirc-mangle-text): Add bold face property without replacing existing
Eli Zaretskii <eliz@gnu.org>
parents: 66703
diff changeset
2358 (:foreground "LightGray" :weight bold :slant italic))
d3d8e2bcfa98 (rcirc-mangle-text): Add bold face property without replacing existing
Eli Zaretskii <eliz@gnu.org>
parents: 66703
diff changeset
2359 (((class color) (min-colors 88) (background light))
d3d8e2bcfa98 (rcirc-mangle-text): Add bold face property without replacing existing
Eli Zaretskii <eliz@gnu.org>
parents: 66703
diff changeset
2360 (:foreground "Firebrick"))
d3d8e2bcfa98 (rcirc-mangle-text): Add bold face property without replacing existing
Eli Zaretskii <eliz@gnu.org>
parents: 66703
diff changeset
2361 (((class color) (min-colors 88) (background dark))
d3d8e2bcfa98 (rcirc-mangle-text): Add bold face property without replacing existing
Eli Zaretskii <eliz@gnu.org>
parents: 66703
diff changeset
2362 (:foreground "chocolate1"))
d3d8e2bcfa98 (rcirc-mangle-text): Add bold face property without replacing existing
Eli Zaretskii <eliz@gnu.org>
parents: 66703
diff changeset
2363 (((class color) (min-colors 16) (background light))
d3d8e2bcfa98 (rcirc-mangle-text): Add bold face property without replacing existing
Eli Zaretskii <eliz@gnu.org>
parents: 66703
diff changeset
2364 (:foreground "red"))
d3d8e2bcfa98 (rcirc-mangle-text): Add bold face property without replacing existing
Eli Zaretskii <eliz@gnu.org>
parents: 66703
diff changeset
2365 (((class color) (min-colors 16) (background dark))
d3d8e2bcfa98 (rcirc-mangle-text): Add bold face property without replacing existing
Eli Zaretskii <eliz@gnu.org>
parents: 66703
diff changeset
2366 (:foreground "red1"))
d3d8e2bcfa98 (rcirc-mangle-text): Add bold face property without replacing existing
Eli Zaretskii <eliz@gnu.org>
parents: 66703
diff changeset
2367 (((class color) (min-colors 8) (background light))
d3d8e2bcfa98 (rcirc-mangle-text): Add bold face property without replacing existing
Eli Zaretskii <eliz@gnu.org>
parents: 66703
diff changeset
2368 )
d3d8e2bcfa98 (rcirc-mangle-text): Add bold face property without replacing existing
Eli Zaretskii <eliz@gnu.org>
parents: 66703
diff changeset
2369 (((class color) (min-colors 8) (background dark))
d3d8e2bcfa98 (rcirc-mangle-text): Add bold face property without replacing existing
Eli Zaretskii <eliz@gnu.org>
parents: 66703
diff changeset
2370 )
d3d8e2bcfa98 (rcirc-mangle-text): Add bold face property without replacing existing
Eli Zaretskii <eliz@gnu.org>
parents: 66703
diff changeset
2371 (t (:weight bold :slant italic)))
66703
6cfb275aa300 Use split-string OMIT-NULLS argument.
Eli Zaretskii <eliz@gnu.org>
parents: 66272
diff changeset
2372 "The face used to highlight server messages."
6cfb275aa300 Use split-string OMIT-NULLS argument.
Eli Zaretskii <eliz@gnu.org>
parents: 66272
diff changeset
2373 :group 'rcirc-faces)
66248
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
2374
67014
d3d8e2bcfa98 (rcirc-mangle-text): Add bold face property without replacing existing
Eli Zaretskii <eliz@gnu.org>
parents: 66703
diff changeset
2375 (defface rcirc-server-prefix ; font-lock-comment-delimiter-face
68731
85be285e3494 (rcirc-startup-channels-alist): Add irc.freenode.net and #emacs as defaults.
Eli Zaretskii <eliz@gnu.org>
parents: 68648
diff changeset
2376 '((default :inherit rcirc-server)
67014
d3d8e2bcfa98 (rcirc-mangle-text): Add bold face property without replacing existing
Eli Zaretskii <eliz@gnu.org>
parents: 66703
diff changeset
2377 (((class grayscale)))
d3d8e2bcfa98 (rcirc-mangle-text): Add bold face property without replacing existing
Eli Zaretskii <eliz@gnu.org>
parents: 66703
diff changeset
2378 (((class color) (min-colors 16)))
d3d8e2bcfa98 (rcirc-mangle-text): Add bold face property without replacing existing
Eli Zaretskii <eliz@gnu.org>
parents: 66703
diff changeset
2379 (((class color) (min-colors 8) (background light))
d3d8e2bcfa98 (rcirc-mangle-text): Add bold face property without replacing existing
Eli Zaretskii <eliz@gnu.org>
parents: 66703
diff changeset
2380 :foreground "red")
d3d8e2bcfa98 (rcirc-mangle-text): Add bold face property without replacing existing
Eli Zaretskii <eliz@gnu.org>
parents: 66703
diff changeset
2381 (((class color) (min-colors 8) (background dark))
d3d8e2bcfa98 (rcirc-mangle-text): Add bold face property without replacing existing
Eli Zaretskii <eliz@gnu.org>
parents: 66703
diff changeset
2382 :foreground "red1"))
d3d8e2bcfa98 (rcirc-mangle-text): Add bold face property without replacing existing
Eli Zaretskii <eliz@gnu.org>
parents: 66703
diff changeset
2383 "The face used to highlight server prefixes."
d3d8e2bcfa98 (rcirc-mangle-text): Add bold face property without replacing existing
Eli Zaretskii <eliz@gnu.org>
parents: 66703
diff changeset
2384 :group 'rcirc-faces)
d3d8e2bcfa98 (rcirc-mangle-text): Add bold face property without replacing existing
Eli Zaretskii <eliz@gnu.org>
parents: 66703
diff changeset
2385
d3d8e2bcfa98 (rcirc-mangle-text): Add bold face property without replacing existing
Eli Zaretskii <eliz@gnu.org>
parents: 66703
diff changeset
2386 (defface rcirc-timestamp
d3d8e2bcfa98 (rcirc-mangle-text): Add bold face property without replacing existing
Eli Zaretskii <eliz@gnu.org>
parents: 66703
diff changeset
2387 '((t (:inherit default)))
d3d8e2bcfa98 (rcirc-mangle-text): Add bold face property without replacing existing
Eli Zaretskii <eliz@gnu.org>
parents: 66703
diff changeset
2388 "The face used to highlight timestamps."
d3d8e2bcfa98 (rcirc-mangle-text): Add bold face property without replacing existing
Eli Zaretskii <eliz@gnu.org>
parents: 66703
diff changeset
2389 :group 'rcirc-faces)
d3d8e2bcfa98 (rcirc-mangle-text): Add bold face property without replacing existing
Eli Zaretskii <eliz@gnu.org>
parents: 66703
diff changeset
2390
d3d8e2bcfa98 (rcirc-mangle-text): Add bold face property without replacing existing
Eli Zaretskii <eliz@gnu.org>
parents: 66703
diff changeset
2391 (defface rcirc-nick-in-message ; font-lock-keyword-face
d3d8e2bcfa98 (rcirc-mangle-text): Add bold face property without replacing existing
Eli Zaretskii <eliz@gnu.org>
parents: 66703
diff changeset
2392 '((((class grayscale) (background light)) (:foreground "LightGray" :weight bold))
d3d8e2bcfa98 (rcirc-mangle-text): Add bold face property without replacing existing
Eli Zaretskii <eliz@gnu.org>
parents: 66703
diff changeset
2393 (((class grayscale) (background dark)) (:foreground "DimGray" :weight bold))
d3d8e2bcfa98 (rcirc-mangle-text): Add bold face property without replacing existing
Eli Zaretskii <eliz@gnu.org>
parents: 66703
diff changeset
2394 (((class color) (min-colors 88) (background light)) (:foreground "Purple"))
d3d8e2bcfa98 (rcirc-mangle-text): Add bold face property without replacing existing
Eli Zaretskii <eliz@gnu.org>
parents: 66703
diff changeset
2395 (((class color) (min-colors 88) (background dark)) (:foreground "Cyan1"))
d3d8e2bcfa98 (rcirc-mangle-text): Add bold face property without replacing existing
Eli Zaretskii <eliz@gnu.org>
parents: 66703
diff changeset
2396 (((class color) (min-colors 16) (background light)) (:foreground "Purple"))
d3d8e2bcfa98 (rcirc-mangle-text): Add bold face property without replacing existing
Eli Zaretskii <eliz@gnu.org>
parents: 66703
diff changeset
2397 (((class color) (min-colors 16) (background dark)) (:foreground "Cyan"))
d3d8e2bcfa98 (rcirc-mangle-text): Add bold face property without replacing existing
Eli Zaretskii <eliz@gnu.org>
parents: 66703
diff changeset
2398 (((class color) (min-colors 8)) (:foreground "cyan" :weight bold))
d3d8e2bcfa98 (rcirc-mangle-text): Add bold face property without replacing existing
Eli Zaretskii <eliz@gnu.org>
parents: 66703
diff changeset
2399 (t (:weight bold)))
72616
1c7de7b9540b (rcirc-keywords): New variable.
Eli Zaretskii <eliz@gnu.org>
parents: 72468
diff changeset
2400 "The face used to highlight instances of your nick within messages."
66703
6cfb275aa300 Use split-string OMIT-NULLS argument.
Eli Zaretskii <eliz@gnu.org>
parents: 66272
diff changeset
2401 :group 'rcirc-faces)
66248
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
2402
72616
1c7de7b9540b (rcirc-keywords): New variable.
Eli Zaretskii <eliz@gnu.org>
parents: 72468
diff changeset
2403 (defface rcirc-nick-in-message-full-line
1c7de7b9540b (rcirc-keywords): New variable.
Eli Zaretskii <eliz@gnu.org>
parents: 72468
diff changeset
2404 '((t (:bold t)))
1c7de7b9540b (rcirc-keywords): New variable.
Eli Zaretskii <eliz@gnu.org>
parents: 72468
diff changeset
2405 "The face used emphasize the entire message when your nick is mentioned."
1c7de7b9540b (rcirc-keywords): New variable.
Eli Zaretskii <eliz@gnu.org>
parents: 72468
diff changeset
2406 :group 'rcirc-faces)
1c7de7b9540b (rcirc-keywords): New variable.
Eli Zaretskii <eliz@gnu.org>
parents: 72468
diff changeset
2407
67014
d3d8e2bcfa98 (rcirc-mangle-text): Add bold face property without replacing existing
Eli Zaretskii <eliz@gnu.org>
parents: 66703
diff changeset
2408 (defface rcirc-prompt ; comint-highlight-prompt
d3d8e2bcfa98 (rcirc-mangle-text): Add bold face property without replacing existing
Eli Zaretskii <eliz@gnu.org>
parents: 66703
diff changeset
2409 '((((min-colors 88) (background dark)) (:foreground "cyan1"))
d3d8e2bcfa98 (rcirc-mangle-text): Add bold face property without replacing existing
Eli Zaretskii <eliz@gnu.org>
parents: 66703
diff changeset
2410 (((background dark)) (:foreground "cyan"))
66248
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
2411 (t (:foreground "dark blue")))
68563
979fba30166f (rcirc-debug): Fix docstring.
Juanma Barranquero <lekktu@gmail.com>
parents: 68079
diff changeset
2412 "The face used to highlight prompts."
66703
6cfb275aa300 Use split-string OMIT-NULLS argument.
Eli Zaretskii <eliz@gnu.org>
parents: 66272
diff changeset
2413 :group 'rcirc-faces)
66248
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
2414
72616
1c7de7b9540b (rcirc-keywords): New variable.
Eli Zaretskii <eliz@gnu.org>
parents: 72468
diff changeset
2415 (defface rcirc-track-nick
1c7de7b9540b (rcirc-keywords): New variable.
Eli Zaretskii <eliz@gnu.org>
parents: 72468
diff changeset
2416 '((t (:inverse-video t)))
1c7de7b9540b (rcirc-keywords): New variable.
Eli Zaretskii <eliz@gnu.org>
parents: 72468
diff changeset
2417 "The face used in the mode-line when your nick is mentioned."
1c7de7b9540b (rcirc-keywords): New variable.
Eli Zaretskii <eliz@gnu.org>
parents: 72468
diff changeset
2418 :group 'rcirc-faces)
1c7de7b9540b (rcirc-keywords): New variable.
Eli Zaretskii <eliz@gnu.org>
parents: 72468
diff changeset
2419
1c7de7b9540b (rcirc-keywords): New variable.
Eli Zaretskii <eliz@gnu.org>
parents: 72468
diff changeset
2420 (defface rcirc-track-keyword
1c7de7b9540b (rcirc-keywords): New variable.
Eli Zaretskii <eliz@gnu.org>
parents: 72468
diff changeset
2421 '((t (:bold t )))
1c7de7b9540b (rcirc-keywords): New variable.
Eli Zaretskii <eliz@gnu.org>
parents: 72468
diff changeset
2422 "The face used in the mode-line when keywords are mentioned."
1c7de7b9540b (rcirc-keywords): New variable.
Eli Zaretskii <eliz@gnu.org>
parents: 72468
diff changeset
2423 :group 'rcirc-faces)
1c7de7b9540b (rcirc-keywords): New variable.
Eli Zaretskii <eliz@gnu.org>
parents: 72468
diff changeset
2424
1c7de7b9540b (rcirc-keywords): New variable.
Eli Zaretskii <eliz@gnu.org>
parents: 72468
diff changeset
2425 (defface rcirc-url
66248
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
2426 '((t (:bold t)))
72616
1c7de7b9540b (rcirc-keywords): New variable.
Eli Zaretskii <eliz@gnu.org>
parents: 72468
diff changeset
2427 "The face used to highlight urls."
1c7de7b9540b (rcirc-keywords): New variable.
Eli Zaretskii <eliz@gnu.org>
parents: 72468
diff changeset
2428 :group 'rcirc-faces)
1c7de7b9540b (rcirc-keywords): New variable.
Eli Zaretskii <eliz@gnu.org>
parents: 72468
diff changeset
2429
1c7de7b9540b (rcirc-keywords): New variable.
Eli Zaretskii <eliz@gnu.org>
parents: 72468
diff changeset
2430 (defface rcirc-keyword
1c7de7b9540b (rcirc-keywords): New variable.
Eli Zaretskii <eliz@gnu.org>
parents: 72468
diff changeset
2431 '((t (:inherit highlight)))
1c7de7b9540b (rcirc-keywords): New variable.
Eli Zaretskii <eliz@gnu.org>
parents: 72468
diff changeset
2432 "The face used to highlight keywords."
66703
6cfb275aa300 Use split-string OMIT-NULLS argument.
Eli Zaretskii <eliz@gnu.org>
parents: 66272
diff changeset
2433 :group 'rcirc-faces)
69860
000a5d4aa083 (rcirc-default-server): Rename from rcirc-server.
Eli Zaretskii <eliz@gnu.org>
parents: 69694
diff changeset
2434
66248
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
2435
66703
6cfb275aa300 Use split-string OMIT-NULLS argument.
Eli Zaretskii <eliz@gnu.org>
parents: 66272
diff changeset
2436 ;; When using M-x flyspell-mode, only check words after the prompt
66248
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
2437 (put 'rcirc-mode 'flyspell-mode-predicate 'rcirc-looking-at-input)
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
2438 (defun rcirc-looking-at-input ()
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
2439 "Returns true if point is past the input marker."
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
2440 (>= (point) rcirc-prompt-end-marker))
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
2441
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
2442
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
2443 (provide 'rcirc)
66258
4e4cce911e2e Add arch tagline
Miles Bader <miles@gnu.org>
parents: 66252
diff changeset
2444
4e4cce911e2e Add arch tagline
Miles Bader <miles@gnu.org>
parents: 66252
diff changeset
2445 ;; arch-tag: b471b7e8-6b5a-4399-b2c6-a3c78dfc8ffb
66248
6914d742203d New file.
Richard M. Stallman <rms@gnu.org>
parents:
diff changeset
2446 ;;; rcirc.el ends here