summaryrefslogtreecommitdiff
path: root/git/repo/base.py
diff options
context:
space:
mode:
authorKostis Anagnostopoulos <ankostis@gmail.com>2016-10-28 12:21:43 +0200
committerKostis Anagnostopoulos <ankostis@gmail.com>2016-12-08 14:29:49 +0100
commitf1a82e45fc177cec8cffcfe3ff970560d272d0bf (patch)
tree974c7dc6b76e35a4e0bf89cf771d8c00e8446b7e /git/repo/base.py
parent2f207e0e15ad243dd24eafce8b60ed2c77d6e725 (diff)
downloadgitpython-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.py14
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):