From mboxrd@z Thu Jan 1 00:00:00 1970 Return-Path: Received: from mp10.migadu.com ([2001:41d0:8:6d80::]) (using TLSv1.3 with cipher TLS_AES_256_GCM_SHA384 (256/256 bits)) by ms9.migadu.com with LMTPS id WEy4G9iopGRA6wAASxT56A (envelope-from ) for ; Wed, 05 Jul 2023 01:18:48 +0200 Received: from aspmx1.migadu.com ([2001:41d0:8:6d80::]) (using TLSv1.3 with cipher TLS_AES_256_GCM_SHA384 (256/256 bits)) by mp10.migadu.com with LMTPS id qJfSGtiopGRzwQAAG6o9tA (envelope-from ) for ; Wed, 05 Jul 2023 01:18:48 +0200 Received: from lists.gnu.org (lists.gnu.org [209.51.188.17]) (using TLSv1.2 with cipher ECDHE-RSA-AES256-GCM-SHA384 (256/256 bits)) (No client certificate requested) by aspmx1.migadu.com (Postfix) with ESMTPS id A21BABE17 for ; Wed, 5 Jul 2023 01:18:47 +0200 (CEST) Authentication-Results: aspmx1.migadu.com; dkim=pass header.d=lipklim.org header.s=key1 header.b=UCnnEO0y; dmarc=pass (policy=quarantine) header.from=lipklim.org; spf=pass (aspmx1.migadu.com: domain of "emacs-orgmode-bounces+larch=yhetil.org@gnu.org" designates 209.51.188.17 as permitted sender) smtp.mailfrom="emacs-orgmode-bounces+larch=yhetil.org@gnu.org" ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=yhetil.org; s=key1; t=1688512728; h=from:from:sender:sender:reply-to:subject:subject:date:date: message-id:message-id:to:to:cc:cc:mime-version:mime-version: content-type:content-type:in-reply-to:in-reply-to: references:references:list-id:list-help:list-unsubscribe: list-subscribe:list-post:dkim-signature; bh=xCTCWTuJT5xuwFvu9BmbK92AXDHr941TovdJSNyIVbA=; b=iifoOJOsZFrgWh54MueOlgusp/WmPg2r4J3H9WyzE3OrS3todHMO3oxGtItIAbc/iFAETd 3bdXS6C1yxZjTQ7lYcMQmR9rCFQ9gKqMz7sJOp+lowyxJtc3D96Ll5tRm0TMjzxg6PPWac 0eVJeGeZhqQLRm68j0vX9KtxhT+cDSPpx1wFfvk/Mz/DFt5pJpQUonuVpUDOB3alOZByh9 I6c483a8Frot75X4Eco0nEH9JG/X3GIntl+iLxfVILXm3fYqP9aXms3FXRSTPqfcJOixVV gmIm5nBdoW+I/srbQ7gJPyqRdqfmLe+Sgj6crnlIn6xQ053eYeOadvvsU/J3yg== ARC-Authentication-Results: i=1; aspmx1.migadu.com; dkim=pass header.d=lipklim.org header.s=key1 header.b=UCnnEO0y; dmarc=pass (policy=quarantine) header.from=lipklim.org; spf=pass (aspmx1.migadu.com: domain of "emacs-orgmode-bounces+larch=yhetil.org@gnu.org" designates 209.51.188.17 as permitted sender) smtp.mailfrom="emacs-orgmode-bounces+larch=yhetil.org@gnu.org" ARC-Seal: i=1; s=key1; d=yhetil.org; t=1688512728; a=rsa-sha256; cv=none; b=OWRDKe4GgJRgjVL17mTewHH0IcitxX6BMG5Icvlu96dxS4oEZmKO+0LtjiyrQq25Z5F8oy XGZ1vNXrbpsBsqXROArUtzR/OKz7fwvTvNQyEQGrulkcQOZXsFBcZITbqjyNGjXxwlDuau SeTKw2MOb+1OgSVCCfNpooGQV/uo6TyFhTg6xZkvapVQbmTx0WTXzbRLznYmFHD7Ac5GD8 b569xnKl0kocW4KxRFGzLLyY7cpOznq97MlAoej4oz3ER3j5pcAYTzmSYLDDbW2F5cVuqS Ag83bxnuKiSqLDWu2YP1PXZqBiUPX8tM0Jm4kf37nXSAFv269krEqtqB7MYLoA== Received: from localhost ([::1] helo=lists1p.gnu.org) by lists.gnu.org with esmtp (Exim 4.90_1) (envelope-from ) id 1qGpHE-0007tj-OG; Tue, 04 Jul 2023 19:17:44 -0400 Received: from eggs.gnu.org ([2001:470:142:3::10]) by lists.gnu.org with esmtps (TLS1.2:ECDHE_RSA_AES_256_GCM_SHA384:256) (Exim 4.90_1) (envelope-from ) id 1qGpHC-0007tY-F4 for emacs-orgmode@gnu.org; Tue, 04 Jul 2023 19:17:43 -0400 Received: from out-50.mta0.migadu.com ([2001:41d0:1004:224b::32]) by eggs.gnu.org with esmtps (TLS1.2:ECDHE_RSA_AES_256_GCM_SHA384:256) (Exim 4.90_1) (envelope-from ) id 1qGpH7-00077q-Pi for emacs-orgmode@gnu.org; Tue, 04 Jul 2023 19:17:42 -0400 References: <873527q5iw.fsf@localhost> <20230701131902.1679-1-eugene.dev@lipklim.org> <87ilb1go5p.fsf@localhost> DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=lipklim.org; s=key1; t=1688512652; h=from:from:reply-to:subject:subject:date:date:message-id:message-id: to:to:cc:cc:mime-version:mime-version:content-type:content-type: in-reply-to:in-reply-to:references:references; bh=xCTCWTuJT5xuwFvu9BmbK92AXDHr941TovdJSNyIVbA=; b=UCnnEO0ylSQndiZtZyYblcnm5OTfD3iPqkG33y2CU9HucZeN3VBLIlD5ZqTUSHGax2Brae ty5d+pXTt5JGJTjfjbScPKiY+N9+wjhJ1wTmsSPESJSJtEuh906lBhD8USAiDrDgbZAvgG njSLOkoXbO3govGG9dRDNfsQTcCgqRQ= X-Report-Abuse: Please report any abuse attempt to abuse@migadu.com and include these headers. From: Evgenii Klimov To: Ihor Radchenko Cc: emacs-orgmode@gnu.org Subject: [PATCH v3] lisp/org.el: Add final hooks to S-/M-/S-M-cursor commands Date: Tue, 04 Jul 2023 23:28:45 +0100 In-reply-to: <87ilb1go5p.fsf@localhost> Message-ID: <87ilazuv04.fsf@lipklim.org> MIME-Version: 1.0 Content-Type: multipart/mixed; boundary="=-=-=" Received-SPF: pass client-ip=2001:41d0:1004:224b::32; envelope-from=eugene.dev@lipklim.org; helo=out-50.mta0.migadu.com X-Spam_score_int: -20 X-Spam_score: -2.1 X-Spam_bar: -- X-Spam_report: (-2.1 / 5.0 requ) BAYES_00=-1.9, DKIM_SIGNED=0.1, DKIM_VALID=-0.1, DKIM_VALID_AU=-0.1, DKIM_VALID_EF=-0.1, SPF_HELO_NONE=0.001, SPF_PASS=-0.001, T_SCC_BODY_TEXT_LINE=-0.01 autolearn=ham autolearn_force=no X-Spam_action: no action X-BeenThere: emacs-orgmode@gnu.org X-Mailman-Version: 2.1.29 Precedence: list List-Id: "General discussions about Org-mode." List-Unsubscribe: , List-Archive: List-Post: List-Help: List-Subscribe: , Errors-To: emacs-orgmode-bounces+larch=yhetil.org@gnu.org Sender: emacs-orgmode-bounces+larch=yhetil.org@gnu.org X-Migadu-Country: US X-Migadu-Flow: FLOW_IN X-Migadu-Scanner: scn0.migadu.com X-Migadu-Spam-Score: -9.76 X-Spam-Score: -9.76 X-Migadu-Queue-Id: A21BABE17 X-TUID: XLWTCD3iArxK --=-=-= Content-Type: text/plain Ihor Radchenko writes: > Evgenii Klimov writes: [...] > Few comments. > > First, please add Changelog entry for etc/ORG-NEWS. Done. >> +(defvar org-metaleft-final-hook nil >> + "Hook for functions attaching themselves to `M-left'. >> +See `org-ctrl-c-ctrl-c-hook' for more information.") > > Note that unlike the docstring your added, `org-shiftup-final-hook' > specifies when the hook is executed: > > (defvar org-shiftup-final-hook nil > "Hook for functions attaching themselves to `S-up'. > This one runs after all other options except shift-select have been excluded. > See `org-ctrl-c-ctrl-c-hook' for more information.") > > It is better to follow the pattern and clarify the purpose of the hook > better instead of leaving docstrings for both the -final and other hook > same. Done. >> +individual commands for more information. >> + >> +This function runs the hook `org-shiftmetaleft-hook' as a first >> +step, `org-shiftmetaleft-final-hook' as the penultimate step, and >> +returns at first non-nil value." > > Upon looking closer, I realized that you also defined return value of > the function here. Is there any particular reason for this? The return > value is currently not defined and supposed to be discarded. > Apparently the original wording is quite confusing. > What it is supposed to say is: > > This function runs the functions in `org-metaleft-hook' one by one > as a first step, and exits immediately if a function from the hook > returns non-nil. Reworded as we discussed. Also for commands that support `shift-select-mode' (i.e. org-shift{up,down,right,left}) mentioned it and `org-support-shift-select'. --=-=-= Content-Type: text/x-diff Content-Disposition: inline; filename=v3-0001-lisp-org.el-Add-final-hooks-to-S-M-S-M-cursor-com.patch >From b27b95efbad7645d7bd4870becd112abc25c9840 Mon Sep 17 00:00:00 2001 From: Evgenii Klimov Date: Thu, 29 Jun 2023 20:06:33 +0100 Subject: [PATCH v3] lisp/org.el: Add final hooks to S-/M-/S-M-cursor commands * lisp/org.el (org-metaleft-final-hook, org-metaright-final-hook, org-metaup-final-hook, org-metadown-final-hook): Define final hooks for S-cursor commands. (org-metaleft, org-metaright, org-metaup, org-metadown): Add final hooks to M-commands and document them in the docstring. * lisp/org.el (org-shiftup, org-shiftdown, org-shiftright, org-shiftleft): Document hooks for S-cursor commands in the docstring. * lisp/org.el (org-shiftmetaleft-final-hook, org-shiftmetaright-final-hook, org-shiftmetaup-final-hook, org-shiftmetadown-final-hook): Define final hooks for the S-M-cursor commands. (org-shiftmetaleft, org-shiftmetaright, org-shiftmetaup, org-shiftmetadown): Add final hooks to the S-M-cursor commands and document hooks in the docstring. * etc/ORG-NEWS (New final hooks for Modifier-Cursor keys): Document new hooks. TINYCHANGE --- etc/ORG-NEWS | 17 ++++++ lisp/org.el | 155 +++++++++++++++++++++++++++++++++++++++++++++------ 2 files changed, 156 insertions(+), 16 deletions(-) diff --git a/etc/ORG-NEWS b/etc/ORG-NEWS index d04e92275..973a97a2f 100644 --- a/etc/ORG-NEWS +++ b/etc/ORG-NEWS @@ -437,6 +437,23 @@ Currently implemented options are: iCalendar programs support this usage. ** New features +*** New final hooks for Modifier-Cursor keys + +Final hooks are added to the following commands: +- ~org-metaleft-final-hook~ to ~org-metaleft~ (bound to =M-=). +- ~org-metaright-final-hook~ to ~org-metaright~ (bound to + =M-=). +- ~org-metaup-final-hook~ to ~org-metaup~ (bound to =M-=). +- ~org-metadown-final-hook~ to ~org-metadown~ (bound to =M-=). +- ~org-shiftmetaleft-final-hook~ to ~org-shiftmetaleft~ (bound to + =M-S-=). +- ~org-shiftmetaright-final-hook~ to ~org-shiftmetaright~ (bound to + =M-S-=). +- ~org-shiftmetaup-final-hook~ to ~org-shiftmetaup~ (bound to + =M-S-=). +- ~org-shiftmetadown-final-hook~ to ~org-shiftmetadown~ (bound to + =M-S-=). + *** ~org-insert-todo-heading-respect-content~ now accepts prefix arguments The prefix arguments are passed to ~org-insert-todo-heading~. diff --git a/lisp/org.el b/lisp/org.el index 36235322d..57d8082e5 100644 --- a/lisp/org.el +++ b/lisp/org.el @@ -16658,27 +16658,63 @@ before indentation and \t insertion takes place.") (defvar org-metaleft-hook nil "Hook for functions attaching themselves to `M-left'. See `org-ctrl-c-ctrl-c-hook' for more information.") +(defvar org-metaleft-final-hook nil + "Hook for functions attaching themselves to `M-left'. +This one runs after all options have been excluded. +See `org-ctrl-c-ctrl-c-hook' for more information.") (defvar org-metaright-hook nil "Hook for functions attaching themselves to `M-right'. See `org-ctrl-c-ctrl-c-hook' for more information.") +(defvar org-metaright-final-hook nil + "Hook for functions attaching themselves to `M-right'. +This one runs after all options have been excluded. +See `org-ctrl-c-ctrl-c-hook' for more information.") (defvar org-metaup-hook nil "Hook for functions attaching themselves to `M-up'. See `org-ctrl-c-ctrl-c-hook' for more information.") +(defvar org-metaup-final-hook nil + "Hook for functions attaching themselves to `M-up'. +This one runs after all other options except +`org-drag-element-backward' have been excluded. See +`org-ctrl-c-ctrl-c-hook' for more information.") (defvar org-metadown-hook nil "Hook for functions attaching themselves to `M-down'. See `org-ctrl-c-ctrl-c-hook' for more information.") +(defvar org-metadown-final-hook nil + "Hook for functions attaching themselves to `M-down'. +This one runs after all other options except +`org-drag-element-forward' have been excluded. See +`org-ctrl-c-ctrl-c-hook' for more information.") (defvar org-shiftmetaleft-hook nil "Hook for functions attaching themselves to `M-S-left'. See `org-ctrl-c-ctrl-c-hook' for more information.") +(defvar org-shiftmetaleft-final-hook nil + "Hook for functions attaching themselves to `M-S-left'. +This one runs after all other options have been excluded. See +`org-ctrl-c-ctrl-c-hook' for more information.") (defvar org-shiftmetaright-hook nil "Hook for functions attaching themselves to `M-S-right'. See `org-ctrl-c-ctrl-c-hook' for more information.") +(defvar org-shiftmetaright-final-hook nil + "Hook for functions attaching themselves to `M-S-right'. +This one runs after all other options have been excluded. See +`org-ctrl-c-ctrl-c-hook' for more information.") (defvar org-shiftmetaup-hook nil "Hook for functions attaching themselves to `M-S-up'. See `org-ctrl-c-ctrl-c-hook' for more information.") +(defvar org-shiftmetaup-final-hook nil + "Hook for functions attaching themselves to `M-S-up'. +This one runs after all other options except +`org-drag-line-backward' have been excluded. See +`org-ctrl-c-ctrl-c-hook' for more information.") (defvar org-shiftmetadown-hook nil "Hook for functions attaching themselves to `M-S-down'. See `org-ctrl-c-ctrl-c-hook' for more information.") +(defvar org-shiftmetadown-final-hook nil + "Hook for functions attaching themselves to `M-S-down'. +This one runs after all other options except +`org-drag-line-forward' have been excluded. See +`org-ctrl-c-ctrl-c-hook' for more information.") (defvar org-metareturn-hook nil "Hook for functions attaching themselves to `M-RET'. See `org-ctrl-c-ctrl-c-hook' for more information.") @@ -16746,7 +16782,13 @@ When ARG is a numeric prefix, show contents of this level." "Promote subtree or delete table column. Calls `org-promote-subtree', `org-outdent-item-tree', or `org-table-delete-column', depending on context. See the -individual commands for more information." +individual commands for more information. + +This function runs the functions in `org-shiftmetaleft-hook' one +by one as a first step, and exits immediately if a function from +the hook returns non-nil. In the absence of a specific context, +the function also runs `org-shiftmetaleft-final-hook' using the +same logic." (interactive) (cond ((and (eq system-type 'darwin) @@ -16760,13 +16802,20 @@ individual commands for more information." (save-excursion (goto-char (region-beginning)) (org-at-item-p))) (call-interactively 'org-outdent-item-tree)) + ((run-hook-with-args-until-success 'org-shiftmetaleft-final-hook)) (t (org-modifier-cursor-error)))) (defun org-shiftmetaright () "Demote subtree or insert table column. Calls `org-demote-subtree', `org-indent-item-tree', or `org-table-insert-column', depending on context. See the -individual commands for more information." +individual commands for more information. + +This function runs the functions in `org-shiftmetaright-hook' one +by one as a first step, and exits immediately if a function from +the hook returns non-nil. In the absence of a specific context, +the function also runs `org-shiftmetaright-final-hook' using the +same logic." (interactive) (cond ((and (eq system-type 'darwin) @@ -16780,6 +16829,7 @@ individual commands for more information." (save-excursion (goto-char (region-beginning)) (org-at-item-p))) (call-interactively 'org-indent-item-tree)) + ((run-hook-with-args-until-success 'org-shiftmetaright-final-hook)) (t (org-modifier-cursor-error)))) (defun org-shiftmetaup (&optional _arg) @@ -16787,13 +16837,20 @@ individual commands for more information." In a table, kill the current row. On a clock timestamp, update the value of the timestamp like `S-' but also adjust the previous clocked item in the clock history. -Everywhere else, drag the line at point up." +Everywhere else, drag the line at point up. + +This function runs the functions in `org-shiftmetaup-hook' one by +one as a first step, and exits immediately if a function from the +hook returns non-nil. In the absence of a specific context, the +function also runs `org-shiftmetaup-final-hook' using the same +logic." (interactive "P") (cond ((run-hook-with-args-until-success 'org-shiftmetaup-hook)) ((org-at-table-p) (call-interactively 'org-table-kill-row)) ((org-at-clock-log-p) (let ((org-clock-adjust-closest t)) (call-interactively 'org-timestamp-up))) + ((run-hook-with-args-until-success 'org-shiftmetaup-final-hook)) (t (call-interactively 'org-drag-line-backward)))) (defun org-shiftmetadown (&optional _arg) @@ -16801,13 +16858,20 @@ Everywhere else, drag the line at point up." In a table, insert an empty row at the current line. On a clock timestamp, update the value of the timestamp like `S-' but also adjust the previous clocked item in the clock history. -Everywhere else, drag the line at point down." +Everywhere else, drag the line at point down. + +This function runs the functions in `org-shiftmetadown-hook' one +by one as a first step, and exits immediately if a function from +the hook returns non-nil. In the absence of a specific context, +the function also runs `org-shiftmetadown-final-hook' using the +same logic." (interactive "P") (cond ((run-hook-with-args-until-success 'org-shiftmetadown-hook)) ((org-at-table-p) (call-interactively 'org-table-insert-row)) ((org-at-clock-log-p) (let ((org-clock-adjust-closest t)) (call-interactively 'org-timestamp-down))) + ((run-hook-with-args-until-success 'org-shiftmetadown-final-hook)) (t (call-interactively 'org-drag-line-forward)))) (defsubst org-hidden-tree-error () @@ -16822,8 +16886,10 @@ depending on context. With no specific context, calls the Emacs default `backward-word'. See the individual commands for more information. -This function runs the hook `org-metaleft-hook' as a first step, -and returns at first non-nil value." +This function runs the functions in `org-metaleft-hook' one by +one as a first step, and exits immediately if a function from the +hook returns non-nil. In the absence of a specific context, the +function runs `org-metaleft-final-hook' using the same logic." (interactive "P") (cond ((run-hook-with-args-until-success 'org-metaleft-hook)) @@ -16846,6 +16912,7 @@ and returns at first non-nil value." (org-at-item-p)))) (when (org-check-for-hidden 'items) (org-hidden-tree-error)) (call-interactively 'org-outdent-item)) + ((run-hook-with-args-until-success 'org-metaleft-final-hook)) (t (call-interactively 'backward-word)))) (defun org-metaright (&optional _arg) @@ -16858,8 +16925,10 @@ Calls `org-do-demote', `org-indent-item', `org-table-move-column', With no specific context, calls the Emacs default `forward-word'. See the individual commands for more information. -This function runs the hook `org-metaright-hook' as a first step, -and returns at first non-nil value." +This function runs the functions in `org-metaright-hook' one by +one as a first step, and exits immediately if a function from the +hook returns non-nil. In the absence of a specific context, the +function runs `org-metaright-final-hook' using the same logic." (interactive "P") (cond ((run-hook-with-args-until-success 'org-metaright-hook)) @@ -16884,6 +16953,7 @@ and returns at first non-nil value." (org-at-item-p)))) (when (org-check-for-hidden 'items) (org-hidden-tree-error)) (call-interactively 'org-indent-item)) + ((run-hook-with-args-until-success 'org-metaright-final-hook)) (t (call-interactively 'forward-word)))) (defun org-check-for-hidden (what) @@ -16916,8 +16986,14 @@ this function returns t, nil otherwise." (defun org-metaup (&optional _arg) "Move subtree up or move table row up. Calls `org-move-subtree-up' or `org-table-move-row' or -`org-move-item-up', depending on context. See the individual commands -for more information." +`org-move-item-up', depending on context. Everywhere else, move +backward the element at point. See the individual commands for +more information. + +This function runs the functions in `org-metaup-hook' one by one +as a first step, and exits immediately if a function from the +hook returns non-nil. In the absence of a specific context, the +function runs `org-metaup-final-hook' using the same logic." (interactive "P") (cond ((run-hook-with-args-until-success 'org-metaup-hook)) @@ -16974,13 +17050,20 @@ for more information." (org-drag-element-backward)) ((org-at-heading-p) (call-interactively 'org-move-subtree-up)) ((org-at-item-p) (call-interactively 'org-move-item-up)) + ((run-hook-with-args-until-success 'org-metaup-final-hook)) (t (org-drag-element-backward)))) (defun org-metadown (&optional _arg) "Move subtree down or move table row down. Calls `org-move-subtree-down' or `org-table-move-row' or -`org-move-item-down', depending on context. See the individual -commands for more information." +`org-move-item-down', depending on context. Everywhere else, +move forward the element at point. See the individual commands +for more information. + +This function runs the functions in `org-metadown-hook' one by +one as a first step, and exits immediately if a function from the +hook returns non-nil. In the absence of a specific context, the +function runs `org-metadown-final-hook' using the same logic." (interactive "P") (cond ((run-hook-with-args-until-success 'org-metadown-hook)) @@ -17033,13 +17116,24 @@ commands for more information." (org-drag-element-forward)) ((org-at-heading-p) (call-interactively 'org-move-subtree-down)) ((org-at-item-p) (call-interactively 'org-move-item-down)) + ((run-hook-with-args-until-success 'org-metadown-final-hook)) (t (org-drag-element-forward)))) (defun org-shiftup (&optional arg) "Act on current element according to context. Call `org-timestamp-up' or `org-priority-up', or `org-previous-item', or `org-table-move-cell-up'. See the -individual commands for more information." +individual commands for more information. + +This function runs the functions in `org-shiftup-hook' one by one +as a first step, and exits immediately if a function from the +hook returns non-nil. In the absence of a specific context, the +function also runs `org-shiftup-final-hook' using the same logic. + +If none of the previous steps succeed and +`org-support-shift-select' is non-nil, the function runs +`shift-select-mode' associated command. See that variable for +more information." (interactive "P") (cond ((run-hook-with-args-until-success 'org-shiftup-hook)) @@ -17067,7 +17161,18 @@ individual commands for more information." "Act on current element according to context. Call `org-timestamp-down' or `org-priority-down', or `org-next-item', or `org-table-move-cell-down'. See the -individual commands for more information." +individual commands for more information. + +This function runs the functions in `org-shiftdown-hook' one by +one as a first step, and exits immediately if a function from the +hook returns non-nil. In the absence of a specific context, the +function also runs `org-shiftdown-final-hook' using the same +logic. + +If none of the previous steps succeed and +`org-support-shift-select' is non-nil, the function runs +`shift-select-mode' associated command. See that variable for +more information." (interactive "P") (cond ((run-hook-with-args-until-success 'org-shiftdown-hook)) @@ -17100,7 +17205,16 @@ This does one of the following: - on an item, switch entire list to the next bullet type - on a property line, switch to the next allowed value - on a clocktable definition line, move time block into the future -- in a table, move a single cell right" +- in a table, move a single cell right + +This function runs the functions in `org-shiftright-hook' one by +one as a first step, and exits immediately if a function from the +hook returns non-nil. In the absence of a specific context, the +function runs `org-shiftright-final-hook' using the same logic. + +If none of the above succeeds and `org-support-shift-select' is +non-nil, runs `shift-select-mode' specific command. See that +variable for more information." (interactive "P") (cond ((run-hook-with-args-until-success 'org-shiftright-hook)) @@ -17140,7 +17254,16 @@ This does one of the following: - on an item, switch entire list to the previous bullet type - on a property line, switch to the previous allowed value - on a clocktable definition line, move time block into the past -- in a table, move a single cell left" +- in a table, move a single cell left + +This function runs the functions in `org-shiftleft-hook' one by +one as a first step, and exits immediately if a function from the +hook returns non-nil. In the absence of a specific context, the +function runs `org-shiftleft-final-hook' using the same logic. + +If none of the above succeeds and `org-support-shift-select' is +non-nil, runs `shift-select-mode' specific command. See that +variable for more information." (interactive "P") (cond ((run-hook-with-args-until-success 'org-shiftleft-hook)) -- 2.34.1 --=-=-=--