From 74992aaa27eb384128924c4a3b93052961a3eaab Mon Sep 17 00:00:00 2001 From: Christian Cleberg Date: Sat, 27 Apr 2024 17:01:13 -0500 Subject: test conversion back to markdown --- content/blog/2021-05-30-changing-git-authors.md | 75 +++++++++++++++++++++++++ 1 file changed, 75 insertions(+) create mode 100644 content/blog/2021-05-30-changing-git-authors.md (limited to 'content/blog/2021-05-30-changing-git-authors.md') diff --git a/content/blog/2021-05-30-changing-git-authors.md b/content/blog/2021-05-30-changing-git-authors.md new file mode 100644 index 0000000..6c31b08 --- /dev/null +++ b/content/blog/2021-05-30-changing-git-authors.md @@ -0,0 +1,75 @@ ++++ +date = 2021-05-30 +title = "Changing Git Authors" +description = "" +draft = false ++++ + +# Changing Git Author/Email Based on Previously Committed Email + +Here\'s the dilemma: You\'ve been committing changes to your git +repository with an incorrect name or email (or multiple repositories), +and now you want to fix it. Luckily, there\'s a semi-reliable way to fix +that. While I have never experienced issues with this method, some +people have warned that it can mess with historical hashes and integrity +of commits, so use this method only if you\'re okay accepting that risk. + +Okay, let\'s create the bash script: + +```sh +nano change_git_authors.sh +``` + +The following information can be pasted directly into your bash script. +The only changes you need to make are to the following variables: + +- `OLD_EMAIL` +- `CORRECT_NAME` +- `CORRECT_EMAIL` + +```sh +#!/bin/sh + +# List all sub-directories in the current directory +for dir in */ +do + # Remove the trailing "/" + dir=${dir%*/} + # Enter sub-directory + cd $dir + + git filter-branch --env-filter ' + + OLD_EMAIL="old@example.com" + CORRECT_NAME="your-new-name" + CORRECT_EMAIL="new@example.com" + + if [ "$GIT_COMMITTER_EMAIL" = "$OLD_EMAIL" ] + then + export GIT_COMMITTER_NAME="$CORRECT_NAME" + export GIT_COMMITTER_EMAIL="$CORRECT_EMAIL" + fi + if [ "$GIT_AUTHOR_EMAIL" = "$OLD_EMAIL" ] + then + export GIT_AUTHOR_NAME="$CORRECT_NAME" + export GIT_AUTHOR_EMAIL="$CORRECT_EMAIL" + fi + ' --tag-name-filter cat -- --branches --tags + + git push --force --tags origin 'refs/heads/*' + + cd .. +done +``` + +Finally, save the bash script and make it executable. + +```sh +chmod a+x change_git_authors.sh +``` + +Now you can run the script and should see the process begin. + +```sh +./change_git_authors.sh +``` -- cgit v1.2.3-70-g09d2