1 ;;; cc-mode.el --- major mode for editing C, C++, Objective-C, and Java code
3 ;; Copyright (C) 1985,1987,1992-2000 Free Software Foundation, Inc.
5 ;; Authors: 2000- Martin Stjernholm
6 ;; 1998-1999 Barry A. Warsaw and Martin Stjernholm
7 ;; 1992-1997 Barry A. Warsaw
8 ;; 1987 Dave Detlefs and Stewart Clamen
9 ;; 1985 Richard M. Stallman
10 ;; Maintainer: bug-cc-mode@gnu.org
11 ;; Created: a long, long, time ago. adapted from the original c-mode.el
12 ;; Keywords: c languages oop
14 (defconst c-version
"5.27"
15 "CC Mode version number.")
17 ;; NOTE: Read the commentary below for the right way to submit bug reports!
18 ;; NOTE: See the accompanying texinfo manual for details on using this mode!
20 ;; This file is part of GNU Emacs.
22 ;; GNU Emacs is free software; you can redistribute it and/or modify
23 ;; it under the terms of the GNU General Public License as published by
24 ;; the Free Software Foundation; either version 2, or (at your option)
27 ;; GNU Emacs is distributed in the hope that it will be useful,
28 ;; but WITHOUT ANY WARRANTY; without even the implied warranty of
29 ;; MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
30 ;; GNU General Public License for more details.
32 ;; You should have received a copy of the GNU General Public License
33 ;; along with GNU Emacs; see the file COPYING. If not, write to the
34 ;; Free Software Foundation, Inc., 59 Temple Place - Suite 330,
35 ;; Boston, MA 02111-1307, USA.
39 ;; This package provides GNU Emacs major modes for editing C, C++,
40 ;; Objective-C, Java, IDL and Pike code. As of the latest Emacs and
41 ;; XEmacs releases, it is the default package for editing these
42 ;; languages. This package is called "CC Mode", and should be spelled
45 ;; CC Mode supports K&R and ANSI C, ANSI C++, Objective-C, Java,
46 ;; CORBA's IDL, and Pike with a consistent indentation model across
47 ;; all modes. This indentation model is intuitive and very flexible,
48 ;; so that almost any desired style of indentation can be supported.
49 ;; Installation, usage, and programming details are contained in an
50 ;; accompanying texinfo manual.
52 ;; CC Mode's immediate ancestors were, c++-mode.el, cplus-md.el, and
55 ;; NOTE: This mode does not perform font-locking (a.k.a syntactic
56 ;; coloring, keyword highlighting, etc.) for any of the supported
57 ;; modes. Typically this is done by a package called font-lock.el
58 ;; which we do *not* maintain. You should contact the Emacs or XEmacs
59 ;; maintainers for questions about coloring or highlighting in any
62 ;; To submit bug reports, type "C-c C-b". These will be sent to
63 ;; bug-gnu-emacs@gnu.org (mirrored as the Usenet newsgroup
64 ;; gnu.emacs.bug) as well as bug-cc-mode@gnu.org, which directly
65 ;; contacts the CC Mode maintainers. Questions can sent to
66 ;; help-gnu-emacs@gnu.org (mirrored as gnu.emacs.help) and/or
67 ;; bug-cc-mode@gnu.org. Please use bug-cc-mode@gnu.org instead.
68 ;; Please do not send bugs or questions to our personal accounts; we
69 ;; reserve the right to ignore such email!
71 ;; Many, many thanks go out to all the folks on the beta test list.
72 ;; Without their patience, testing, insight, code contributions, and
73 ;; encouragement CC Mode would be a far inferior package.
75 ;; You can get the latest version of CC Mode, including PostScript
76 ;; documentation and separate individual files from:
78 ;; http://cc-mode.sourceforge.net/
80 ;; You can join a moderated CC Mode announcement-only mailing list by
83 ;; http://lists.sourceforge.net/mailman/listinfo/cc-mode-announce
89 ;; Try to make sure the source directory is at the front of
90 ;; load-path when we load cc-defs.
91 (if (and (boundp 'byte-compile-current-file
)
92 (stringp byte-compile-current-file
))
93 ;; byte-compile-current-file is set by the byte compiler
94 ;; to the full path to this file.
95 (cons (file-name-directory byte-compile-current-file
)
98 ;; Load our version of cc-defs unconditionally, since an older
99 ;; version might very well be dumped in or already loaded. This
100 ;; way we ensure that the code is compiled with the correct macros
101 ;; and defsubsts. The same problem affects the subpackages that's
102 ;; require'd below, but that doesn't harm the compiler; it can
103 ;; only cause some bogus warnings.
104 (load "cc-defs" nil t
)))
106 (require 'cc-defs
) ; Not meaningless; this passes on require's from cc-defs.
116 ;; Other modes and packages which depend on CC Mode should do the
117 ;; following to make sure everything is loaded and available for their
120 ;; (require 'cc-mode)
121 ;; (c-initialize-cc-mode)
124 (defun c-initialize-cc-mode ()
125 (setq c-buffer-is-cc-mode t
)
126 (let ((initprop 'cc-mode-is-initialized
)
128 (unless (get 'c-initialize-cc-mode initprop
)
131 (put 'c-initialize-cc-mode initprop t
)
132 (c-initialize-builtin-style)
133 (run-hooks 'c-initialization-hook
)
134 ;; Fix obsolete variables.
135 (if (boundp 'c-comment-continuation-stars
)
136 (setq c-block-comment-prefix c-comment-continuation-stars
))
137 (setq c-initialization-ok t
))
138 ;; Will try initialization hooks again if they failed.
139 (put 'c-initialize-cc-mode initprop c-initialization-ok
)))
145 "Major mode for editing K&R and ANSI C code.
146 To submit a problem report, enter `\\[c-submit-bug-report]' from a
147 c-mode buffer. This automatically sets up a mail buffer with version
148 information already added. You just need to add a description of the
149 problem, including a reproducible test case and send the message.
151 To see what version of CC Mode you are running, enter `\\[c-version]'.
153 The hook variable `c-mode-hook' is run with no args, if that value is
154 bound and has a non-nil value. Also the hook `c-mode-common-hook' is
160 (c-initialize-cc-mode)
161 (kill-all-local-variables)
162 (set-syntax-table c-mode-syntax-table
)
163 (setq major-mode
'c-mode
165 local-abbrev-table c-mode-abbrev-table
)
166 (use-local-map c-mode-map
)
168 (setq comment-start
"/* "
170 c-conditional-key c-C-conditional-key
171 c-class-key c-C-class-key
173 c-comment-start-regexp c-C-comment-start-regexp
174 c-bitfield-key c-C-bitfield-key
176 (cc-imenu-init cc-imenu-c-generic-expression
)
177 (run-hooks 'c-mode-common-hook
)
178 (run-hooks 'c-mode-hook
)
184 "Major mode for editing C++ code.
185 To submit a problem report, enter `\\[c-submit-bug-report]' from a
186 c++-mode buffer. This automatically sets up a mail buffer with
187 version information already added. You just need to add a description
188 of the problem, including a reproducible test case, and send the
191 To see what version of CC Mode you are running, enter `\\[c-version]'.
193 The hook variable `c++-mode-hook' is run with no args, if that
194 variable is bound and has a non-nil value. Also the hook
195 `c-mode-common-hook' is run first.
200 (c-initialize-cc-mode)
201 (kill-all-local-variables)
202 (set-syntax-table c
++-mode-syntax-table
)
203 (setq major-mode
'c
++-mode
205 local-abbrev-table c
++-mode-abbrev-table
)
206 (use-local-map c
++-mode-map
)
208 (setq comment-start
"// "
210 c-conditional-key c-C
++-conditional-key
211 c-comment-start-regexp c-C
++-comment-start-regexp
212 c-class-key c-C
++-class-key
213 c-extra-toplevel-key c-C
++-extra-toplevel-key
214 c-access-key c-C
++-access-key
215 c-recognize-knr-p nil
216 c-bitfield-key c-C-bitfield-key
218 (cc-imenu-init cc-imenu-c
++-generic-expression
)
219 (run-hooks 'c-mode-common-hook
)
220 (run-hooks 'c
++-mode-hook
)
226 "Major mode for editing Objective C code.
227 To submit a problem report, enter `\\[c-submit-bug-report]' from an
228 objc-mode buffer. This automatically sets up a mail buffer with
229 version information already added. You just need to add a description
230 of the problem, including a reproducible test case, and send the
233 To see what version of CC Mode you are running, enter `\\[c-version]'.
235 The hook variable `objc-mode-hook' is run with no args, if that value
236 is bound and has a non-nil value. Also the hook `c-mode-common-hook'
242 (c-initialize-cc-mode)
243 (kill-all-local-variables)
244 (set-syntax-table objc-mode-syntax-table
)
245 (setq major-mode
'objc-mode
247 local-abbrev-table objc-mode-abbrev-table
)
248 (use-local-map objc-mode-map
)
250 (setq comment-start
"// "
252 c-conditional-key c-ObjC-conditional-key
253 c-comment-start-regexp c-ObjC-comment-start-regexp
254 c-class-key c-ObjC-class-key
256 c-access-key c-ObjC-access-key
257 c-method-key c-ObjC-method-key
259 (cc-imenu-init cc-imenu-objc-generic-expression
)
260 (run-hooks 'c-mode-common-hook
)
261 (run-hooks 'objc-mode-hook
)
267 "Major mode for editing Java code.
268 To submit a problem report, enter `\\[c-submit-bug-report]' from a
269 java-mode buffer. This automatically sets up a mail buffer with
270 version information already added. You just need to add a description
271 of the problem, including a reproducible test case and send the
274 To see what version of CC Mode you are running, enter `\\[c-version]'.
276 The hook variable `java-mode-hook' is run with no args, if that value
277 is bound and has a non-nil value. Also the common hook
278 `c-mode-common-hook' is run first. Note that this mode automatically
279 sets the \"java\" style before calling any hooks so be careful if you
280 set styles in `c-mode-common-hook'.
285 (c-initialize-cc-mode)
286 (kill-all-local-variables)
287 (set-syntax-table java-mode-syntax-table
)
288 (setq major-mode
'java-mode
290 local-abbrev-table java-mode-abbrev-table
291 c-append-paragraph-start c-Java-javadoc-paragraph-start
)
292 (use-local-map java-mode-map
)
294 (setq comment-start
"// "
296 c-conditional-key c-Java-conditional-key
297 c-comment-start-regexp c-Java-comment-start-regexp
298 c-class-key c-Java-class-key
301 c-recognize-knr-p nil
302 c-access-key c-Java-access-key
303 c-inexpr-class-key c-Java-inexpr-class-key
304 ;defun-prompt-regexp c-Java-defun-prompt-regexp
306 (cc-imenu-init cc-imenu-java-generic-expression
)
307 (run-hooks 'c-mode-common-hook
)
308 (run-hooks 'java-mode-hook
)
314 "Major mode for editing CORBA's IDL code.
315 To submit a problem report, enter `\\[c-submit-bug-report]' from an
316 idl-mode buffer. This automatically sets up a mail buffer with
317 version information already added. You just need to add a description
318 of the problem, including a reproducible test case, and send the
321 To see what version of CC Mode you are running, enter `\\[c-version]'.
323 The hook variable `idl-mode-hook' is run with no args, if that
324 variable is bound and has a non-nil value. Also the hook
325 `c-mode-common-hook' is run first.
330 (c-initialize-cc-mode)
331 (kill-all-local-variables)
332 (set-syntax-table idl-mode-syntax-table
)
333 (setq major-mode
'idl-mode
335 local-abbrev-table idl-mode-abbrev-table
)
336 (use-local-map idl-mode-map
)
338 (setq comment-start
"// "
340 c-conditional-key c-IDL-conditional-key
341 c-comment-start-regexp c-IDL-comment-start-regexp
342 c-class-key c-IDL-class-key
345 c-extra-toplevel-key c-IDL-extra-toplevel-key
346 c-access-key c-IDL-access-key
347 c-recognize-knr-p nil
349 ;;(cc-imenu-init cc-imenu-idl-generic-expression) ;FIXME
350 (run-hooks 'c-mode-common-hook
)
351 (run-hooks 'idl-mode-hook
)
357 "Major mode for editing Pike code.
358 To submit a problem report, enter `\\[c-submit-bug-report]' from an
359 idl-mode buffer. This automatically sets up a mail buffer with
360 version information already added. You just need to add a description
361 of the problem, including a reproducible test case, and send the
364 To see what version of CC Mode you are running, enter `\\[c-version]'.
366 The hook variable `pike-mode-hook' is run with no args, if that value
367 is bound and has a non-nil value. Also the common hook
368 `c-mode-common-hook' is run first.
373 (c-initialize-cc-mode)
374 (kill-all-local-variables)
375 (set-syntax-table pike-mode-syntax-table
)
376 (setq major-mode
'pike-mode
378 local-abbrev-table pike-mode-abbrev-table
)
379 (use-local-map pike-mode-map
)
381 (setq comment-start
"// "
383 c-conditional-key c-Pike-conditional-key
384 c-comment-start-regexp c-Pike-comment-start-regexp
385 c-class-key c-Pike-class-key
388 c-recognize-knr-p nil
389 c-access-key c-Pike-access-key
390 c-lambda-key c-Pike-lambda-key
391 c-inexpr-block-key c-Pike-inexpr-block-key
392 c-inexpr-class-key c-Pike-inexpr-class-key
393 c-special-brace-lists c-Pike-special-brace-lists
395 ;;(cc-imenu-init cc-imenu-pike-generic-expression) ;FIXME
396 (run-hooks 'c-mode-common-hook
)
397 (run-hooks 'pike-mode-hook
)
401 (defun c-setup-filladapt ()
402 "Convenience function to configure Kyle E. Jones' Filladapt mode for
403 CC Mode by making sure the proper entries are present on
404 `filladapt-token-table', `filladapt-token-match-table', and
405 `filladapt-token-conversion-table'. This is intended to be used on
406 `c-mode-common-hook' or similar."
407 ;; This function is intended to be used explicitly by the end user
410 ;; The default configuration already handles C++ comments, but we
411 ;; need to add handling of C block comments. A new filladapt token
412 ;; `c-comment' is added for that.
414 (setq p filladapt-token-table
)
415 (while (and p
(not (eq (car-safe (cdr-safe (car-safe p
))) 'c-comment
)))
416 (setq p
(cdr-safe p
)))
418 (setcar (car p
) c-comment-prefix-regexp
)
419 (setq filladapt-token-table
420 (append (list (car filladapt-token-table
)
421 (list c-comment-prefix-regexp
'c-comment
))
422 (cdr filladapt-token-table
)))))
423 (unless (assq 'c-comment filladapt-token-match-table
)
424 (setq filladapt-token-match-table
425 (append '((c-comment c-comment
))
426 filladapt-token-match-table
)))
427 (unless (assq 'c-comment filladapt-token-conversion-table
)
428 (setq filladapt-token-conversion-table
429 (append '((c-comment . exact
))
430 filladapt-token-conversion-table
))))
435 (defconst c-mode-help-address
436 "bug-gnu-emacs@gnu.org, bug-cc-mode@gnu.org"
437 "Addresses for CC Mode bug reports.")
440 "Echo the current version of CC Mode in the minibuffer."
442 (message "Using CC Mode version %s" c-version
)
443 (c-keep-region-active))
445 (defun c-submit-bug-report ()
446 "Submit via mail a bug report on CC Mode."
451 (let ((reporter-prompt-for-summary-p t
)
452 (reporter-dont-compact-list '(c-offsets-alist))
453 (style c-indentation-style
)
454 (hook c-special-indent-hook
)
455 (c-features c-emacs-features
))
457 (if (y-or-n-p "Do you want to submit a report on CC Mode? ")
460 (reporter-submit-bug-report
462 (concat "CC Mode " c-version
" ("
463 (cond ((eq major-mode
'c
++-mode
) "C++")
464 ((eq major-mode
'c-mode
) "C")
465 ((eq major-mode
'objc-mode
) "ObjC")
466 ((eq major-mode
'java-mode
) "Java")
467 ((eq major-mode
'idl-mode
) "IDL")
468 ((eq major-mode
'pike-mode
) "Pike")
472 ;; report only the vars that affect indentation
475 c-electric-pound-behavior
476 c-indent-comments-syntactically-p
481 parse-sexp-ignore-comments
482 ;; A brain-damaged XEmacs only variable that, if
483 ;; set to nil can cause all kinds of chaos.
484 signal-error-on-buffer-boundary
485 ;; Variables that affect line breaking and comments.
493 adaptive-fill-regexp
)
495 (delq 'c-special-indent-hook vars
)
496 (mapcar (lambda (var) (unless (boundp var
) (delq var vars
)))
497 '(signal-error-on-buffer-boundary
499 defun-prompt-regexp
))
504 "Buffer Style: " style
"\n\n"
505 (format "c-emacs-features: %s\n" c-features
)
511 ;;; cc-mode.el ends here