AS_HELP_STRING несколько строк

Есть ли способ заставить AS_HELP_STRING (или есть альтернативный макрос) красиво отформатировать справку в несколько строк?

У меня есть --enable-option=, который может принимать несколько значений val1,val2,..., и я хочу, чтобы configure --help показывало одну строку справки для каждого значения.


person Alex    schedule 21.08.2015    source источник
comment
Меня это тоже очень раздражает, например, когда я хочу краткое описание различных опций под: --enable-foo[=yes] ... [basic description] — иногда это заставляет меня отказаться от AS_HELP_STRING и использовать отступы вручную, чтобы сообщение выглядело «красиво» .   -  person Brett Hale    schedule 21.08.2015
comment
Это (обычно) определено в ./share/autoconf/m4sugar/m4sh.m4, и я все время откладываю изучение M4. Это не ошибка, но запрос функции к сопровождающим autoconf может быть полезным. К сожалению, 2.7x давно не работает.   -  person Brett Hale    schedule 21.08.2015
comment
m4 должен быть макроязыком какого-то древнего инопланетянина...   -  person Alex    schedule 21.08.2015
comment
На самом деле это было написано на стенах древних неолитических пещер, и ошибочно считалось, что это иероглифы внутри пирамид.   -  person Brett Hale    schedule 21.08.2015
comment
Итак, глядя на m4sh.m4, он никак не может обработать несколько строк, как-нибудь заключить его в цикл? (Я взглянул на зацикливание с m4... отсюда и комментарий выше)   -  person Alex    schedule 21.08.2015


Ответы (1)


Я написал свой собственный макрос NA_HELP_STRINGS() для таких ситуаций:

dnl  NA_HELP_STRINGS(list1, help1[, list2, help2[, ... listN, helpN]])
dnl  **************************************************************************
dnl
dnl  Similar to `AS_HELP_STRING()`, but with support for multiple strings, each
dnl  one associated with one or more options
dnl
dnl  From: https://github.com/madmurphy/not-autotools
dnl
dnl  **************************************************************************
m4_define([NA_HELP_STRINGS],
    [m4_if(m4_count($1), [1],
        [m4_if([$#], [0], [], [$#], [1],
            [m4_text_wrap($1, [  ])],
            [AS_HELP_STRING(m4_normalize($1), [$2])m4_if([$#], [2], [], [m4_newline()NA_HELP_STRINGS(m4_shift2($@))])])],
        [m4_text_wrap(m4_argn(1, $1)[,], [  ])m4_newline()NA_HELP_STRINGS(m4_dquote(m4_shift($1))m4_if([$#], [1], [], [, m4_shift($@)]))])])

Пример использования:

AC_ARG_ENABLE([foo],
    [NA_HELP_STRINGS(
        [--disable-foo],
            [disable the `foo` feature; on some machines the package might not
            work properly without the `foo` feature enabled],
        [[--enable-foo], [--enable-foo=yes], [--enable-foo=enhanced]],
            [install this package with the `foo` feature enabled; if `foo` is
            enabled in `enhanced` mode Autoconf might get sentimental],
        [[--enable-foo=auto], [--enable-foo=check], [@<:@omitted@:>@]],
            [decide automatically whether it is opportune to enable the `foo`
            feature on this machine or not]
    )],
    [:],
    [AS_VAR_SET([enable_foo], ['check'])])

Вывод, когда пользователь запускает ./configure --help:

  --disable-foo           disable the `foo` feature; on some machines the
                          package might not work properly without the `foo`
                          feature enabled
  --enable-foo,
  --enable-foo=yes,
  --enable-foo=enhanced   install this package with the `foo` feature enabled;
                          if `foo` is enabled in `enhanced` mode Autoconf
                          might get sentimental
  --enable-foo=auto,
  --enable-foo=check,
  [omitted]               decide automatically whether it is opportune to
                          enable the `foo` feature on this machine or not

Дополнительные примеры в стиле m4 см. на странице Not Autotools проект.

person madmurphy    schedule 05.12.2019
comment
Спасибо @madmurphy, давно мне не приходилось использовать автоинструменты, принятые на веру - person Alex; 05.12.2019
comment
Спасибо, Бретт! У меня только что была дискуссия сегодня на моей конференции Not Autotools репозиторий о вкладе в архив Autoconf. Правда в том, что у меня не было бы на это времени. Кроме того, публикация макросов в репозитории с большой базой пользователей была бы довольно ответственной. Хотя я был бы рад, если бы кто-то заинтересованный опубликовал мои макросы в AX. - person madmurphy; 07.10.2020