Это вывод моей команды исправления:
Hunk #11 merged at 4184,4190.
Hunk #12 merged at 4444.
Hunk #13 merged at 4944.
Hunk #14 NOT MERGED at 5106-5116.
Hunk #15 merged at 5290.
Hunk #16 merged at 5448.
patch unexpectedly ends in middle of line
Hunk #17 merged at 5608,5611.
Команда была
patch -d ~/SOME_DIR -p1 --merge --verbose -u
Патч был создан с использованием git:
git --git-dir ~/SOME_DIR/.git diff -U8 bb1ee538982957b421a4c0e78f30428e73c9a072 HEAD -- malloc.c
Что patch unexpectedly ends in middle of line
значит, и это проблема? Имеется в виду лом 16 или 17? Что я могу найти в файле патча, чтобы выяснить, что вызывает это?
источник
Если вы не используете
git
(комментарий @ maxslepzig был об использовании patch в контекстеgit
), попробуйте добавить возврат каретки в конце вашего файла. Я сделал это иpatch
принял мой патч.источник
Чтобы добавить к этой очень старой дискуссии:
Проблема, приводящая к предупреждению, отмеченному OP, обычно вызвана проблемами с окончаниями строки.
patch
хочет задний перевод строки (LF), чтобы определить конец файла (и предупреждает об объединенном diff, который мог быть случайно обрезан)Добавить правильный перевод строки, не открывая файл для редактирования (что может изменить ваши окончания строк или убрать завершающие строки / пробелы в зависимости от настроек вашего редактора), вы можете сделать что-то простое, например:
echo -e "\n" >> YOURPATCHFILE
Это добавляет символ перевода строки в конец файла без каких-либо других изменений.
Если ваш файл патча уже странный или вы хотите выполнить несколько возможных исправлений одновременно, вы можете исправить многие проблемы с кодировкой (в ascii), включая окончания строк (CR или CRLF - LF):
dos2unix -k YOURPATCHFILE
Возможно, вам придется установить бинарный файл dos2unix из диспетчера пакетов вашей ОС; т.е.
sudo apt install dos2unix
sudo yum install dos2unix
brew install dos2unix
источник