From mboxrd@z Thu Jan 1 00:00:00 1970 Path: news.gmane.org!not-for-mail From: Volkan YAZICI Newsgroups: gmane.emacs.help Subject: Re: Common Lisp DEF Macro Indentation Date: Wed, 16 Jul 2008 12:07:05 -0700 (PDT) Organization: http://groups.google.com Message-ID: References: NNTP-Posting-Host: lo.gmane.org Mime-Version: 1.0 Content-Type: text/plain; charset=ISO-8859-1 Content-Transfer-Encoding: 7bit X-Trace: ger.gmane.org 1216237296 1381 80.91.229.12 (16 Jul 2008 19:41:36 GMT) X-Complaints-To: usenet@ger.gmane.org NNTP-Posting-Date: Wed, 16 Jul 2008 19:41:36 +0000 (UTC) To: help-gnu-emacs@gnu.org Original-X-From: help-gnu-emacs-bounces+geh-help-gnu-emacs=m.gmane.org@gnu.org Wed Jul 16 21:42:24 2008 Return-path: Envelope-to: geh-help-gnu-emacs@m.gmane.org Original-Received: from lists.gnu.org ([199.232.76.165]) by lo.gmane.org with esmtp (Exim 4.50) id 1KJCtE-0006vK-Nc for geh-help-gnu-emacs@m.gmane.org; Wed, 16 Jul 2008 21:42:17 +0200 Original-Received: from localhost ([127.0.0.1]:33718 helo=lists.gnu.org) by lists.gnu.org with esmtp (Exim 4.43) id 1KJCsM-0004a5-B7 for geh-help-gnu-emacs@m.gmane.org; Wed, 16 Jul 2008 15:41:22 -0400 Original-Path: news.stanford.edu!newsfeed.stanford.edu!postnews.google.com!k37g2000hsf.googlegroups.com!not-for-mail Original-Newsgroups: gnu.emacs.help Original-Lines: 73 Original-NNTP-Posting-Host: 88.230.56.196 Original-X-Trace: posting.google.com 1216235225 31877 127.0.0.1 (16 Jul 2008 19:07:05 GMT) Original-X-Complaints-To: groups-abuse@google.com Original-NNTP-Posting-Date: Wed, 16 Jul 2008 19:07:05 +0000 (UTC) Complaints-To: groups-abuse@google.com Injection-Info: k37g2000hsf.googlegroups.com; posting-host=88.230.56.196; posting-account=xozGQQoAAAD99EQH9srmwM1ajggyokYW User-Agent: G2/1.0 X-HTTP-UserAgent: Mozilla/5.0 (X11; U; Linux x86_64; en-US; rv:1.8.1.15) Gecko/20080612 Iceweasel/2.0.0.15 (Debian-2.0.0.15-0etch1), gzip(gfe), gzip(gfe) Original-Xref: news.stanford.edu gnu.emacs.help:160300 X-BeenThere: help-gnu-emacs@gnu.org X-Mailman-Version: 2.1.5 Precedence: list List-Id: Users list for the GNU Emacs text editor List-Unsubscribe: , List-Archive: List-Post: List-Help: List-Subscribe: , Original-Sender: help-gnu-emacs-bounces+geh-help-gnu-emacs=m.gmane.org@gnu.org Errors-To: help-gnu-emacs-bounces+geh-help-gnu-emacs=m.gmane.org@gnu.org Xref: news.gmane.org gmane.emacs.help:55647 Archived-At: On Jul 14, 4:03 pm, Volkan YAZICI wrote: > ... > What might be causing the problem? Are there any mistakes with forms I > supplied to LISP-INDENT-259? Any kind of help will be appreciated. Here goes the fixed version: (require 'cl) (defmacro concatenate-def-types-for-regexp (&rest symbols) (with-output-to-string (princ "(?\\(") (let (not-first) (while symbols (if not-first (princ "\\|") (setq not-first t)) (princ (pop symbols)))) (princ "\\)"))) (defcustom lisp-indent-def-function-regexp (concatenate-def-types-for-regexp function macro compiler-macro method generic type print-object class condition) "Definer types will be indented like a function definition form." :type 'string :group 'lisp-indent) (defcustom lisp-indent-def-variable-regexp (concatenate-def-types-for-regexp variable constant load-time-constant special-variable symbol-macro struct) "Definer types will be indented like a variable definition form." :type 'string :group 'lisp-indent) (defcustom lisp-indent-def-setf-regexp (concatenate-def-types-for-regexp setf) "Definer types will be indented like a setf definition form." :type 'string :group 'lisp-indent) (defmacro with-position-at-def-type (position &rest body) `(save-excursion (goto-char ,position) (forward-char) (forward-sexp 1) (while (forward-comment 1)) ,@body)) (defun lisp-indent-def (path state indent-point sexp-column normal- indent) (lisp-indent-259 (with-position-at-def-type (elt state 1) (cond ((looking-at lisp-indent-def-function-regexp) '(4 4 &lambda &body)) ((looking-at lisp-indent-def-variable-regexp) '(4 4 &body)) ((looking-at lisp-indent-def-setf-regexp) '(4 4 &lambda &body)) (t '(&body)))) path state indent-point sexp-column normal-indent)) (put 'def 'common-lisp-indent-function 'lisp-indent-def) Pay attention that, in LISP-INDENT-DEF, if we couldn't find an appropriate known definer type, we pass '(&body) to LISP-INDENT-259. (Also fixed indentation routines in demacs too.) Regards.