[Top][All Lists]
[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]
[Emacs-diffs] Changes to emacs/lisp/textmodes/reftex-toc.el [lexbind]
From: |
Miles Bader |
Subject: |
[Emacs-diffs] Changes to emacs/lisp/textmodes/reftex-toc.el [lexbind] |
Date: |
Tue, 14 Oct 2003 19:30:36 -0400 |
Index: emacs/lisp/textmodes/reftex-toc.el
diff -c emacs/lisp/textmodes/reftex-toc.el:1.12.4.1
emacs/lisp/textmodes/reftex-toc.el:1.12.4.2
*** emacs/lisp/textmodes/reftex-toc.el:1.12.4.1 Fri Apr 4 01:20:40 2003
--- emacs/lisp/textmodes/reftex-toc.el Tue Oct 14 19:30:22 2003
***************
*** 1,8 ****
;;; reftex-toc.el --- RefTeX's table of contents mode
! ;; Copyright (c) 1997, 1998, 1999, 2000 Free Software Foundation, Inc.
;; Author: Carsten Dominik <address@hidden>
! ;; Version: 4.18
;; This file is part of GNU Emacs.
--- 1,8 ----
;;; reftex-toc.el --- RefTeX's table of contents mode
! ;; Copyright (c) 1997, 1998, 1999, 2000, 2003 Free Software Foundation, Inc.
;; Author: Carsten Dominik <address@hidden>
! ;; Version: 4.21
;; This file is part of GNU Emacs.
***************
*** 46,66 ****
(interactive)
(kill-all-local-variables)
(setq major-mode 'reftex-toc-mode
! mode-name "TOC")
(use-local-map reftex-toc-map)
(set (make-local-variable 'revert-buffer-function) 'reftex-toc-revert)
(set (make-local-variable 'reftex-toc-include-labels-indicator) "")
(set (make-local-variable 'reftex-toc-max-level-indicator)
(if (= reftex-toc-max-level 100)
! "ALL"
! (int-to-string reftex-toc-max-level)))
(setq mode-line-format
! (list "---- " 'mode-line-buffer-identification
! " " 'global-mode-string " (" mode-name ")"
! " L<" 'reftex-toc-include-labels-indicator ">"
! " I<" 'reftex-toc-include-index-indicator ">"
! " T<" 'reftex-toc-max-level-indicator ">"
! " -%-"))
(setq truncate-lines t)
(when (featurep 'xemacs)
;; XEmacs needs the call to make-local-hook
--- 46,68 ----
(interactive)
(kill-all-local-variables)
(setq major-mode 'reftex-toc-mode
! mode-name "TOC")
(use-local-map reftex-toc-map)
+ (set (make-local-variable 'transient-mark-mode) t)
+ (set (make-local-variable 'zmacs-regions) t)
(set (make-local-variable 'revert-buffer-function) 'reftex-toc-revert)
(set (make-local-variable 'reftex-toc-include-labels-indicator) "")
(set (make-local-variable 'reftex-toc-max-level-indicator)
(if (= reftex-toc-max-level 100)
! "ALL"
! (int-to-string reftex-toc-max-level)))
(setq mode-line-format
! (list "---- " 'mode-line-buffer-identification
! " " 'global-mode-string " (" mode-name ")"
! " L<" 'reftex-toc-include-labels-indicator ">"
! " I<" 'reftex-toc-include-index-indicator ">"
! " T<" 'reftex-toc-max-level-indicator ">"
! " -%-"))
(setq truncate-lines t)
(when (featurep 'xemacs)
;; XEmacs needs the call to make-local-hook
***************
*** 91,110 ****
SPC Show the corresponding location of the LaTeX document.
TAB Goto the location and keep the *toc* window.
RET Goto the location and hide the *toc* window (also on mouse-2).
C-c > Display Index. With prefix arg, restrict index to current section.
q / k Hide/Kill *toc* buffer, return to position of reftex-toc command.
l i c F Toggle display of [l]abels, [i]ndex, [c]ontext, [F]ile borders.
t Change maximum toc depth (e.g. `3 t' hides levels greater than 3).
! f / a / g Toggle follow mode / toggle auto recenter / Refresh *toc* buffer.
r / C-u r Reparse the LaTeX document / Reparse entire LaTeX document.
. In other window, show position from where `reftex-toc' was called.
x Switch to TOC of external document (with LaTeX package `xr').
! z Jump to a specific section (e.g. '3 z' goes to section 3")
! (defun reftex-toc (&optional rebuild)
"Show the table of contents for the current document.
When called with a raw C-u prefix, rescan the document first."
(interactive)
(if (or (not (string= reftex-last-toc-master (reftex-TeX-master-file)))
--- 93,118 ----
SPC Show the corresponding location of the LaTeX document.
TAB Goto the location and keep the *toc* window.
RET Goto the location and hide the *toc* window (also on mouse-2).
+ < / > Promote / Demote section, or all sections in region.
C-c > Display Index. With prefix arg, restrict index to current section.
q / k Hide/Kill *toc* buffer, return to position of reftex-toc command.
l i c F Toggle display of [l]abels, [i]ndex, [c]ontext, [F]ile borders.
t Change maximum toc depth (e.g. `3 t' hides levels greater than 3).
! f / g Toggle follow mode / Refresh *toc* buffer.
! a / d Toggle auto recenter / Toggle dedicated frame
r / C-u r Reparse the LaTeX document / Reparse entire LaTeX document.
. In other window, show position from where `reftex-toc' was called.
+ M-% Global search and replace to rename label at point.
x Switch to TOC of external document (with LaTeX package `xr').
! z Jump to a specific section (e.g. '3 z' goes to section 3).")
! (defun reftex-toc (&optional rebuild reuse)
"Show the table of contents for the current document.
When called with a raw C-u prefix, rescan the document first."
+ ;; The REUSE argument means, search all visible frames for a window
+ ;; displaying the toc window. If yes, reuse this window.
+
(interactive)
(if (or (not (string= reftex-last-toc-master (reftex-TeX-master-file)))
***************
*** 129,168 ****
(reftex-access-scan-info current-prefix-arg)
(let* ((this-buf (current-buffer))
! (docstruct-symbol reftex-docstruct-symbol)
! (xr-data (assq 'xr (symbol-value reftex-docstruct-symbol)))
! (xr-alist (cons (cons "" (buffer-file-name)) (nth 1 xr-data)))
! (here-I-am (if (boundp 'reftex-rebuilding-toc)
! (get 'reftex-toc :reftex-data)
! (car (reftex-where-am-I))))
! offset)
!
! (if (get-buffer-window "*toc*")
! (select-window (get-buffer-window "*toc*"))
(when (or (not reftex-toc-keep-other-windows)
! (< (window-height) (* 2 window-min-height)))
! (delete-other-windows))
(setq reftex-last-window-width (window-width)
! reftex-last-window-height (window-height)) ; remember
! (if reftex-toc-split-windows-horizontally
! (split-window-horizontally
! (floor (* (frame-width)
reftex-toc-split-windows-horizontally-fraction)))
! (split-window))
(let ((default-major-mode 'reftex-toc-mode))
! (switch-to-buffer "*toc*")))
(or (eq major-mode 'reftex-toc-mode) (reftex-toc-mode))
(set (make-local-variable 'reftex-docstruct-symbol) docstruct-symbol)
(setq reftex-toc-include-labels-indicator
! (if (eq reftex-toc-include-labels t)
! "ALL"
! reftex-toc-include-labels))
(setq reftex-toc-include-index-indicator
! (if (eq reftex-toc-include-index-entries t)
! "ALL"
! reftex-toc-include-index-entries))
(cond
((= (buffer-size) 0)
--- 137,186 ----
(reftex-access-scan-info current-prefix-arg)
(let* ((this-buf (current-buffer))
! (docstruct-symbol reftex-docstruct-symbol)
! (xr-data (assq 'xr (symbol-value reftex-docstruct-symbol)))
! (xr-alist (cons (cons "" (buffer-file-name)) (nth 1 xr-data)))
! (here-I-am (if (boundp 'reftex-rebuilding-toc)
! (get 'reftex-toc :reftex-data)
! (car (reftex-where-am-I))))
! (unsplittable (if (fboundp 'frame-property)
! (frame-property (selected-frame) 'unsplittable)
! (frame-parameter (selected-frame) 'unsplittable)))
! offset toc-window)
!
! (if (setq toc-window (get-buffer-window
! "*toc*"
! (if reuse 'visible)))
! (select-window toc-window)
(when (or (not reftex-toc-keep-other-windows)
! (< (window-height) (* 2 window-min-height)))
! (delete-other-windows))
(setq reftex-last-window-width (window-width)
! reftex-last-window-height (window-height)) ; remember
!
! (unless unsplittable
! (if reftex-toc-split-windows-horizontally
! (split-window-horizontally
! (floor (* (window-width)
! reftex-toc-split-windows-fraction)))
! (split-window-vertically
! (floor (* (window-height)
! reftex-toc-split-windows-fraction)))))
(let ((default-major-mode 'reftex-toc-mode))
! (switch-to-buffer "*toc*")))
(or (eq major-mode 'reftex-toc-mode) (reftex-toc-mode))
(set (make-local-variable 'reftex-docstruct-symbol) docstruct-symbol)
(setq reftex-toc-include-labels-indicator
! (if (eq reftex-toc-include-labels t)
! "ALL"
! reftex-toc-include-labels))
(setq reftex-toc-include-index-indicator
! (if (eq reftex-toc-include-index-entries t)
! "ALL"
! reftex-toc-include-index-entries))
(cond
((= (buffer-size) 0)
***************
*** 177,215 ****
" (abbreviate-file-name reftex-last-toc-master)))
(if (reftex-use-fonts)
! (put-text-property 1 (point) 'face reftex-toc-header-face))
! (put-text-property 1 (point) 'intangible t)
! (put-text-property 1 2 'xr-alist xr-alist)
(setq offset
! (reftex-insert-docstruct
! this-buf
! t ; include toc
! reftex-toc-include-labels
! reftex-toc-include-index-entries
! reftex-toc-include-file-boundaries
! reftex-toc-include-context
! nil ; counter
! nil ; commented
! here-I-am
! "" ; xr-prefix
! t ; a toc buffer
! ))
!
(run-hooks 'reftex-display-copied-context-hook)
(message "Building *toc* buffer...done.")
(setq buffer-read-only t))
(t
;; Only compute the offset
(setq offset
! (or (reftex-get-offset this-buf here-I-am
! (if reftex-toc-include-labels " " nil)
! t
! reftex-toc-include-index-entries
! reftex-toc-include-file-boundaries)
! (reftex-last-assoc-before-elt
! 'toc here-I-am
! (symbol-value reftex-docstruct-symbol))))
(put 'reftex-toc :reftex-line 3)
(goto-line 3)
(beginning-of-line)))
--- 195,233 ----
" (abbreviate-file-name reftex-last-toc-master)))
(if (reftex-use-fonts)
! (put-text-property (point-min) (point) 'face
reftex-toc-header-face))
! (put-text-property (point-min) (point) 'intangible t)
! (put-text-property (point-min) (1+ (point-min)) 'xr-alist xr-alist)
(setq offset
! (reftex-insert-docstruct
! this-buf
! t ; include toc
! reftex-toc-include-labels
! reftex-toc-include-index-entries
! reftex-toc-include-file-boundaries
! reftex-toc-include-context
! nil ; counter
! nil ; commented
! here-I-am
! "" ; xr-prefix
! t ; a toc buffer
! ))
!
(run-hooks 'reftex-display-copied-context-hook)
(message "Building *toc* buffer...done.")
(setq buffer-read-only t))
(t
;; Only compute the offset
(setq offset
! (or (reftex-get-offset this-buf here-I-am
! (if reftex-toc-include-labels " " nil)
! t
! reftex-toc-include-index-entries
! reftex-toc-include-file-boundaries)
! (reftex-last-assoc-before-elt
! 'toc here-I-am
! (symbol-value reftex-docstruct-symbol))))
(put 'reftex-toc :reftex-line 3)
(goto-line 3)
(beginning-of-line)))
***************
*** 221,247 ****
(defun reftex-toc-recenter (&optional arg)
"Display the TOC window and highlight line corresponding to current
position."
(interactive "P")
! (let ((buf (current-buffer)))
! (reftex-toc arg)
(if (= (count-lines 1 (point)) 2)
! (let ((current-prefix-arg nil))
! (select-window (get-buffer-window buf))
! (reftex-toc nil)))
(and (> (point) 1)
! (not (get-text-property (point) 'intangible))
! (memq reftex-highlight-selection '(cursor both))
! (reftex-highlight 2
! (or (previous-single-property-change
! (min (point-max) (1+ (point))) :data)
! (point-min))
! (or (next-single-property-change (point) :data)
! (point-max))))
! (select-window (get-buffer-window buf))))
(defun reftex-toc-pre-command-hook ()
;; used as pre command hook in *toc* buffer
(reftex-unhighlight 0)
- ;; (reftex-unhighlight 1) ;; remove highlight on leaving buffer.
)
(defun reftex-toc-post-command-hook ()
--- 239,265 ----
(defun reftex-toc-recenter (&optional arg)
"Display the TOC window and highlight line corresponding to current
position."
(interactive "P")
! (let ((buf (current-buffer))
! (frame (selected-frame)))
! (reftex-toc arg t)
(if (= (count-lines 1 (point)) 2)
! (let ((current-prefix-arg nil))
! (select-window (get-buffer-window buf frame))
! (reftex-toc nil t)))
(and (> (point) 1)
! (not (get-text-property (point) 'intangible))
! (memq reftex-highlight-selection '(cursor both))
! (reftex-highlight 2
! (or (previous-single-property-change
! (min (point-max) (1+ (point))) :data)
! (point-min))
! (or (next-single-property-change (point) :data)
! (point-max))))
! (select-window (get-buffer-window buf frame))))
(defun reftex-toc-pre-command-hook ()
;; used as pre command hook in *toc* buffer
(reftex-unhighlight 0)
)
(defun reftex-toc-post-command-hook ()
***************
*** 249,285 ****
(when (get-text-property (point) :data)
(put 'reftex-toc :reftex-data (get-text-property (point) :data))
(and (> (point) 1)
! (not (get-text-property (point) 'intangible))
! (memq reftex-highlight-selection '(cursor both))
! (reftex-highlight 2
! (or (previous-single-property-change (1+ (point)) :data)
! (point-min))
! (or (next-single-property-change (point) :data)
! (point-max)))))
(if (integerp reftex-toc-follow-mode)
;; remove delayed action
(setq reftex-toc-follow-mode t)
! (and reftex-toc-follow-mode
! (not (equal reftex-last-follow-point (point)))
! ;; show context in other window
! (setq reftex-last-follow-point (point))
! (condition-case nil
! (reftex-toc-visit-location nil (not reftex-revisit-to-follow))
! (error t)))))
(defun reftex-re-enlarge ()
! ;; Enlarge windiw to a remembered size
(if reftex-toc-split-windows-horizontally
(enlarge-window-horizontally
(max 0 (- (or reftex-last-window-width (window-width))
! (window-width))))
(enlarge-window
(max 0 (- (or reftex-last-window-height (window-height))
! (window-height))))))
(defun reftex-toc-show-help ()
"Show a summary of special key bindings."
(interactive)
(with-output-to-temp-buffer "*RefTeX Help*"
(princ reftex-toc-help))
(reftex-enlarge-to-fit "*RefTeX Help*" t)
--- 267,318 ----
(when (get-text-property (point) :data)
(put 'reftex-toc :reftex-data (get-text-property (point) :data))
(and (> (point) 1)
! (not (get-text-property (point) 'intangible))
! (memq reftex-highlight-selection '(cursor both))
! (reftex-highlight 2
! (or (previous-single-property-change (1+ (point)) :data)
! (point-min))
! (or (next-single-property-change (point) :data)
! (point-max)))))
(if (integerp reftex-toc-follow-mode)
;; remove delayed action
(setq reftex-toc-follow-mode t)
! (and (not (reftex-toc-dframe-p))
! reftex-toc-follow-mode
! (not (equal reftex-last-follow-point (point)))
! ;; show context in other window
! (setq reftex-last-follow-point (point))
! (condition-case nil
! (reftex-toc-visit-location nil (not reftex-revisit-to-follow))
! (error t)))))
(defun reftex-re-enlarge ()
! ;; Enlarge window to a remembered size.
(if reftex-toc-split-windows-horizontally
(enlarge-window-horizontally
(max 0 (- (or reftex-last-window-width (window-width))
! (window-width))))
(enlarge-window
(max 0 (- (or reftex-last-window-height (window-height))
! (window-height))))))
!
! (defun reftex-toc-dframe-p (&optional frame error)
! ;; Check if FRAME is the dedicated TOC frame.
! ;; If yes, and ERROR is non-nil, throw an error.
! (setq frame (or frame (selected-frame)))
! (let ((res (equal
! (if (fboundp 'frame-property)
! (frame-property frame 'name)
! (frame-parameter frame 'name))
! "RefTeX TOC Frame")))
! (if (and res error)
! (error "This frame is view-only. Use `C-c =' to create toc window
for commands."))
! res))
(defun reftex-toc-show-help ()
"Show a summary of special key bindings."
(interactive)
+ (reftex-toc-dframe-p nil 'error)
(with-output-to-temp-buffer "*RefTeX Help*"
(princ reftex-toc-help))
(reftex-enlarge-to-fit "*RefTeX Help*" t)
***************
*** 290,314 ****
(defun reftex-toc-next (&optional arg)
"Move to next selectable item."
(interactive "p")
(setq reftex-callback-fwd t)
(or (eobp) (forward-char 1))
! (goto-char (or (next-single-property-change (point) :data)
! (point))))
(defun reftex-toc-previous (&optional arg)
"Move to previous selectable item."
(interactive "p")
(setq reftex-callback-fwd nil)
(goto-char (or (previous-single-property-change (point) :data)
! (point))))
(defun reftex-toc-next-heading (&optional arg)
"Move to next table of contentes line."
(interactive "p")
(end-of-line)
(re-search-forward "^ " nil t arg)
(beginning-of-line))
(defun reftex-toc-previous-heading (&optional arg)
"Move to previous table of contentes line."
(interactive "p")
(re-search-backward "^ " nil t arg))
(defun reftex-toc-toggle-follow ()
"Toggle follow (other window follows with context)."
--- 323,351 ----
(defun reftex-toc-next (&optional arg)
"Move to next selectable item."
(interactive "p")
+ (if (boundp 'zmacs-region-stays) (setq zmacs-region-stays t))
(setq reftex-callback-fwd t)
(or (eobp) (forward-char 1))
! (goto-char (or (next-single-property-change (point) :data)
! (point))))
(defun reftex-toc-previous (&optional arg)
"Move to previous selectable item."
(interactive "p")
+ (if (boundp 'zmacs-region-stays) (setq zmacs-region-stays t))
(setq reftex-callback-fwd nil)
(goto-char (or (previous-single-property-change (point) :data)
! (point))))
(defun reftex-toc-next-heading (&optional arg)
"Move to next table of contentes line."
(interactive "p")
+ (if (boundp 'zmacs-region-stays) (setq zmacs-region-stays t))
(end-of-line)
(re-search-forward "^ " nil t arg)
(beginning-of-line))
(defun reftex-toc-previous-heading (&optional arg)
"Move to previous table of contentes line."
(interactive "p")
+ (if (boundp 'zmacs-region-stays) (setq zmacs-region-stays t))
(re-search-backward "^ " nil t arg))
(defun reftex-toc-toggle-follow ()
"Toggle follow (other window follows with context)."
***************
*** 319,334 ****
"Toggle inclusion of file boundaries in *toc* buffer."
(interactive)
(setq reftex-toc-include-file-boundaries
! (not reftex-toc-include-file-boundaries))
(reftex-toc-revert))
(defun reftex-toc-toggle-labels (arg)
"Toggle inclusion of labels in *toc* buffer.
With prefix ARG, prompt for a label type and include only labels of
that specific type."
(interactive "P")
! (setq reftex-toc-include-labels
! (if arg (reftex-query-label-type)
! (not reftex-toc-include-labels)))
(reftex-toc-revert))
(defun reftex-toc-toggle-index (arg)
"Toggle inclusion of index in *toc* buffer.
--- 356,371 ----
"Toggle inclusion of file boundaries in *toc* buffer."
(interactive)
(setq reftex-toc-include-file-boundaries
! (not reftex-toc-include-file-boundaries))
(reftex-toc-revert))
(defun reftex-toc-toggle-labels (arg)
"Toggle inclusion of labels in *toc* buffer.
With prefix ARG, prompt for a label type and include only labels of
that specific type."
(interactive "P")
! (setq reftex-toc-include-labels
! (if arg (reftex-query-label-type)
! (not reftex-toc-include-labels)))
(reftex-toc-revert))
(defun reftex-toc-toggle-index (arg)
"Toggle inclusion of index in *toc* buffer.
***************
*** 336,343 ****
specific index."
(interactive "P")
(setq reftex-toc-include-index-entries
! (if arg (reftex-index-select-tag)
! (not reftex-toc-include-index-entries)))
(reftex-toc-revert))
(defun reftex-toc-toggle-context ()
"Toggle inclusion of label context in *toc* buffer.
--- 373,380 ----
specific index."
(interactive "P")
(setq reftex-toc-include-index-entries
! (if arg (reftex-index-select-tag)
! (not reftex-toc-include-index-entries)))
(reftex-toc-revert))
(defun reftex-toc-toggle-context ()
"Toggle inclusion of label context in *toc* buffer.
***************
*** 351,396 ****
levels are shown. For eaxample, to set the level to 3, type `3 m'."
(interactive "P")
(setq reftex-toc-max-level (if arg
! (prefix-numeric-value arg)
! 100))
(setq reftex-toc-max-level-indicator
! (if arg (int-to-string reftex-toc-max-level) "ALL"))
(reftex-toc-revert))
(defun reftex-toc-view-line ()
"View document location in other window."
(interactive)
(reftex-toc-visit-location))
(defun reftex-toc-goto-line-and-hide ()
"Go to document location in other window. Hide the *toc* window."
(interactive)
(reftex-toc-visit-location 'hide))
(defun reftex-toc-goto-line ()
"Go to document location in other window. *toc* window stays."
(interactive)
(reftex-toc-visit-location t))
(defun reftex-toc-mouse-goto-line-and-hide (ev)
"Go to document location in other window. Hide the *toc* window."
(interactive "e")
(mouse-set-point ev)
(reftex-toc-visit-location 'hide))
(defun reftex-toc-show-calling-point ()
"Show point where reftex-toc was called from."
(interactive)
(let ((this-window (selected-window)))
(unwind-protect
! (progn
! (switch-to-buffer-other-window
! (marker-buffer reftex-toc-return-marker))
! (goto-char (marker-position reftex-toc-return-marker))
! (recenter '(4)))
(select-window this-window))))
(defun reftex-toc-quit ()
! "Hide the *toc* window and do not move point."
(interactive)
! (or (one-window-p) (delete-window))
! (switch-to-buffer (marker-buffer reftex-toc-return-marker))
! (reftex-re-enlarge)
! (goto-char (or (marker-position reftex-toc-return-marker) (point))))
(defun reftex-toc-quit-and-kill ()
"Kill the *toc* buffer."
(interactive)
--- 388,444 ----
levels are shown. For eaxample, to set the level to 3, type `3 m'."
(interactive "P")
(setq reftex-toc-max-level (if arg
! (prefix-numeric-value arg)
! 100))
(setq reftex-toc-max-level-indicator
! (if arg (int-to-string reftex-toc-max-level) "ALL"))
(reftex-toc-revert))
(defun reftex-toc-view-line ()
"View document location in other window."
(interactive)
+ (reftex-toc-dframe-p nil 'error)
(reftex-toc-visit-location))
(defun reftex-toc-goto-line-and-hide ()
"Go to document location in other window. Hide the *toc* window."
(interactive)
+ (reftex-toc-dframe-p nil 'error)
(reftex-toc-visit-location 'hide))
(defun reftex-toc-goto-line ()
"Go to document location in other window. *toc* window stays."
(interactive)
+ (reftex-toc-dframe-p nil 'error)
(reftex-toc-visit-location t))
(defun reftex-toc-mouse-goto-line-and-hide (ev)
"Go to document location in other window. Hide the *toc* window."
(interactive "e")
(mouse-set-point ev)
+ (reftex-toc-dframe-p nil 'error)
(reftex-toc-visit-location 'hide))
(defun reftex-toc-show-calling-point ()
"Show point where reftex-toc was called from."
(interactive)
+ (reftex-toc-dframe-p nil 'error)
(let ((this-window (selected-window)))
(unwind-protect
! (progn
! (switch-to-buffer-other-window
! (marker-buffer reftex-toc-return-marker))
! (goto-char (marker-position reftex-toc-return-marker))
! (recenter '(4)))
(select-window this-window))))
(defun reftex-toc-quit ()
! "Hide the *toc* window and do not move point.
! If the toc window is the only window on the dedicated TOC frame, the frame
! is destroyed."
(interactive)
! (if (and (one-window-p)
! (reftex-toc-dframe-p)
! (> (length (frame-list)) 1))
! (delete-frame)
! (or (one-window-p) (delete-window))
! (switch-to-buffer (marker-buffer reftex-toc-return-marker))
! (reftex-re-enlarge)
! (goto-char (or (marker-position reftex-toc-return-marker) (point)))))
(defun reftex-toc-quit-and-kill ()
"Kill the *toc* buffer."
(interactive)
***************
*** 404,440 ****
This works just like `reftex-display-index' from a LaTeX buffer.
With prefix arg 1, restrict index to the section at point."
(interactive "P")
(let ((data (get-text-property (point) :data))
! (docstruct (symbol-value reftex-docstruct-symbol))
! bor eor restr)
(when (equal arg 2)
(setq bor (reftex-last-assoc-before-elt 'toc data docstruct)
! eor (assoc 'toc (cdr (memq bor docstruct)))
! restr (list (nth 6 bor) bor eor)))
(reftex-toc-goto-line)
(reftex-display-index (if restr nil arg) restr)))
(defun reftex-toc-rescan (&rest ignore)
"Regenerate the *toc* buffer by reparsing file of section at point."
(interactive)
! (if (and reftex-enable-partial-scans
! (null current-prefix-arg))
(let* ((data (get-text-property (point) :data))
! (what (car data))
! (file (cond ((eq what 'toc) (nth 3 data))
! ((memq what '(eof bof file-error)) (nth 1 data))
! ((stringp what) (nth 3 data))
! ((eq what 'index) (nth 3 data))))
! (line (+ (count-lines (point-min) (point)) (if (bolp) 1 0))))
(if (not file)
(error "Don't know which file to rescan. Try `C-u r'")
! (put 'reftex-toc :reftex-line line)
(switch-to-buffer-other-window
(reftex-get-file-buffer-force file))
! (setq current-prefix-arg '(4))
! (let ((reftex-rebuilding-toc t))
! (reftex-toc))))
(reftex-toc-Rescan))
(reftex-kill-temporary-buffers))
(defun reftex-toc-Rescan (&rest ignore)
"Regenerate the *toc* buffer by reparsing the entire document."
(interactive)
--- 452,492 ----
This works just like `reftex-display-index' from a LaTeX buffer.
With prefix arg 1, restrict index to the section at point."
(interactive "P")
+ (reftex-toc-dframe-p nil 'error)
(let ((data (get-text-property (point) :data))
! (docstruct (symbol-value reftex-docstruct-symbol))
! bor eor restr)
(when (equal arg 2)
(setq bor (reftex-last-assoc-before-elt 'toc data docstruct)
! eor (assoc 'toc (cdr (memq bor docstruct)))
! restr (list (nth 6 bor) bor eor)))
(reftex-toc-goto-line)
(reftex-display-index (if restr nil arg) restr)))
+
+ ;; Rescanning the document and rebuilding the TOC buffer.
(defun reftex-toc-rescan (&rest ignore)
"Regenerate the *toc* buffer by reparsing file of section at point."
(interactive)
! (if (and reftex-enable-partial-scans
! (null current-prefix-arg))
(let* ((data (get-text-property (point) :data))
! (what (car data))
! (file (cond ((eq what 'toc) (nth 3 data))
! ((memq what '(eof bof file-error)) (nth 1 data))
! ((stringp what) (nth 3 data))
! ((eq what 'index) (nth 3 data))))
! (line (+ (count-lines (point-min) (point)) (if (bolp) 1 0))))
(if (not file)
(error "Don't know which file to rescan. Try `C-u r'")
! (put 'reftex-toc :reftex-line line)
(switch-to-buffer-other-window
(reftex-get-file-buffer-force file))
! (setq current-prefix-arg '(4))
! (let ((reftex-rebuilding-toc t))
! (reftex-toc))))
(reftex-toc-Rescan))
(reftex-kill-temporary-buffers))
+
(defun reftex-toc-Rescan (&rest ignore)
"Regenerate the *toc* buffer by reparsing the entire document."
(interactive)
***************
*** 445,472 ****
(setq current-prefix-arg '(16))
(let ((reftex-rebuilding-toc t))
(reftex-toc)))
(defun reftex-toc-revert (&rest ignore)
"Regenerate the *toc* from the internal lists."
(interactive)
! (switch-to-buffer-other-window
! (reftex-get-file-buffer-force reftex-last-toc-file))
(reftex-erase-buffer "*toc*")
(setq current-prefix-arg nil)
! (let ((reftex-rebuilding-toc t))
! (reftex-toc t)))
(defun reftex-toc-external (&rest ignore)
"Switch to table of contents of an external document."
(interactive)
(let* ((old-buf (current-buffer))
! (xr-alist (get-text-property 1 'xr-alist))
! (xr-index (reftex-select-external-document
! xr-alist 0)))
(switch-to-buffer-other-window (or (reftex-get-file-buffer-force
! (cdr (nth xr-index xr-alist)))
! (error "Cannot switch document")))
(reftex-toc)
(if (equal old-buf (current-buffer))
! (message "")
(message "Switched document"))))
(defun reftex-toc-jump (arg)
--- 497,534 ----
(setq current-prefix-arg '(16))
(let ((reftex-rebuilding-toc t))
(reftex-toc)))
+
(defun reftex-toc-revert (&rest ignore)
"Regenerate the *toc* from the internal lists."
(interactive)
! (let ((unsplittable
! (if (fboundp 'frame-property)
! (frame-property (selected-frame) 'unsplittable)
! (frame-parameter (selected-frame) 'unsplittable)))
! (reftex-rebuilding-toc t))
! (if unsplittable
! (switch-to-buffer
! (reftex-get-file-buffer-force reftex-last-toc-file))
! (switch-to-buffer-other-window
! (reftex-get-file-buffer-force reftex-last-toc-file))))
(reftex-erase-buffer "*toc*")
(setq current-prefix-arg nil)
! (reftex-toc t))
!
(defun reftex-toc-external (&rest ignore)
"Switch to table of contents of an external document."
(interactive)
+ (reftex-toc-dframe-p nil 'error)
(let* ((old-buf (current-buffer))
! (xr-alist (get-text-property 1 'xr-alist))
! (xr-index (reftex-select-external-document
! xr-alist 0)))
(switch-to-buffer-other-window (or (reftex-get-file-buffer-force
! (cdr (nth xr-index xr-alist)))
! (error "Cannot switch document")))
(reftex-toc)
(if (equal old-buf (current-buffer))
! (message "")
(message "Switched document"))))
(defun reftex-toc-jump (arg)
***************
*** 479,490 ****
nil t)
(beginning-of-line))
(defun reftex-toc-visit-location (&optional final no-revisit)
;; Visit the tex file corresponding to the toc entry on the current line.
;; If FINAL is t, stay there
;; If FINAL is 'hide, hide the *toc* window.
;; Otherwise, move cursor back into *toc* window.
! ;; NO-REVISIT means don't visit files, just use live biffers.
;; This function is pretty clever about finding back a section heading,
;; even if the buffer is not live, or things like outline, x-symbol etc.
;; have been active.
--- 541,800 ----
nil t)
(beginning-of-line))
+ ;; Promotion/Demotion stuff
+
+ (defun reftex-toc-demote (&optional arg)
+ "Demote section at point. If region is active, apply to all in region."
+ (interactive "p")
+ (reftex-toc-do-promote 1))
+ (defun reftex-toc-promote (&optional arg)
+ "Promote section at point. If region is active, apply to all in region."
+ (interactive "p")
+ (reftex-toc-do-promote -1))
+ (defun reftex-toc-do-promote (delta)
+ "Workhorse for reftex-toc-promote and reftex-to-demote.
+ Changes the level of sections in the current region, or just the section at
+ point."
+ ;; We should not do anything unless we are sure this is going to work for
+ ;; each section in the region. Therefore we first collect information and
+ ;; test.
+ (let* ((start-line (+ (count-lines (point-min) (point))
+ (if (bolp) 1 0)))
+ (mark-line (if (reftex-region-active-p)
+ (save-excursion (goto-char (mark))
+ (+ (count-lines (point-min) (point))
+ (if (bolp) 1 0)))))
+ (start-pos (point))
+ (pro-or-de (if (> delta 0) "de" "pro"))
+ beg end entries data sections nsec mpos msg)
+ (setq msg
+ (catch 'exit
+ (if (reftex-region-active-p)
+ ;; A region is dangerous, check if we have a brandnew scan,
+ ;; to make sure we are not missing any section statements.
+ (if (not (reftex-toc-check-docstruct))
+ (reftex-toc-load-all-files-for-promotion) ;; exits
+ (setq beg (min (point) (mark))
+ end (max (point) (mark))))
+ (setq beg (point) end (point)))
+ (goto-char beg)
+ (while (and (setq data (get-text-property (point) :data))
+ (<= (point) end))
+ (if (eq (car data) 'toc) (push (cons data (point)) entries))
+ (goto-char (or (next-single-property-change (point) :data)
+ (point-max))))
+ (setq entries (nreverse entries))
+ ;; Get the relevant section numbers, for an informative message
+ (goto-char start-pos)
+ (setq sections (reftex-toc-extract-section-number (car entries)))
+ (if (> (setq nsec (length entries)) 1)
+ (setq sections
+ (concat sections "-"
+ (reftex-toc-extract-section-number
+ (nth (1- nsec) entries)))))
+ ;; Run through the list and prepare the changes.
+ (setq entries (mapcar 'reftex-toc-promote-prepare entries))
+ ;; Ask for permission
+ (if (or (not reftex-toc-confirm-promotion) ; never
confirm
+ (and (integerp reftex-toc-confirm-promotion) ; confirm if
many
+ (< nsec reftex-toc-confirm-promotion))
+ (yes-or-no-p ; ask
+ (format "%s %d toc-entr%s (section%s %s)? "
+ (if (< delta 0) "Promote" "Demote")
+ nsec
+ (if (= 1 nsec) "y" "ies")
+ (if (= 1 nsec) "" "s")
+ sections)))
+ nil ; we have permission, do nothing
+ (error "Abort")) ; abort, we don't have permission
+ ;; Do the changes
+ (mapcar 'reftex-toc-promote-action entries)
+ ;; Rescan the document and rebuilt the toc buffer
+ (save-window-excursion
+ (reftex-toc-Rescan))
+ (reftex-toc-restore-region start-line mark-line)
+ (message "%d section%s %smoted"
+ nsec (if (= 1 nsec) "" "s") pro-or-de)
+ nil))
+ (if msg (progn (ding) (message msg)))))
+
+ (defvar delta)
+ (defvar mpos)
+ (defvar pro-or-de)
+ (defvar start-pos)
+ (defvar start-line)
+ (defvar mark-line)
+
+ (defun reftex-toc-restore-region (point-line &optional mark-line)
+ (if mark-line
+ (progn (goto-line mark-line)
+ (setq mpos (point))))
+ (if point-line (goto-line point-line))
+ (if mark-line
+ (progn
+ (set-mark mpos)
+ (if (fboundp 'zmacs-activate-region)
+ (zmacs-activate-region)
+ (setq mark-active t
+ deactivate-mark nil)))))
+
+ (defun reftex-toc-promote-prepare (x)
+ "Look at a toc entry and see if we could pro/demote it.
+ Expects the level change DELTA to be dynamically scoped into this function.
+ This function prepares everything for the changes, but does not do it.
+ The return value is a list with information needed when doing the
+ promotion/demotion later."
+ (let* ((data (car x))
+ (toc-point (cdr x))
+ (marker (nth 4 data))
+ (literal (nth 7 data))
+ (load nil)
+ (name nil)
+ ;; Here follows some paranoid code to make very sure we are not
+ ;; going to break anything
+ (name1 ; dummy
+ (if (and (markerp marker) (marker-buffer marker))
+ ;; Buffer is still live and we have the marker.
+ (progn
+ (save-excursion
+ ;; Goto the buffer and check of section is unchanged
+ (set-buffer (marker-buffer marker))
+ (goto-char (marker-position marker))
+ (if (looking-at (regexp-quote literal))
+ ;; OK, get the makro name
+ (progn
+ (beginning-of-line 1)
+ (if (looking-at reftex-section-regexp)
+ (setq name (reftex-match-string 2))
+ (error "Something is wrong! Contact maintainer!")))
+ ;; Section has changed, request scan and loading
+ ;; We use a variable to delay until after the safe-exc.
+ ;; because otherwise we loose the region.
+ (setq load t)))
+ ;; Scan document and load all files, this exits command
+ (if load (reftex-toc-load-all-files-for-promotion))) ; exits
+ ;; We don't have a live marker: scan and load files.
+ (reftex-toc-load-all-files-for-promotion)))
+ (level (cdr (assoc name reftex-section-levels-all)))
+ (dummy (if (not (integerp level))
+ (progn
+ (goto-char toc-point)
+ (error "Cannot %smote special sections" pro-or-de))))
+ ;; Delta is dynamically scoped into here...
+ (newlevel (if (>= level 0) (+ delta level) (- level delta)))
+ (dummy2 (if (or (and (>= level 0) (= newlevel -1))
+ (and (< level 0) (= newlevel 0)))
+ (error "Cannot %smote \\%s" pro-or-de name)))
+ (newname (reftex-toc-newhead-from-alist newlevel name
+ reftex-section-levels-all)))
+ (if (and name newname)
+ (list data name newname toc-point)
+ (goto-char toc-point)
+ (error "Cannot %smote \\%s" pro-or-de name))))
+
+ (defun reftex-toc-promote-action (x)
+ "Change the level of a toc entry.
+ DELTA and PRO-OR-DE are assumed to be dynamically scoped into this function."
+ (let* ((data (car x))
+ (name (nth 1 x))
+ (newname (nth 2 x))
+ (marker (nth 4 data)))
+ (save-excursion
+ (set-buffer (marker-buffer marker))
+ (goto-char (marker-position marker))
+ (if (looking-at (concat "\\([ \t]*\\\\\\)" (regexp-quote name)))
+ (replace-match (concat "\\1" newname))
+ (error "Fatal error during %smotion" pro-or-de)))))
+
+ (defun reftex-toc-extract-section-number (entry)
+ "Get the numbering of a toc entry, for message purposes."
+ (if (string-match "\\s-*\\(\\S-+\\)" (nth 2 (car entry)))
+ (match-string 1 (nth 2 (car entry)))
+ "?"))
+
+ (defun reftex-toc-newhead-from-alist (nlevel head alist)
+ "Get new heading with level NLEVEL from ALIST.
+ If there are no such entries, return nil.
+ If there are several different entries with same new level, choose
+ the one with the smallest distance to the assocation of HEAD in the alist.
+ This makes it possible for promotion to work several sets of headings,
+ if these sets are sorted blocks in the alist."
+ (let* ((al alist)
+ (ass (assoc head al))
+ (pos (length (memq ass al)))
+ dist (mindist 1000) newhead)
+ (while al
+ (if (equal (cdar al) nlevel)
+ (progn
+ (setq dist (abs (- (length al) pos)))
+ (if (< dist mindist)
+ (setq newhead (car (car al))
+ mindist dist))))
+ (setq al (cdr al)))
+ newhead))
+
+ (defun reftex-toc-check-docstruct ()
+ "Check if the current docstruct is fully up to date and all files visited."
+ ;; We do this by checking if all sections are on the right position
+ (let ((docstruct (symbol-value reftex-docstruct-symbol))
+ entry marker empoint)
+ (catch 'exit
+ (while (setq entry (pop docstruct))
+ (if (eq (car entry) 'toc)
+ (progn
+ (setq marker (nth 4 entry)
+ empoint (nth 8 entry))
+ (if (not (and (markerp marker)
+ (marker-buffer marker)
+ (= (marker-position marker) empoint)))
+ (throw 'exit nil)))))
+ t)))
+
+ (defun reftex-toc-load-all-files-for-promotion ()
+ "Make sure all files of the document are being visited by buffers,
+ and that the scanning info is absolutely up to date.
+ We do this by rescanning with reftex-keep-temporary-buffers bound to t.
+ The variable PRO-OR-DE is assumed to be dynamically scoped into thes function.
+ When finished, we exit with an error message."
+ (let ((reftex-keep-temporary-buffers t))
+ (reftex-toc-Rescan)
+ (reftex-toc-restore-region start-line mark-line)
+ (throw 'exit
+ (format "TOC had to be updated first. Please check selection and
repeat the command." pro-or-de))))
+
+ (defun reftex-toc-rename-label ()
+ "Rename the currently selected label in the *TOC* buffer.
+ This launches a global search and replace in order to rename a label.
+ Renaming a label is hardly ever necessary - the only exeption is after
+ promotion/demotion in connection with a package like fancyref, where the
+ label prefix determines the wording of a reference."
+ (interactive)
+ (let* ((toc (get-text-property (point) :data))
+ (label (car toc)) newlabel)
+ (if (not (stringp label))
+ (error "This is not a label entry."))
+ (setq newlabel (read-string (format "Rename label \"%s\" to:" label)))
+ (if (assoc newlabel (symbol-value reftex-docstruct-symbol))
+ (if (not (y-or-n-p
+ (format "Label '%s' exists. Use anyway? " label)))
+ (error "Abort")))
+ (save-excursion
+ (save-window-excursion
+ (reftex-toc-visit-location t)
+ (condition-case nil
+ (reftex-query-replace-document
+ (concat "{" (regexp-quote label) "}")
+ (format "{%s}" newlabel))
+ (error t))))
+ (reftex-toc-rescan)))
+
+
(defun reftex-toc-visit-location (&optional final no-revisit)
;; Visit the tex file corresponding to the toc entry on the current line.
;; If FINAL is t, stay there
;; If FINAL is 'hide, hide the *toc* window.
;; Otherwise, move cursor back into *toc* window.
! ;; NO-REVISIT means don't visit files, just use live buffers.
;; This function is pretty clever about finding back a section heading,
;; even if the buffer is not live, or things like outline, x-symbol etc.
;; have been active.
***************
*** 494,502 ****
show-window show-buffer match)
(unless toc (error "Don't know which toc line to visit"))
!
(cond
!
((eq (car toc) 'toc)
;; a toc entry
(setq match (reftex-toc-find-section toc no-revisit)))
--- 804,812 ----
show-window show-buffer match)
(unless toc (error "Don't know which toc line to visit"))
!
(cond
!
((eq (car toc) 'toc)
;; a toc entry
(setq match (reftex-toc-find-section toc no-revisit)))
***************
*** 508,526 ****
((memq (car toc) '(bof eof))
;; A file entry
(setq match
! (let ((where (car toc))
! (file (nth 1 toc)))
! (if (or (not no-revisit) (reftex-get-buffer-visiting file))
! (progn
! (switch-to-buffer-other-window
! (reftex-get-file-buffer-force file nil))
! (goto-char (if (eq where 'bof) (point-min) (point-max))))
! (message reftex-no-follow-message) nil))))
((stringp (car toc))
;; a label
(setq match (reftex-show-label-location toc reftex-callback-fwd
! no-revisit t))))
(setq show-window (selected-window)
show-buffer (current-buffer))
--- 818,836 ----
((memq (car toc) '(bof eof))
;; A file entry
(setq match
! (let ((where (car toc))
! (file (nth 1 toc)))
! (if (or (not no-revisit) (reftex-get-buffer-visiting file))
! (progn
! (switch-to-buffer-other-window
! (reftex-get-file-buffer-force file nil))
! (goto-char (if (eq where 'bof) (point-min) (point-max))))
! (message reftex-no-follow-message) nil))))
((stringp (car toc))
;; a label
(setq match (reftex-show-label-location toc reftex-callback-fwd
! no-revisit t))))
(setq show-window (selected-window)
show-buffer (current-buffer))
***************
*** 539,583 ****
((eq final 'hide)
(reftex-unhighlight 0)
(or (one-window-p) (delete-window))
! (switch-to-buffer show-buffer)
(reftex-re-enlarge))
(t nil))))
(defun reftex-toc-find-section (toc &optional no-revisit)
(let* ((file (nth 3 toc))
! (marker (nth 4 toc))
! (level (nth 5 toc))
! (literal (nth 7 toc))
! (emergency-point (nth 8 toc))
! (match
! (cond
! ((and (markerp marker) (marker-buffer marker))
! ;; Buffer is still live and we have the marker. Should be easy.
! (switch-to-buffer-other-window (marker-buffer marker))
! (goto-char (marker-position marker))
! (or (looking-at (regexp-quote literal))
! (looking-at (reftex-make-regexp-allow-for-ctrl-m literal))
! (looking-at (reftex-make-desperate-section-regexp literal))
! (looking-at (concat "\\\\"
! (regexp-quote
! (car
! (rassq level
! reftex-section-levels-all)))
! "[[{]?"))))
! ((or (not no-revisit)
! (reftex-get-buffer-visiting file))
! ;; Marker is lost. Use the backup method.
! (switch-to-buffer-other-window
! (reftex-get-file-buffer-force file nil))
! (goto-char (or emergency-point (point-min)))
! (or (looking-at (regexp-quote literal))
! (let ((len (length literal)))
! (or (reftex-nearest-match (regexp-quote literal) len)
! (reftex-nearest-match
! (reftex-make-regexp-allow-for-ctrl-m literal) len)
! (reftex-nearest-match
! (reftex-make-desperate-section-regexp literal) len)))))
! (t (message reftex-no-follow-message) nil))))
(when match
(goto-char (match-beginning 0))
(if (not (= (point) (point-max))) (recenter 1))
--- 849,897 ----
((eq final 'hide)
(reftex-unhighlight 0)
(or (one-window-p) (delete-window))
! ;; If `show-window' is still live, show-buffer is already visible
! ;; so let's not make it visible in yet-another-window.
! (if (window-live-p show-window)
! (set-buffer show-buffer)
! (switch-to-buffer show-buffer))
(reftex-re-enlarge))
(t nil))))
(defun reftex-toc-find-section (toc &optional no-revisit)
(let* ((file (nth 3 toc))
! (marker (nth 4 toc))
! (level (nth 5 toc))
! (literal (nth 7 toc))
! (emergency-point (nth 8 toc))
! (match
! (cond
! ((and (markerp marker) (marker-buffer marker))
! ;; Buffer is still live and we have the marker. Should be easy.
! (switch-to-buffer-other-window (marker-buffer marker))
! (goto-char (marker-position marker))
! (or (looking-at (regexp-quote literal))
! (looking-at (reftex-make-regexp-allow-for-ctrl-m literal))
! (looking-at (reftex-make-desperate-section-regexp literal))
! (looking-at (concat "\\\\"
! (regexp-quote
! (car
! (rassq level
! reftex-section-levels-all)))
! "[[{]?"))))
! ((or (not no-revisit)
! (reftex-get-buffer-visiting file))
! ;; Marker is lost. Use the backup method.
! (switch-to-buffer-other-window
! (reftex-get-file-buffer-force file nil))
! (goto-char (or emergency-point (point-min)))
! (or (looking-at (regexp-quote literal))
! (let ((len (length literal)))
! (or (reftex-nearest-match (regexp-quote literal) len)
! (reftex-nearest-match
! (reftex-make-regexp-allow-for-ctrl-m literal) len)
! (reftex-nearest-match
! (reftex-make-desperate-section-regexp literal) len)))))
! (t (message reftex-no-follow-message) nil))))
(when match
(goto-char (match-beginning 0))
(if (not (= (point) (point-max))) (recenter 1))
***************
*** 599,613 ****
(setq old (substring old (match-end 0))))
new))
(defun reftex-recenter-toc-when-idle ()
(and (> (buffer-size) 5)
reftex-mode
(not (active-minibuffer-window))
(fboundp 'reftex-toc-mode)
! (get-buffer-window "*toc*")
(string= reftex-last-toc-master (reftex-TeX-master-file))
! (reftex-toc-recenter)))
(defun reftex-toggle-auto-toc-recenter ()
"Toggle the automatic recentering of the toc window.
--- 913,929 ----
(setq old (substring old (match-end 0))))
new))
+ ;; Auto recentering of TOC window
(defun reftex-recenter-toc-when-idle ()
(and (> (buffer-size) 5)
reftex-mode
(not (active-minibuffer-window))
(fboundp 'reftex-toc-mode)
! (get-buffer-window "*toc*" 'visible)
(string= reftex-last-toc-master (reftex-TeX-master-file))
! (let (current-prefix-arg)
! (reftex-toc-recenter))))
(defun reftex-toggle-auto-toc-recenter ()
"Toggle the automatic recentering of the toc window.
***************
*** 616,635 ****
(interactive)
(if reftex-toc-auto-recenter-timer
(progn
! (if (featurep 'xemacs)
! (delete-itimer reftex-toc-auto-recenter-timer)
! (cancel-timer reftex-toc-auto-recenter-timer))
! (setq reftex-toc-auto-recenter-timer nil)
! (message "Automatic recentering of toc buffer was turned off"))
(setq reftex-toc-auto-recenter-timer
! (if (featurep 'xemacs)
! (start-itimer "RefTeX Idle Timer for recenter"
! 'reftex-recenter-toc-when-idle
! reftex-idle-time reftex-idle-time t)
! (run-with-idle-timer
! reftex-idle-time t 'reftex-recenter-toc-when-idle)))
(message "Automatic recentering of toc window was turned on")))
;; Table of Contents map
(define-key reftex-toc-map (if (featurep 'xemacs) [(button2)] [(mouse-2)])
--- 932,1004 ----
(interactive)
(if reftex-toc-auto-recenter-timer
(progn
! (if (featurep 'xemacs)
! (delete-itimer reftex-toc-auto-recenter-timer)
! (cancel-timer reftex-toc-auto-recenter-timer))
! (setq reftex-toc-auto-recenter-timer nil)
! (message "Automatic recentering of toc windwo was turned off"))
(setq reftex-toc-auto-recenter-timer
! (if (featurep 'xemacs)
! (start-itimer "RefTeX Idle Timer for recenter"
! 'reftex-recenter-toc-when-idle
! reftex-idle-time reftex-idle-time t)
! (run-with-idle-timer
! reftex-idle-time t 'reftex-recenter-toc-when-idle)))
(message "Automatic recentering of toc window was turned on")))
+ (defun reftex-toc-toggle-dedicated-frame ()
+ "Toggle the display of a separate frame for the TOC.
+ This frame is not used by the `reftex-toc' commands, but it is useful to
+ always show the current section in connection with the option
+ `reftex-auto-recenter-toc'."
+ (interactive)
+ (catch 'exit
+ (let* ((frames (frame-list)) frame
+ (get-frame-prop-func (if (fboundp 'frame-property)
+ 'frame-property
+ 'frame-parameter)))
+ (while (setq frame (pop frames))
+ (if (equal (funcall get-frame-prop-func frame 'name)
+ "RefTeX TOC Frame")
+ (progn
+ (delete-frame frame)
+ (throw 'exit nil))))
+ (reftex-make-separate-toc-frame))))
+
+ (defun reftex-make-separate-toc-frame ()
+ ;; Create a new fame showing only the toc buffer.
+ (let ((current-frame (selected-frame))
+ (current-window (selected-window))
+ (current-toc-window (get-buffer-window "*toc*" 'visible))
+ current-toc-frame)
+ (if (and current-toc-window
+ (not (equal (selected-frame) (window-frame current-toc-window))))
+ nil
+ (setq current-toc-frame
+ (make-frame
+ '((name . "RefTeX TOC Frame")
+ (height . 20) (width . 60)
+ (unsplittable . t)
+ (minibuffer . nil)
+ (default-toolbar-visible-p . nil)
+ (menubar-visible-p . nil)
+ (horizontal-scrollbar-visible-p . nil))))
+ (select-frame current-toc-frame)
+ (switch-to-buffer "*toc*")
+ (select-frame current-frame)
+ (if (fboundp 'focus-frame) (focus-frame current-frame)
+ (if (fboundp 'x-focus-frame) (x-focus-frame current-frame)))
+ (select-window current-window)
+ (when (eq reftex-auto-recenter-toc 'frame)
+ (unless reftex-toc-auto-recenter-timer
+ (reftex-toggle-auto-toc-recenter))
+ (add-hook 'delete-frame-hook 'reftex-toc-delete-frame-hook)))))
+
+ (defun reftex-toc-delete-frame-hook (frame)
+ (if (and reftex-toc-auto-recenter-timer
+ (reftex-toc-dframe-p frame))
+ (progn
+ (reftex-toggle-auto-toc-recenter))))
;; Table of Contents map
(define-key reftex-toc-map (if (featurep 'xemacs) [(button2)] [(mouse-2)])
***************
*** 641,687 ****
'previous-line 'reftex-toc-previous reftex-toc-map global-map)
(loop for x in
! '(("n" . reftex-toc-next)
! ("p" . reftex-toc-previous)
! ("?" . reftex-toc-show-help)
! (" " . reftex-toc-view-line)
! ("\C-m" . reftex-toc-goto-line-and-hide)
! ("\C-i" . reftex-toc-goto-line)
! ("\C-c>". reftex-toc-display-index)
! ("r" . reftex-toc-rescan)
! ("R" . reftex-toc-Rescan)
! ("g" . revert-buffer)
! ("q" . reftex-toc-quit)
! ("k" . reftex-toc-quit-and-kill)
! ("f" . reftex-toc-toggle-follow)
! ("a" . reftex-toggle-auto-toc-recenter)
! ("F" . reftex-toc-toggle-file-boundary)
! ("i" . reftex-toc-toggle-index)
! ("l" . reftex-toc-toggle-labels)
! ("t" . reftex-toc-max-level)
! ("c" . reftex-toc-toggle-context)
! ("%" . reftex-toc-toggle-commented)
! ("x" . reftex-toc-external)
! ("z" . reftex-toc-jump)
! ("." . reftex-toc-show-calling-point)
! ("\C-c\C-n" . reftex-toc-next-heading)
! ("\C-c\C-p" . reftex-toc-previous-heading))
do (define-key reftex-toc-map (car x) (cdr x)))
(loop for key across "0123456789" do
(define-key reftex-toc-map (vector (list key)) 'digit-argument))
(define-key reftex-toc-map "-" 'negative-argument)
! (easy-menu-define
reftex-toc-menu reftex-toc-map
"Menu for Table of Contents buffer"
'("TOC"
["Show Location" reftex-toc-view-line t]
["Go To Location" reftex-toc-goto-line t]
["Exit & Go To Location" reftex-toc-goto-line-and-hide t]
! ["Index" reftex-toc-display-index t]
["Quit" reftex-toc-quit t]
"--"
["External Document TOC " reftex-toc-external t]
"--"
("Update"
--- 1010,1066 ----
'previous-line 'reftex-toc-previous reftex-toc-map global-map)
(loop for x in
! '(("n" . reftex-toc-next)
! ("p" . reftex-toc-previous)
! ("?" . reftex-toc-show-help)
! (" " . reftex-toc-view-line)
! ("\C-m" . reftex-toc-goto-line-and-hide)
! ("\C-i" . reftex-toc-goto-line)
! ("\C-c>" . reftex-toc-display-index)
! ("r" . reftex-toc-rescan)
! ("R" . reftex-toc-Rescan)
! ("g" . revert-buffer)
! ("q" . reftex-toc-quit);
! ("k" . reftex-toc-quit-and-kill)
! ("f" . reftex-toc-toggle-follow);
! ("a" . reftex-toggle-auto-toc-recenter)
! ("d" . reftex-toc-toggle-dedicated-frame)
! ("F" . reftex-toc-toggle-file-boundary)
! ("i" . reftex-toc-toggle-index)
! ("l" . reftex-toc-toggle-labels)
! ("t" . reftex-toc-max-level)
! ("c" . reftex-toc-toggle-context)
! ; ("%" . reftex-toc-toggle-commented)
! ("\M-%" . reftex-toc-rename-label)
! ("x" . reftex-toc-external)
! ("z" . reftex-toc-jump)
! ("." . reftex-toc-show-calling-point)
! ("\C-c\C-n" . reftex-toc-next-heading)
! ("\C-c\C-p" . reftex-toc-previous-heading)
! (">" . reftex-toc-demote)
! ("<" . reftex-toc-promote))
do (define-key reftex-toc-map (car x) (cdr x)))
(loop for key across "0123456789" do
(define-key reftex-toc-map (vector (list key)) 'digit-argument))
(define-key reftex-toc-map "-" 'negative-argument)
! (easy-menu-define
reftex-toc-menu reftex-toc-map
"Menu for Table of Contents buffer"
'("TOC"
["Show Location" reftex-toc-view-line t]
["Go To Location" reftex-toc-goto-line t]
["Exit & Go To Location" reftex-toc-goto-line-and-hide t]
! ["Show Calling Point" reftex-toc-show-calling-point t]
["Quit" reftex-toc-quit t]
"--"
+ ("Edit"
+ ["Promote" reftex-toc-promote t]
+ ["Demote" reftex-toc-demote t]
+ ["Rename Label" reftex-toc-rename-label t])
+ "--"
+ ["Index" reftex-toc-display-index t]
["External Document TOC " reftex-toc-external t]
"--"
("Update"
***************
*** 699,708 ****
["Context" reftex-toc-toggle-context :style toggle
:selected reftex-toc-include-context]
"--"
! ["Follow Mode" reftex-toc-toggle-follow :style toggle
! :selected reftex-toc-follow-mode])
"--"
["Help" reftex-toc-show-help t]))
! ;;; reftex-toc.el ends here
--- 1078,1091 ----
["Context" reftex-toc-toggle-context :style toggle
:selected reftex-toc-include-context]
"--"
! ["Follow Mode" reftex-toc-toggle-follow :style toggle
! :selected reftex-toc-follow-mode]
! ["Auto Recenter" reftex-toggle-auto-toc-recenter :style toggle
! :selected reftex-toc-auto-recenter-timer]
! ["Dedicated Frame" reftex-toc-toggle-dedicated-frame t])
"--"
["Help" reftex-toc-show-help t]))
! ;;; arch-tag: 92400ce2-0b86-4c89-a606-4ed71acea17e
! ;;; reftex-toc.el ends here
\ No newline at end of file
[Prev in Thread] |
Current Thread |
[Next in Thread] |
- [Emacs-diffs] Changes to emacs/lisp/textmodes/reftex-toc.el [lexbind],
Miles Bader <=