all messages for Guix-related lists mirrored at yhetil.org
 help / color / mirror / code / Atom feed
From: Eric Bavier <ericbavier@openmailbox.org>
To: Mathieu Lirzin <mthl@gnu.org>
Cc: guix-devel@gnu.org
Subject: Re: [PATCH 06/13] build: Generate man pages after compiling guile objects.
Date: Fri, 29 Jan 2016 10:46:55 -0600	[thread overview]
Message-ID: <a2f7bede1bdbd72fec77826bab045466@openmailbox.org> (raw)
In-Reply-To: <87y4b8nywm.fsf@gnu.org>

On 2016-01-29 10:17, Mathieu Lirzin wrote:
> Eric Bavier <ericbavier@openmailbox.org> writes:
> 
>> On Thu, 28 Jan 2016 18:00:35 +0100
>> Mathieu Lirzin <mthl@gnu.org> wrote:
>> 
>>> OTOH I must admit that for maintainability reasons I would prefer
>>> avoiding complexity in Makefiles as much as possible.  This means
>>> using Automake's abstract concepts as much as possible, having a
>>> simple dependency graph on top of that, and put things that don't fit
>>> well in this scheme in individual "build-aux/" scripts.  For that
>>> reason I still prefer the embed help2man solution.  but otherwise it
>>> looks nice.  :)
>> 
>> I sympathize with the concerns for maintainability.  In this case, it
>> seems to me that a few lines of make/shell would be preferable to 20k
>> lines of perl.  Perhaps the simpler attached patch is better?
> 
> A few lines of Make/Shell seems more maintainable than a full perl
> program.  But in this case the maintenance is handled upstream, so it
> only consists in updating the script periodically (which is still not
> ideal).
> 
> Your patch is definitely better now since the hack is localized to a
> specific target.  Let's use this solution!  I have attached an updated
> version which simplifies how silent rules are handled and integrates
> changes from my initial patch.
> 
> Are you OK with it?

> This improves compilation speed since scripts are not compiled twice.

It helps immensely on my little netbook :)

> +# Man pages are generated using GNU help2man.
> +gen_man = LANGUAGE= $(top_builddir)/pre-inst-env $(HELP2MAN)

I like what you did with sub_commands_mans and gen_man

> +doc/guix-%.1: guix/scripts/%.scm $(GOBJECTS)
> +	-$(AM_V_HELP2MAN)case '$?' in \
> +	  *$<*) $(gen_man) --output="$@" "guix `basename "$<" .scm`";; \
> +	  *)    : ;; \
> +	esac

The `basename "$<" .scm` could be reduced to $* here.

In my patch I was trying to avoid printing the case et al in verbose 
mode.  This should be fine though; anyone reading the output of a 
verbose build might not be put off my the sh.

The rest LGTM!

> ps: I was speaking of 20KB (790 lines of perl) not 20K lines of code.
> :)

heh :)

-- 
`~Eric

  reply	other threads:[~2016-01-29 16:47 UTC|newest]

Thread overview: 65+ messages / expand[flat|nested]  mbox.gz  Atom feed  top
2016-01-24 20:19 [PATCH 00/13] New syntax 'package@version' and compilation improvements Mathieu Lirzin
2016-01-24 20:19 ` [PATCH 01/13] tests: Use 'dummy-origin' for lint tests when possible Mathieu Lirzin
2016-01-26 15:58   ` Ludovic Courtès
2016-01-24 20:19 ` [PATCH 02/13] lint: Remove an unneeded clause in 'check-patch-file-names' Mathieu Lirzin
2016-01-26 16:00   ` Ludovic Courtès
2016-01-24 20:19 ` [PATCH 03/13] lint: Rewrite 'check-patch-file-names' Mathieu Lirzin
2016-01-26 16:01   ` Ludovic Courtès
2016-01-24 20:19 ` [PATCH 04/13] utils: Use '@' for separating package names and version numbers Mathieu Lirzin
2016-01-25 11:37   ` Alex Kost
2016-01-25 20:56     ` Mathieu Lirzin
2016-01-26 16:22       ` Ludovic Courtès
2016-01-26 20:52         ` Mathieu Lirzin
2016-01-26 21:08           ` Ludovic Courtès
2016-02-19 20:49         ` Mathieu Lirzin
2016-02-23 11:11           ` Ludovic Courtès
2016-02-29  0:28             ` Mathieu Lirzin
2016-02-29 16:00               ` Ludovic Courtès
2016-03-02 21:35                 ` Mathieu Lirzin
2016-03-05  1:28                 ` Nils Gillmann
2016-03-05  9:24                   ` Alex Kost
2016-03-05  9:36                   ` Mathieu Lirzin
2016-03-03 10:29               ` Alex Kost
2016-03-03 16:55                 ` Ludovic Courtès
2016-03-04 10:19                   ` Alex Kost
2016-03-04 23:03                 ` Mathieu Lirzin
2016-03-04 23:25                   ` Ludovic Courtès
2016-03-05  1:08                     ` Mathieu Lirzin
2016-03-05  9:16                   ` Alex Kost
2016-01-25 14:04   ` Thompson, David
2016-01-25 21:41     ` Mathieu Lirzin
2016-01-25 23:33       ` Alex Kost
2016-01-26 17:57         ` Mathieu Lirzin
2016-01-24 20:19 ` [PATCH 05/13] packages: Use '@' in package record printers Mathieu Lirzin
2016-01-26 16:22   ` Ludovic Courtès
2016-01-24 20:19 ` [PATCH 06/13] build: Generate man pages after compiling guile objects Mathieu Lirzin
2016-01-26 16:52   ` Ludovic Courtès
2016-01-26 20:08     ` Mathieu Lirzin
2016-01-28  2:37       ` Eric Bavier
2016-01-28 15:44         ` Mathieu Lirzin
2016-01-28 15:59           ` Eric Bavier
2016-01-28 17:00             ` Mathieu Lirzin
2016-01-29  0:27               ` Eric Bavier
2016-01-29 16:17                 ` Mathieu Lirzin
2016-01-29 16:46                   ` Eric Bavier [this message]
2016-01-29 22:56                     ` Mathieu Lirzin
2016-01-31  9:17                       ` Ludovic Courtès
2016-01-24 20:19 ` [PATCH 07/13] build: Add 'DL' silent rule Mathieu Lirzin
2016-01-26 16:28   ` Ludovic Courtès
2016-01-26 17:44     ` Mathieu Lirzin
2016-01-26 19:22       ` Taylan Ulrich Bayırlı/Kammer
2016-01-26 21:06       ` Ludovic Courtès
2016-01-26 21:14         ` Mathieu Lirzin
2016-01-24 20:19 ` [PATCH 08/13] build: Add 'DOT' " Mathieu Lirzin
2016-01-26 16:28   ` Ludovic Courtès
2016-01-24 20:19 ` [PATCH 09/13] build: Add 'EMACS' " Mathieu Lirzin
2016-01-26 16:28   ` Ludovic Courtès
2016-01-24 20:19 ` [PATCH 10/13] build: Add 'HELP2MAN' " Mathieu Lirzin
2016-01-26 16:29   ` Ludovic Courtès
2016-01-24 20:19 ` [PATCH 11/13] build: Delete emacs/guix-autoloads.el when 'make clean' Mathieu Lirzin
2016-01-26 16:33   ` Ludovic Courtès
2016-01-26 22:55     ` Mathieu Lirzin
2016-01-24 20:19 ` [PATCH 12/13] build: Use 'GEN' and 'at' silent rules Mathieu Lirzin
2016-01-26 16:34   ` Ludovic Courtès
2016-01-24 20:19 ` [PATCH 13/13] Update .gitignore Mathieu Lirzin
2016-01-26 16:34   ` Ludovic Courtès

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

* Reply using the --to, --cc, and --in-reply-to
  switches of git-send-email(1):

  git send-email \
    --in-reply-to=a2f7bede1bdbd72fec77826bab045466@openmailbox.org \
    --to=ericbavier@openmailbox.org \
    --cc=guix-devel@gnu.org \
    --cc=mthl@gnu.org \
    /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 external index

	https://git.savannah.gnu.org/cgit/guix.git

This is an external index of several public inboxes,
see mirroring instructions on how to clone and mirror
all data and code used by this external index.