Skip to content

Instantly share code, notes, and snippets.

@abraithwaite
Created September 25, 2014 03:36
Fix the index-filter command
diff --git a/home/abraithwaite/.virtualenvs/gitfat/bin/git-fat b/home/abraithwaite/git-fat
index d459746..7838567 100755
--- a/home/abraithwaite/.virtualenvs/gitfat/bin/git-fat
+++ b/home/abraithwaite/git-fat
@@ -619,10 +619,9 @@ class GitFat(object):
# Add lines to the .gitattributes file
new_ga = old_ga + ['{0} filter=fat -text'.format(f) for f in newfiles]
stdout, _ = ga_hashobj.communicate('\n'.join(new_ga) + '\n')
- self._update_index(ga_mode, stdout.strip(), ga_stno, '.gitattributes')
return ga_mode, stdout.strip(), ga_stno, '.gitattributes'
- def _process_index_filter_line(self, line, update_index, workdir, excludes):
+ def _process_index_filter_line(self, line, workdir, excludes):
mode, blobhash, stageno, filename = self._parse_ls_files(line)
@@ -647,8 +646,8 @@ class GitFat(object):
return mode, objhash, stageno, filename
def index_filter(self, filelist, add_gitattributes=True, **kwargs):
-
- workdir = os.path.join(self.gitdir, 'fat', 'index-filter')
+ gitdir = sub.check_output('git rev-parse --git-dir'.split()).strip()
+ workdir = os.path.join(gitdir, 'fat', 'index-filter')
mkdir_p(workdir)
with open(filelist) as excludes:
@@ -659,17 +658,16 @@ class GitFat(object):
newfiles = []
for line in ls_files.stdout:
- newfile = self._process_index_filter_line(line)
+ newfile = self._process_index_filter_line(line, workdir, files_to_exclude)
if newfile:
self._update_index(uip, *newfile)
# The filename is in the last position
newfiles.append(newfile[-1])
- newfiles = self._filter_clean_index(ls_files.stdout, files_to_exclude)
-
if add_gitattributes:
# Add the files to the gitattributes file and update the index
- self._update_index(uip, *self._add_gitattributes(newfiles))
+ attrs = self._add_gitattributes(newfiles, add_gitattributes)
+ self._update_index(uip, *attrs)
ls_files.wait()
uip.stdin.close()
@@ -927,10 +925,14 @@ def main():
log_level = logging.WARNING
_configure_logging(log_level)
+ require_backend = ('pull', 'push')
+
try:
backend_opt = kwargs.pop('backend', None)
config_file = kwargs.pop('config_file', None)
- backend = _parse_config(backend=backend_opt, cfg_file_path=config_file)
+ backend = None
+ if kwargs['func'] in require_backend:
+ backend = _parse_config(backend=backend_opt, cfg_file_path=config_file)
run(backend, **kwargs)
except RuntimeError as err:
logging.error(str(err))
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment