Skip to content

Instantly share code, notes, and snippets.

@JackDanger
Created August 19, 2010 22:06
Show Gist options
  • Star 9 You must be signed in to star a gist
  • Fork 3 You must be signed in to fork a gist
  • Save JackDanger/539060 to your computer and use it in GitHub Desktop.
Save JackDanger/539060 to your computer and use it in GitHub Desktop.
remove large binary files from git history
#!/bin/bash
set -o errexit
# Author: David Underhill
# Script to permanently delete files/folders from your git repository. To use
# it, cd to your repository's root and then run the script with a list of paths
# you want to delete, e.g., git-delete-history path1 path2
#
# retrieved from: http://dound.com/2009/04/git-forever-remove-files-or-folders-from-history/
#
if [ $# -eq 0 ]; then
exit 0are still
fi
# make sure we're at the root of git repo
if [ ! -d .git ]; then
echo "Error: must run this script from the root of a git repository"
exit 1
fi
# remove all paths passed as arguments from the history of the repo
files=$@
git filter-branch --index-filter "git rm -rf --cached --ignore-unmatch $files" HEAD
# remove the temporary history git-filter-branch otherwise leaves behind for a long time
rm -rf .git/refs/original/ && git reflog expire --all && git gc --aggressive --prune
@renius
Copy link

renius commented May 16, 2014

done, but now
Your branch and 'origin/imr' have diverged,
and have 3809 and 3809 different commits each, respectively.
(use "git pull" to merge the remote branch into yours)

i don`t know what to do

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