1 ;;; cc-mode.el --- major mode for editing C, C++, Objective-C, and Java code
3 ;; Copyright (C) 1985,1987,1992-1999 Free Software Foundation, Inc.
5 ;; Authors: 1998-1999 Barry A. Warsaw and Martin Stjernholm
6 ;; 1992-1997 Barry A. Warsaw
7 ;; 1987 Dave Detlefs and Stewart Clamen
8 ;; 1985 Richard M. Stallman
9 ;; Maintainer: bug-cc-mode@gnu.org
10 ;; Created: a long, long, time ago. adapted from the original c-mode.el
11 ;; Keywords: c languages oop
13 (defconst c-version "5.26e"
14 "CC Mode version number.")
16 ;; NOTE: Read the commentary below for the right way to submit bug reports!
17 ;; NOTE: See the accompanying texinfo manual for details on using this mode!
19 ;; This file is part of GNU Emacs.
21 ;; GNU Emacs is free software; you can redistribute it and/or modify
22 ;; it under the terms of the GNU General Public License as published by
23 ;; the Free Software Foundation; either version 2, or (at your option)
26 ;; GNU Emacs is distributed in the hope that it will be useful,
27 ;; but WITHOUT ANY WARRANTY; without even the implied warranty of
28 ;; MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
29 ;; GNU General Public License for more details.
31 ;; You should have received a copy of the GNU General Public License
32 ;; along with GNU Emacs; see the file COPYING. If not, write to the
33 ;; Free Software Foundation, Inc., 59 Temple Place - Suite 330,
34 ;; Boston, MA 02111-1307, USA.
38 ;; This package provides GNU Emacs major modes for editing C, C++,
39 ;; Objective-C, Java, IDL and Pike code. As of the latest Emacs and
40 ;; XEmacs releases, it is the default package for editing these
41 ;; languages. This package is called "CC Mode", and should be spelled
44 ;; CC Mode supports K&R and ANSI C, ANSI C++, Objective-C, Java,
45 ;; CORBA's IDL, and Pike with a consistent indentation model across
46 ;; all modes. This indentation model is intuitive and very flexible,
47 ;; so that almost any desired style of indentation can be supported.
48 ;; Installation, usage, and programming details are contained in an
49 ;; accompanying texinfo manual.
51 ;; CC Mode's immediate ancestors were, c++-mode.el, cplus-md.el, and
54 ;; NOTE: This mode does not perform font-locking (a.k.a syntactic
55 ;; coloring, keyword highlighting, etc.) for any of the supported
56 ;; modes. Typically this is done by a package called font-lock.el
57 ;; which we do *not* maintain. You should contact the Emacs or XEmacs
58 ;; maintainers for questions about coloring or highlighting in any
61 ;; To submit bug reports, type "C-c C-b". These will be sent to
62 ;; bug-gnu-emacs@gnu.org (mirrored as the Usenet newsgroup
63 ;; gnu.emacs.bug) as well as bug-cc-mode@gnu.org, which directly
64 ;; contacts the CC Mode maintainers. Questions can sent to
65 ;; help-gnu-emacs@gnu.org (mirrored as gnu.emacs.help) and/or
66 ;; bug-cc-mode@gnu.org. The old CC Mode contact address,
67 ;; cc-mode-help@python.org is currently still active, but its use is
68 ;; discouraged. Please use bug-cc-mode@gnu.org instead. Please do
69 ;; not send bugs or questions to our personal accounts; we reserve the
70 ;; right to ignore such email!
72 ;; Many, many thanks go out to all the folks on the beta test list.
73 ;; Without their patience, testing, insight, code contributions, and
74 ;; encouragement CC Mode would be a far inferior package.
76 ;; You can get the latest version of CC Mode, including PostScript
77 ;; documentation and separate individual files from:
79 ;; http://www.python.org/emacs/cc-mode/
81 ;; You can join a moderated CC Mode announcement-only mailing list by
84 ;; http://www.python.org/mailman/listinfo/cc-mode-announce
90 ;; Try to make sure the source directory is at the front of
91 ;; load-path when we load cc-defs.
92 (if (and (boundp 'byte-compile-current-file)
93 (stringp byte-compile-current-file))
94 ;; byte-compile-current-file is set by the byte compiler
95 ;; to the full path to this file.
96 (cons (file-name-directory byte-compile-current-file)
99 ;; Load our version of cc-defs unconditionally, since an older
100 ;; version might very well be dumped in or already loaded. This
101 ;; way we ensure that the code is compiled with the correct macros
102 ;; and defsubsts. The same problem affects the subpackages that's
103 ;; require'd below, but that doesn't harm the compiler; it can
104 ;; only cause some bogus warnings.
105 (load "cc-defs" nil t)))
107 (require 'cc-defs) ; Not meaningless; this passes on require's from cc-defs.
117 ;; Other modes and packages which depend on CC Mode should do the
118 ;; following to make sure everything is loaded and available for their
121 ;; (require 'cc-mode)
122 ;; (c-initialize-cc-mode)
125 (defun c-initialize-cc-mode ()
126 (setq c-buffer-is-cc-mode t)
127 (let ((initprop 'cc-mode-is-initialized)
129 (unless (get 'c-initialize-cc-mode initprop)
132 (put 'c-initialize-cc-mode initprop t)
133 (c-initialize-builtin-style)
134 (run-hooks 'c-initialization-hook)
135 ;; Fix obsolete variables.
136 (if (boundp 'c-comment-continuation-stars)
137 (setq c-block-comment-prefix c-comment-continuation-stars))
138 (setq c-initialization-ok t))
139 ;; Will try initialization hooks again if they failed.
140 (put 'c-initialize-cc-mode initprop c-initialization-ok)))
146 "Major mode for editing K&R and ANSI C code.
147 To submit a problem report, enter `\\[c-submit-bug-report]' from a
148 c-mode buffer. This automatically sets up a mail buffer with version
149 information already added. You just need to add a description of the
150 problem, including a reproducible test case and send the message.
152 To see what version of CC Mode you are running, enter `\\[c-version]'.
154 The hook variable `c-mode-hook' is run with no args, if that value is
155 bound and has a non-nil value. Also the hook `c-mode-common-hook' is
161 (c-initialize-cc-mode)
162 (kill-all-local-variables)
163 (set-syntax-table c-mode-syntax-table)
164 (setq major-mode 'c-mode
166 local-abbrev-table c-mode-abbrev-table)
167 (use-local-map c-mode-map)
169 (setq comment-start "/* "
171 c-conditional-key c-C-conditional-key
172 c-class-key c-C-class-key
174 c-comment-start-regexp c-C-comment-start-regexp
175 c-bitfield-key c-C-bitfield-key
177 (cc-imenu-init cc-imenu-c-generic-expression)
178 (run-hooks 'c-mode-common-hook)
179 (run-hooks 'c-mode-hook)
185 "Major mode for editing C++ code.
186 To submit a problem report, enter `\\[c-submit-bug-report]' from a
187 c++-mode buffer. This automatically sets up a mail buffer with
188 version information already added. You just need to add a description
189 of the problem, including a reproducible test case, and send the
192 To see what version of CC Mode you are running, enter `\\[c-version]'.
194 The hook variable `c++-mode-hook' is run with no args, if that
195 variable is bound and has a non-nil value. Also the hook
196 `c-mode-common-hook' is run first.
201 (c-initialize-cc-mode)
202 (kill-all-local-variables)
203 (set-syntax-table c++-mode-syntax-table)
204 (setq major-mode 'c++-mode
206 local-abbrev-table c++-mode-abbrev-table)
207 (use-local-map c++-mode-map)
209 (setq comment-start "// "
211 c-conditional-key c-C++-conditional-key
212 c-comment-start-regexp c-C++-comment-start-regexp
213 c-class-key c-C++-class-key
214 c-extra-toplevel-key c-C++-extra-toplevel-key
215 c-access-key c-C++-access-key
216 c-recognize-knr-p nil
217 c-bitfield-key c-C-bitfield-key
219 (cc-imenu-init cc-imenu-c++-generic-expression)
220 (run-hooks 'c-mode-common-hook)
221 (run-hooks 'c++-mode-hook)
227 "Major mode for editing Objective C code.
228 To submit a problem report, enter `\\[c-submit-bug-report]' from an
229 objc-mode buffer. This automatically sets up a mail buffer with
230 version information already added. You just need to add a description
231 of the problem, including a reproducible test case, and send the
234 To see what version of CC Mode you are running, enter `\\[c-version]'.
236 The hook variable `objc-mode-hook' is run with no args, if that value
237 is bound and has a non-nil value. Also the hook `c-mode-common-hook'
243 (c-initialize-cc-mode)
244 (kill-all-local-variables)
245 (set-syntax-table objc-mode-syntax-table)
246 (setq major-mode 'objc-mode
248 local-abbrev-table objc-mode-abbrev-table)
249 (use-local-map objc-mode-map)
251 (setq comment-start "// "
253 c-conditional-key c-ObjC-conditional-key
254 c-comment-start-regexp c-ObjC-comment-start-regexp
255 c-class-key c-ObjC-class-key
257 c-access-key c-ObjC-access-key
258 c-method-key c-ObjC-method-key
260 (cc-imenu-init cc-imenu-objc-generic-expression)
261 (run-hooks 'c-mode-common-hook)
262 (run-hooks 'objc-mode-hook)
268 "Major mode for editing Java code.
269 To submit a problem report, enter `\\[c-submit-bug-report]' from a
270 java-mode buffer. This automatically sets up a mail buffer with
271 version information already added. You just need to add a description
272 of the problem, including a reproducible test case and send the
275 To see what version of CC Mode you are running, enter `\\[c-version]'.
277 The hook variable `java-mode-hook' is run with no args, if that value
278 is bound and has a non-nil value. Also the common hook
279 `c-mode-common-hook' is run first. Note that this mode automatically
280 sets the \"java\" style before calling any hooks so be careful if you
281 set styles in `c-mode-common-hook'.
286 (c-initialize-cc-mode)
287 (kill-all-local-variables)
288 (set-syntax-table java-mode-syntax-table)
289 (setq major-mode 'java-mode
291 local-abbrev-table java-mode-abbrev-table)
292 (use-local-map java-mode-map)
294 (setq comment-start "// "
296 paragraph-start (concat paragraph-start
298 c-Java-javadoc-paragraph-start
300 c-conditional-key c-Java-conditional-key
301 c-comment-start-regexp c-Java-comment-start-regexp
302 c-class-key c-Java-class-key
305 c-recognize-knr-p nil
306 c-access-key c-Java-access-key
307 c-inexpr-class-key c-Java-inexpr-class-key
308 ;defun-prompt-regexp c-Java-defun-prompt-regexp
310 (cc-imenu-init cc-imenu-java-generic-expression)
311 (run-hooks 'c-mode-common-hook)
312 (run-hooks 'java-mode-hook)
318 "Major mode for editing CORBA's IDL code.
319 To submit a problem report, enter `\\[c-submit-bug-report]' from an
320 idl-mode buffer. This automatically sets up a mail buffer with
321 version information already added. You just need to add a description
322 of the problem, including a reproducible test case, and send the
325 To see what version of CC Mode you are running, enter `\\[c-version]'.
327 The hook variable `idl-mode-hook' is run with no args, if that
328 variable is bound and has a non-nil value. Also the hook
329 `c-mode-common-hook' is run first.
334 (c-initialize-cc-mode)
335 (kill-all-local-variables)
336 (set-syntax-table idl-mode-syntax-table)
337 (setq major-mode 'idl-mode
339 local-abbrev-table idl-mode-abbrev-table)
340 (use-local-map idl-mode-map)
342 (setq comment-start "// "
344 c-conditional-key c-IDL-conditional-key
345 c-comment-start-regexp c-IDL-comment-start-regexp
346 c-class-key c-IDL-class-key
349 c-extra-toplevel-key c-IDL-extra-toplevel-key
350 c-access-key c-IDL-access-key
351 c-recognize-knr-p nil
353 ;;(cc-imenu-init cc-imenu-idl-generic-expression) ;FIXME
354 (run-hooks 'c-mode-common-hook)
355 (run-hooks 'idl-mode-hook)
361 "Major mode for editing Pike code.
362 To submit a problem report, enter `\\[c-submit-bug-report]' from an
363 idl-mode buffer. This automatically sets up a mail buffer with
364 version information already added. You just need to add a description
365 of the problem, including a reproducible test case, and send the
368 To see what version of CC Mode you are running, enter `\\[c-version]'.
370 The hook variable `pike-mode-hook' is run with no args, if that value
371 is bound and has a non-nil value. Also the common hook
372 `c-mode-common-hook' is run first.
377 (c-initialize-cc-mode)
378 (kill-all-local-variables)
379 (set-syntax-table pike-mode-syntax-table)
380 (setq major-mode 'pike-mode
382 local-abbrev-table pike-mode-abbrev-table)
383 (use-local-map pike-mode-map)
385 (setq comment-start "// "
387 c-conditional-key c-Pike-conditional-key
388 c-comment-start-regexp c-Pike-comment-start-regexp
389 c-class-key c-Pike-class-key
392 c-recognize-knr-p nil
393 c-access-key c-Pike-access-key
394 c-lambda-key c-Pike-lambda-key
395 c-inexpr-block-key c-Pike-inexpr-block-key
396 c-special-brace-lists c-Pike-special-brace-lists
398 ;;(cc-imenu-init cc-imenu-pike-generic-expression) ;FIXME
399 (run-hooks 'c-mode-common-hook)
400 (run-hooks 'pike-mode-hook)
404 (defun c-setup-filladapt ()
405 "Convenience function to configure Kyle E. Jones' Filladapt mode for
406 CC Mode by making sure the proper entries are present on
407 `filladapt-token-table', `filladapt-token-match-table', and
408 `filladapt-token-conversion-table'. This is intended to be used on
409 `c-mode-common-hook' or similar."
410 ;; This function is intended to be used explicitly by the end user
413 ;; The default configuration already handles C++ comments, but we
414 ;; need to add handling of C block comments. A new filladapt token
415 ;; `c-comment' is added for that.
417 (setq p filladapt-token-table)
418 (while (and p (not (eq (car-safe (cdr-safe (car-safe p))) 'c-comment)))
419 (setq p (cdr-safe p)))
421 (setcar (car p) c-comment-prefix-regexp)
422 (setq filladapt-token-table
423 (append (list (car filladapt-token-table)
424 (list c-comment-prefix-regexp 'c-comment))
425 (cdr filladapt-token-table)))))
426 (unless (assq 'c-comment filladapt-token-match-table)
427 (setq filladapt-token-match-table
428 (append '((c-comment c-comment))
429 filladapt-token-match-table)))
430 (unless (assq 'c-comment filladapt-token-conversion-table)
431 (setq filladapt-token-conversion-table
432 (append '((c-comment . exact))
433 filladapt-token-conversion-table))))
438 (defconst c-mode-help-address
439 "bug-gnu-emacs@gnu.org, bug-cc-mode@gnu.org"
440 "Addresses for CC Mode bug reports.")
443 "Echo the current version of CC Mode in the minibuffer."
445 (message "Using CC Mode version %s" c-version)
446 (c-keep-region-active))
448 (defun c-submit-bug-report ()
449 "Submit via mail a bug report on CC Mode."
454 (let ((reporter-prompt-for-summary-p t)
455 (reporter-dont-compact-list '(c-offsets-alist))
456 (style c-indentation-style)
457 (hook c-special-indent-hook)
458 (c-features c-emacs-features))
460 (if (y-or-n-p "Do you want to submit a report on CC Mode? ")
463 (reporter-submit-bug-report
465 (concat "CC Mode " c-version " ("
466 (cond ((eq major-mode 'c++-mode) "C++")
467 ((eq major-mode 'c-mode) "C")
468 ((eq major-mode 'objc-mode) "ObjC")
469 ((eq major-mode 'java-mode) "Java")
470 ((eq major-mode 'idl-mode) "IDL")
471 ((eq major-mode 'pike-mode) "Pike")
475 ;; report only the vars that affect indentation
478 c-electric-pound-behavior
479 c-indent-comments-syntactically-p
484 parse-sexp-ignore-comments
485 ;; A brain-damaged XEmacs only variable that, if
486 ;; set to nil can cause all kinds of chaos.
487 signal-error-on-buffer-boundary
488 ;; Variables that affect line breaking and comments.
496 adaptive-fill-regexp)
498 (delq 'c-special-indent-hook vars)
499 (unless (boundp 'defun-prompt-regexp)
500 (delq 'defun-prompt-regexp vars))
501 (unless (boundp 'filladapt-mode)
502 (delq 'filladapt-mode vars))
507 "Buffer Style: " style "\n\n"
509 (or (/= (length hook) 1)
510 (not (eq (car hook) 'c-gnu-impose-minimum))
512 (concat "\n@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@\n"
513 "c-special-indent-hook is set to '"
515 ".\nPerhaps this is your problem?\n"
516 "@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@\n\n")
518 (format "c-emacs-features: %s\n" c-features)
521 "Dear Barry and Martin,"
526 ;;; cc-mode.el ends here