Ошибка сборки "ISO C ++ запрещает массив нулевого размера 'f_handle' [-Wpedantic]" только при использовании Snapcraft VM - PullRequest
0 голосов
/ 11 марта 2020

Я использую инструменты командной строки catkin для сборки benchmark_catkin , которая является оболочкой catkin для теста Google. Сборка использует файл CMakeLists и до сих пор работала нормально на Ubuntu 18.04. Я сейчас пытаюсь собрать этот пакет с помощью snapcraft. Snapcraft имеет плагин catkin-tools и настраивает виртуальную машину перед сборкой. Однако теперь я получаю сообщение об ошибке из системной библиотеки, и сборка не удалась:

In file included from /root/parts/workspace/install/usr/include/x86_64-linux-gnu/bits/fcntl.h:61:0,
                 from /root/parts/workspace/install/usr/include/fcntl.h:35,
                 from /root/parts/workspace/build/benchmark_catkin/benchmark_src-prefix/src/benchmark_src/src/sysinfo.cc:23:
/root/parts/workspace/install/usr/include/x86_64-linux-gnu/bits/fcntl-linux.h:355:27: error: ISO C++ forbids zero-size array ‘f_handle’ [-Wpedantic]
   unsigned char f_handle[0];
                           ^
In file included from /root/parts/workspace/install/usr/include/x86_64-linux-gnu/bits/fcntl.h:61:0,
                 from /root/parts/workspace/install/usr/include/fcntl.h:35,
                 from /root/parts/workspace/build/benchmark_catkin/benchmark_src-prefix/src/benchmark_src/src/timers.cc:23:
/root/parts/workspace/install/usr/include/x86_64-linux-gnu/bits/fcntl-linux.h:355:27: error: ISO C++ forbids zero-size array ‘f_handle’ [-Wpedantic]
   unsigned char f_handle[0];
                           ^
make[5]: *** [src/CMakeFiles/benchmark.dir/sysinfo.cc.o] Error 1
make[5]: *** Waiting for unfinished jobs....
make[5]: *** [src/CMakeFiles/benchmark.dir/timers.cc.o] Error 1
make[4]: *** [src/CMakeFiles/benchmark.dir/all] Error 2
make[4]: *** Waiting for unfinished jobs....
make[3]: *** [all] Error 2
make[2]: *** [benchmark_src-prefix/src/benchmark_src-stamp/benchmark_src-build] Error 2
make[1]: *** [CMakeFiles/benchmark_src.dir/all] Error 2
make: *** [all] Error 2

Я предполагаю, что эта ошибка относится к массиву нулевого размера в библиотеке libc6-dev. Поскольку я использую base: core18 в своем snapcraft.yaml, а также использую систему Ubuntu 18.04, мне интересно, почему я просто получаю сообщение об ошибке в ВМ. Это ошибка в библиотеке? Как я могу решить эту проблему?


Для справки, мой файл snapcraft.yaml:

name: nav 
base: core18 
version: 'w1.0'
summary: The Nav Software  
description: |

grade: devel  
confinement: strict 

plugs:   
  network:
  network-bind:

parts: 

  core-dep:
    plugin: nil
    build-packages:
      - autoconf
      - libtool
      - git

  workspace:
    plugin: catkin-tools
    source: .
    catkin-packages: [catkin_simple, glog_catkin, gflags_catkin, benchmark_catkin]
    after: [core-dep]

По запросу, здесь код вокруг ошибочной строки / usr / include / x86_64 - linux -gnu / bits / fcntl- linux .h:

/* File handle structure.  */
struct file_handle
{
  unsigned int handle_bytes;
  int handle_type;
  /* File identifier.  */
  unsigned char f_handle[0];
};

1 Ответ

2 голосов
/ 11 марта 2020

Я посмотрел в проект. CMakeLists.txt из benchmark_catkin внутренне проверяет google / benchmark и создает его. Ошибка происходит из этой сборки.

CMakeLists.txt google / benchmark устанавливает тонны опций компилятора и, в частности, -pedanti c -errors (а также -pedanti c и -Werror), который вызывает компилятор, чтобы остановить любое использование языкового расширения. Честно говоря, по моему мнению, CMakeLists.txt не должен устанавливать какие-либо предупреждающие флаги и, в частности, не устанавливать флаги -Werror или -pedanti c без ошибок пользователя, поэтому я считаю, что это ошибка, но разработчики Google могут не согласиться.

Заголовок glib c использует расширение языка. Но это нормально, потому что предупреждения в системных заголовках следует игнорировать. Таким образом, настоящей причиной сбоя сборки является неспособность считать заголовок glib c системным заголовком.

Я ничего не знаю о snapcraft, но подозреваю, что причина проблемы там.

...