# HG changeset patch # User Alan Mackenzie # Date 1279484880 0 # Node ID d898f8a84d482d28158b63d8260649eef5651f3e # Parent 597339bd6bef7768492d551770e90ec8ff9e58fb Enhance `c-file-style' in file/directory local variables. cc-mode.el (c-count-cfss): New function. (c-before-hack-hook): Call `c-set-style' differently according to whether c-file-style was set in file or directory local variables. diff -r 597339bd6bef -r d898f8a84d48 lisp/ChangeLog --- a/lisp/ChangeLog Sun Jul 18 14:44:32 2010 -0400 +++ b/lisp/ChangeLog Sun Jul 18 20:28:00 2010 +0000 @@ -1,3 +1,11 @@ +2010-07-18 Alan Mackenzie + + Enhance `c-file-style' in file/directory local variables. + * cc-mode.el (c-count-cfss): New function. + (c-before-hack-hook): Call `c-set-style' differently according to + whether c-file-style was set in file or directory local + variables. + 2010-07-18 Michael R. Mauger * progmodes/sql.el: Version 2.2. diff -r 597339bd6bef -r d898f8a84d48 lisp/progmodes/cc-mode.el --- a/lisp/progmodes/cc-mode.el Sun Jul 18 14:44:32 2010 -0400 +++ b/lisp/progmodes/cc-mode.el Sun Jul 18 20:28:00 2010 +0000 @@ -662,6 +662,17 @@ (and (cdr rfn) (setq require-final-newline mode-require-final-newline))))) +(defun c-count-cfss (lv-alist) + ;; LV-ALIST is an alist like `file-local-variables-alist'. Count how many + ;; elements with the key `c-file-style' there are in it. + (let ((elt-ptr lv-alist) elt (cownt 0)) + (while elt-ptr + (setq elt (car elt-ptr) + elt-ptr (cdr elt-ptr)) + (when (eq (car elt) 'c-file-style) + (setq cownt (1+ cownt)))) + cownt)) + (defun c-before-hack-hook () "Set the CC Mode style and \"offsets\" when in the buffer's local variables. They are set only when, respectively, the pseudo variables @@ -678,7 +689,15 @@ (delq mode-cons file-local-variables-alist))) (when stile (or (stringp stile) (error "c-file-style is not a string")) - (c-set-style stile)) + (if (boundp 'dir-local-variables-alist) + ;; Determine whether `c-file-style' was set in the file's local + ;; variables or in a .dir-locals.el (a directory setting). + (let ((cfs-in-file-and-dir-count + (c-count-cfss file-local-variables-alist)) + (cfs-in-dir-count (c-count-cfss dir-local-variables-alist))) + (c-set-style stile + (= cfs-in-file-and-dir-count cfs-in-dir-count))) + (c-set-style stile))) (when offsets (mapc (lambda (langentry)