Компиляция m4 1.4.10 к 1.4.18 сбоям, должным “Нравиться порту gnulib freadahead.c на Вашу платформу!” на Ubuntu 18.10

Здание tarball выпусков GNU m4 1.4.10 к 1.4.18 (не протестировал все версии текущих исправлений, но я предполагаю, что ошибка последовательна среди этого диапазона) с ./configure && make -j1 и мерзавец git репозиторий http://git.savannah.gnu.org/r/m4.git с ./bootstrap && ./configure && make -j1 (фиксация cvs-readonly-359-gd69fa528 т.е. HEAD из master) перестал работать из-за

freadahead.c: In function 'freadahead':
freadahead.c:92:3: error: #error "Please port gnulib freadahead.c to your platform! Look at the definition of fflush, fread, ungetc on your system, then report this to bug-gnulib."
  #error "Please port gnulib freadahead.c to your platform! Look at the definition of fflush, fread, ungetc on your system, then report this to bug-gnulib."
   ^~~~~
make[3]: *** [Makefile:1910: freadahead.o] Error 1
make[3]: Leaving directory '/mnt/data/sources/m4-1.4.18/lib'

Я очень смущен этой ошибкой, и по данным поверхностного Google ищут, проблемой является последствие чрезмерно долгого проигнорированного восходящего обновления, посмотрите, например, https://bugzilla.redhat.com/show_bug.cgi? id=1573342 с документацией гения фиксации "Спасибо за отчет об ошибках, исправленный!" - если это не помогает другим...

Я пытался создать glibc из источника и установить его в пользовательский префикс [1]. 2.28 и 2.27 показывают ту же проблему и 2,26 сбоя из-за

make[2]: Verzeichnis „/mnt/data/sources/glibc-2.26/inet“ wird betreten
gcc ../sysdeps/unix/sysv/linux/if_index.c -c -std=gnu11 -fgnu89-inline  -O2 -Wall -Werror -Wundef -Wwrite-strings -fmerge-all-constants -fno-stack-protector -frounding-math -g -Wstrict-prototypes -Wold-style-definition     -ftls-model=initial-exec   -U_FORTIFY_SOURCE   -I../include -I/mnt/data/sources/glibc-2.26-build/inet  -I/mnt/data/sources/glibc-2.26-build  -I../sysdeps/unix/sysv/linux/x86_64/64  -I../sysdeps/unix/sysv/linux/x86_64  -I../sysdeps/unix/sysv/linux/x86  -I../sysdeps/x86/nptl  -I../sysdeps/unix/sysv/linux/wordsize-64  -I../sysdeps/x86_64/nptl  -I../sysdeps/unix/sysv/linux/include -I../sysdeps/unix/sysv/linux  -I../sysdeps/nptl  -I../sysdeps/pthread  -I../sysdeps/gnu  -I../sysdeps/unix/inet  -I../sysdeps/unix/sysv  -I../sysdeps/unix/x86_64  -I../sysdeps/unix  -I../sysdeps/posix  -I../sysdeps/x86_64/64  -I../sysdeps/x86_64/fpu/multiarch  -I../sysdeps/x86_64/fpu  -I../sysdeps/x86/fpu/include -I../sysdeps/x86/fpu  -I../sysdeps/x86_64/multiarch  -I../sysdeps/x86_64  -I../sysdeps/x86  -I../sysdeps/ieee754/float128  -I../sysdeps/ieee754/ldbl-96/include -I../sysdeps/ieee754/ldbl-96  -I../sysdeps/ieee754/dbl-64/wordsize-64  -I../sysdeps/ieee754/dbl-64  -I../sysdeps/ieee754/flt-32  -I../sysdeps/wordsize-64  -I../sysdeps/ieee754  -I../sysdeps/generic  -I.. -I../libio -I.   -D_LIBC_REENTRANT -include /mnt/data/sources/glibc-2.26-build/libc-modules.h -DMODULE_NAME=libc -include ../include/libc-symbols.h  -DPIC     -DTOP_NAMESPACE=glibc -o /mnt/data/sources/glibc-2.26-build/inet/if_index.o -MD -MP -MF /mnt/data/sources/glibc-2.26-build/inet/if_index.o.dt -MT /mnt/data/sources/glibc-2.26-build/inet/if_index.o
../sysdeps/unix/sysv/linux/if_index.c: In function ‘__if_nametoindex’:
../sysdeps/unix/sysv/linux/if_index.c:46:3: error: ‘strncpy’ specified bound 16 equals destination size [-Werror=stringop-truncation]
   strncpy (ifr.ifr_name, ifname, sizeof (ifr.ifr_name));
   ^~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
cc1: all warnings being treated as errors
make[2]: *** [/mnt/data/sources/glibc-2.26-build/sysd-rules:213: /mnt/data/sources/glibc-2.26-build/inet/if_index.o] Fehler 1
make[2]: Verzeichnis „/mnt/data/sources/glibc-2.26/inet“ wird verlassen
make[1]: *** [Makefile:215: inet/subdir_lib] Fehler 2
make[1]: Verzeichnis „/mnt/data/sources/glibc-2.26“ wird verlassen
make: *** [Makefile:9: all] Fehler 2

и 2,25 должных к

strftime_l.c: In function ‘__strftime_internal’:
strftime_l.c:719:4: error: macro expands to multiple statements [-Werror=multistatement-macros]
    digits = d > width ? d : width;          \
    ^~~~~~
strftime_l.c:1260:6: note: in expansion of macro ‘DO_NUMBER’
      DO_NUMBER (1, tp->tm_year + TM_YEAR_BASE);
      ^~~~~~~~~
strftime_l.c:1259:4: note: some parts of macro expansion are not guarded by this ‘else’ clause
    else
    ^~~~
In file included from wcsftime_l.c:23:
strftime_l.c: In function ‘__strftime_internal’:
strftime_l.c:719:4: error: macro expands to multiple statements [-Werror=multistatement-macros]
    digits = d > width ? d : width;          \
    ^~~~~~
strftime_l.c:1260:6: note: in expansion of macro ‘DO_NUMBER’
      DO_NUMBER (1, tp->tm_year + TM_YEAR_BASE);
      ^~~~~~~~~
strftime_l.c:1259:4: note: some parts of macro expansion are not guarded by this ‘else’ clause
    else
    ^~~~
cc1: all warnings being treated as errors
make[2]: *** [../o-iterator.mk:9: /mnt/data/sources/glibc-2.25-build/time/strftime_l.os] Fehler 1

который заставил меня решить не испытать дальнейшую версию.

[Обсуждение отчета о подобной проблеме в findutils] предлагает перезаписать freadahead.{c,h} от актуального gnulib исходного корня. Это вызывает цепочку проблем, которая является ненужной к документу здесь, поскольку я не знаю то, что я делаю.

Как начать с фиксацией, созданием отчетов и/или работой вокруг этой проблемы?

Я создаю m4 из источника для сценария начальной загрузки для систем, где у пользователя нет полномочий использовать диспетчер пакетов. Я действительно просто интересуюсь созданием исходного GNU m4 из источника выпуска tarballs.

Обзор результатов сборки в других столь же пустых системах предоставлен в https://gitlab.com/krichter/m4/pipelines/36977411.


[1] В случае, если Вы занимаетесь расследованиями, это всегда устанавливает glibc в пользовательский префикс потому что установка в префиксе по умолчанию /usr/local будет несомненно моча Ваша система. Рассмотреть использование checkinstall быть уверенным.

1
задан 8 December 2018 в 19:20

2 ответа

Если Вы хотите создать m4 из источника, затем запускаются путем получения его зависимостей от сборки от репозитория:

  1. включите Исходный код в программном обеспечении и Обновлениях (software-properties-gtk)
  2. установите необходимые инструменты сборки

    sudo apt-get install build-essential
    
  3. получите необходимые зависимости от сборки для тока m4 двоичный пакет

    sudo apt-get build-dep m4
    
  4. получите исходный код тока m4 двоичный пакет (со всеми необходимыми патчами, обеспеченными Debian и/или Ubuntu):

    apt-get source m4
    cd m4-*
    
  5. затем скомпилируйте его, как обычно,

3
ответ дан 3 December 2019 в 07:22

Попытайтесь применить этот патч. Это - OpenEmbedded-сгенерированный бэкпорт восходящего патча.

0
ответ дан 3 December 2019 в 07:22

Другие вопросы по тегам:

Похожие вопросы: