This article will describe how the github Pull Request’s commit log is displayed as a single line. I have written two similar articles before:

  1. Github pull Request
  2. Github forks the original project, how to update the local repository code to the latest version?

Merge pull Request, merge request, merge request, merge request, merge request, merge request, merge request, merge request The commit log also looks interlaced, making it hard to read. Such as below

After working through this article, the commit log looks clean and tidy as shown below.

————— below 👇 to the topic —————–

Diagram of the whole process

The detailed steps

1. The fork warehouse

2. Clone fork the warehouse to the local PC

3. Connect with upstream

Enter the following command in the fork local repository to associate:

Git remote add upstreamCopy the code

View warehouse address:

git remote -v
Copy the code

4. Fork local repository commit+push

After modifying the file, run the following command:

Git add. Git commit -m 'message' //Copy the code

5. Initiate a Pull Request

Fork the remote repository and click Pull Request->New Pull Request. Base Repository is a branch of the original repository. Head repository sends a branch of head to a branch of base

6. Merge the original warehouse into PR

Pull Requests into the original repository can see the PR just launched

Making the pull request is introduced: help.github.com/cn/github/c…

Introduction of the three joining methods:

  • Merge Pull Request: Merge every commit from the fork repository into the original repository, and a Merge Commit log is also generated.
  • Squash and merge: If multiple commits are merged into a commit and added to the repository, a new COMMIT ID is generated.
  • Rebase and merge: Rebase every commit from the fork repository to the original repository, but github’s Rebase behavior differs slightly from git Rebase. Rebasing and merging on GitHub always updates committer information and creates a new commit, which generates a new Commit ID.

Select Squash and merge to merge This results in a commit as shown in the following figure: this commit contains several commits for fork the repository when PR is initiated

7. Fork local warehouse update

A new COMMIT ID is generated when the original repository is merged, which needs to be updated at the fork local repository for consistency

Git pull --rebase upstream masterCopy the code

Before update: test4 and test5 are committed twiceUpdate: test4 and test5 are merged to fork a commit generated by squash and merge

8. After modifying the file, commit + push

At this point, the push is pushed to the remote repository, and the forked remote repository needs to be overwritten. The fork remote repository is still a double COMMIT from test4 and test5, while the local repository has been updated and synchronized to a merge COMMIT from the original repository. Not forcing overwrites prompts for updates to synchronize with remote branches at push time.

git push origin master --force
Copy the code

Come here!! Fork, Clone, Commit, push, pull the entire process is complete.

Keep learning! Keep climbing holes! Keep summarizing! Write better code!