;;; riece-emacs.el --- FSF Emacs specific functions ;; Copyright (C) 1999 Daiki Ueno ;; Author: Daiki Ueno ;; Created: 1999-08-21 ;; Keywords: emulation ;; This file is part of Riece. ;; This program is free software; you can redistribute it and/or modify ;; it under the terms of the GNU General Public License as published by ;; the Free Software Foundation; either version 2, or (at your option) ;; any later version. ;; This program is distributed in the hope that it will be useful, ;; but WITHOUT ANY WARRANTY; without even the implied warranty of ;; MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the ;; GNU General Public License for more details. ;; 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. ;;; Code: (defalias 'riece-set-case-syntax-pair 'set-case-syntax-pair) ;;; stolen (and renamed) from gnus-ems.el. ;;; In GNU Emacs, user can intercept whole mouse tracking events by ;;; assigning [mouse-X]. In XEmacs, however, which causes different ;;; effect, that is, the command assigned to [mouse-X] only catches ;;; button-release events. (defvar riece-mouse-2 [mouse-2]) ;;; popup-menu compatibility stuff, stolen (and renamed) from ;;; semi-def.el. (defmacro riece-popup-menu-bogus-filter-constructor (menu) ;; #### Kludge for FSF Emacs-style menu. (let ((bogus-menu (make-symbol "bogus-menu"))) `(let (,bogus-menu selection function) (easy-menu-define ,bogus-menu nil nil ,menu) (setq selection (x-popup-menu t ,bogus-menu)) (when selection (setq function (lookup-key ,bogus-menu (apply #'vector selection))) ;; If a callback entry has no name, easy-menu wraps its value. ;; See `easy-menu-make-symbol'. (if (eq t (compare-strings "menu-function-" 0 nil (symbol-name function) 0 14)) (car (last (symbol-function function))) function))))) (defun riece-popup-menu-popup (menu event) (let ((function (riece-popup-menu-bogus-filter-constructor menu)) (pos (event-start event))) (when (symbolp function) (select-window (posn-window pos)) (goto-char (posn-point pos)) (funcall function)))) (provide 'riece-emacs) ;;; riece-emacs.el ends here