annotate lisp/cc-mode/cc-menus.el @ 201:eb5470882647 r20-3b27

Import from CVS: tag r20-3b27
author cvs
date Mon, 13 Aug 2007 10:01:22 +0200
parents 489f57a838ef
children 850242ba4a81
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
171
929b76928fce Import from CVS: tag r20-3b12
cvs
parents: 165
diff changeset
1 ;;; cc-menus.el --- imenu support for CC Mode
165
5a88923fcbfe Import from CVS: tag r20-3b9
cvs
parents:
diff changeset
2
5a88923fcbfe Import from CVS: tag r20-3b9
cvs
parents:
diff changeset
3 ;; Copyright (C) 1985,87,92,93,94,95,96,97 Free Software Foundation, Inc.
5a88923fcbfe Import from CVS: tag r20-3b9
cvs
parents:
diff changeset
4
5a88923fcbfe Import from CVS: tag r20-3b9
cvs
parents:
diff changeset
5 ;; Authors: 1992-1997 Barry A. Warsaw
5a88923fcbfe Import from CVS: tag r20-3b9
cvs
parents:
diff changeset
6 ;; 1987 Dave Detlefs and Stewart Clamen
5a88923fcbfe Import from CVS: tag r20-3b9
cvs
parents:
diff changeset
7 ;; 1985 Richard M. Stallman
5a88923fcbfe Import from CVS: tag r20-3b9
cvs
parents:
diff changeset
8 ;; Maintainer: cc-mode-help@python.org
5a88923fcbfe Import from CVS: tag r20-3b9
cvs
parents:
diff changeset
9 ;; Created: 22-Apr-1997 (split from cc-mode.el)
189
489f57a838ef Import from CVS: tag r20-3b21
cvs
parents: 187
diff changeset
10 ;; Version: 5.18
165
5a88923fcbfe Import from CVS: tag r20-3b9
cvs
parents:
diff changeset
11 ;; Keywords: c languages oop
5a88923fcbfe Import from CVS: tag r20-3b9
cvs
parents:
diff changeset
12
5a88923fcbfe Import from CVS: tag r20-3b9
cvs
parents:
diff changeset
13 ;; This file is part of GNU Emacs.
5a88923fcbfe Import from CVS: tag r20-3b9
cvs
parents:
diff changeset
14
5a88923fcbfe Import from CVS: tag r20-3b9
cvs
parents:
diff changeset
15 ;; GNU Emacs is free software; you can redistribute it and/or modify
5a88923fcbfe Import from CVS: tag r20-3b9
cvs
parents:
diff changeset
16 ;; it under the terms of the GNU General Public License as published by
5a88923fcbfe Import from CVS: tag r20-3b9
cvs
parents:
diff changeset
17 ;; the Free Software Foundation; either version 2, or (at your option)
5a88923fcbfe Import from CVS: tag r20-3b9
cvs
parents:
diff changeset
18 ;; any later version.
5a88923fcbfe Import from CVS: tag r20-3b9
cvs
parents:
diff changeset
19
5a88923fcbfe Import from CVS: tag r20-3b9
cvs
parents:
diff changeset
20 ;; GNU Emacs is distributed in the hope that it will be useful,
5a88923fcbfe Import from CVS: tag r20-3b9
cvs
parents:
diff changeset
21 ;; but WITHOUT ANY WARRANTY; without even the implied warranty of
5a88923fcbfe Import from CVS: tag r20-3b9
cvs
parents:
diff changeset
22 ;; MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
5a88923fcbfe Import from CVS: tag r20-3b9
cvs
parents:
diff changeset
23 ;; GNU General Public License for more details.
5a88923fcbfe Import from CVS: tag r20-3b9
cvs
parents:
diff changeset
24
5a88923fcbfe Import from CVS: tag r20-3b9
cvs
parents:
diff changeset
25 ;; You should have received a copy of the GNU General Public License
5a88923fcbfe Import from CVS: tag r20-3b9
cvs
parents:
diff changeset
26 ;; along with GNU Emacs; see the file COPYING. If not, write to the
5a88923fcbfe Import from CVS: tag r20-3b9
cvs
parents:
diff changeset
27 ;; Free Software Foundation, Inc., 59 Temple Place - Suite 330,
5a88923fcbfe Import from CVS: tag r20-3b9
cvs
parents:
diff changeset
28 ;; Boston, MA 02111-1307, USA.
5a88923fcbfe Import from CVS: tag r20-3b9
cvs
parents:
diff changeset
29
5a88923fcbfe Import from CVS: tag r20-3b9
cvs
parents:
diff changeset
30
5a88923fcbfe Import from CVS: tag r20-3b9
cvs
parents:
diff changeset
31 ;; imenu integration
189
489f57a838ef Import from CVS: tag r20-3b21
cvs
parents: 187
diff changeset
32 (defvar cc-imenu-c-prototype-macro-regexp nil
489f57a838ef Import from CVS: tag r20-3b21
cvs
parents: 187
diff changeset
33 "RE matching macro names used to conditionally specify function prototypes.
489f57a838ef Import from CVS: tag r20-3b21
cvs
parents: 187
diff changeset
34
489f57a838ef Import from CVS: tag r20-3b21
cvs
parents: 187
diff changeset
35 For example:
489f57a838ef Import from CVS: tag r20-3b21
cvs
parents: 187
diff changeset
36
489f57a838ef Import from CVS: tag r20-3b21
cvs
parents: 187
diff changeset
37 #ifdef __STDC__
489f57a838ef Import from CVS: tag r20-3b21
cvs
parents: 187
diff changeset
38 #define _P(x) x
489f57a838ef Import from CVS: tag r20-3b21
cvs
parents: 187
diff changeset
39 #else
489f57a838ef Import from CVS: tag r20-3b21
cvs
parents: 187
diff changeset
40 #define _P(x) /*nothing*/
489f57a838ef Import from CVS: tag r20-3b21
cvs
parents: 187
diff changeset
41 #endif
489f57a838ef Import from CVS: tag r20-3b21
cvs
parents: 187
diff changeset
42
489f57a838ef Import from CVS: tag r20-3b21
cvs
parents: 187
diff changeset
43 int main _P( (int argc, char *argv[]) )
489f57a838ef Import from CVS: tag r20-3b21
cvs
parents: 187
diff changeset
44
489f57a838ef Import from CVS: tag r20-3b21
cvs
parents: 187
diff changeset
45 A sample value might look like: `\\(_P\\|_PROTO\\)'.")
489f57a838ef Import from CVS: tag r20-3b21
cvs
parents: 187
diff changeset
46
165
5a88923fcbfe Import from CVS: tag r20-3b9
cvs
parents:
diff changeset
47 (defvar cc-imenu-c++-generic-expression
5a88923fcbfe Import from CVS: tag r20-3b9
cvs
parents:
diff changeset
48 (`
189
489f57a838ef Import from CVS: tag r20-3b21
cvs
parents: 187
diff changeset
49 (
489f57a838ef Import from CVS: tag r20-3b21
cvs
parents: 187
diff changeset
50 ;; Try to match ::operator definitions first. Otherwise `X::operator new ()'
489f57a838ef Import from CVS: tag r20-3b21
cvs
parents: 187
diff changeset
51 ;; will be incorrectly recognised as function `new ()' because the regexps
489f57a838ef Import from CVS: tag r20-3b21
cvs
parents: 187
diff changeset
52 ;; work by backtracking from the end of the definition.
489f57a838ef Import from CVS: tag r20-3b21
cvs
parents: 187
diff changeset
53 (nil
165
5a88923fcbfe Import from CVS: tag r20-3b9
cvs
parents:
diff changeset
54 (,
5a88923fcbfe Import from CVS: tag r20-3b9
cvs
parents:
diff changeset
55 (concat
189
489f57a838ef Import from CVS: tag r20-3b21
cvs
parents: 187
diff changeset
56 "^\\<.*"
489f57a838ef Import from CVS: tag r20-3b21
cvs
parents: 187
diff changeset
57 "[^a-zA-Z0-9_:<>~]" ; match any non-identifier char
489f57a838ef Import from CVS: tag r20-3b21
cvs
parents: 187
diff changeset
58 ; (note: this can be `\n')
489f57a838ef Import from CVS: tag r20-3b21
cvs
parents: 187
diff changeset
59 "\\("
489f57a838ef Import from CVS: tag r20-3b21
cvs
parents: 187
diff changeset
60 "\\([a-zA-Z0-9_:<>~]*::\\)?" ; match an operator
489f57a838ef Import from CVS: tag r20-3b21
cvs
parents: 187
diff changeset
61 "operator\\>[ \t]*"
489f57a838ef Import from CVS: tag r20-3b21
cvs
parents: 187
diff changeset
62 "\\(()\\|[^(]*\\)" ; special case for `()' operator
489f57a838ef Import from CVS: tag r20-3b21
cvs
parents: 187
diff changeset
63 "\\)"
489f57a838ef Import from CVS: tag r20-3b21
cvs
parents: 187
diff changeset
64
489f57a838ef Import from CVS: tag r20-3b21
cvs
parents: 187
diff changeset
65 "[ \t]*([^)]*)[ \t]*[^ \t;]" ; followed by ws, arg list,
489f57a838ef Import from CVS: tag r20-3b21
cvs
parents: 187
diff changeset
66 ; require something other than
489f57a838ef Import from CVS: tag r20-3b21
cvs
parents: 187
diff changeset
67 ; a `;' after the (...) to
489f57a838ef Import from CVS: tag r20-3b21
cvs
parents: 187
diff changeset
68 ; avoid prototypes. Can't
489f57a838ef Import from CVS: tag r20-3b21
cvs
parents: 187
diff changeset
69 ; catch cases with () inside
489f57a838ef Import from CVS: tag r20-3b21
cvs
parents: 187
diff changeset
70 ; the parentheses surrounding
489f57a838ef Import from CVS: tag r20-3b21
cvs
parents: 187
diff changeset
71 ; the parameters. e.g.:
489f57a838ef Import from CVS: tag r20-3b21
cvs
parents: 187
diff changeset
72 ; `int foo(int a=bar()) {...}'
489f57a838ef Import from CVS: tag r20-3b21
cvs
parents: 187
diff changeset
73 )) 1)
489f57a838ef Import from CVS: tag r20-3b21
cvs
parents: 187
diff changeset
74 ;; Special case to match a line like `main() {}'
489f57a838ef Import from CVS: tag r20-3b21
cvs
parents: 187
diff changeset
75 ;; e.g. no return type, not even on the previous line.
489f57a838ef Import from CVS: tag r20-3b21
cvs
parents: 187
diff changeset
76 (nil
489f57a838ef Import from CVS: tag r20-3b21
cvs
parents: 187
diff changeset
77 (,
489f57a838ef Import from CVS: tag r20-3b21
cvs
parents: 187
diff changeset
78 (concat
489f57a838ef Import from CVS: tag r20-3b21
cvs
parents: 187
diff changeset
79 "^"
489f57a838ef Import from CVS: tag r20-3b21
cvs
parents: 187
diff changeset
80 "\\([a-zA-Z_][a-zA-Z0-9_:<>~]*\\)" ; match function name
489f57a838ef Import from CVS: tag r20-3b21
cvs
parents: 187
diff changeset
81 "[ \t]*([^)]*)[ \t]*[^ \t;]" ; see above
489f57a838ef Import from CVS: tag r20-3b21
cvs
parents: 187
diff changeset
82 )) 1)
489f57a838ef Import from CVS: tag r20-3b21
cvs
parents: 187
diff changeset
83 ;; Special case for definitions using phony prototype macros like:
489f57a838ef Import from CVS: tag r20-3b21
cvs
parents: 187
diff changeset
84 ;; `int main _PROTO( (int argc,char *argv[]) )'.
489f57a838ef Import from CVS: tag r20-3b21
cvs
parents: 187
diff changeset
85 ;; This case is only included if cc-imenu-c-prototype-macro-regexp is set.
489f57a838ef Import from CVS: tag r20-3b21
cvs
parents: 187
diff changeset
86 ;; Only supported in c-code, so no `:<>~' chars in function name!
489f57a838ef Import from CVS: tag r20-3b21
cvs
parents: 187
diff changeset
87 (,@ (if cc-imenu-c-prototype-macro-regexp
489f57a838ef Import from CVS: tag r20-3b21
cvs
parents: 187
diff changeset
88 (` ((nil
489f57a838ef Import from CVS: tag r20-3b21
cvs
parents: 187
diff changeset
89 (,
489f57a838ef Import from CVS: tag r20-3b21
cvs
parents: 187
diff changeset
90 (concat
489f57a838ef Import from CVS: tag r20-3b21
cvs
parents: 187
diff changeset
91 "^\\<.*" ; line MUST start with word char
489f57a838ef Import from CVS: tag r20-3b21
cvs
parents: 187
diff changeset
92 "[^a-zA-Z0-9_]" ; match any non-identifier char
489f57a838ef Import from CVS: tag r20-3b21
cvs
parents: 187
diff changeset
93 "\\([a-zA-Z_][a-zA-Z0-9_]*\\)" ; match function name
489f57a838ef Import from CVS: tag r20-3b21
cvs
parents: 187
diff changeset
94 "[ \t]*" ; whitespace before macro name
489f57a838ef Import from CVS: tag r20-3b21
cvs
parents: 187
diff changeset
95 cc-imenu-c-prototype-macro-regexp
489f57a838ef Import from CVS: tag r20-3b21
cvs
parents: 187
diff changeset
96 "[ \t]*(" ; ws followed by first paren.
489f57a838ef Import from CVS: tag r20-3b21
cvs
parents: 187
diff changeset
97 "[ \t]*([^)]*)[ \t]*[^ \t;]" ; see above
489f57a838ef Import from CVS: tag r20-3b21
cvs
parents: 187
diff changeset
98 )) 1)))))
489f57a838ef Import from CVS: tag r20-3b21
cvs
parents: 187
diff changeset
99 ;; General function name regexp
489f57a838ef Import from CVS: tag r20-3b21
cvs
parents: 187
diff changeset
100 (nil
489f57a838ef Import from CVS: tag r20-3b21
cvs
parents: 187
diff changeset
101 (,
489f57a838ef Import from CVS: tag r20-3b21
cvs
parents: 187
diff changeset
102 (concat
489f57a838ef Import from CVS: tag r20-3b21
cvs
parents: 187
diff changeset
103 "^\\<.*" ; line MUST start with word char
489f57a838ef Import from CVS: tag r20-3b21
cvs
parents: 187
diff changeset
104 "[^a-zA-Z0-9_:<>~]" ; match any non-identifier char
489f57a838ef Import from CVS: tag r20-3b21
cvs
parents: 187
diff changeset
105 "\\([a-zA-Z_][a-zA-Z0-9_:<>~]*\\)" ; match function name
489f57a838ef Import from CVS: tag r20-3b21
cvs
parents: 187
diff changeset
106 "[ \t]*([^)]*)[ \t]*[^ \t;]" ; see above
489f57a838ef Import from CVS: tag r20-3b21
cvs
parents: 187
diff changeset
107 )) 1)
489f57a838ef Import from CVS: tag r20-3b21
cvs
parents: 187
diff changeset
108 ;; Class definitions
165
5a88923fcbfe Import from CVS: tag r20-3b9
cvs
parents:
diff changeset
109 ("Class"
5a88923fcbfe Import from CVS: tag r20-3b9
cvs
parents:
diff changeset
110 (, (concat
189
489f57a838ef Import from CVS: tag r20-3b21
cvs
parents: 187
diff changeset
111 "^" ; beginning of line is required
489f57a838ef Import from CVS: tag r20-3b21
cvs
parents: 187
diff changeset
112 "\\(template[ \t]*<[^>]+>[ \t]*\\)?" ; there may be a `template <...>'
489f57a838ef Import from CVS: tag r20-3b21
cvs
parents: 187
diff changeset
113 "class[ \t]+"
489f57a838ef Import from CVS: tag r20-3b21
cvs
parents: 187
diff changeset
114 "\\([a-zA-Z0-9_]+\\)" ; the string we want to get
489f57a838ef Import from CVS: tag r20-3b21
cvs
parents: 187
diff changeset
115 "[ \t]*[:{]"
489f57a838ef Import from CVS: tag r20-3b21
cvs
parents: 187
diff changeset
116 )) 2)))
165
5a88923fcbfe Import from CVS: tag r20-3b9
cvs
parents:
diff changeset
117 "Imenu generic expression for C++ mode. See `imenu-generic-expression'.")
5a88923fcbfe Import from CVS: tag r20-3b9
cvs
parents:
diff changeset
118
5a88923fcbfe Import from CVS: tag r20-3b9
cvs
parents:
diff changeset
119 (defvar cc-imenu-c-generic-expression
5a88923fcbfe Import from CVS: tag r20-3b9
cvs
parents:
diff changeset
120 cc-imenu-c++-generic-expression
5a88923fcbfe Import from CVS: tag r20-3b9
cvs
parents:
diff changeset
121 "Imenu generic expression for C mode. See `imenu-generic-expression'.")
5a88923fcbfe Import from CVS: tag r20-3b9
cvs
parents:
diff changeset
122
5a88923fcbfe Import from CVS: tag r20-3b9
cvs
parents:
diff changeset
123 (defvar cc-imenu-java-generic-expression
5a88923fcbfe Import from CVS: tag r20-3b9
cvs
parents:
diff changeset
124 (`
5a88923fcbfe Import from CVS: tag r20-3b9
cvs
parents:
diff changeset
125 ((nil
5a88923fcbfe Import from CVS: tag r20-3b9
cvs
parents:
diff changeset
126 (,
5a88923fcbfe Import from CVS: tag r20-3b9
cvs
parents:
diff changeset
127 (concat
5a88923fcbfe Import from CVS: tag r20-3b9
cvs
parents:
diff changeset
128 "^\\([ \t]\\)*"
5a88923fcbfe Import from CVS: tag r20-3b9
cvs
parents:
diff changeset
129 "\\([A-Za-z0-9_-]+[ \t]+\\)?" ; type specs; there can be
5a88923fcbfe Import from CVS: tag r20-3b9
cvs
parents:
diff changeset
130 "\\([A-Za-z0-9_-]+[ \t]+\\)?" ; more than 3 tokens, right?
5a88923fcbfe Import from CVS: tag r20-3b9
cvs
parents:
diff changeset
131 "\\([A-Za-z0-9_-]+[ \t]*[[]?[]]?\\)"
5a88923fcbfe Import from CVS: tag r20-3b9
cvs
parents:
diff changeset
132 "\\([ \t]\\)"
5a88923fcbfe Import from CVS: tag r20-3b9
cvs
parents:
diff changeset
133 "\\([A-Za-z0-9_-]+\\)" ; the string we want to get
5a88923fcbfe Import from CVS: tag r20-3b9
cvs
parents:
diff changeset
134 "\\([ \t]*\\)+("
5a88923fcbfe Import from CVS: tag r20-3b9
cvs
parents:
diff changeset
135 "\\([a-zA-Z,_1-9\n \t]*[[]?[]]?\\)*" ; arguments
5a88923fcbfe Import from CVS: tag r20-3b9
cvs
parents:
diff changeset
136 ")[ \t]*"
189
489f57a838ef Import from CVS: tag r20-3b21
cvs
parents: 187
diff changeset
137 ; "[^;(]"
165
5a88923fcbfe Import from CVS: tag r20-3b9
cvs
parents:
diff changeset
138 "[,a-zA-Z_1-9\n \t]*{"
5a88923fcbfe Import from CVS: tag r20-3b9
cvs
parents:
diff changeset
139 )) 6)))
5a88923fcbfe Import from CVS: tag r20-3b9
cvs
parents:
diff changeset
140 "Imenu generic expression for Java mode. See `imenu-generic-expression'.")
5a88923fcbfe Import from CVS: tag r20-3b9
cvs
parents:
diff changeset
141
189
489f57a838ef Import from CVS: tag r20-3b21
cvs
parents: 187
diff changeset
142 (defvar cc-imenu-objc-generic-expression
489f57a838ef Import from CVS: tag r20-3b21
cvs
parents: 187
diff changeset
143 (concat
489f57a838ef Import from CVS: tag r20-3b21
cvs
parents: 187
diff changeset
144 ;; For C
489f57a838ef Import from CVS: tag r20-3b21
cvs
parents: 187
diff changeset
145 ;; Pick a token by (match-string 6)
489f57a838ef Import from CVS: tag r20-3b21
cvs
parents: 187
diff changeset
146 (car (cdr (car cc-imenu-c++-generic-expression)))
489f57a838ef Import from CVS: tag r20-3b21
cvs
parents: 187
diff changeset
147 ;; For Objective-C
489f57a838ef Import from CVS: tag r20-3b21
cvs
parents: 187
diff changeset
148 ;; Pick a token by (match-string 8)
489f57a838ef Import from CVS: tag r20-3b21
cvs
parents: 187
diff changeset
149 "\\|\\("
489f57a838ef Import from CVS: tag r20-3b21
cvs
parents: 187
diff changeset
150 "^[-+][:a-zA-Z0-9()*_<>\n\t ]*[;{]" ; Methods
489f57a838ef Import from CVS: tag r20-3b21
cvs
parents: 187
diff changeset
151 "\\|"
489f57a838ef Import from CVS: tag r20-3b21
cvs
parents: 187
diff changeset
152 "^@interface[\t ]+[a-zA-Z0-9_]+[\t ]*:"
489f57a838ef Import from CVS: tag r20-3b21
cvs
parents: 187
diff changeset
153 "\\|"
489f57a838ef Import from CVS: tag r20-3b21
cvs
parents: 187
diff changeset
154 "^@interface[\t ]+[a-zA-Z0-9_]+[\t ]*([a-zA-Z0-9_]+)"
489f57a838ef Import from CVS: tag r20-3b21
cvs
parents: 187
diff changeset
155 "\\|"
489f57a838ef Import from CVS: tag r20-3b21
cvs
parents: 187
diff changeset
156 ;; For NSObject, NSProxy and Object... They don't have super class.
489f57a838ef Import from CVS: tag r20-3b21
cvs
parents: 187
diff changeset
157 "^@interface[\t ]+[a-zA-Z0-9_]+[\t ]*.*$"
489f57a838ef Import from CVS: tag r20-3b21
cvs
parents: 187
diff changeset
158 "\\|"
489f57a838ef Import from CVS: tag r20-3b21
cvs
parents: 187
diff changeset
159 "^@implementation[\t ]+[a-zA-Z0-9_]+[\t ]*([a-zA-Z0-9_]+)"
489f57a838ef Import from CVS: tag r20-3b21
cvs
parents: 187
diff changeset
160 "\\|"
489f57a838ef Import from CVS: tag r20-3b21
cvs
parents: 187
diff changeset
161 "^@implementation[\t ]+[a-zA-Z0-9_]+"
489f57a838ef Import from CVS: tag r20-3b21
cvs
parents: 187
diff changeset
162 "\\|"
489f57a838ef Import from CVS: tag r20-3b21
cvs
parents: 187
diff changeset
163 "^@protocol[\t ]+[a-zA-Z0-9_]+" "\\)")
489f57a838ef Import from CVS: tag r20-3b21
cvs
parents: 187
diff changeset
164 "Imenu generic expression for ObjC mode. See `imenu-generic-expression'.")
489f57a838ef Import from CVS: tag r20-3b21
cvs
parents: 187
diff changeset
165
489f57a838ef Import from CVS: tag r20-3b21
cvs
parents: 187
diff changeset
166
489f57a838ef Import from CVS: tag r20-3b21
cvs
parents: 187
diff changeset
167 ;; Imenu support for objective-c uses functions.
489f57a838ef Import from CVS: tag r20-3b21
cvs
parents: 187
diff changeset
168 (defsubst cc-imenu-objc-method-to-selector (method)
489f57a838ef Import from CVS: tag r20-3b21
cvs
parents: 187
diff changeset
169 "Return the objc selector style string of METHOD.
489f57a838ef Import from CVS: tag r20-3b21
cvs
parents: 187
diff changeset
170 Example:
489f57a838ef Import from CVS: tag r20-3b21
cvs
parents: 187
diff changeset
171 - perform: (SEL)aSelector withObject: object1 withObject: object2; /* METHOD */
489f57a838ef Import from CVS: tag r20-3b21
cvs
parents: 187
diff changeset
172 =>
489f57a838ef Import from CVS: tag r20-3b21
cvs
parents: 187
diff changeset
173 -perform:withObject:withObject:withObject: /* selector */"
489f57a838ef Import from CVS: tag r20-3b21
cvs
parents: 187
diff changeset
174 (let ((return "") ; String to be returned
489f57a838ef Import from CVS: tag r20-3b21
cvs
parents: 187
diff changeset
175 (p 0) ; Current scanning position in METHOD
489f57a838ef Import from CVS: tag r20-3b21
cvs
parents: 187
diff changeset
176 (pmax (length method)) ;
489f57a838ef Import from CVS: tag r20-3b21
cvs
parents: 187
diff changeset
177 char ; Current scanning target
489f57a838ef Import from CVS: tag r20-3b21
cvs
parents: 187
diff changeset
178 (betweenparen 0) ; CHAR is in parentheses.
489f57a838ef Import from CVS: tag r20-3b21
cvs
parents: 187
diff changeset
179 argreq ; An argument is required.
489f57a838ef Import from CVS: tag r20-3b21
cvs
parents: 187
diff changeset
180 inargvar) ; position of CHAR is in an argument variable.
489f57a838ef Import from CVS: tag r20-3b21
cvs
parents: 187
diff changeset
181 (while (< p pmax)
489f57a838ef Import from CVS: tag r20-3b21
cvs
parents: 187
diff changeset
182 (setq char (aref method p)
489f57a838ef Import from CVS: tag r20-3b21
cvs
parents: 187
diff changeset
183 p (1+ p))
489f57a838ef Import from CVS: tag r20-3b21
cvs
parents: 187
diff changeset
184 (cond
489f57a838ef Import from CVS: tag r20-3b21
cvs
parents: 187
diff changeset
185 ;; Is CHAR part of a objc token?
489f57a838ef Import from CVS: tag r20-3b21
cvs
parents: 187
diff changeset
186 ((and (not inargvar) ; Ignore if CHAR is part of an argument variable.
489f57a838ef Import from CVS: tag r20-3b21
cvs
parents: 187
diff changeset
187 (eq 0 betweenparen) ; Ignore if CHAR is in parentheses.
489f57a838ef Import from CVS: tag r20-3b21
cvs
parents: 187
diff changeset
188 (or (and (<= ?a char) (<= char ?z))
489f57a838ef Import from CVS: tag r20-3b21
cvs
parents: 187
diff changeset
189 (and (<= ?A char) (<= char ?Z))
489f57a838ef Import from CVS: tag r20-3b21
cvs
parents: 187
diff changeset
190 (and (<= ?0 char) (<= char ?9))
489f57a838ef Import from CVS: tag r20-3b21
cvs
parents: 187
diff changeset
191 (= ?_ char)))
489f57a838ef Import from CVS: tag r20-3b21
cvs
parents: 187
diff changeset
192 (if argreq
489f57a838ef Import from CVS: tag r20-3b21
cvs
parents: 187
diff changeset
193 (setq inargvar t
489f57a838ef Import from CVS: tag r20-3b21
cvs
parents: 187
diff changeset
194 argreq nil)
489f57a838ef Import from CVS: tag r20-3b21
cvs
parents: 187
diff changeset
195 (setq return (concat return (char-to-string char)))))
489f57a838ef Import from CVS: tag r20-3b21
cvs
parents: 187
diff changeset
196 ;; Or a white space?
489f57a838ef Import from CVS: tag r20-3b21
cvs
parents: 187
diff changeset
197 ((and inargvar (or (eq ?\ char) (eq ?\n char))
489f57a838ef Import from CVS: tag r20-3b21
cvs
parents: 187
diff changeset
198 (setq inargvar nil)))
489f57a838ef Import from CVS: tag r20-3b21
cvs
parents: 187
diff changeset
199 ;; Or a method separator?
489f57a838ef Import from CVS: tag r20-3b21
cvs
parents: 187
diff changeset
200 ;; If a method separator, the next token will be an argument variable.
489f57a838ef Import from CVS: tag r20-3b21
cvs
parents: 187
diff changeset
201 ((eq ?: char)
489f57a838ef Import from CVS: tag r20-3b21
cvs
parents: 187
diff changeset
202 (setq argreq t
489f57a838ef Import from CVS: tag r20-3b21
cvs
parents: 187
diff changeset
203 return (concat return (char-to-string char))))
489f57a838ef Import from CVS: tag r20-3b21
cvs
parents: 187
diff changeset
204 ;; Or an open parentheses?
489f57a838ef Import from CVS: tag r20-3b21
cvs
parents: 187
diff changeset
205 ((eq ?\( char)
489f57a838ef Import from CVS: tag r20-3b21
cvs
parents: 187
diff changeset
206 (setq betweenparen (1+ betweenparen)))
489f57a838ef Import from CVS: tag r20-3b21
cvs
parents: 187
diff changeset
207 ;; Or a close parentheses?
489f57a838ef Import from CVS: tag r20-3b21
cvs
parents: 187
diff changeset
208 ((eq ?\) char)
489f57a838ef Import from CVS: tag r20-3b21
cvs
parents: 187
diff changeset
209 (setq betweenparen (1- betweenparen)))))
489f57a838ef Import from CVS: tag r20-3b21
cvs
parents: 187
diff changeset
210 return))
489f57a838ef Import from CVS: tag r20-3b21
cvs
parents: 187
diff changeset
211
489f57a838ef Import from CVS: tag r20-3b21
cvs
parents: 187
diff changeset
212 (defun cc-imenu-objc-remove-white-space (str)
489f57a838ef Import from CVS: tag r20-3b21
cvs
parents: 187
diff changeset
213 "Remove all spaces and tabs from STR."
489f57a838ef Import from CVS: tag r20-3b21
cvs
parents: 187
diff changeset
214 (let ((return "")
489f57a838ef Import from CVS: tag r20-3b21
cvs
parents: 187
diff changeset
215 (p 0)
489f57a838ef Import from CVS: tag r20-3b21
cvs
parents: 187
diff changeset
216 (max (length str))
489f57a838ef Import from CVS: tag r20-3b21
cvs
parents: 187
diff changeset
217 char)
489f57a838ef Import from CVS: tag r20-3b21
cvs
parents: 187
diff changeset
218 (while (< p max)
489f57a838ef Import from CVS: tag r20-3b21
cvs
parents: 187
diff changeset
219 (setq char (aref str p))
489f57a838ef Import from CVS: tag r20-3b21
cvs
parents: 187
diff changeset
220 (setq p (1+ p))
489f57a838ef Import from CVS: tag r20-3b21
cvs
parents: 187
diff changeset
221 (if (or (= char ?\ ) (= char ?\t))
489f57a838ef Import from CVS: tag r20-3b21
cvs
parents: 187
diff changeset
222 ()
489f57a838ef Import from CVS: tag r20-3b21
cvs
parents: 187
diff changeset
223 (setq return (concat return (char-to-string char)))))
489f57a838ef Import from CVS: tag r20-3b21
cvs
parents: 187
diff changeset
224 return))
489f57a838ef Import from CVS: tag r20-3b21
cvs
parents: 187
diff changeset
225
489f57a838ef Import from CVS: tag r20-3b21
cvs
parents: 187
diff changeset
226 (defun cc-imenu-objc-function ()
489f57a838ef Import from CVS: tag r20-3b21
cvs
parents: 187
diff changeset
227 "imenu supports for objc-mode."
489f57a838ef Import from CVS: tag r20-3b21
cvs
parents: 187
diff changeset
228 (let (methodlist
489f57a838ef Import from CVS: tag r20-3b21
cvs
parents: 187
diff changeset
229 clist
489f57a838ef Import from CVS: tag r20-3b21
cvs
parents: 187
diff changeset
230 (C 6)
489f57a838ef Import from CVS: tag r20-3b21
cvs
parents: 187
diff changeset
231 (OBJC 8)
489f57a838ef Import from CVS: tag r20-3b21
cvs
parents: 187
diff changeset
232 langnum
489f57a838ef Import from CVS: tag r20-3b21
cvs
parents: 187
diff changeset
233 (classcount 0)
489f57a838ef Import from CVS: tag r20-3b21
cvs
parents: 187
diff changeset
234 toplist
489f57a838ef Import from CVS: tag r20-3b21
cvs
parents: 187
diff changeset
235 stupid
489f57a838ef Import from CVS: tag r20-3b21
cvs
parents: 187
diff changeset
236 str
489f57a838ef Import from CVS: tag r20-3b21
cvs
parents: 187
diff changeset
237 str2
489f57a838ef Import from CVS: tag r20-3b21
cvs
parents: 187
diff changeset
238 (intflen (length "@interface"))
489f57a838ef Import from CVS: tag r20-3b21
cvs
parents: 187
diff changeset
239 (implen (length "@implementation"))
489f57a838ef Import from CVS: tag r20-3b21
cvs
parents: 187
diff changeset
240 (prtlen (length "@protocol"))
489f57a838ef Import from CVS: tag r20-3b21
cvs
parents: 187
diff changeset
241 bufsubst-fun)
489f57a838ef Import from CVS: tag r20-3b21
cvs
parents: 187
diff changeset
242 ;;
489f57a838ef Import from CVS: tag r20-3b21
cvs
parents: 187
diff changeset
243 ;; Does this emacs has buffer-substring-no-properties?
489f57a838ef Import from CVS: tag r20-3b21
cvs
parents: 187
diff changeset
244 ;;
489f57a838ef Import from CVS: tag r20-3b21
cvs
parents: 187
diff changeset
245 (fset 'bufsubst-fun (if (fboundp 'buffer-substring-no-properties)
489f57a838ef Import from CVS: tag r20-3b21
cvs
parents: 187
diff changeset
246 (symbol-function 'buffer-substring-no-properties)
489f57a838ef Import from CVS: tag r20-3b21
cvs
parents: 187
diff changeset
247 (symbol-function 'buffer-substring)))
489f57a838ef Import from CVS: tag r20-3b21
cvs
parents: 187
diff changeset
248 (goto-char (point-max))
489f57a838ef Import from CVS: tag r20-3b21
cvs
parents: 187
diff changeset
249 (imenu-progress-message stupid 0)
489f57a838ef Import from CVS: tag r20-3b21
cvs
parents: 187
diff changeset
250 ;;
489f57a838ef Import from CVS: tag r20-3b21
cvs
parents: 187
diff changeset
251 (while (re-search-backward cc-imenu-objc-generic-expression nil t)
489f57a838ef Import from CVS: tag r20-3b21
cvs
parents: 187
diff changeset
252 (imenu-progress-message stupid)
489f57a838ef Import from CVS: tag r20-3b21
cvs
parents: 187
diff changeset
253 (setq langnum (if (match-beginning C) C OBJC))
489f57a838ef Import from CVS: tag r20-3b21
cvs
parents: 187
diff changeset
254 (setq str (bufsubst-fun (match-beginning langnum) (match-end langnum)))
489f57a838ef Import from CVS: tag r20-3b21
cvs
parents: 187
diff changeset
255 ;;
489f57a838ef Import from CVS: tag r20-3b21
cvs
parents: 187
diff changeset
256 (cond
489f57a838ef Import from CVS: tag r20-3b21
cvs
parents: 187
diff changeset
257 ;;
489f57a838ef Import from CVS: tag r20-3b21
cvs
parents: 187
diff changeset
258 ;; C
489f57a838ef Import from CVS: tag r20-3b21
cvs
parents: 187
diff changeset
259 ;;
489f57a838ef Import from CVS: tag r20-3b21
cvs
parents: 187
diff changeset
260 ((eq langnum C)
489f57a838ef Import from CVS: tag r20-3b21
cvs
parents: 187
diff changeset
261 (setq clist (cons (cons str (match-beginning langnum)) clist)))
489f57a838ef Import from CVS: tag r20-3b21
cvs
parents: 187
diff changeset
262 ;;
489f57a838ef Import from CVS: tag r20-3b21
cvs
parents: 187
diff changeset
263 ;; ObjC
489f57a838ef Import from CVS: tag r20-3b21
cvs
parents: 187
diff changeset
264 ;;
489f57a838ef Import from CVS: tag r20-3b21
cvs
parents: 187
diff changeset
265 ;; An instance Method
489f57a838ef Import from CVS: tag r20-3b21
cvs
parents: 187
diff changeset
266 ((eq (aref str 0) ?-)
489f57a838ef Import from CVS: tag r20-3b21
cvs
parents: 187
diff changeset
267 (setq str (concat "-" (cc-imenu-objc-method-to-selector str)))
489f57a838ef Import from CVS: tag r20-3b21
cvs
parents: 187
diff changeset
268 (setq methodlist (cons (cons str
489f57a838ef Import from CVS: tag r20-3b21
cvs
parents: 187
diff changeset
269 (match-beginning langnum))
489f57a838ef Import from CVS: tag r20-3b21
cvs
parents: 187
diff changeset
270 methodlist)))
489f57a838ef Import from CVS: tag r20-3b21
cvs
parents: 187
diff changeset
271 ;; A factory Method
489f57a838ef Import from CVS: tag r20-3b21
cvs
parents: 187
diff changeset
272 ((eq (aref str 0) ?+)
489f57a838ef Import from CVS: tag r20-3b21
cvs
parents: 187
diff changeset
273 (setq str (concat "+" (cc-imenu-objc-method-to-selector str)))
489f57a838ef Import from CVS: tag r20-3b21
cvs
parents: 187
diff changeset
274 (setq methodlist (cons (cons str
489f57a838ef Import from CVS: tag r20-3b21
cvs
parents: 187
diff changeset
275 (match-beginning langnum))
489f57a838ef Import from CVS: tag r20-3b21
cvs
parents: 187
diff changeset
276 methodlist)))
489f57a838ef Import from CVS: tag r20-3b21
cvs
parents: 187
diff changeset
277 ;; Interface or implementation or protocol
489f57a838ef Import from CVS: tag r20-3b21
cvs
parents: 187
diff changeset
278 ((eq (aref str 0) ?@)
489f57a838ef Import from CVS: tag r20-3b21
cvs
parents: 187
diff changeset
279 (setq classcount (1+ classcount))
489f57a838ef Import from CVS: tag r20-3b21
cvs
parents: 187
diff changeset
280 (cond
489f57a838ef Import from CVS: tag r20-3b21
cvs
parents: 187
diff changeset
281 ((and (> (length str) implen)
489f57a838ef Import from CVS: tag r20-3b21
cvs
parents: 187
diff changeset
282 (string= (substring str 0 implen) "@implementation"))
489f57a838ef Import from CVS: tag r20-3b21
cvs
parents: 187
diff changeset
283 (setq str (substring str implen)
489f57a838ef Import from CVS: tag r20-3b21
cvs
parents: 187
diff changeset
284 str2 "@implementation"))
489f57a838ef Import from CVS: tag r20-3b21
cvs
parents: 187
diff changeset
285 ((string= (substring str 0 intflen) "@interface")
489f57a838ef Import from CVS: tag r20-3b21
cvs
parents: 187
diff changeset
286 (setq str (substring str intflen)
489f57a838ef Import from CVS: tag r20-3b21
cvs
parents: 187
diff changeset
287 str2 "@interface"))
489f57a838ef Import from CVS: tag r20-3b21
cvs
parents: 187
diff changeset
288 ((string= (substring str 0 prtlen) "@protocol")
489f57a838ef Import from CVS: tag r20-3b21
cvs
parents: 187
diff changeset
289 (setq str (substring str prtlen)
489f57a838ef Import from CVS: tag r20-3b21
cvs
parents: 187
diff changeset
290 str2 "@protocol")))
489f57a838ef Import from CVS: tag r20-3b21
cvs
parents: 187
diff changeset
291 (setq str (cc-imenu-objc-remove-white-space str))
489f57a838ef Import from CVS: tag r20-3b21
cvs
parents: 187
diff changeset
292 (setq methodlist (cons (cons str2
489f57a838ef Import from CVS: tag r20-3b21
cvs
parents: 187
diff changeset
293 (match-beginning langnum))
489f57a838ef Import from CVS: tag r20-3b21
cvs
parents: 187
diff changeset
294 methodlist))
489f57a838ef Import from CVS: tag r20-3b21
cvs
parents: 187
diff changeset
295 (setq toplist (cons nil (cons (cons str
489f57a838ef Import from CVS: tag r20-3b21
cvs
parents: 187
diff changeset
296 methodlist) toplist))
489f57a838ef Import from CVS: tag r20-3b21
cvs
parents: 187
diff changeset
297 methodlist nil))))
489f57a838ef Import from CVS: tag r20-3b21
cvs
parents: 187
diff changeset
298 ;;
489f57a838ef Import from CVS: tag r20-3b21
cvs
parents: 187
diff changeset
299 (imenu-progress-message stupid 100)
489f57a838ef Import from CVS: tag r20-3b21
cvs
parents: 187
diff changeset
300 (if (eq (car toplist) nil)
489f57a838ef Import from CVS: tag r20-3b21
cvs
parents: 187
diff changeset
301 (setq toplist (cdr toplist)))
489f57a838ef Import from CVS: tag r20-3b21
cvs
parents: 187
diff changeset
302
489f57a838ef Import from CVS: tag r20-3b21
cvs
parents: 187
diff changeset
303 ;; In this buffer, there is only one or zero @{interface|implementation|protocol}.
489f57a838ef Import from CVS: tag r20-3b21
cvs
parents: 187
diff changeset
304 (if (< classcount 2)
489f57a838ef Import from CVS: tag r20-3b21
cvs
parents: 187
diff changeset
305 (let ((classname (car (car toplist)))
489f57a838ef Import from CVS: tag r20-3b21
cvs
parents: 187
diff changeset
306 (p (cdr (car (cdr (car toplist)))))
489f57a838ef Import from CVS: tag r20-3b21
cvs
parents: 187
diff changeset
307 last)
489f57a838ef Import from CVS: tag r20-3b21
cvs
parents: 187
diff changeset
308 (setq toplist (cons (cons classname p) (cdr (cdr (car toplist)))))
489f57a838ef Import from CVS: tag r20-3b21
cvs
parents: 187
diff changeset
309 ;; Add C lang token
489f57a838ef Import from CVS: tag r20-3b21
cvs
parents: 187
diff changeset
310 (if clist
489f57a838ef Import from CVS: tag r20-3b21
cvs
parents: 187
diff changeset
311 (progn
489f57a838ef Import from CVS: tag r20-3b21
cvs
parents: 187
diff changeset
312 (setq last toplist)
489f57a838ef Import from CVS: tag r20-3b21
cvs
parents: 187
diff changeset
313 (while (cdr last)
489f57a838ef Import from CVS: tag r20-3b21
cvs
parents: 187
diff changeset
314 (setq last (cdr last)))
489f57a838ef Import from CVS: tag r20-3b21
cvs
parents: 187
diff changeset
315 (setcdr last clist))))
489f57a838ef Import from CVS: tag r20-3b21
cvs
parents: 187
diff changeset
316 ;; Add C lang tokens as a sub menu
489f57a838ef Import from CVS: tag r20-3b21
cvs
parents: 187
diff changeset
317 (setq toplist (cons (cons "C" clist) toplist)))
489f57a838ef Import from CVS: tag r20-3b21
cvs
parents: 187
diff changeset
318 ;;
489f57a838ef Import from CVS: tag r20-3b21
cvs
parents: 187
diff changeset
319 toplist
489f57a838ef Import from CVS: tag r20-3b21
cvs
parents: 187
diff changeset
320 ))
489f57a838ef Import from CVS: tag r20-3b21
cvs
parents: 187
diff changeset
321
165
5a88923fcbfe Import from CVS: tag r20-3b9
cvs
parents:
diff changeset
322
5a88923fcbfe Import from CVS: tag r20-3b9
cvs
parents:
diff changeset
323 (provide 'cc-menus)
5a88923fcbfe Import from CVS: tag r20-3b9
cvs
parents:
diff changeset
324 ;;; cc-menus.el ends here