Странная ошибка gcc: заблудиться в программе \ NNN - PullRequest
6 голосов
/ 25 октября 2009

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

У двух моих пользователей (gcc) есть ошибки компилятора, которые выглядят так:

/home/someone/Source/src/._regex.cpp:1:1: warning: null character(s) ignored
/home/someone/Source/src/._regex.cpp:1: error: stray ‘\5’ in program
/home/someone/Source/src/._regex.cpp:1: error: stray ‘\26’ in program
/home/someone/Source/src/._regex.cpp:1: error: stray ‘\7’ in program
/home/someone/Source/src/._regex.cpp:1:5: warning: null character(s) ignored
/home/someone/Source/src/._regex.cpp:1: error: stray ‘\2’ in program
...

Я не могу воспроизвести эти ошибки; код прекрасно компилируется на всех машинах, которые я тестировал.

Похоже, что поиск в Google указывает на то, что это часто является результатом странной кодировки или странного форматирования, но я пропустил весь источник через шестнадцатеричный редактор, и все символы могут быть либо ASCII для печати (0x20 - 0x7E), либо табуляцией, либо новая линия. Вот и все.

Также оба пользователя успешно скомпилировали предыдущую версию библиотеки; но конкретный рассматриваемый файл (regex.cpp) и его заголовочные файлы с тех пор не изменялись!

Пожалуйста, смотрите здесь для более подробной информации, включая ссылки для загрузки кода, если хотите. Но я был бы счастлив только указателем в возможном направлении.

Ответы [ 5 ]

13 голосов
/ 25 октября 2009

Ошибки в ._regex.cpp, а не regex.cpp. Файлы, начинающиеся с ._, автоматически создаются MacOS. Похоже, ваша система сборки пытается скомпилировать все файлы, заканчивающиеся на .cpp. Вероятно, он не должен ничего компилировать, начиная с точки.

7 голосов
/ 25 октября 2009

Баффе Бойуа получил правильный общий ответ - ваши правила CMake, должно быть, слишком много делают.

На MacOS X 10.5.8 (Leopard) я получаю:

Osiris JL: cmake ..
-- The C compiler identification is GNU
-- The CXX compiler identification is GNU
-- Check for working C compiler: /usr/bin/gcc
-- Check for working C compiler: /usr/bin/gcc -- works
-- Detecting C compiler ABI info
-- Detecting C compiler ABI info - done
-- Check for working CXX compiler: /usr/bin/c++
-- Check for working CXX compiler: /usr/bin/c++ -- works
-- Detecting CXX compiler ABI info
-- Detecting CXX compiler ABI info - done
-- Configuring done
-- Generating done
-- Build files have been written to: /Users/jleffler/tmp/yaml-cpp-0.2.3/build
Osiris JL: make
Scanning dependencies of target yaml-cpp
[  2%] Building CXX object CMakeFiles/yaml-cpp.dir/src/._conversion.cpp.o
/tmp/yaml-cpp-0.2.3/src/._conversion.cpp:1:1: warning: null character(s) ignored
/tmp/yaml-cpp-0.2.3/src/._conversion.cpp:1: error: stray ‘\5’ in program
/tmp/yaml-cpp-0.2.3/src/._conversion.cpp:1: error: stray ‘\22’ in program
/tmp/yaml-cpp-0.2.3/src/._conversion.cpp:1: error: stray ‘\7’ in program
/tmp/yaml-cpp-0.2.3/src/._conversion.cpp:1:5: warning: null character(s) ignored
/tmp/yaml-cpp-0.2.3/src/._conversion.cpp:1: error: stray ‘\2’ in program
/tmp/yaml-cpp-0.2.3/src/._conversion.cpp:1:7: warning: null character(s) ignored
/tmp/yaml-cpp-0.2.3/src/._conversion.cpp:1:17: warning: null character(s) ignored
...

Вы должны перечислить файлы, которые вам нужно скомпилировать; не стоит просто компилировать все и вся.

Проблема, кажется, в CMakeLists.txt:

file(GLOB public_headers include/*.h)
file(GLOB private_headers src/*.h)
file(GLOB sources src/*.cpp)

Либо CMake GLOB слишком увлечен (я использую версию 2.6-patch 4), либо вы не можете позволить себе использовать его, пока кто-либо из ваших клиентов использует MacOS X.

То, что делает GLOB, расширяется и включает файлы, начинающиеся с '.' чье-то предположение; Я был бы склонен рассматривать это как ошибку в cmake.

Однако в качестве обходного пути я отредактировал CMakeLists.txt и заставил его работать:

file(GLOB public_headers include/[a-z]*.h)
file(GLOB private_headers src/[a-z]*.h)
file(GLOB sources src/[a-z]*.cpp)

Это не полное решение: я столкнулся с продолжением проблемы с кодом в каталоге yaml-reader. Я изменил файл yaml-reader / CMakeLists.txt практически таким же образом.

FWIW:

$ file ._*
._conversion.cpp: AppleDouble encoded Macintosh file
._exp.cpp:        AppleDouble encoded Macintosh file
._map.cpp:        AppleDouble encoded Macintosh file
._map.h:          AppleDouble encoded Macintosh file
._node.cpp:       AppleDouble encoded Macintosh file
._null.cpp:       AppleDouble encoded Macintosh file
._ostream.cpp:    AppleDouble encoded Macintosh file
._parser.cpp:     AppleDouble encoded Macintosh file
._regex.cpp:      AppleDouble encoded Macintosh file
._regeximpl.h:    AppleDouble encoded Macintosh file
._scanner.cpp:    AppleDouble encoded Macintosh file
._scanner.h:      AppleDouble encoded Macintosh file
._scanscalar.cpp: AppleDouble encoded Macintosh file
._scanscalar.h:   AppleDouble encoded Macintosh file
._sequence.cpp:   AppleDouble encoded Macintosh file
._simplekey.cpp:  AppleDouble encoded Macintosh file
._stream.cpp:     AppleDouble encoded Macintosh file
._token.h:        AppleDouble encoded Macintosh file
$ odx ._con*.cpp 
0x0000: 00 05 16 07 00 02 00 00 4D 61 63 20 4F 53 20 58   ........Mac OS X
0x0010: 20 20 20 20 20 20 20 20 00 02 00 00 00 09 00 00           ........
0x0020: 00 32 00 00 00 79 00 00 00 02 00 00 00 AB 00 00   .2...y..........
0x0030: 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00   ................
*
0x0050: 00 00 00 00 41 54 54 52 00 3C E0 2B 00 00 00 AB   ....ATTR.<.+....
0x0060: 00 00 00 9C 00 00 00 0F 00 00 00 00 00 00 00 00   ................
0x0070: 00 00 00 00 00 00 00 01 00 00 00 9C 00 00 00 0F   ................
0x0080: 00 00 17 63 6F 6D 2E 61 70 70 6C 65 2E 54 65 78   ...com.apple.Tex
0x0090: 74 45 6E 63 6F 64 69 6E 67 00 00 00 55 54 46 2D   tEncoding...UTF-
0x00A0: 38 3B 31 33 34 32 31 37 39 38 34                  8;134217984
0x00AB:
$

Одна странная деталь - некоторые файлы в каталоге 'src' не имеют теневых файлов. Когда я выполняю tar -tvf yaml-cpp-0.2.3.tar.gz, я вижу файлы, поставляемые с источником:

Osiris JL: tar -tvf yaml-cpp-0.2.3.tar.gz
drwxr-xr-x beder/staff       0 2009-10-22 15:13:52 ./
-rw-r--r-- beder/staff    1750 2009-10-22 15:09:05 ./CMakeLists.txt
drwxr-xr-x beder/staff       0 2009-10-19 16:40:15 ./include/
-rw-r--r-- beder/staff     171 2009-09-06 13:41:54 ./include/._conversion.h
-rw-r--r-- beder/staff    1118 2009-09-06 13:41:54 ./include/conversion.h
-rw-r--r-- beder/staff     302 2009-07-29 15:25:23 ./include/crt.h
-rw-r--r-- beder/staff    2254 2009-10-19 16:40:14 ./include/emitter.h
-rw-r--r-- beder/staff    1660 2009-10-19 16:40:14 ./include/emittermanip.h
-rw-r--r-- beder/staff     171 2009-08-18 22:07:22 ./include/._exceptions.h
-rw-r--r-- beder/staff    5638 2009-08-18 22:07:22 ./include/exceptions.h
-rw-r--r-- beder/staff     765 2009-07-29 15:25:23 ./include/iterator.h
-rw-r--r-- beder/staff     444 2009-07-29 15:25:23 ./include/mark.h
-rw-r--r-- beder/staff     171 2009-09-06 12:25:12 ./include/._node.h
-rw-r--r-- beder/staff    3467 2009-09-06 12:25:12 ./include/node.h
-rw-r--r-- beder/staff     171 2009-09-15 20:54:20 ./include/._nodeimpl.h
...
-rw-r--r-- beder/staff     171 2009-07-29 21:28:26 ./include/._yaml.h
-rw-r--r-- beder/staff     321 2009-07-29 21:28:26 ./include/yaml.h
-rw-r--r-- beder/staff     167 2009-09-05 16:01:06 ./._install.txt
-rw-r--r-- beder/staff     652 2009-09-05 16:01:06 ./install.txt
-rw-r--r-- beder/staff    1073 2009-05-29 19:31:21 ./license.txt
drwxr-xr-x beder/staff       0 2009-10-22 14:49:11 ./src/
-rw-r--r-- beder/staff    1697 2009-08-24 16:28:46 ./src/aliascontent.cpp
-rw-r--r-- beder/staff    1171 2009-08-24 16:28:46 ./src/aliascontent.h
-rw-r--r-- beder/staff     112 2009-05-29 19:31:21 ./src/content.cpp
-rw-r--r-- beder/staff    1557 2009-08-24 16:28:46 ./src/content.h
-rw-r--r-- beder/staff     171 2009-09-06 13:31:56 ./src/._conversion.cpp
-rw-r--r-- beder/staff    2027 2009-09-06 13:31:56 ./src/conversion.cpp
...

Таким образом, злонамеренные файлы поставляются с файлом tar продукта. Вы где-то заразились - не знаете как.

0 голосов
/ 22 марта 2014

Я только что это случилось с моей программой на С ++, которую я делал. Это произошло, когда я скопировал формулу двойного хеширования из файла PDF, который был

return (randomNumber % (tableSize - 2)) + 1;

Я через него был оператором по модулю, но оказалось, что это была кодировка или что-то в этом роде, но я решил это, удалив его и напечатав вручную.

0 голосов
/ 15 января 2010

Убедитесь, что в вашем каталоге компоновки есть только файлы .o. У меня была эта проблема, и причиной была ошибка в моем Makefile (на самом деле это был файл scons), который создал один исходный файл в файл .c вместо файла .o Полученный файл был двоичным, но я предполагаю, что gcc пытался интерпретировать его как файл .c.

0 голосов
/ 25 октября 2009

Может быть поврежден файл с их стороны.

Что находится в строке 1 _regex.cpp в их системе.

Если возникла проблема с загрузкой / кодированием, вам придется посмотреть, что находится в файлах в их системе, а не в вашем хранилище кода.

...