Skip to main content

[Git] Handle trailing space when patching with git

After complete coding one module in development branch. Next phase is merging.
Obviously, you can merge source code automatically without no errors happen.
However, life is not dream.

Create a patch
git diff HEAD > newTariff.patch

Apply patch
git apply newTariff.patch

then problem happens
Problem
git apply newTariff.patch:106: trailing whitespace. patch does not apply


Route cause:
Nguyên nhân:
Do trong source code có những dấu space thừa (ô vuông màu đỏ hình dưới)
Some whitespaces is existed in your patch. (red area in below pictures)

Fix
Clean white space and patch again.
Cách khắc phục
Xóa những dấu space này đi và thực hiện patch lại

Make up after complete coding. Find and clean whitespace before create patch file.
Sửa sau khi code xong
Kiểm tra sau khi code xong có lỗi này không
git diff HEAD --check

Prevent whitespace by manually when typing source code
Sửa ngay khi đang code
=>Bật chức năng hiển thị các dấu whitespace, hoặc remove trailing space. Tùy từng editor
Ví dụ:
Notepad ++
Edit -> Blank Operation -> Trim Trailing Space

Visual Studio Code
View -> Toggle Render Whitespace


Reference:
https://stackoverflow.com/questions/14509950/my-diff-contains-trailing-whitespace-how-to-get-rid-of-it#

For me
git apply --reject --whitespace=fix newTariff..path

Howerver it generate a new file *.rej (rej is shorted of "rejected").
I open rej file and continue fixing my problem manually


Other good guideline version.
http://vanwilson.info/2016/05/wrangling-wandering-whitespace-git/


More, Sometimes, for whatever reason, You have to produce patch-files (under Linux) that are in the wrong direction.
Reverse patch file
patch -p1 -R < path/file.patch
(If your patch was applied with the -p0 option, use that instead.)Or:
git apply -R path/file.patch

Showing trailing spaces in vim

:highlight ExtraWhitespace ctermbg=red guibg=red
:match ExtraWhitespace /\s\+$/


Comments

Popular posts from this blog

How to test frame buffer in linux

The intended goal of this article is to provide the user with enough information so they can display an image onto a screen of their choosing. How to re-build frame buffer testing application. Base knowledge http://trac.gateworks.com/wiki/OpenEmbedded/Video_Out Frame buffer test application - rebuild fb-test-app step 1: Download soure code ( git installed on your machine and account in git-hub is required) https://github.com/prpplague/fb-test-app Command in git: git init git clone https://github.com/prpplague/fb-test-app.git step 2: Change makefile vi Makefile //open Makefile by vim editor :set nu //show line number replace from line 6 to line 12 by folow code: CC=arm-linux-gnueabi-gcc CFLAGS=-02 -Wall Save change command :wq step 3: Rebuid Type “make” command step 4: Copy execute file to target system by filezilla or something like that step 5: Remote target by root account, change mode of execute file (what copied from host)

[Vi] Công nghệ phát triển ngược đời - How is AI harming my world

Tiếng cười khanh khách của mấy cậu sinh viên quốc tế người Bắc Ấn sau bài kiểm tra cuối khóa (a final exam) làm gã thấy buồn một góc tâm hồn. Sự trống rỗng ngay lập tức xâm chiếm lấy tâm trí gã sau khi nộp bài môn thi cuối cùng của kỳ học. Gã hiểu gã quá mà, gã đang cố gắng giải thích cho nỗi nhục của chính bản thân ở bên trong. Đầu gã thoáng nghĩ về cái lần thi cuối kỳ một môn học ở bậc thạc sỹ nơi quê nhà hơn mười năm về trước, cái ánh mắt khinh bỉ đến ám ảnh của một anh dọn vệ sinh dành cho những học viên cao học đang quay cóp trong giờ thi của một trường đại học hàng đầu quốc gia như vết dao khứa vào lòng tự trọng của gã. Vết thương vẫn nhói đau lại khi những mùa thi đến. Một lão già sinh viên quốc tế ranh ma. Gã đang học lại cái thứ mà gã đã học từ hai mươi năm về trước với một thứ ngôn ngữ không mới và cái tâm bằng sắt nung. Kinh nghiệm làm việc chuyên môn lâu năm cộng với việc vừa được trang bị thứ vũ khí khoa học tối tân AI (Trí truệ nhân tạo) khiến lão trở thành sát thủ trong