From: Simon South <ssouth@slowcomputing.org>
To: emacs-pretest-bug@gnu.org
Subject: bug#4354: 23.0.60; delphi-mode: TAB should indent region in Transient Mark mode (with patch)
Date: Sun, 06 Sep 2009 00:13:32 -0400 [thread overview]
Message-ID: <87pra4lngz.fsf@hamlet.localdomain> (raw)
The patch below makes delphi-mode indent the region when the TAB key
is pressed, whenever Transient Mark mode is enabled and the region is
active. (This became standard behaviour with Emacs 23.1 but wasn't
automatically reflected by delphi-mode as it defines its own TAB-key
binding.)
I've tested this with different combinations of transient-mark-mode,
delphi-tab-always-indents and delphi-newline-always-indents and it
appears to work fine.
Changes:
(delphi-tab): Indent region when Transient Mark mode is enabled and
region is active; otherwise indent or insert TAB as usual.
(delphi-mode): Update description of TAB-key binding.
Index: lisp/progmodes/delphi.el
===================================================================
RCS file: /sources/emacs/emacs/lisp/progmodes/delphi.el,v
retrieving revision 3.33
diff -c -r3.33 delphi.el
*** lisp/progmodes/delphi.el 5 Jan 2009 03:23:27 -0000 3.33
--- lisp/progmodes/delphi.el 6 Sep 2009 03:33:09 -0000
***************
*** 1652,1665 ****
(defun delphi-tab ()
! "Indent the current line or insert a TAB, depending on the value of
! `delphi-tab-always-indents' and the current line position."
(interactive)
! (if (or delphi-tab-always-indents ; We are always indenting
! ;; Or we are before the first non-space character on the line.
! (save-excursion (skip-chars-backward delphi-space-chars) (bolp)))
! (delphi-indent-line)
! (insert "\t")))
(defun delphi-is-directory (path)
--- 1652,1674 ----
(defun delphi-tab ()
! "Indent the region, when Transient Mark mode is enabled and the region is
! active. Otherwise, indent the current line or insert a TAB, depending on the
! value of `delphi-tab-always-indents' and the current line position."
(interactive)
! (cond ((use-region-p)
! ;; If Transient Mark mode is enabled and the region is active, indent
! ;; the entire region.
! (indent-region (region-beginning) (region-end)))
! ((or delphi-tab-always-indents
! (save-excursion (skip-chars-backward delphi-space-chars) (bolp)))
! ;; Otherwise, if we are configured always to indent (regardless of the
! ;; point's position in the line) or we are before the first non-space
! ;; character on the line, indent the line.
! (delphi-indent-line))
! (t
! ;; Otherwise, insert a tab character.
! (insert "\t"))))
(defun delphi-is-directory (path)
***************
*** 1935,1941 ****
;;;###autoload
(defun delphi-mode (&optional skip-initial-parsing)
"Major mode for editing Delphi code. \\<delphi-mode-map>
! \\[delphi-tab]\t- Indents the current line for Delphi code.
\\[delphi-find-unit]\t- Search for a Delphi source file.
\\[delphi-fill-comment]\t- Fill the current comment.
\\[delphi-new-comment-line]\t- If in a // comment, do a new comment line.
--- 1944,1951 ----
;;;###autoload
(defun delphi-mode (&optional skip-initial-parsing)
"Major mode for editing Delphi code. \\<delphi-mode-map>
! \\[delphi-tab]\t- Indents the current line (or region, if Transient Mark mode
! \t is enabled and the region is active) of Delphi code.
\\[delphi-find-unit]\t- Search for a Delphi source file.
\\[delphi-fill-comment]\t- Fill the current comment.
\\[delphi-new-comment-line]\t- If in a // comment, do a new comment line.
next reply other threads:[~2009-09-06 4:13 UTC|newest]
Thread overview: 2+ messages / expand[flat|nested] mbox.gz Atom feed top
[not found] <1252636926.4395.6.camel@hamlet.localdomain>
2009-09-06 4:13 ` Simon South [this message]
2009-09-11 2:50 ` bug#4354: marked as done (23.0.60; delphi-mode: TAB should indent region in Transient Mark mode (with patch)) Emacs bug Tracking System
Reply instructions:
You may reply publicly to this message via plain-text email
using any one of the following methods:
* Save the following mbox file, import it into your mail client,
and reply-to-all from there: mbox
Avoid top-posting and favor interleaved quoting:
https://en.wikipedia.org/wiki/Posting_style#Interleaved_style
List information: https://www.gnu.org/software/emacs/
* Reply using the --to, --cc, and --in-reply-to
switches of git-send-email(1):
git send-email \
--in-reply-to=87pra4lngz.fsf@hamlet.localdomain \
--to=ssouth@slowcomputing.org \
--cc=4354@emacsbugs.donarmstrong.com \
--cc=emacs-pretest-bug@gnu.org \
/path/to/YOUR_REPLY
https://kernel.org/pub/software/scm/git/docs/git-send-email.html
* If your mail client supports setting the In-Reply-To header
via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line
before the message body.
Code repositories for project(s) associated with this public inbox
https://git.savannah.gnu.org/cgit/emacs.git
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox;
as well as URLs for read-only IMAP folder(s) and NNTP newsgroup(s).