Make "^C<fg>[,<bg>]" ctlseq matching robuster.
[riece] / lisp / riece-menu.el
index 612b7b0..6e6a6c7 100644 (file)
@@ -1,4 +1,4 @@
-;;; riece-menu.el --- setup Riece's command menus
+;;; riece-menu.el --- setup menus
 ;; Copyright (C) 1998-2003 Daiki Ueno
 
 ;; Author: Daiki Ueno <ueno@unixuser.org>
@@ -19,8 +19,8 @@
 
 ;; You should have received a copy of the GNU General Public License
 ;; along with GNU Emacs; see the file COPYING.  If not, write to the
-;; Free Software Foundation, Inc., 59 Temple Place - Suite 330,
-;; Boston, MA 02111-1307, USA.
+;; Free Software Foundation, Inc., 51 Franklin Street, Fifth Floor,
+;; Boston, MA 02110-1301, USA.
 
 ;;; Commentary:
 
 (require 'riece-identity)
 (require 'riece-layout)
 (require 'riece-server)
-
-(defvar riece-menu-items
-  `("Riece"
-    ["Version" riece-version t]
-    ["Submit Bug Report" riece-submit-bug-report t]
-    "----"
-    ("Change Window Layout..." :filter riece-menu-create-layouts-menu)
-    ["Toggle Freeze Channel Buffer"
-     riece-command-toggle-freeze t]
-    ["Toggle Freeze Channel Buffer Until Next Message"
-     riece-command-toggle-own-freeze t]
-    ["Toggle Display Channel Buffer"
-     riece-command-toggle-channel-buffer-mode t]
-    ["Toggle Display Channel List Buffer"
-     riece-command-toggle-channel-list-buffer-mode t]
-    ["Toggle Display User List Buffer"
-     riece-command-toggle-user-list-buffer-mode t]
-    "----"
-    ["Join Channel" riece-command-join t]
-    ["Change Nickname" riece-command-change-nickname t]
-    ["Mark As Away" riece-command-toggle-away t]
-    ["Quit IRC" riece-command-quit t]
-    "----"
-    ["Part Channel" riece-command-part riece-current-channel]
-    ["Set Channel Topic" riece-command-topic riece-current-channel]
-    ["Kick User" riece-command-kick riece-current-channel]
-    ["Invite User" riece-command-invite riece-current-channel]
-    "----"
-    ["Next Channel" riece-command-next-channel riece-current-channels]
-    ["Previous Channel" riece-command-previous-channel riece-current-channels]
-    "----"
-    ("Channels" :filter riece-menu-create-channels-menu)
-    ("Servers" :filter riece-menu-create-servers-menu))
-  "Menu used in command mode.")
+(require 'riece-mcat)
+
+(defcustom riece-menu-items
+  (list
+   "Riece"
+   (vector (riece-mcat "Next Channel") 'riece-command-next-channel
+          'riece-current-channels)
+   (vector (riece-mcat "Previous Channel") 'riece-command-previous-channel
+          'riece-current-channels)
+   "----"
+   (list (riece-mcat "Channels")
+        :filter 'riece-menu-create-channels-menu)
+   (list (riece-mcat "Servers")
+        :filter 'riece-menu-create-servers-menu)
+   "----"
+   (vector (riece-mcat "Redraw Layout") 'riece-command-configure-windows t)
+   (list (riece-mcat "Change Window Layout...")
+        :filter 'riece-menu-create-layouts-menu)
+   (list (riece-mcat "Toggle...")
+        (vector (riece-mcat "Freeze Channel Buffer")
+                'riece-command-toggle-freeze t)
+        (vector (riece-mcat "Freeze Channel Buffer Until Next Message")
+                'riece-command-toggle-own-freeze t)
+        (vector (riece-mcat "Display Channel Buffer")
+                'riece-command-toggle-channel-buffer-mode t)
+        (vector (riece-mcat "Display Channel List Buffer")
+                'riece-command-toggle-channel-list-buffer-mode t)
+        (vector (riece-mcat "Display User List Buffer")
+                'riece-command-toggle-user-list-buffer-mode t))
+   "----"
+   (vector (riece-mcat "Join Channel") 'riece-command-join t)
+   (vector (riece-mcat "Part Channel") 'riece-command-part
+          'riece-current-channel)
+   (vector (riece-mcat "Set Channel Topic") 'riece-command-topic
+          'riece-current-channel)
+   (vector (riece-mcat "Kick User") 'riece-command-kick
+          'riece-current-channel)
+   (vector (riece-mcat "Invite User") 'riece-command-invite
+          'riece-current-channel)
+   "----"
+   (vector (riece-mcat "Manage Add-ons") 'riece-command-list-addons t)
+   (vector (riece-mcat "Version") 'riece-version t)
+   (vector (riece-mcat "Submit Bug Report") 'riece-submit-bug-report t)
+   "----"
+   (vector (riece-mcat "Mark As Away") 'riece-command-toggle-away t)
+   (vector (riece-mcat "Change Nickname") 'riece-command-change-nickname t)
+   (vector (riece-mcat "Quit IRC") 'riece-command-quit t))
+  "Menu used in command mode."
+  :type 'sexp
+  :group 'riece-options)
 
 (defconst riece-menu-description
   "Setup Riece's command menus.")
          riece-layout-alist))
 
 (defun riece-menu-create-channels-menu (menu)
-  (mapcar (lambda (channel)
-           (list (riece-format-identity channel)
-                 (vector "Switch To Channel"
-                         (list 'riece-command-switch-to-channel channel) t)
-                 (vector "Part Channel"
-                         (list 'riece-command-part channel) t)
-                 (vector "List Channel"
-                         (list 'riece-command-list
-                               (riece-identity-prefix channel)) t)))
-         riece-current-channels))
+  (delq nil
+       (mapcar (lambda (channel)
+                 (if channel
+                     (list (riece-format-identity channel)
+                           (vector (riece-mcat "Switch To Channel")
+                                   (list 'riece-command-switch-to-channel
+                                         channel)
+                                   t)
+                           (vector (riece-mcat "Part Channel")
+                                   (list 'riece-command-part channel) t)
+                           (vector (riece-mcat "List Channel")
+                                   (list 'riece-command-list
+                                         (riece-identity-prefix channel)) t))))
+               riece-current-channels)))
 
 (defun riece-menu-create-servers-menu (menu)
   (mapcar (lambda (entry)
            (list (car entry)
-                 (vector "Open Server"
+                 (vector (riece-mcat "Open Server")
                          (list 'riece-command-open-server (car entry))
                          (not (riece-server-opened (car entry))))
-                 (vector "Close Server"
+                 (vector (riece-mcat "Close Server")
                          (list 'riece-command-close-server (car entry))
                          (riece-server-opened (car entry)))))
          riece-server-alist))
                    riece-menu-items)
   (easy-menu-add riece-menu))
 
+(defun riece-menu-requires ()
+  (if (memq 'riece-mcat riece-addons)
+      '(riece-mcat)))
+
 (defun riece-menu-insinuate ()
+  (if (fboundp 'custom-reevaluate-setting)
+      (custom-reevaluate-setting 'riece-menu-items)
+    ;; We could emulate custom-reevaluate-setting by manually eval the
+    ;; 'standard-value property of 'riece-menu-items.  In that case
+    ;; (i.e. XEmacs 21.4), however, there is no way to render
+    ;; non-ASCII labels in the menu, so give up here.
+    )
+  (if riece-command-buffer
+      (with-current-buffer riece-command-buffer
+       (riece-menu-command-mode-hook)))
   (add-hook 'riece-command-mode-hook
            'riece-menu-command-mode-hook))
 
 (defun riece-menu-uninstall ()
+  (if riece-command-buffer
+      (with-current-buffer riece-command-buffer
+       (easy-menu-remove riece-menu)))
   (remove-hook 'riece-command-mode-hook
-              'riece-menu-command-mode-hook)
-  ;;FIXME: couldn't uninstall completely.
-  )
+              'riece-menu-command-mode-hook))
 
 (provide 'riece-menu)