From: Gerd Moellmann Date: Sun, 5 Dec 1999 13:24:44 +0000 (+0000) Subject: (bibtex-hs-forward-sexp): Added to support X-Git-Tag: emacs-pretest-21.0.90~5881 X-Git-Url: http://git.eshelyaron.com/gitweb/?a=commitdiff_plain;h=28f2ee6659fc09d71e21f1e0fe1844a768f3c8e7;p=emacs.git (bibtex-hs-forward-sexp): Added to support using the hideshow package. (hs-special-modes-alist): Added entry for bibtex to allow the use of the hideshow package. (bibtex-hide-entry-bodies): Deleted as hiding of entry bodies is not longer provided by bibtex.el directly. Instead the hideshow package should be used. (bibtex-mode-map, bibtex-edit-menu, bibtex-mode): Delete references to bibtex-hide-entry-bodies. Copyright notice is up to date. Moved maintainer information closer to the beginning of the bibtex.el file. (bibtex-maintainer-salutation): New constant. bibtex-version): New constant. bibtex-submit-bug-report): Use bibtex-version and bibtex-maintainer-salutation. (bibtex-entry-field-alist): Made booktitle field optional for @inproceedings entries when crossreferenced. (bibtex-entry-field-alist): Added booktitle field to proceedings entry type (for cross referencing). Thanks to Wagner Toledo Correa for the suggestion. (bibtex-string-file-path): Fixed typo. (bibtex-mode-map): Reserved the key `C-c &' for reftex.el. (bibtex-edit-menu): Added `reftex-view-crossref-from-bibtex' to menu. --- diff --git a/lisp/ChangeLog b/lisp/ChangeLog index 11b1b6f5180..6af6a1640b6 100644 --- a/lisp/ChangeLog +++ b/lisp/ChangeLog @@ -1,3 +1,38 @@ +1999-12-05 Dirk Herrmann + + * textmodes/bibtex.el (bibtex-hs-forward-sexp): Added to support + using the hideshow package. + (hs-special-modes-alist): Added entry for bibtex to allow the use + of the hideshow package. + (bibtex-hide-entry-bodies): Deleted as hiding of entry bodies is + not longer provided by bibtex.el directly. Instead the hideshow + package should be used. + (bibtex-mode-map, bibtex-edit-menu, bibtex-mode): Delete + references to bibtex-hide-entry-bodies. + +1999-12-05 Dirk Herrmann + + * textmodes/bibtex.el: Copyright notice is up to date. Moved + maintainer information closer to the beginning of the bibtex.el + file. + (bibtex-maintainer-salutation): New constant. + (bibtex-version): New constant. + (bibtex-submit-bug-report): Use bibtex-version and + bibtex-maintainer-salutation. + (bibtex-entry-field-alist): Made booktitle field optional for + @inproceedings entries when crossreferenced. + (bibtex-entry-field-alist): Added booktitle field to proceedings + entry type (for cross referencing). Thanks to Wagner Toledo Correa + for the suggestion. + (bibtex-string-file-path): Fixed typo. + +1999-12-05 Carsten Dominik + + * textmodes/bibtex.el (bibtex-mode-map): Reserved the key `C-c &' + for reftex.el. + (bibtex-edit-menu): Added `reftex-view-crossref-from-bibtex' + to menu. + 1999-12-04 Dave Love * delsel.el: Revert previous change -- region is significant to diff --git a/lisp/textmodes/bibtex.el b/lisp/textmodes/bibtex.el index d9513f13601..6ae02eded4d 100644 --- a/lisp/textmodes/bibtex.el +++ b/lisp/textmodes/bibtex.el @@ -1,6 +1,6 @@ ;;; bibtex.el --- BibTeX mode for GNU Emacs -;; Copyright (C) 1992, 1994, 1995, 1996, 1997 Free Software Foundation, Inc. +;; Copyright (C) 1992, 1994, 1995, 1996, 1997, 1998, 1999 Free Software Foundation, Inc. ;; Author: Stefan Schoef ;; Bengt Martensson @@ -43,6 +43,22 @@ (eval-when-compile (require 'compile)) + +;; Bug Reporting + +(defconst + bibtex-maintainer-address "Dirk Herrmann ") +;; current maintainer + +(defconst + bibtex-maintainer-salutation "Hallo Dirk,") +;; current maintainer + +(defconst + bibtex-version "(emacs 20.4)") +;; current version of the bibtex.el file + + ;; User Options: (defgroup bibtex nil @@ -318,9 +334,9 @@ after last parsing and which are maintained in sorted order are parsed." ("publisher" "Publishing company, its location") ("note" "Remarks to be put at the end of the \\bibitem"))) ((("author" "Author1 [and Author2 ...] [and others]") - ("title" "Title of the article in proceedings (BibTeX converts it to lowercase)") - ("booktitle" "Name of the conference proceedings")) - (("pages" "Pages in the conference proceedings") + ("title" "Title of the article in proceedings (BibTeX converts it to lowercase)")) + (("booktitle" "Name of the conference proceedings") + ("pages" "Pages in the conference proceedings") ("year" "Year of publication") ("editor" "Editor1 [and Editor2 ...] [and others]") ("volume" "Volume of the conference proceedings in the series") @@ -364,7 +380,8 @@ after last parsing and which are maintained in sorted order are parsed." ("note" "Remarks to be put at the end of the \\bibitem"))))) ("Proceedings" . (((("title" "Title of the conference proceedings") ("year" "Year of publication")) - (("editor" "Editor1 [and Editor2 ...] [and others]") + (("booktitle" "Title of the proceedings for cross references") + ("editor" "Editor1 [and Editor2 ...] [and others]") ("volume" "Volume of the conference proceedings in the series") ("number" "Number of the conference proceedings in a small series (overwritten by volume)") ("series" "Series in which the conference proceedings appeared") @@ -452,7 +469,7 @@ file)." :type '(repeat file)) (defvar bibtex-string-file-path (getenv "BIBINPUTS") - "*Colon separated list of pathes to search for `bibtex-string-files'.") + "*Colon separated list of paths to search for `bibtex-string-files'.") (defcustom bibtex-help-message t "*If not nil print help messages in the echo area on entering a new field." @@ -730,6 +747,23 @@ the value of `bibtex-text-indentation', minus 2." (defun bibtex-run-with-idle-timer (secs repeat function &rest args) (start-itimer "bibtex" function secs (if repeat secs nil) t))) + +;; Support for hideshow minor mode +(defun bibtex-hs-forward-sexp (arg) + "Replacement for `forward-sexp' to be used by `hs-minor-mode'." + (if (< arg 0) + (backward-sexp 1) + (if (looking-at "@\\S(*\\s(") + (progn + (goto-char (match-end 0)) + (forward-char -1) + (forward-sexp 1)) + (forward-sexp 1)))) + +(add-to-list + 'hs-special-modes-alist + '(bibtex-mode "@\\S(*\\s(" "\\s)" nil bibtex-hs-forward-sexp nil)) + ;; Syntax Table, Keybindings and BibTeX Entry List (defvar bibtex-mode-syntax-table @@ -747,6 +781,7 @@ the value of `bibtex-text-indentation', minus 2." (defvar bibtex-mode-map (let ((km (make-sparse-keymap))) + ;; The Key `C-c&' is reserved for reftex.el (define-key km "\t" 'bibtex-find-text) (define-key km "\n" 'bibtex-next-field) (define-key km "\M-\t" 'bibtex-complete-string) @@ -773,7 +808,6 @@ the value of `bibtex-text-indentation', minus 2." (define-key km "\C-\M-l" 'bibtex-reposition-window) (define-key km "\C-\M-h" 'bibtex-mark-entry) (define-key km "\C-c\C-b" 'bibtex-entry) - (define-key km "\C-c\C-t" 'bibtex-hide-entry-bodies) (define-key km "\C-c\C-rn" 'bibtex-narrow-to-entry) (define-key km "\C-c\C-rw" 'widen) (define-key km "\C-c\C-o" 'bibtex-remove-OPT-or-ALT) @@ -816,7 +850,10 @@ the value of `bibtex-text-indentation', minus 2." "--" ["Ispell Entry" bibtex-ispell-entry t] ["Ispell Entry Abstract" bibtex-ispell-abstract t] - ["Narrow to Entry" bibtex-narrow-to-entry t]) + ["Narrow to Entry" bibtex-narrow-to-entry t] + "--" + ["View Cite Locations (RefTeX)" reftex-view-crossref-from-bibtex + (fboundp 'reftex-view-crossref-from-bibtex)]) ("Operating on Current Field" ["Remove Delimiters" bibtex-remove-delimiters t] ["Remove OPT or ALT Prefix" bibtex-remove-OPT-or-ALT t] @@ -840,7 +877,6 @@ the value of `bibtex-text-indentation', minus 2." ["Validate Entries" bibtex-validate t] ["Sort Entries" bibtex-sort-buffer t] ["Reformat Entries" bibtex-reformat t] - ["Hide Entry Bodies" bibtex-hide-entry-bodies t] ["Count Entries" bibtex-count-entries t]) ("Miscellaneous" ["Convert Alien Buffer" bibtex-convert-alien t] @@ -865,13 +901,6 @@ the value of `bibtex-text-indentation', minus 2." ["String" bibtex-String t] ["Preamble" bibtex-Preamble t])) - -;; Bug Reporting - -(defconst - bibtex-maintainer-address "Dirk Herrmann ") -;; current maintainer - ;; Internal Variables @@ -964,7 +993,7 @@ the value of `bibtex-text-indentation', minus 2." ;; Regexp defining the type part of a BibTeX reference entry (almost ;; the same as bibtex-field-name) -(defconst bibtex-reference-key "[][a-z0-9.:;?!`'/*@+=|()<>&_^$-]+") +(defconst bibtex-reference-key "[][a-zA-Z0-9.:;?!`'/*@+=|()<>&_^$-]+") ;; Regexp defining the label part of a BibTeX reference entry (defconst bibtex-field-name "[^\"#%'(),={} \t\n0-9][^\"#%'(),={} \t\n]*") @@ -1394,7 +1423,7 @@ the value of `bibtex-text-indentation', minus 2." (defun bibtex-move-outside-of-entry () ;; Make sure we are outside of a BibTeX entry. (let ((orig-point (point))) - (bibtex-end-of-entry) + (bibtex-end-of-entry) (if (< (point) orig-point) ;; We moved backward, so we weren't inside an entry to begin with. ;; Leave point at the beginning of a line, and preferably @@ -1966,7 +1995,7 @@ the value of `bibtex-text-indentation', minus 2." titleword bibtex-autokey-titleword-ignore) (setq counter (1- counter)) - (setq + (setq titleword (funcall bibtex-autokey-titleword-case-convert titleword)) (if (or (not (numberp bibtex-autokey-titlewords)) @@ -2471,7 +2500,6 @@ The following may be of interest as well: bibtex-ispell-abstract bibtex-ispell-entry bibtex-narrow-to-entry - bibtex-hide-entry-bodies bibtex-sort-buffer bibtex-validate bibtex-count @@ -2612,7 +2640,7 @@ non-nil. (let ((reporter-prompt-for-summary-p t)) (reporter-submit-bug-report bibtex-maintainer-address - (concat "bibtex.el " "(emacs 19.35)") + (concat "bibtex.el " bibtex-version) (list 'system-configuration 'system-configuration-options @@ -2678,9 +2706,9 @@ non-nil. ;; user variables which shouldn't cause any errors ) nil nil - (concat "To the bibtex.el maintainer: + (concat bibtex-maintainer-salutation " -I want to report a bug on Emacs BibTeX mode. +I want to report a bug on Emacs BibTeX mode " bibtex-version ". I've read the `Bugs' section in the `Emacs' info page, so I know how to make a clear and unambiguous report. I have started a fresh Emacs via `"invocation-name " --no-init-file --no-site-file', thereafter (in @@ -3003,22 +3031,6 @@ If mark is active it counts entries in region, if not in whole buffer." (narrow-to-region (bibtex-beginning-of-entry) (bibtex-end-of-entry)))) -(defun bibtex-hide-entry-bodies (&optional arg) - "Hide all lines between first and last BibTeX entries not beginning with @. -With prefix argument ARG, show all text." - (interactive "P") - (save-excursion - (let ((buffer-read-only nil)) - (if arg - (subst-char-in-region (point-min) (point-max) ?\r ?\n t) - (let ((pos (point-max))) - (goto-char (point-max)) - (while (re-search-backward "^@" nil t) - (subst-char-in-region (point) pos ?\n ?\r t) - (if (not (bobp)) (forward-char -1)) - (setq pos (point))))) - (setq selective-display (not arg))))) - (defun bibtex-sort-buffer () "Sort BibTeX buffer alphabetically by key. Text outside of BibTeX entries is not affected. If