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

[STM32] How to configure Timer 1, Channel 3 is PWM 1kHz, duty cycle 20% to control BLDC motor

 To configure Timer1 for a 1 kHz PWM signal with a 20% duty cycle on an STM32H7S3L8 microcontroller, follow these steps: 1. Understand the Timer Parameters PWM Frequency : 1 kHz → Period = 1 ms. Duty Cycle : 20% → ON time = 0.2 ms. The timer’s clock frequency is derived from the APB clock (e.g., TIMCLK). Let’s assume you know the APB clock frequency. The Timer prescaler and auto-reload register (ARR) define the PWM frequency. 2. Compute Timer Parameters Formula: PWM Frequency = Timer Clock (Prescaler + 1) * (ARR + 1) \text{PWM Frequency} = \frac{\text{Timer Clock}}{\text{(Prescaler + 1) * (ARR + 1)}} PWM Frequency = (Prescaler + 1) * (ARR + 1) Timer Clock ​ For 1 kHz PWM: A R R = Timer Clock PWM Frequency ∗ ( Prescaler + 1) − 1 ARR = \frac{\text{Timer Clock}}{\text{PWM Frequency} * (\text{Prescaler + 1)}} - 1 A RR = PWM Frequency ∗ ( Prescaler + 1) Timer Clock ​ −...

[CanadaLife] Example of answers for final test in Smart Service Ontario 2024

If you have failed the final exam in the first attempt. Congratulations, you are not odd. Here, take a look and grab some corrected answers for your next attempt.  Don't waste your money and time for more failure.  Good luck bros. Quick note: remember that, the system will change the bunch of questions after each attempt. Then your next questionnaire will be different compared with the first trial. ========================================== =============FINAL TEST=================== ========================================== TIP: Here is a list of questions you did not answer correctly. *Please note: You will only be able to view this list immediately following your test attempt. ========================================== Alcohol slows down the central nervous system and impacts how a person thinks, acts, and moves. This means alcohol is a: depressant ========================================== Alcohol is metabolized in the body at a set rate. For most people, that rate is: one...

How to use ChatGPT to get your resume shortlisted?

How to use ChatGPT to get your resume shortlisted? Core steps: Chat GPT -> Resume Creator -> LinkedIn(Copy the job description to ChatGPT) -> Add your personal information -> Copy output from ChatGPT to Instaresume.io to make the template -> Goto SkillSyncer to check ATS(Applicant Tracking Software) score, point out the missing keywords. Detail ☑️In my pursuit of job #opportunities, I encountered a familiar challenge - my resume seemingly disappeared into oblivion, yielding no responses despite my diverse skill set and numerous applications. ☑️As I delved into my research, I uncovered the existence of ATS software, the automated gatekeeper of #resumes, which swiftly filtered out those lacking relevant keywords. ☑️The outcome? Not just one #company, but over a dozen organizations recognized the potential in my resume, resulting in multiple shortlists and promising #job prospects! 💻If you want to supercharge your resume and unlock countless opportunities, don't miss o...