diff options
author | Kostis Anagnostopoulos <ankostis@gmail.com> | 2016-10-28 12:21:43 +0200 |
---|---|---|
committer | Kostis Anagnostopoulos <ankostis@gmail.com> | 2016-12-08 14:29:49 +0100 |
commit | f1a82e45fc177cec8cffcfe3ff970560d272d0bf (patch) | |
tree | 974c7dc6b76e35a4e0bf89cf771d8c00e8446b7e /git/repo/base.py | |
parent | 2f207e0e15ad243dd24eafce8b60ed2c77d6e725 (diff) | |
download | gitpython-f1a82e45fc177cec8cffcfe3ff970560d272d0bf.tar.gz |
fix(leaks): repo context-man to cleanup global mman on repo-delete
Improve API for problems like #553.
Diffstat (limited to 'git/repo/base.py')
-rw-r--r-- | git/repo/base.py | 14 |
1 files changed, 14 insertions, 0 deletions
diff --git a/git/repo/base.py b/git/repo/base.py index 0f85e3d9..a9f90a17 100644 --- a/git/repo/base.py +++ b/git/repo/base.py @@ -33,6 +33,8 @@ from git.util import Actor, finalize_process, decygpath, hex_to_bin import os.path as osp from .fun import rev_parse, is_git_dir, find_submodule_git_dir, touch +import gc +import gitdb log = logging.getLogger(__name__) @@ -177,9 +179,21 @@ class Repo(object): args.append(self.git) self.odb = odbt(*args) + def __enter__(self): + return self + + def __exit__(self, exc_type, exc_value, traceback): + self.close() + def __del__(self): + self.close() + + def close(self): if self.git: self.git.clear_cache() + gc.collect() + gitdb.util.mman.collect() + gc.collect() def __eq__(self, rhs): if isinstance(rhs, Repo): |