Skip to content

Instantly share code, notes, and snippets.

@robertpainsi
Last active November 22, 2023 12:02
Show Gist options
  • Save robertpainsi/cb81b13b1008f6cf31f8 to your computer and use it in GitHub Desktop.
Save robertpainsi/cb81b13b1008f6cf31f8 to your computer and use it in GitHub Desktop.

If you aren't familiar how to restore a branch, please take a look at git reset and git reflog first. If you have any problems during the procedure, let me know as well.

How to format your code?

   # Your working directory has to be clean
1. $ git checkout <YOUR-BRANCH>
2. $ git reset --soft $(git merge-base @ upstream/develop) #Adapt base if necessary

   # Sync the Android Studio project with gradle.
   # Right click on the packages you want to format and click 'Reformat Code'.
   # Normally org.catrobat.catroid, org.catrobat.catroid(androidTest).
   # Clicking on java, another subfolder or the project itself will NOT work properly.
   # Enable 'Include subdirectories', 'Optimize Imports', 'Only VCS changed text' and
   # click 'Run'. For an optimal result, run the formatter twice over all packages.
   # Hint: If 'Only VCS changed text' is greyed out,
           don't run the formatter for the selected package.

3. git commit -c ORIG_HEAD

or use an alias (https://gist.github.com/robertpainsi/cb81b13b1008f6cf31f8#gistcomment-1589707)

  • If you have a single commit, you can use git reset --soft @~ as the second command instead.

  • If you have a few commits and no merge commits, try to format each commit by interactive rebasing. At each rebase stop, skip step 1 and use git reset --soft @~ as the second command. However, there can be nasty merge-conflicts during the rebase process. Consider to perform If you have many commits or merge commits instead.

  • If you have many commits or merge commits, create a new commit with the formatted code. Change the commit message accordingly.

Note: Never format the whole project. Always format your changes only. git reset --soft $(git merge-base @ upstream/develop) will set your branch to the latest commit of upstream/develop which you share with your branch but will keep all the changes of your branch in the staged area. So by formatting 'Only VCS changed text', you'll format all new changes in your branch only.

@robertpainsi
Copy link
Author

And for people lazy like me there is an alias:

.gitconfig

format-code = "!f() { git checkout $1 && git reset --soft $(git merge-base @ $2) && echo 'Sync your project with gradle and format the code. Do not add the formatted files to the staging area! Press enter to continue...' && read 'foo' && git reset $(git rev-list @{1} -1); }; f"

Usage:

git format-code <YOUR-BRANCH> <OTHER-BRANCH>
<YOUR-BRANCH> required
<OTHER-BRANCH> required, for a PR, the branch you want to merge into

Example:

git format-code feature/physics upstream/develop
  • If you just want to format your last commit, use git format-code @ @~ and amend the changes.
  • If you rebase interactively, call git format-code @ @~ for each rebase stop.

@robertpainsi
Copy link
Author

If the status report already provided feedback on your PR, just follow the next steps.
image

  • Click on Details on the Pull Request status report format.
  • Add .diff to the end of the github url. (infos to .diff, .patch)
  • Save the file, further named format.diff, to your local machine.
  • git apply format.diff
  • Add and commit or amend the changes.

@p4p4
Copy link

p4p4 commented Jun 23, 2016

just a suggestion: as 3rd step after formatting the last commit one might do

 git commit -c ORIG_HEAD

instead. This creates the commit with the commit message again.

@robertpainsi
Copy link
Author

@p4p4: Thanks for the hint, updated! 😸

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment