Commit 5d3b0f18 authored by Richard M. Stallman's avatar Richard M. Stallman
Browse files

(imenu, imenu--flatten-index-alist): Add marker support.

(imenu--cleanup): New function.
(imenu-example--name-and-position): Now uses markers.

(imenu-add-to-menubar): New function to add an entry
to the menubar for the buffer's current local keymap.
parent f150bd2b
......@@ -5,7 +5,7 @@
;; Author: Ake Stenhoff <>
;; Lars Lindberg <>
;; Created: 8 Feb 1994
;; Version: 1.7
;; Version: 1.11
;; Keywords: tools
;; This program is free software; you can redistribute it and/or modify
......@@ -43,6 +43,15 @@
;; supplied.
;;; Change Log:
;; v1.11 Jul 26 1994 Ake Stenhoff
;; Fixed bugs in 'imenu-add-to-menubar'.
;; v1.10 Jul 21 1994 Ake Stenhoff
;; Added support for markers.
;; Changed the examples to use
;; markers.
;; Thanks [alon].
;; v1.9 Jun 14 1994 Ake Stenhoff
;; Added 'imenu-add-to-menubar'.
;; v1.7 Apr 12 1994 Ake Stenhoff
;; Changed doc strings refering to symbols.
;; Require 'cl' when compiling only.
......@@ -77,7 +86,7 @@
;;; Thanks goes to
;; [simon] - Simon Leinen
;; [dean] - Dean Andrews
;; [alon] - Alon Albert
;;; Code
(eval-when-compile (require 'cl))
......@@ -287,7 +296,25 @@ This function is called after the function pointed out by
(error "No items suitable for an index found in this buffer."))
;; Add a rescan option to the index.
(cons imenu--rescan-item imenu--index-alist))
;;; Find all markers in alist and makes
;;; them point nowhere.
(defun imenu--cleanup (&optional alist)
;; Sets the markers in imenu--index-alist
;; point nowhere.
;; if alist is provided use that list.
(and imenu--index-alist
(lambda (item)
((markerp (cdr item))
(set-marker (cdr item) nil))
((listp (cdr item))
(imenu--cleanup (cdr item))))))
(if alist alist imenu--index-alist))
(defun imenu-default-create-index-function ()
"*Wrapper for index searching functions.
......@@ -350,7 +377,7 @@ Their results are gathered into an index alist."
(concat prefix imenu-level-separator name)
((numberp pos)
((or (markerp pos) (numberp pos))
(list (cons new-prefix pos)))
(imenu--flatten-index-alist pos new-prefix))))))
......@@ -468,9 +495,20 @@ The returned value is on the form (INDEX-NAME . INDEX-POSITION)."
(imenu--mouse-menu index-alist last-nonmenu-event)
(imenu--completion-buffer index-alist prompt)))
(and (eq result t)
(setq imenu--index-alist nil)))
(defun imenu-add-to-menubar (name)
"Adds an \"imenu\" entry to the menubar for the
current local keymap.
NAME is the string naming the menu to be added.
See 'imenu' for more information."
(interactive "sMenu name: ")
(and window-system
(define-key (current-local-map) [menu-bar index]
(cons name 'imenu))))
(defun imenu ()
"Jump to a place in the buffer chosen using a buffer menu or mouse menu.
......@@ -480,7 +518,12 @@ See `imenu-choose-buffer-index' for more information."
(and index-item
(goto-char (cdr index-item))))))
((markerp (cdr index-item))
(goto-char (marker-position (cdr index-item))))
(goto-char (cdr index-item))))))))
......@@ -495,9 +538,11 @@ See `imenu-choose-buffer-index' for more information."
(forward-sexp -1)
(let ((beg (point))
(end (progn (forward-sexp) (point))))
(end (progn (forward-sexp) (point)))
(marker (make-marker)))
(set-marker marker beg)
(cons (buffer-substring beg end)
;;; Lisp
Markdown is supported
0% or .
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment