unofficial mirror of bug-guix@gnu.org 
 help / color / mirror / code / Atom feed
* bug#36772: feature request: checked variant of "substitute*"
@ 2019-07-23 12:49 Robert Vollmert
  2019-07-23 13:35 ` Ricardo Wurmus
  0 siblings, 1 reply; 4+ messages in thread
From: Robert Vollmert @ 2019-07-23 12:49 UTC (permalink / raw)
  To: 36772

I think it would be great to have the following variant of substitute*:

(substitute*-once filename (pattern vars) body)

which acts like the usual substitute-*, except it also asserts that the
substitution applies to exactly one line in the file, causing a build
failure otherwise.

In the cases where this is sufficient (I believe most), it would make
substitution work quite a bit more reliably, making it both easier to
debug substitution when first packaging, and noticing more easily when
they need to be adapted on upgrades.

(It would be possible to make the signature a bit more flexible and to
allow multiple files or patterns as in substitute*, but that would
make the meaning of “applies exactly once” a bit unclear, so I’d prefer
to not do that. Similarly, I find it cleaner to potentially call
substitute*-once several times in a row with different substitutions to
make the ordering of effects explicit.)

(I’d be happy to supply a patch myself eventually, but the syntax rule
business is a bit out of reach at this point.)

^ permalink raw reply	[flat|nested] 4+ messages in thread

end of thread, other threads:[~2019-07-25 17:41 UTC | newest]

Thread overview: 4+ messages (download: mbox.gz follow: Atom feed
-- links below jump to the message on this page --
2019-07-23 12:49 bug#36772: feature request: checked variant of "substitute*" Robert Vollmert
2019-07-23 13:35 ` Ricardo Wurmus
2019-07-23 13:41   ` Robert Vollmert
2019-07-25 17:40   ` Ludovic Courtès

Code repositories for project(s) associated with this public inbox

	https://git.savannah.gnu.org/cgit/guix.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).