Mercurial > emacs
view lisp/scroll-all.el @ 42249:50adfc6e47b2
More sophisticated indentation of cpp directive.
(antlr-indent-at-bol-alist): New user option.
(antlr-indent-line): Use it.
(antlr-indent-style): New user option.
(antlr-mode): Use it.
(antlr-indent-item-regexp): Customize.
Syntax highlighting changes.
(antlr-font-lock-literal-regexp): New user option.
(antlr-font-lock-syntax-face): New face used for :, |, ....
(antlr-font-lock-default-face): New face.
(antlr-font-lock-additional-keywords): Use them.
New command to insert options -- variables.
(antlr-mode-map): New binding [C-c C-o].
(antlr-mode-menu): New submenus.
(antlr-options-use-submenus): New user option.
(antlr-tool-version): New user option.
(antlr-options-auto-colon): New user option.
(antlr-options-style): New user option.
(antlr-options-push-mark): New user option.
(antlr-options-assign-string): New user option.
(antlr-options-headings): New variable.
New command to insert options -- specific.
(antlr-options-alists): New variable.
(antlr-read-value): New function.
(antlr-read-boolean): New function.
(antlr-language-option-extra): New function.
(antlr-language-limit-n-regexp): Change default to higher LIMIT.
(antlr-c++-mode-extra): New function.
(antlr-grammar-tokens): New function.
(antlr-imenu-create-index-function): New optional argument.
New command to insert options -- functions.
(antlr-insert-option): New command.
(antlr-insert-option-interactive): New function.
(antlr-options-menu-filter): New function.
(antlr-option-kind): New function.
(antlr-scan-lists): New alias.
(antlr-scan-lists-internal): New function.
(antlr-skip-file-prelude): Hack for special SKIP-COMMENT.
(antlr-option-level): New function.
(antlr-syntactic-grammar-depth): New function.
(antlr-option-location): New function.
(antlr-insert-option-do): New function.
(antlr-option-spec): New function.
(antlr-version-string): New function.
(antlr-insert-option-existing): New function.
(antlr-insert-option-space): New function.
(antlr-insert-option-area): New function.
New electric keys ":;|&(){}", TAB works better
with narrowing. Menu change. Miscellaneous.
(antlr-mode-menu): Include "Indent Region" and "Customize Antlr".
(antlr-mode-map): New bindings for characters in ":;|&(){}".
(antlr-electric-character): New command.
(antlr-class-header-regexp): New variable.
(antlr-font-lock-additional-keywords): Use it.
(antlr-imenu-create-index-function): Use it.
(antlr-file-dependencies): Use it.
(antlr-indent-line): Also works with restrictions.
(antlr-indent-command): Interactive spec - changes the buffer.
(antlr-language-for-option): Deletia.
(antlr-language-option): New function, defined instead.
(antlr-mode): Use it.
author | Richard M. Stallman <rms@gnu.org> |
---|---|
date | Fri, 21 Dec 2001 23:55:39 +0000 |
parents | b174db545cfd |
children | 193981425f19 |
line wrap: on
line source
;;; scroll-all.el --- scroll all buffers together minor mode ;; Copyright (C) 1997 Free Software Foundation, Inc. ;; Author: Gary D. Foster <Gary.Foster@corp.sun.com> ;; Keywords: scroll crisp brief lock ;; This file is part of GNU Emacs. ;; GNU Emacs 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. ;; GNU Emacs 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. ;;; Commentary: ;; This mode allows multiple buffers to be 'locked' so that scrolling ;; up or down lines in any buffer causes all the buffers to mirror ;; the scrolling. It hooks into the post-command-hook to check for ;; potential scrolling commands and if we're locked, mirrors them in all ;; windows. This allows us to grab line-at-a-time scrolling as well as ;; screen-at-a-time scrolling, and doesn't remap any of the keyboard ;; commands to do it. ;; You can enable and disable this mode with the 'scroll-all-mode' command. ;; Suggestions/ideas from: ;; Rick Macdonald <rickm@vsl.com> ;; Anders Lindgren <andersl@csd.uu.se> ;;; Code: (defvar running-xemacs (string-match "XEmacs\\|Lucid" emacs-version)) ;;;###autoload (defcustom scroll-all-mode nil "Control/track scroll locking. Setting this variable directly does not take effect; use either M-x customize or the function `scroll-all-mode'." :set (lambda (symbol value) (scroll-all-mode (if value 1 0))) :initialize 'custom-initialize-default :require 'scroll-all :type 'boolean :group 'windows) (if running-xemacs (add-minor-mode 'scroll-all-mode " *SL*") (or (assq 'scroll-all-mode-mode minor-mode-alist) (setq minor-mode-alist (cons '(scroll-all-mode-mode " *SL*") minor-mode-alist)))) (defun scroll-all-scroll-down-all (arg) "Scroll down all visible windows." (interactive "P") (let ((num-windows (count-windows)) (count 1)) (if (> num-windows 1) ( progn (other-window 1) (while (< count num-windows) (if (not (eq (point) (point-max))) (progn (call-interactively 'next-line))) (other-window 1) (setq count (1+ count))))))) (defun scroll-all-scroll-up-all (arg) "Scroll up all visible windows." (interactive "P") (let ((num-windows (count-windows)) (count 1)) (if (> num-windows 1) ( progn (other-window 1) (while (< count num-windows) (if (not (eq (point) (point-min))) (progn (call-interactively 'previous-line))) (other-window 1) (setq count (1+ count))))))) (defun scroll-all-page-down-all (arg) "Page down in all visible windows." (interactive "P") (let ((num-windows (count-windows)) (count 1)) (if (> num-windows 1) (progn (other-window 1) (while (< count num-windows) (call-interactively 'fkey-scroll-up) (other-window 1) (setq count (1+ count))))))) (defun scroll-all-page-up-all (arg) "Page up in all visible windows." (interactive "P") (let ((num-windows (count-windows)) (count 1)) (if (> num-windows 1) (progn (other-window 1) (while (< count num-windows) (call-interactively 'fkey-scroll-down) (other-window 1) (setq count (1+ count))))))) (defun scroll-all-check-to-scroll () "Check `last-command' to see if a scroll was done." (if (eq this-command 'next-line) (call-interactively 'scroll-all-scroll-down-all)) (if (eq this-command 'previous-line) (call-interactively 'scroll-all-scroll-up-all)) (if (eq this-command 'fkey-scroll-up) (call-interactively 'scroll-all-page-down-all)) (if (eq this-command 'fkey-scroll-down) (call-interactively 'scroll-all-page-up-all))) ;;;###autoload (defun scroll-all-mode (arg) "Toggle Scroll-All minor mode." (interactive "P") (setq scroll-all-mode (not scroll-all-mode)) (cond ((eq scroll-all-mode 't) (add-hook 'post-command-hook 'scroll-all-check-to-scroll)) ((eq scroll-all-mode 'nil) (remove-hook 'post-command-hook 'scroll-all-check-to-scroll)))) (provide 'scroll-all) ;;; scroll-all.el ends here