From mboxrd@z Thu Jan 1 00:00:00 1970 Path: news.gmane.org!not-for-mail From: Toby Cubitt Newsgroups: gmane.emacs.bugs Subject: bug#459: Zero-length overlays, overlay keymaps, and `overlays-at' Date: Sat, 21 Jun 2008 16:37:47 +0100 Message-ID: <485D204B.2@dr-qubit.org> Reply-To: Toby Cubitt , 459@emacsbugs.donarmstrong.com NNTP-Posting-Host: lo.gmane.org Mime-Version: 1.0 Content-Type: text/plain; charset=ISO-8859-1; format=flowed Content-Transfer-Encoding: 7bit X-Trace: ger.gmane.org 1214064858 20830 80.91.229.12 (21 Jun 2008 16:14:18 GMT) X-Complaints-To: usenet@ger.gmane.org NNTP-Posting-Date: Sat, 21 Jun 2008 16:14:18 +0000 (UTC) To: bug-gnu-emacs@gnu.org Original-X-From: bug-gnu-emacs-bounces+geb-bug-gnu-emacs=m.gmane.org@gnu.org Sat Jun 21 18:15:03 2008 Return-path: Envelope-to: geb-bug-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 1KA5jx-0004yb-Ny for geb-bug-gnu-emacs@m.gmane.org; Sat, 21 Jun 2008 18:15:02 +0200 Original-Received: from localhost ([127.0.0.1]:49694 helo=lists.gnu.org) by lists.gnu.org with esmtp (Exim 4.43) id 1KA5j7-0007Q2-4o for geb-bug-gnu-emacs@m.gmane.org; Sat, 21 Jun 2008 12:14:09 -0400 Original-Received: from mailman by lists.gnu.org with tmda-scanned (Exim 4.43) id 1KA5JC-0000It-SI for bug-gnu-emacs@gnu.org; Sat, 21 Jun 2008 11:47:22 -0400 Original-Received: from exim by lists.gnu.org with spam-scanned (Exim 4.43) id 1KA5J8-0000CG-3C for bug-gnu-emacs@gnu.org; Sat, 21 Jun 2008 11:47:19 -0400 Original-Received: from [199.232.76.173] (port=38435 helo=monty-python.gnu.org) by lists.gnu.org with esmtp (Exim 4.43) id 1KA5J7-0000Bz-64 for bug-gnu-emacs@gnu.org; Sat, 21 Jun 2008 11:47:17 -0400 Original-Received: from rzlab.ucr.edu ([138.23.92.77]:42053) by monty-python.gnu.org with esmtps (TLS-1.0:DHE_RSA_AES_256_CBC_SHA1:32) (Exim 4.60) (envelope-from ) id 1KA5J5-0002JC-Ak for bug-gnu-emacs@gnu.org; Sat, 21 Jun 2008 11:47:16 -0400 Original-Received: from rzlab.ucr.edu (rzlab.ucr.edu [127.0.0.1]) by rzlab.ucr.edu (8.13.8/8.13.8/Debian-3) with ESMTP id m5LFl9O9031677; Sat, 21 Jun 2008 08:47:10 -0700 Original-Received: (from debbugs@localhost) by rzlab.ucr.edu (8.13.8/8.13.8/Submit) id m5LFj3uu030564; Sat, 21 Jun 2008 08:45:03 -0700 X-Loop: don@donarmstrong.com Resent-From: Toby Cubitt Resent-To: bug-submit-list@donarmstrong.com Resent-CC: Emacs Bugs Resent-Date: Sat, 21 Jun 2008 15:45:03 +0000 Resent-Message-ID: Resent-Sender: don@donarmstrong.com X-Emacs-PR-Message: report 459 X-Emacs-PR-Package: emacs X-Emacs-PR-Keywords: Original-Received: via spool by submit@emacsbugs.donarmstrong.com id=B.121406268729322 (code B ref -1); Sat, 21 Jun 2008 15:45:03 +0000 Original-Received: (at submit) by emacsbugs.donarmstrong.com; 21 Jun 2008 15:38:07 +0000 Original-Received: from lists.gnu.org (lists.gnu.org [199.232.76.165]) by rzlab.ucr.edu (8.13.8/8.13.8/Debian-3) with ESMTP id m5LFc2SL029316 for ; Sat, 21 Jun 2008 08:38:04 -0700 Original-Received: from mailman by lists.gnu.org with tmda-scanned (Exim 4.43) id 1KA5A9-0003UR-ET for bug-gnu-emacs@gnu.org; Sat, 21 Jun 2008 11:38:01 -0400 Original-Received: from exim by lists.gnu.org with spam-scanned (Exim 4.43) id 1KA5A5-0003U9-6n for bug-gnu-emacs@gnu.org; Sat, 21 Jun 2008 11:38:00 -0400 Original-Received: from [199.232.76.173] (port=41256 helo=monty-python.gnu.org) by lists.gnu.org with esmtp (Exim 4.43) id 1KA5A5-0003U6-2u for bug-gnu-emacs@gnu.org; Sat, 21 Jun 2008 11:37:57 -0400 Original-Received: from mail.geekisp.com ([216.168.135.169]:15176 helo=starfish.geekisp.com) by monty-python.gnu.org with esmtps (TLS-1.0:DHE_RSA_AES_256_CBC_SHA1:32) (Exim 4.60) (envelope-from ) id 1KA5A4-0006cO-G6 for bug-gnu-emacs@gnu.org; Sat, 21 Jun 2008 11:37:57 -0400 Original-Received: (qmail 6244 invoked by uid 1003); 21 Jun 2008 15:37:50 -0000 Original-Received: from [192.168.2.2] (localhost.geekisp.com [127.0.0.1]) by localhost.geekisp.com (tmda-ofmipd) with ESMTP; Sat, 21 Jun 2008 11:37:48 -0400 User-Agent: Thunderbird 2.0.0.14 (X11/20080508) X-Delivery-Agent: TMDA/1.1.11 (Ladyburn) X-Primary-Address: t.s.cubitt.98@cantab.net X-detected-kernel: by monty-python.gnu.org: OpenBSD 3.0-3.9 X-detected-kernel: by monty-python.gnu.org: Linux 2.6 (newer, 3) Resent-Date: Sat, 21 Jun 2008 11:47:19 -0400 X-Mailman-Approved-At: Sat, 21 Jun 2008 12:06:38 -0400 X-BeenThere: bug-gnu-emacs@gnu.org X-Mailman-Version: 2.1.5 Precedence: list List-Id: "Bug reports for GNU Emacs, the Swiss army knife of text editors" List-Unsubscribe: , List-Archive: List-Post: List-Help: List-Subscribe: , Original-Sender: bug-gnu-emacs-bounces+geb-bug-gnu-emacs=m.gmane.org@gnu.org Errors-To: bug-gnu-emacs-bounces+geb-bug-gnu-emacs=m.gmane.org@gnu.org Xref: news.gmane.org gmane.emacs.bugs:18483 Archived-At: Two separate issues involving zero-length overlays. By "zero-length", I mean an overlay that starts and ends at the same position. (I'm not knowledgeable enough about Emacs' c internals to work it out whether these issues are fundamentally related or not.) Strictly speaking, neither of these issues are bugs, since the behaviour is consistent with the documentation. But it makes it difficult or impossible to do certain things in Emacs that one would expect to be able to do. Both "bugs" have been present since version 21, including the current stable version and in recent CVS (20.0.60.1). 1. Overlay keymaps ================== "Bug" description: ------------------ When a zero-length overlay has a keymap property, that keymap is never active, even if when the point is at the overlay's start (and end) position. This makes it impossible in Emacs to define a key binding that is only active at a single point in the buffer. Steps to reproduce: ------------------- (setq test-overlay (make-overlay 1 1)) ; any position will do (overlay-put test-overlay 'keymap (make-sparse-keymap)) ;; any key binding will do (define-key (overlay-get test-overlay 'keymap) "a" 'end-of-line) Move point to position 1. Type "a". The character "a" is inserted instead of the point moving to the end of the line. Impact: ------- Zero-length overlays are probably rarely used. But it is strange to be able to define a keybinding in Emacs that is active at two or more neighbouring point positions, but not at a single point position. At the very least, this is a missing feature. When this behaviour *is* needed (as in my completion-UI and auto-overlays packages), it is extremely difficult to work-around this issue. In fact, it requires abandoning overlay keymaps entirely, and simulating this behaviour via minor-mode maps and an ugly hack to check for overlays, temporarily disable the minor-mode map if no overlay was found, look up the keybinding again, call whatever command it is now bound to it, then re-enable the minor-mode map. Suggestions for possible fixes: ------------------------------- a) Make overlay keymaps active when the point is at the start, end, or within the overlay (currently, it is only active when the next character is within the overlay). This seems unlikely to have significant impact on other parts of Emacs, since zero-length overlays are rarely used. b) If a) is undesirable, why not make the behaviour depend on the overlay's front-advance and read-advance properties? If the zero-length overlay has null front-advance and non-null read-advance, then there is some logic in making its keymap active when point is at that position, since any character inserted at that point will be within the overlay after insertion. c) Add another overlay property to control the keymap behaviour in the case of zero-length overlays. (This seems an ugly solution to me, since it involves adding a whole new property just to deal with a very rare edge-case.) 2. `overlays-at' ================ "Bug" description: ------------------ `overlays-at' never returns zero-length overlays. Steps to reproduce: ------------------- (make-overlay 1 1) ; any position will do (overlays-at 1) Returns nil instead of the overlay from 1 to 1. Impact: ------- Again, zero-length overlays are probably rarely used. But this makes it impossible in Emacs to find a zero-length overlay using `overlays-at'. Instead, one has to work-around this using three calls to `overlays-in' then filter out overlays that shouldn't be in the list. Overlays do fairly frequently become zero-length when the text they cover is deleted (depending on their front- and rear-advance properties), and this "bug" makes them suddenly disappear from the return value of `overlays-at' even though they still exist in the buffer. Suggestions for possible fixes: ------------------------------- a) Modify (overlays-at pos) to return zero-length overlays that start at pos (it already returns all other overlays that start at pos). Again, this seems unlikely to have significant impact on other parts of Emacs, since zero-length overlays are rarely used. b) Modify (overlays-at pos) to return zero-length overlays that start at pos, and have a null front-advance and non-nil rear-advance property. (The logic for this is the same as in option b) for the overlay keymaps issue.) c) Leave `overlays-at' unchanged, and define a new function `overlays-at-point' that implements either a) or b). Toby Cubitt