* RFE: Capture: property prompt: default completion @ 2020-09-12 18:20 Phil Hudson 2020-09-13 23:32 ` Phil Hudson 0 siblings, 1 reply; 8+ messages in thread From: Phil Hudson @ 2020-09-12 18:20 UTC (permalink / raw) To: emacs orgmode-mailinglist I'd like us to add the ability to provide a default completion value for a property prompt in a capture template, as already exists for a non-property prompt. So where at the moment we can have: %^{prompt|default|completion2|completion3|...} I want, by analogy: %^{prop|default}p with the remaining completions provided by the #+prop_ALL in-buffer setting, and with the implied constraint that "default" is a member of that set. ^ permalink raw reply [flat|nested] 8+ messages in thread
* Re: RFE: Capture: property prompt: default completion 2020-09-12 18:20 RFE: Capture: property prompt: default completion Phil Hudson @ 2020-09-13 23:32 ` Phil Hudson 2020-09-14 8:20 ` [PATCH] " Phil Hudson 0 siblings, 1 reply; 8+ messages in thread From: Phil Hudson @ 2020-09-13 23:32 UTC (permalink / raw) To: emacs orgmode-mailinglist [-- Attachment #1: Type: text/plain, Size: 604 bytes --] On Sat, 12 Sep 2020 at 19:20, Phil Hudson <phil.hudson@iname.com> wrote: > > I'd like us to add the ability to provide a default completion value > for a property prompt in a capture template, as already exists for a > non-property prompt. > > So where at the moment we can have: > > %^{prompt|default|completion2|completion3|...} > > I want, by analogy: > > %^{prop|default}p > > with the remaining completions provided by the #+prop_ALL in-buffer > setting, and with the implied constraint that "default" is a member of > that set. I'm going to take silence for consent, then. Patch attached. [-- Attachment #2: org-capture-default-for-property.patch --] [-- Type: text/x-patch, Size: 2879 bytes --] diff --git a/doc/org-manual.org b/doc/org-manual.org index 46498bd22..659e3ffaf 100644 --- a/doc/org-manual.org +++ b/doc/org-manual.org @@ -7854,7 +7854,8 @@ here: - =%^{PROP}p= :: - Prompt the user for a value for property {{{var(PROP)}}}. + Prompt the user for a value for property {{{var(PROP)}}}. You may + specify a default value with =%^{PROP|default}=. - =%^{PROMPT}= :: diff --git a/lisp/org-capture.el b/lisp/org-capture.el index d9c8472b9..de2e19a8b 100644 --- a/lisp/org-capture.el +++ b/lisp/org-capture.el @@ -331,8 +331,10 @@ be replaced with content and expanded: %^C Interactive selection of which kill or clip to use. %^L Like %^C, but insert as link. %^{prop}p Prompt the user for a value for property `prop'. + A default value can be specified like this: + %^{prop|default}p. %^{prompt} Prompt the user for a string and replace this sequence with it. - A default value and a completion table ca be specified like this: + A default value and a completion table can be specified like this: %^{prompt|default|completion2|completion3|...}. %? After completing the template, position cursor here. %\\1 ... %\\N Insert the text entered at the nth %^{prompt}, where N @@ -1782,7 +1784,8 @@ The template may still contain \"%?\" for cursor positioning." (setq l (org-up-heading-safe))) (if l (point-marker) (point-min-marker))))))) - (value (org-read-property-value prompt pom))) + (value + (org-read-property-value prompt pom default))) (org-set-property prompt value))) ((or "t" "T" "u" "U") ;; These are the date/time related ones. diff --git a/lisp/org.el b/lisp/org.el index 3264694aa..4077530f1 100644 --- a/lisp/org.el +++ b/lisp/org.el @@ -13300,11 +13300,12 @@ This is computed according to `org-property-set-functions-alist'." (or (cdr (assoc property org-property-set-functions-alist)) 'org-completing-read)) -(defun org-read-property-value (property &optional pom) +(defun org-read-property-value (property &optional pom default) "Read value for PROPERTY, as a string. When optional argument POM is non-nil, completion uses additional information, i.e., allowed or existing values at point or marker -POM." +POM. +Optional argument DEFAULT provides a default value for PROPERTY." (let* ((completion-ignore-case t) (allowed (or (org-property-get-allowed-values nil property 'table) @@ -13320,7 +13321,8 @@ POM." (if allowed (funcall set-function prompt allowed nil - (not (get-text-property 0 'org-unrestricted (caar allowed)))) + (not (get-text-property 0 'org-unrestricted (caar allowed))) + default nil default) (let ((all (mapcar #'list (append (org-property-values property) (and pom ^ permalink raw reply related [flat|nested] 8+ messages in thread
* [PATCH] Re: RFE: Capture: property prompt: default completion 2020-09-13 23:32 ` Phil Hudson @ 2020-09-14 8:20 ` Phil Hudson 2020-09-23 7:21 ` Bastien 0 siblings, 1 reply; 8+ messages in thread From: Phil Hudson @ 2020-09-14 8:20 UTC (permalink / raw) To: emacs orgmode-mailinglist [-- Attachment #1: Type: text/plain, Size: 727 bytes --] Sorry, should have changed the subject. Re-sending patch (no alterations). On Mon, 14 Sep 2020 at 00:32, Phil Hudson <phil.hudson@iname.com> wrote: > > On Sat, 12 Sep 2020 at 19:20, Phil Hudson <phil.hudson@iname.com> wrote: > > > > I'd like us to add the ability to provide a default completion value > > for a property prompt in a capture template, as already exists for a > > non-property prompt. > > > > So where at the moment we can have: > > > > %^{prompt|default|completion2|completion3|...} > > > > I want, by analogy: > > > > %^{prop|default}p > > > > with the remaining completions provided by the #+prop_ALL in-buffer > > setting, and with the implied constraint that "default" is a member of > > that set. [-- Attachment #2: org-capture-default-for-property.patch --] [-- Type: text/x-patch, Size: 2879 bytes --] diff --git a/doc/org-manual.org b/doc/org-manual.org index 46498bd22..659e3ffaf 100644 --- a/doc/org-manual.org +++ b/doc/org-manual.org @@ -7854,7 +7854,8 @@ here: - =%^{PROP}p= :: - Prompt the user for a value for property {{{var(PROP)}}}. + Prompt the user for a value for property {{{var(PROP)}}}. You may + specify a default value with =%^{PROP|default}=. - =%^{PROMPT}= :: diff --git a/lisp/org-capture.el b/lisp/org-capture.el index d9c8472b9..de2e19a8b 100644 --- a/lisp/org-capture.el +++ b/lisp/org-capture.el @@ -331,8 +331,10 @@ be replaced with content and expanded: %^C Interactive selection of which kill or clip to use. %^L Like %^C, but insert as link. %^{prop}p Prompt the user for a value for property `prop'. + A default value can be specified like this: + %^{prop|default}p. %^{prompt} Prompt the user for a string and replace this sequence with it. - A default value and a completion table ca be specified like this: + A default value and a completion table can be specified like this: %^{prompt|default|completion2|completion3|...}. %? After completing the template, position cursor here. %\\1 ... %\\N Insert the text entered at the nth %^{prompt}, where N @@ -1782,7 +1784,8 @@ The template may still contain \"%?\" for cursor positioning." (setq l (org-up-heading-safe))) (if l (point-marker) (point-min-marker))))))) - (value (org-read-property-value prompt pom))) + (value + (org-read-property-value prompt pom default))) (org-set-property prompt value))) ((or "t" "T" "u" "U") ;; These are the date/time related ones. diff --git a/lisp/org.el b/lisp/org.el index 3264694aa..4077530f1 100644 --- a/lisp/org.el +++ b/lisp/org.el @@ -13300,11 +13300,12 @@ This is computed according to `org-property-set-functions-alist'." (or (cdr (assoc property org-property-set-functions-alist)) 'org-completing-read)) -(defun org-read-property-value (property &optional pom) +(defun org-read-property-value (property &optional pom default) "Read value for PROPERTY, as a string. When optional argument POM is non-nil, completion uses additional information, i.e., allowed or existing values at point or marker -POM." +POM. +Optional argument DEFAULT provides a default value for PROPERTY." (let* ((completion-ignore-case t) (allowed (or (org-property-get-allowed-values nil property 'table) @@ -13320,7 +13321,8 @@ POM." (if allowed (funcall set-function prompt allowed nil - (not (get-text-property 0 'org-unrestricted (caar allowed)))) + (not (get-text-property 0 'org-unrestricted (caar allowed))) + default nil default) (let ((all (mapcar #'list (append (org-property-values property) (and pom ^ permalink raw reply related [flat|nested] 8+ messages in thread
* Re: [PATCH] Re: RFE: Capture: property prompt: default completion 2020-09-14 8:20 ` [PATCH] " Phil Hudson @ 2020-09-23 7:21 ` Bastien 2020-09-23 9:55 ` Phil Hudson 0 siblings, 1 reply; 8+ messages in thread From: Bastien @ 2020-09-23 7:21 UTC (permalink / raw) To: Phil Hudson; +Cc: emacs orgmode-mailinglist Hi Phil, Phil Hudson <phil.hudson@iname.com> writes: > Sorry, should have changed the subject. Re-sending patch (no alterations). It looks good to me. Can you update your patch by adding a proper commit message? See https://orgmode.org/worg/org-contribute.html#commit-messages Thanks a lot, -- Bastien ^ permalink raw reply [flat|nested] 8+ messages in thread
* Re: [PATCH] Re: RFE: Capture: property prompt: default completion 2020-09-23 7:21 ` Bastien @ 2020-09-23 9:55 ` Phil Hudson 2020-09-23 11:15 ` Bastien 0 siblings, 1 reply; 8+ messages in thread From: Phil Hudson @ 2020-09-23 9:55 UTC (permalink / raw) To: Bastien; +Cc: emacs orgmode-mailinglist [-- Attachment #1: Type: text/plain, Size: 210 bytes --] On Wed, 23 Sep 2020 at 08:21, Bastien <bzg@gnu.org> wrote: > It looks good to me. > > Can you update your patch by adding a proper commit message? Herewith. Hope I've got it right. I've signed the FSF papers. [-- Attachment #2: org-capture-default-for-property.patch --] [-- Type: text/x-patch, Size: 3320 bytes --] org-capture.el: Give a default value when prompting for a property * lisp/org-capture.el (org-capture-templates, org-capture-fill-template): Enable declaring a default value when prompting for a property during capture. * lisp/org.el (org-read-property-value): Add parameter DEFAULT for an initial/default/suggested property value. * doc/org-manual.org: Document declaring a default value for a prompted property during capture. diff --git a/doc/org-manual.org b/doc/org-manual.org index 46498bd22..659e3ffaf 100644 --- a/doc/org-manual.org +++ b/doc/org-manual.org @@ -7854,7 +7854,8 @@ here: - =%^{PROP}p= :: - Prompt the user for a value for property {{{var(PROP)}}}. + Prompt the user for a value for property {{{var(PROP)}}}. You may + specify a default value with =%^{PROP|default}=. - =%^{PROMPT}= :: diff --git a/lisp/org-capture.el b/lisp/org-capture.el index d9c8472b9..de2e19a8b 100644 --- a/lisp/org-capture.el +++ b/lisp/org-capture.el @@ -331,8 +331,10 @@ be replaced with content and expanded: %^C Interactive selection of which kill or clip to use. %^L Like %^C, but insert as link. %^{prop}p Prompt the user for a value for property `prop'. + A default value can be specified like this: + %^{prop|default}p. %^{prompt} Prompt the user for a string and replace this sequence with it. - A default value and a completion table ca be specified like this: + A default value and a completion table can be specified like this: %^{prompt|default|completion2|completion3|...}. %? After completing the template, position cursor here. %\\1 ... %\\N Insert the text entered at the nth %^{prompt}, where N @@ -1782,7 +1784,8 @@ The template may still contain \"%?\" for cursor positioning." (setq l (org-up-heading-safe))) (if l (point-marker) (point-min-marker))))))) - (value (org-read-property-value prompt pom))) + (value + (org-read-property-value prompt pom default))) (org-set-property prompt value))) ((or "t" "T" "u" "U") ;; These are the date/time related ones. diff --git a/lisp/org.el b/lisp/org.el index 3264694aa..4077530f1 100644 --- a/lisp/org.el +++ b/lisp/org.el @@ -13300,11 +13300,12 @@ This is computed according to `org-property-set-functions-alist'." (or (cdr (assoc property org-property-set-functions-alist)) 'org-completing-read)) -(defun org-read-property-value (property &optional pom) +(defun org-read-property-value (property &optional pom default) "Read value for PROPERTY, as a string. When optional argument POM is non-nil, completion uses additional information, i.e., allowed or existing values at point or marker -POM." +POM. +Optional argument DEFAULT provides a default value for PROPERTY." (let* ((completion-ignore-case t) (allowed (or (org-property-get-allowed-values nil property 'table) @@ -13320,7 +13321,8 @@ POM." (if allowed (funcall set-function prompt allowed nil - (not (get-text-property 0 'org-unrestricted (caar allowed)))) + (not (get-text-property 0 'org-unrestricted (caar allowed))) + default nil default) (let ((all (mapcar #'list (append (org-property-values property) (and pom ^ permalink raw reply related [flat|nested] 8+ messages in thread
* Re: [PATCH] Re: RFE: Capture: property prompt: default completion 2020-09-23 9:55 ` Phil Hudson @ 2020-09-23 11:15 ` Bastien 2020-09-23 11:40 ` Phil Hudson 0 siblings, 1 reply; 8+ messages in thread From: Bastien @ 2020-09-23 11:15 UTC (permalink / raw) To: Phil Hudson; +Cc: emacs orgmode-mailinglist Phil Hudson <phil.hudson@iname.com> writes: > On Wed, 23 Sep 2020 at 08:21, Bastien <bzg@gnu.org> wrote: >> It looks good to me. >> >> Can you update your patch by adding a proper commit message? > > Herewith. Hope I've got it right. I've signed the FSF papers. Sorry, I should have mentioned this, but the patch does not apply on master. If you have time to merge recent changes and reformat it, I can apply it right afterwarsds, otherwise I will try to do it myself later this week. Thanks, -- Bastien ^ permalink raw reply [flat|nested] 8+ messages in thread
* Re: [PATCH] Re: RFE: Capture: property prompt: default completion 2020-09-23 11:15 ` Bastien @ 2020-09-23 11:40 ` Phil Hudson 2020-09-23 12:12 ` Bastien 0 siblings, 1 reply; 8+ messages in thread From: Phil Hudson @ 2020-09-23 11:40 UTC (permalink / raw) To: Bastien; +Cc: emacs orgmode-mailinglist [-- Attachment #1: Type: text/plain, Size: 308 bytes --] On Wed, 23 Sep 2020 at 12:15, Bastien <bzg@gnu.org> wrote: > > Sorry, I should have mentioned this, but the patch does not apply on > master. If you have time to merge recent changes and reformat it, I > can apply it right afterwarsds, otherwise I will try to do it myself > later this week. OK, herewith. [-- Attachment #2: org-capture-default-for-property.patch --] [-- Type: text/x-patch, Size: 3099 bytes --] org-capture.el: Give a default value when prompting for a property * lisp/org-capture.el (org-capture-templates, org-capture-fill-template): Enable declaring a default value when prompting for a property during capture. * lisp/org.el (org-read-property-value): Add parameter DEFAULT for an initial/default/suggested property value. * doc/org-manual.org: Document declaring a default value for a prompted property during capture. diff --git a/doc/org-manual.org b/doc/org-manual.org index 043f2ddd1..e7d25b90e 100644 --- a/doc/org-manual.org +++ b/doc/org-manual.org @@ -7858,7 +7858,8 @@ here: - =%^{PROP}p= :: - Prompt the user for a value for property {{{var(PROP)}}}. + Prompt the user for a value for property {{{var(PROP)}}}. You may + specify a default value with =%^{PROP|default}=. - =%^{PROMPT}= :: diff --git a/lisp/org-capture.el b/lisp/org-capture.el index 2ef55cd5c..9ea0e9e73 100644 --- a/lisp/org-capture.el +++ b/lisp/org-capture.el @@ -332,6 +332,8 @@ be replaced with content and expanded: %^C Interactive selection of which kill or clip to use. %^L Like %^C, but insert as link. %^{prop}p Prompt the user for a value for property `prop'. + A default value can be specified like this: + %^{prop|default}p. %^{prompt} Prompt the user for a string and replace this sequence with it. A default value and a completion table can be specified like this: %^{prompt|default|completion2|completion3|...}. @@ -1787,7 +1789,8 @@ The template may still contain \"%?\" for cursor positioning." (setq l (org-up-heading-safe))) (if l (point-marker) (point-min-marker))))))) - (value (org-read-property-value prompt pom))) + (value + (org-read-property-value prompt pom default))) (org-set-property prompt value))) ((or "t" "T" "u" "U") ;; These are the date/time related ones. diff --git a/lisp/org.el b/lisp/org.el index d45a789f2..ec336c723 100644 --- a/lisp/org.el +++ b/lisp/org.el @@ -13300,11 +13300,12 @@ This is computed according to `org-property-set-functions-alist'." (or (cdr (assoc property org-property-set-functions-alist)) 'org-completing-read)) -(defun org-read-property-value (property &optional pom) +(defun org-read-property-value (property &optional pom default) "Read value for PROPERTY, as a string. When optional argument POM is non-nil, completion uses additional information, i.e., allowed or existing values at point or marker -POM." +POM. +Optional argument DEFAULT provides a default value for PROPERTY." (let* ((completion-ignore-case t) (allowed (or (org-property-get-allowed-values nil property 'table) @@ -13320,7 +13321,8 @@ POM." (if allowed (funcall set-function prompt allowed nil - (not (get-text-property 0 'org-unrestricted (caar allowed)))) + (not (get-text-property 0 'org-unrestricted (caar allowed))) + default nil default) (let ((all (mapcar #'list (append (org-property-values property) (and pom ^ permalink raw reply related [flat|nested] 8+ messages in thread
* Re: [PATCH] Re: RFE: Capture: property prompt: default completion 2020-09-23 11:40 ` Phil Hudson @ 2020-09-23 12:12 ` Bastien 0 siblings, 0 replies; 8+ messages in thread From: Bastien @ 2020-09-23 12:12 UTC (permalink / raw) To: Phil Hudson; +Cc: emacs orgmode-mailinglist Phil Hudson <phil.hudson@iname.com> writes: > On Wed, 23 Sep 2020 at 12:15, Bastien <bzg@gnu.org> wrote: >> >> Sorry, I should have mentioned this, but the patch does not apply on >> master. If you have time to merge recent changes and reformat it, I >> can apply it right afterwarsds, otherwise I will try to do it myself >> later this week. > > OK, herewith. Applied, thanks! -- Bastien ^ permalink raw reply [flat|nested] 8+ messages in thread
end of thread, other threads:[~2020-09-23 12:13 UTC | newest] Thread overview: 8+ messages (download: mbox.gz follow: Atom feed -- links below jump to the message on this page -- 2020-09-12 18:20 RFE: Capture: property prompt: default completion Phil Hudson 2020-09-13 23:32 ` Phil Hudson 2020-09-14 8:20 ` [PATCH] " Phil Hudson 2020-09-23 7:21 ` Bastien 2020-09-23 9:55 ` Phil Hudson 2020-09-23 11:15 ` Bastien 2020-09-23 11:40 ` Phil Hudson 2020-09-23 12:12 ` Bastien
Code repositories for project(s) associated with this public inbox https://git.savannah.gnu.org/cgit/emacs/org-mode.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).