From: Nicolas Goaziou <mail@nicolasgoaziou.fr>
To: Kaushal Modi <kaushal.modi@gmail.com>
Cc: emacs-orgmode@gnu.org
Subject: Re: Add an optional HOLD argument to "n" Org macro
Date: Thu, 15 Jun 2017 18:07:28 +0200 [thread overview]
Message-ID: <871sqli69r.fsf@nicolasgoaziou.fr> (raw)
In-Reply-To: <CAFyQvY3EmjqoFBYu_PkiGTJoNzt_ZW7pwRCTVCMZh24MSNxJQQ@mail.gmail.com> (Kaushal Modi's message of "Thu, 15 Jun 2017 15:25:42 +0000")
Hello,
Kaushal Modi <kaushal.modi@gmail.com> writes:
> On Thu, Jun 15, 2017 at 9:10 AM Kaushal Modi <kaushal.modi@gmail.com> wrote:
>
>> The patch based off latest master is attached. Please review.
Thank you. Some comments follow.
> This patch adds a dependency on subr-x library for string-trim function
> that was added in emacs 24.4.
We do not need this dependency. In particular, there is already
`org-trim'.
> * lisp/org-macro.el (org-macro--counter-increment): Rename the
> optional arg RESET to ACTION, as now that action can mean setting,
> resetting or even holding the specified counter. ACTION set to
> "hold" or "-" will hold the previous value of the counter.
It is confusing to provide two ways to achieve the same action. I'd
rather have "-" only.
> +Any other non-empty string resets the counter to 1."
> + (let ((action-trimmed (when (org-string-nw-p action)
> + (require 'subr-x)
> + (string-trim action))))
See above.
> + ;; Second argument set to "-" or "hold" holds the counter value.
> + (should
> + (equal "1.1 2.2 8.3 8.1 8.2 8.3 9.3 9.3"
> + (org-test-with-temp-text
> + (concat "{{{n(,-)}}}.{{{n(c)}}}" ;Hold before even starting the counter
> + " {{{n}}}.{{{n(c)}}}" ;Increment after hold
> + " {{{n(,8)}}}.{{{n(c)}}}"
> + " {{{n(,hold)}}}.{{{n(c,reset)}}}" ;Alternative hold arg
> + " {{{n(, - )}}}.{{{n(c)}}}" ;With spaces
> + " {{{n(, hold )}}}.{{{n(c)}}}" ;With spaces
> + " {{{n}}}.{{{n(c,hold)}}}" ;Hold on another counter
> + " {{{n(,hold)}}}.{{{n(c,-)}}}") ;Hold on both counters
> + (org-macro-initialize-templates)
> + (org-macro-replace-all org-macro-templates)
> + (buffer-substring-no-properties
> + (line-beginning-position) (line-end-position))))))
Could you split this into smaller tests, each one testing one feature?
Regards,
--
Nicolas Goaziou
next prev parent reply other threads:[~2017-06-15 16:07 UTC|newest]
Thread overview: 35+ messages / expand[flat|nested] mbox.gz Atom feed top
[not found] <2ee94a64a94b46259b0da6e7d34675c9@HE1PR01MB1898.eurprd01.prod.exchangelabs.com>
2017-05-08 14:00 ` [RFC] The "c" Org macro Eric S Fraga
2017-05-08 15:32 ` Dushyant Juneja
[not found] ` <a4c6d561b12a4cc8ad4fe8c017fa2121@HE1PR01MB1898.eurprd01.prod.exchangelabs.com>
2017-05-08 15:59 ` Eric S Fraga
2017-05-08 16:52 ` Nicolas Goaziou
2017-05-09 7:35 ` Carsten Dominik
2017-05-09 10:35 ` Nicolas Goaziou
2017-05-09 11:25 ` Rasmus
2017-05-09 16:10 ` Nicolas Goaziou
[not found] ` <2069df8c23bc43f3b04b6e203b96be9d@HE1PR01MB1898.eurprd01.prod.exchangelabs.com>
2017-05-11 8:45 ` Eric S Fraga
2017-05-21 13:37 ` Nicolas Goaziou
2017-05-22 3:24 ` Kaushal Modi
2017-05-22 5:58 ` Nicolas Goaziou
2017-05-22 10:46 ` Kaushal Modi
2017-05-22 11:47 ` Nicolas Goaziou
2017-05-22 13:00 ` Kaushal Modi
2017-05-22 13:10 ` Kaushal Modi
2017-05-22 13:13 ` Nicolas Goaziou
2017-05-22 13:39 ` Kaushal Modi
2017-05-25 10:42 ` Nicolas Goaziou
2017-05-25 18:31 ` Kaushal Modi
2017-06-14 17:52 ` Kaushal Modi
2017-06-14 18:33 ` Add an optional HOLD argument to "n" Org macro (Was: [RFC] The "c" Org macro) Kaushal Modi
2017-06-14 19:47 ` Add an optional HOLD argument to "n" Org macro Nicolas Goaziou
2017-06-15 13:10 ` Kaushal Modi
2017-06-15 15:25 ` Kaushal Modi
2017-06-15 16:07 ` Nicolas Goaziou [this message]
2017-06-15 18:07 ` Kaushal Modi
2017-06-17 14:34 ` Kaushal Modi
2017-06-17 23:24 ` Nicolas Goaziou
2017-06-18 4:03 ` Kaushal Modi
2017-06-18 7:16 ` Nicolas Goaziou
2017-06-18 7:45 ` Kaushal Modi
2017-06-14 19:44 ` [RFC] The "c" " Nicolas Goaziou
[not found] ` <a8f5841641834b4cb51af85a3df785da@HE1PR01MB1898.eurprd01.prod.exchangelabs.com>
2017-05-22 8:34 ` Eric S Fraga
2017-05-08 16:30 ` Robert Horn
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.orgmode.org/
* Reply using the --to, --cc, and --in-reply-to
switches of git-send-email(1):
git send-email \
--in-reply-to=871sqli69r.fsf@nicolasgoaziou.fr \
--to=mail@nicolasgoaziou.fr \
--cc=emacs-orgmode@gnu.org \
--cc=kaushal.modi@gmail.com \
/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/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).