annotate lisp/oobr/br-ftr.el @ 24:4103f0995bd7 r19-15b95

Import from CVS: tag r19-15b95
author cvs
date Mon, 13 Aug 2007 08:51:03 +0200
parents 376386a54a3c
children 131b0175ea99
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
0
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1 ;;!emacs
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2 ;;
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
3 ;; FILE: br-ftr.el
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
4 ;; SUMMARY: OO-Browser feature browsing support.
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
5 ;; USAGE: GNU Emacs Lisp Library
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
6 ;; KEYWORDS: oop, tools
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
7 ;;
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
8 ;; AUTHOR: Bob Weiner
24
4103f0995bd7 Import from CVS: tag r19-15b95
cvs
parents: 0
diff changeset
9 ;; ORG: InfoDock Associates
0
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
10 ;;
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
11 ;; ORIG-DATE: 20-Aug-91 at 18:16:36
24
4103f0995bd7 Import from CVS: tag r19-15b95
cvs
parents: 0
diff changeset
12 ;; LAST-MOD: 20-Feb-97 at 07:02:51 by Bob Weiner
0
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
13 ;;
24
4103f0995bd7 Import from CVS: tag r19-15b95
cvs
parents: 0
diff changeset
14 ;; Copyright (C) 1991-1996, Free Software Foundation, Inc.
0
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
15 ;; See the file BR-COPY for license information.
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
16 ;;
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
17 ;; This file is part of the OO-Browser.
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
18 ;;
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
19 ;; DESCRIPTION:
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
20 ;; DESCRIP-END.
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
21
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
22 ;;; ************************************************************************
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
23 ;;; Public variables
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
24 ;;; ************************************************************************
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
25
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
26 (defconst br-feature-type-regexp "[-+=@%>1/]"
24
4103f0995bd7 Import from CVS: tag r19-15b95
cvs
parents: 0
diff changeset
27 "Regular expression which matches the first non-whitespace character in an OO-Browser feature listing.")
0
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
28
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
29 ;;; ************************************************************************
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
30 ;;; Public functions
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
31 ;;; ************************************************************************
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
32
24
4103f0995bd7 Import from CVS: tag r19-15b95
cvs
parents: 0
diff changeset
33 (defun br-edit-feature (class feature-name &optional other-win view-only)
4103f0995bd7 Import from CVS: tag r19-15b95
cvs
parents: 0
diff changeset
34 "Edit the definition of CLASS' FEATURE-NAME, optionally in some OTHER-WIN if non-nil.
4103f0995bd7 Import from CVS: tag r19-15b95
cvs
parents: 0
diff changeset
35 With optional VIEW-ONLY non-nil, view the feature definition instead of editing it.
4103f0995bd7 Import from CVS: tag r19-15b95
cvs
parents: 0
diff changeset
36 Return the pathname of the feature definition if found, else nil."
4103f0995bd7 Import from CVS: tag r19-15b95
cvs
parents: 0
diff changeset
37 (interactive
4103f0995bd7 Import from CVS: tag r19-15b95
cvs
parents: 0
diff changeset
38 (list nil (br-feature-complete 'must-match "Edit feature definition:")
4103f0995bd7 Import from CVS: tag r19-15b95
cvs
parents: 0
diff changeset
39 nil nil))
4103f0995bd7 Import from CVS: tag r19-15b95
cvs
parents: 0
diff changeset
40 (let ((tag-and-file (br-feature-tag-and-file
4103f0995bd7 Import from CVS: tag r19-15b95
cvs
parents: 0
diff changeset
41 (if (null class)
4103f0995bd7 Import from CVS: tag r19-15b95
cvs
parents: 0
diff changeset
42 ;; Assume feature-name includes prepended class in
4103f0995bd7 Import from CVS: tag r19-15b95
cvs
parents: 0
diff changeset
43 ;; proper format, e.g. when called interactively.
4103f0995bd7 Import from CVS: tag r19-15b95
cvs
parents: 0
diff changeset
44 (regexp-quote feature-name)
4103f0995bd7 Import from CVS: tag r19-15b95
cvs
parents: 0
diff changeset
45 (br-feature-tag-regexp class feature-name)))))
4103f0995bd7 Import from CVS: tag r19-15b95
cvs
parents: 0
diff changeset
46 (if tag-and-file (br-edit-feature-from-tag
4103f0995bd7 Import from CVS: tag r19-15b95
cvs
parents: 0
diff changeset
47 (car tag-and-file) (cdr tag-and-file) other-win view-only))))
0
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
48
24
4103f0995bd7 Import from CVS: tag r19-15b95
cvs
parents: 0
diff changeset
49 (defun br-edit-feature-from-tag (tag-entry feature-path &optional other-win view-only)
4103f0995bd7 Import from CVS: tag r19-15b95
cvs
parents: 0
diff changeset
50 "Edit feature for OO-Browser TAG-ENTRY of file FEATURE-PATH, optionally in OTHER-WIN if non-nil.
0
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
51 With optional VIEW-ONLY, view feature definition instead of editing it.
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
52 Return FEATURE-PATH if feature definition is found, else nil."
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
53 (let ((err))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
54 (cond ((and feature-path (file-readable-p feature-path))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
55 (cond ((br-feature-found-p feature-path tag-entry nil other-win)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
56 (br-major-mode)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
57 (if view-only
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
58 (setq buffer-read-only t)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
59 ;; Handle case of already existing buffer in
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
60 ;; read only mode.
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
61 (and buffer-read-only
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
62 (file-writable-p feature-path)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
63 (setq buffer-read-only nil)))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
64 ;; Force mode-line redisplay
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
65 (set-buffer-modified-p (buffer-modified-p)))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
66 ((interactive-p)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
67 (setq err
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
68 (format
24
4103f0995bd7 Import from CVS: tag r19-15b95
cvs
parents: 0
diff changeset
69 "(OO-Browser): No `%s' feature defined in Environment."
0
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
70 tag-entry)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
71 feature-path nil))))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
72 ((interactive-p)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
73 (setq err
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
74 (format
24
4103f0995bd7 Import from CVS: tag r19-15b95
cvs
parents: 0
diff changeset
75 "(OO-Browser): `%s' - src file not found or not readable, %s"
0
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
76 tag-entry feature-path)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
77 feature-path nil)))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
78 (if err (error err))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
79 feature-path))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
80
24
4103f0995bd7 Import from CVS: tag r19-15b95
cvs
parents: 0
diff changeset
81 (defun br-find-feature (&optional feature-entry view-only other-win)
4103f0995bd7 Import from CVS: tag r19-15b95
cvs
parents: 0
diff changeset
82 "Display feature definition for FEATURE-ENTRY in VIEW-ONLY mode if non-nil.
4103f0995bd7 Import from CVS: tag r19-15b95
cvs
parents: 0
diff changeset
83 Return feature path if FEATURE-ENTRY is successfully displayed, nil
4103f0995bd7 Import from CVS: tag r19-15b95
cvs
parents: 0
diff changeset
84 otherwise. Can also signal an error when called interactively."
4103f0995bd7 Import from CVS: tag r19-15b95
cvs
parents: 0
diff changeset
85 (interactive)
4103f0995bd7 Import from CVS: tag r19-15b95
cvs
parents: 0
diff changeset
86 (and (interactive-p) (setq view-only current-prefix-arg))
4103f0995bd7 Import from CVS: tag r19-15b95
cvs
parents: 0
diff changeset
87 (let ((feature-path))
4103f0995bd7 Import from CVS: tag r19-15b95
cvs
parents: 0
diff changeset
88 (setq feature-entry
4103f0995bd7 Import from CVS: tag r19-15b95
cvs
parents: 0
diff changeset
89 (br-feature-signature-and-file
4103f0995bd7 Import from CVS: tag r19-15b95
cvs
parents: 0
diff changeset
90 (or feature-entry
4103f0995bd7 Import from CVS: tag r19-15b95
cvs
parents: 0
diff changeset
91 (br-feature-complete 'must-match
4103f0995bd7 Import from CVS: tag r19-15b95
cvs
parents: 0
diff changeset
92 (if view-only
4103f0995bd7 Import from CVS: tag r19-15b95
cvs
parents: 0
diff changeset
93 "View feature definition:"
4103f0995bd7 Import from CVS: tag r19-15b95
cvs
parents: 0
diff changeset
94 "Edit feature definition:"))))
4103f0995bd7 Import from CVS: tag r19-15b95
cvs
parents: 0
diff changeset
95 feature-path (cdr feature-entry)
4103f0995bd7 Import from CVS: tag r19-15b95
cvs
parents: 0
diff changeset
96 feature-entry (car feature-entry))
4103f0995bd7 Import from CVS: tag r19-15b95
cvs
parents: 0
diff changeset
97 (br-edit-feature-from-tag feature-entry feature-path other-win view-only)))
4103f0995bd7 Import from CVS: tag r19-15b95
cvs
parents: 0
diff changeset
98
0
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
99 (defun br-find-feature-entry ()
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
100 "Return feature entry that point is within or nil."
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
101 (if (= (point) (point-max)) (skip-chars-backward " \t\n"))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
102 (save-excursion
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
103 (beginning-of-line)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
104 (if (or
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
105 (progn (skip-chars-forward " \t")
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
106 (looking-at br-feature-entry))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
107 ;; Get current feature signature, if any.
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
108 (br-feature-get-signature))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
109 (let ((feature (buffer-substring
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
110 (point)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
111 (progn (skip-chars-forward "^\t\n\r") (point)))))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
112 (if (and (equal br-lang-prefix "objc-")
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
113 ;; Remove any trailing class from a category entry.
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
114 (string-match "@ ([^\)]+)" feature))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
115 (substring feature 0 (match-end 0))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
116 feature)))))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
117
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
118 (defun br-feature-complete (&optional must-match prompt)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
119 "Interactively completes feature entry if possible, and returns it.
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
120 Optional MUST-MATCH means must match a completion table entry.
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
121 Optional PROMPT is intial prompt string for user."
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
122 (interactive)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
123 (let ((default (br-find-feature-entry))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
124 (completion-ignore-case t)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
125 completions
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
126 ftr-entry)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
127 ;; Prompt with possible completions of ftr-entry.
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
128 (setq prompt (or prompt "Feature entry:")
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
129 completions (br-feature-completions)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
130 ftr-entry
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
131 (if completions
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
132 (completing-read
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
133 (format "%s (default %s) " prompt default)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
134 completions nil must-match)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
135 (read-string
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
136 (format "%s (default %s) " prompt default))))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
137 (if (equal ftr-entry "") default ftr-entry)))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
138
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
139 (defun br-feature-completions ()
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
140 "Return completion alist of all current Environment elements."
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
141 (cond ((not (and br-feature-tags-file (file-exists-p br-feature-tags-file)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
142 (file-readable-p br-feature-tags-file)))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
143 nil)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
144 ((and br-feature-tags-completions
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
145 (eq
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
146 (car (cdr br-feature-tags-completions)) ;; tags last mod time
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
147 (apply '+ (nth 5 (file-attributes br-feature-tags-file))))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
148 (equal br-env-file (car br-feature-tags-completions)))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
149 (car (cdr (cdr br-feature-tags-completions))))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
150 (t
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
151 (let ((ftr-buf (get-buffer-create "*ftr-buf*"))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
152 (ftr-alist))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
153 (save-excursion
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
154 (br-feature-tags-init)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
155 (copy-to-buffer ftr-buf 1 (point-max))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
156 (set-buffer ftr-buf)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
157 (goto-char 1)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
158 (while (search-forward "\^L" nil t)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
159 (forward-line 1)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
160 ;; Skip past pathname where features are defined.
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
161 (while (and (= (forward-line 1) 0)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
162 (not (looking-at "\^L\\|\\'")))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
163 (setq ftr-alist (cons (cons (br-feature-signature-to-name
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
164 (br-feature-current)
24
4103f0995bd7 Import from CVS: tag r19-15b95
cvs
parents: 0
diff changeset
165 t t)
0
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
166 nil)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
167 ftr-alist)))))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
168 (kill-buffer ftr-buf)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
169 (setq br-feature-tags-completions
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
170 (list br-env-file
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
171 ;; tags last mod time
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
172 (apply '+ (nth 5 (file-attributes
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
173 br-feature-tags-file)))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
174 ftr-alist))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
175 ftr-alist))))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
176
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
177 (defun br-feature-def-file (feature-regexp)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
178 "Return file name in which feature matching FEATURE-REGEXP is, if any.
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
179 Assume feature tags file is current buffer and leave point at the start of
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
180 matching feature tag, if any."
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
181 (goto-char 1)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
182 (and (re-search-forward feature-regexp nil t)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
183 ;; This ensures that point is left on the same line as the feature tag
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
184 ;; which is found.
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
185 (goto-char (match-beginning 0))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
186 (br-feature-file-of-tag)))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
187
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
188 (defun br-feature-file (feature-sig)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
189 "Return file name in which feature matching FEATURE-SIG is, if any."
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
190 (let ((obuf (current-buffer))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
191 (file))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
192 (set-buffer (funcall br-find-file-noselect-function br-feature-tags-file))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
193 (goto-char 1)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
194 (if (search-forward feature-sig nil t)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
195 (setq file (br-feature-file-of-tag)))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
196 (set-buffer obuf)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
197 file))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
198
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
199 (defun br-feature-found-p (buf-file feature-tag
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
200 &optional deferred-class other-win regexp-flag)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
201 "Search BUF-FILE for FEATURE-TAG.
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
202 Return nil if not found, otherwise display it and return non-nil."
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
203 (if buf-file
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
204 (let ((found-def)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
205 (opoint (point))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
206 (prev-buf)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
207 (prev-point)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
208 (config (current-window-configuration)))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
209 (setq prev-buf (get-file-buffer buf-file))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
210 (funcall br-edit-file-function buf-file other-win)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
211 (setq prev-point (point))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
212 (widen)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
213 (goto-char (point-min))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
214 (setq found-def
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
215 (cond (deferred-class
24
4103f0995bd7 Import from CVS: tag r19-15b95
cvs
parents: 0
diff changeset
216 (br-feature-locate-p feature-tag deferred-class))
0
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
217 (regexp-flag
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
218 (br-feature-locate-p feature-tag regexp-flag))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
219 (t (br-feature-locate-p feature-tag))))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
220 (if found-def
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
221 ;; Set appropriate mode for file.
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
222 (br-major-mode)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
223 (setq buf-file (get-file-buffer buf-file))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
224 (if prev-buf
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
225 (goto-char prev-point)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
226 (if buf-file
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
227 (kill-buffer buf-file)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
228 (goto-char prev-point)))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
229 (set-window-configuration config)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
230 (goto-char opoint))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
231 found-def)))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
232
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
233 (defun br-feature-name (ftr-entry)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
234 "Return name part of FTR-ENTRY."
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
235 (if (equal (string-match br-feature-entry ftr-entry) 0)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
236 (substring ftr-entry (match-beginning 1))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
237 ""))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
238
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
239 (defun br-feature-signature-and-file (class-and-feature-name)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
240 "Return (feature signature . feature-def-file-name) of CLASS-AND-FEATURE-NAME."
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
241 (let ((obuf (current-buffer))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
242 ;; Find only exact matches
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
243 (name-regexp (br-feature-name-to-regexp class-and-feature-name))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
244 (result))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
245 (set-buffer (funcall br-find-file-noselect-function br-feature-tags-file))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
246 (goto-char 1)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
247 (if (re-search-forward name-regexp nil t)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
248 (progn (goto-char (match-beginning 0))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
249 (setq result (cons (br-feature-current)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
250 (br-feature-file-of-tag)))))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
251 (set-buffer obuf)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
252 result))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
253
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
254 (defun br-feature-signature (&optional arg)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
255 "Show full feature signature in the view window.
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
256 With optional prefix ARG, display signatures of all features from the current
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
257 buffer."
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
258 (interactive "P")
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
259 (let* ((buf (buffer-name))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
260 (owind (selected-window))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
261 (features (delq nil (if arg (br-feature-get-tags)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
262 (list (br-feature-get-signature))))))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
263 (if (null features)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
264 (progn (beep) (message "No elements."))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
265 (br-to-view-window)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
266 (switch-to-buffer (get-buffer-create (concat buf "-Elements")))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
267 (setq buffer-read-only nil)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
268 (erase-buffer)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
269 (mapcar (function (lambda (feature) (insert feature "\n")))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
270 features)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
271 (br-major-mode)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
272 (goto-char 1)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
273 (select-window owind)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
274 (message ""))))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
275
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
276 ;;; ************************************************************************
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
277 ;;; Listing buffer entry tag property handling.
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
278 ;;; ************************************************************************
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
279
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
280 (if (string-match "^19\." emacs-version)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
281 (progn
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
282 ;;
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
283 ;; Emacs 19 buffer entry tags functions
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
284 ;;
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
285
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
286 (defun br-feature-clear-signatures (&optional buf-nm)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
287 "Erase any feature signatures saved with current buffer or optional BUF-NM."
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
288 (save-excursion
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
289 (if buf-nm (set-buffer (get-buffer buf-nm)))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
290 (save-restriction
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
291 (widen)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
292 (remove-text-properties (point-min) (point-max) '(tag)))))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
293
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
294 (defun br-feature-get-signature (&optional line-num-minus-one)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
295 (save-excursion
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
296 (if (numberp line-num-minus-one)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
297 (goto-line (1+ line-num-minus-one)))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
298 (end-of-line)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
299 (car (cdr (memq 'tag (text-properties-at (1- (point))))))))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
300
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
301 (defun br-feature-get-tags ()
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
302 (save-excursion
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
303 (goto-char (point-max))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
304 (let ((found t)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
305 (tags)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
306 tag)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
307 (while found
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
308 (setq tag (get-text-property (1- (point)) 'tag))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
309 (if tag (setq tags (cons tag tags)))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
310 (setq found (= (forward-line -1) 0))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
311 (end-of-line))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
312 tags)))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
313
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
314 ;; Tag property is placed at end of line in case leading indent is
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
315 ;; removed by an OO-Browser operation. In that case, we don't want to
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
316 ;; lose the tag property.
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
317 (defun br-feature-put-signatures (ftr-sigs)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
318 (while ftr-sigs
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
319 (end-of-line)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
320 (put-text-property (- (point) 2) (point) 'tag (car ftr-sigs))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
321 (setq ftr-sigs (cdr ftr-sigs))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
322 (if (and ftr-sigs (/= (forward-line 1) 0))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
323 (error "(br-feature-put-signatures): Too few lines in this buffer"))))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
324
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
325 )
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
326
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
327 ;;
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
328 ;; Emacs 18 buffer entry tags functions
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
329 ;;
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
330
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
331 (defun br-feature-clear-signatures (&optional buf-nm)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
332 "Erase any feature signatures saved with current buffer or optional BUF-NM."
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
333 (put (intern (or buf-nm (buffer-name))) 'features nil))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
334
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
335 (defun br-feature-get-signature (&optional line-num)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
336 (or (numberp line-num)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
337 (save-excursion
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
338 (beginning-of-line)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
339 (setq line-num (count-lines 1 (point)))))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
340 (cdr (assq line-num (get (intern-soft (buffer-name)) 'features))))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
341
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
342 (defun br-feature-get-tags ()
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
343 (get (intern-soft (buffer-name)) 'features))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
344
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
345 (defun br-feature-put-signatures (ftr-sigs)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
346 (beginning-of-line)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
347 (let* ((line (count-lines 1 (point)))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
348 (meth-alist (mapcar (function
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
349 (lambda (meth)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
350 (prog1 (cons line meth)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
351 (setq line (1+ line)))))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
352 ftr-sigs))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
353 (buf-sym (intern (buffer-name))))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
354 (put buf-sym 'features
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
355 (nconc (get buf-sym 'features) meth-alist))))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
356 )
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
357
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
358 ;;; ************************************************************************
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
359 ;;; END - Listing buffer entry tag property handling.
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
360 ;;; ************************************************************************
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
361
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
362 (defun br-feature-tags-init ()
24
4103f0995bd7 Import from CVS: tag r19-15b95
cvs
parents: 0
diff changeset
363 "Set up `br-feature-tags-file' for writing."
0
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
364 (setq br-feature-tags-completions nil
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
365 br-feature-tags-file (br-feature-tags-file-name br-env-file)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
366 br-tags-file (concat br-env-file "-TAGS"))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
367 (set-buffer (funcall br-find-file-noselect-function br-feature-tags-file))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
368 (setq buffer-read-only nil))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
369
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
370 (defun br-feature-tags-file-name (env-file)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
371 (concat env-file "-FTR"))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
372
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
373 (defun br-feature-tags-save ()
24
4103f0995bd7 Import from CVS: tag r19-15b95
cvs
parents: 0
diff changeset
374 "Filter out extraneous lines and save `br-feature-tags-file'."
0
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
375 (let ((obuf (current-buffer)))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
376 (set-buffer (funcall br-find-file-noselect-function br-feature-tags-file))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
377 (goto-char (point-min))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
378 (delete-matching-lines "^[ \t]*$")
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
379 (goto-char (point-min))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
380 (replace-regexp "^[ \t]+\\|[ \t]+$" "")
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
381 (and br-c-tags-flag
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
382 (br-member br-lang-prefix '("c++-" "objc-"))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
383 (progn (c-build-element-tags)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
384 (goto-char (point-min))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
385 (replace-regexp "[ \t]*//.*" "")))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
386 (goto-char (point-min))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
387 (delete-matching-lines "^$")
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
388 (save-buffer)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
389 (set-buffer obuf)))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
390
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
391 (defun br-insert-features (feature-tag-list &optional indent)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
392 "Insert feature names from FEATURE-TAG-LIST in current buffer indented INDENT columns."
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
393 (let ((start (point)))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
394 (mapcar (function
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
395 (lambda (feature-tag)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
396 (if indent (indent-to indent))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
397 (if feature-tag
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
398 (insert (br-feature-signature-to-name feature-tag nil t)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
399 "\n"))))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
400 feature-tag-list)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
401 (save-excursion
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
402 (goto-char start)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
403 (br-feature-put-signatures feature-tag-list))))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
404
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
405 ;;; ************************************************************************
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
406 ;;; Private functions
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
407 ;;; ************************************************************************
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
408
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
409 (defun br-feature-current ()
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
410 "Extract current feature from tags file and leave point at the end of line."
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
411 (beginning-of-line)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
412 (buffer-substring (point) (progn (end-of-line) (point))))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
413
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
414 (defun br-feature-file-of-tag ()
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
415 "Return the file name of the file whose tag point is within.
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
416 Assumes the tag table is the current buffer."
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
417 (save-excursion
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
418 (search-backward " " nil t)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
419 (forward-line 1)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
420 (let ((start (point)))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
421 (end-of-line)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
422 (buffer-substring start (point)))))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
423
24
4103f0995bd7 Import from CVS: tag r19-15b95
cvs
parents: 0
diff changeset
424 (defun br-feature-tag-and-file (feature-tag-regexp)
4103f0995bd7 Import from CVS: tag r19-15b95
cvs
parents: 0
diff changeset
425 "Return a cons (FEATURE-TAG . FEATURE-DEF-FILENAME) for the first tag match of FEATURE-TAG-REGEXP, or nil.
4103f0995bd7 Import from CVS: tag r19-15b95
cvs
parents: 0
diff changeset
426 Use br-feature-tag-regexp to create FEATURE-TAG-REGEXP.
4103f0995bd7 Import from CVS: tag r19-15b95
cvs
parents: 0
diff changeset
427 Feature tags come from the file named by br-feature-tags-file."
4103f0995bd7 Import from CVS: tag r19-15b95
cvs
parents: 0
diff changeset
428 (let ((obuf (current-buffer))
4103f0995bd7 Import from CVS: tag r19-15b95
cvs
parents: 0
diff changeset
429 result)
4103f0995bd7 Import from CVS: tag r19-15b95
cvs
parents: 0
diff changeset
430 (unwind-protect
4103f0995bd7 Import from CVS: tag r19-15b95
cvs
parents: 0
diff changeset
431 (progn
4103f0995bd7 Import from CVS: tag r19-15b95
cvs
parents: 0
diff changeset
432 (set-buffer (funcall br-find-file-noselect-function br-feature-tags-file))
4103f0995bd7 Import from CVS: tag r19-15b95
cvs
parents: 0
diff changeset
433 (setq result (br-feature-def-file feature-tag-regexp))
4103f0995bd7 Import from CVS: tag r19-15b95
cvs
parents: 0
diff changeset
434 (if result (cons (br-feature-current) result)))
4103f0995bd7 Import from CVS: tag r19-15b95
cvs
parents: 0
diff changeset
435 (set-buffer obuf))))
4103f0995bd7 Import from CVS: tag r19-15b95
cvs
parents: 0
diff changeset
436
0
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
437 ;;; ************************************************************************
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
438 ;;; Private variables
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
439 ;;; ************************************************************************
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
440
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
441 (defconst br-feature-entry
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
442 (concat br-feature-type-regexp " \\([^\t\n\r]*[^ \t\n\r]\\)")
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
443 "Regexp matching a feature entry in a browser listing buffer.")
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
444
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
445 (defvar br-feature-tags-completions nil
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
446 "List of (envir-name tags-file-last-mod-time tags-completion-alist).")
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
447
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
448 (defvar br-feature-tags-file nil
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
449 "Pathname where current object-oriented feature tags are stored.")
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
450
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
451 (defvar br-tags-file nil
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
452 "Pathname where current non-object-oriented feature tags are stored.")
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
453
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
454 (provide 'br-ftr)