summaryrefslogtreecommitdiff
path: root/gbp/scripts/common/buildpackage.py
diff options
context:
space:
mode:
Diffstat (limited to 'gbp/scripts/common/buildpackage.py')
-rw-r--r--gbp/scripts/common/buildpackage.py24
1 files changed, 13 insertions, 11 deletions
diff --git a/gbp/scripts/common/buildpackage.py b/gbp/scripts/common/buildpackage.py
index dc47b75..5de315f 100644
--- a/gbp/scripts/common/buildpackage.py
+++ b/gbp/scripts/common/buildpackage.py
@@ -36,8 +36,6 @@ wc_names = {'WC': {'force': True, 'untracked': True},
'WC.TRACKED': {'force': False, 'untracked': False},
'WC.UNTRACKED': {'force': False, 'untracked': True},
'WC.IGNORED': {'force': True, 'untracked': True}}
-# index file name used to export working copy
-wc_index = ".git/gbp_index"
def sanitize_prefix(prefix):
@@ -145,21 +143,25 @@ def dump_tree(repo, export_dir, treeish, with_submodules, recursive=True):
return True
+def wc_index(repo):
+ """Get path of the temporary index file used for exporting working copy"""
+ return os.path.join(repo.git_dir, "gbp_index")
+
def write_wc(repo, force=True, untracked=True):
"""write out the current working copy as a treeish object"""
- clone_index()
- repo.add_files(repo.path, force=force, untracked=untracked, index_file=wc_index)
- tree = repo.write_tree(index_file=wc_index)
+ clone_index(repo)
+ repo.add_files(repo.path, force=force, untracked=untracked, index_file=wc_index(repo))
+ tree = repo.write_tree(index_file=wc_index(repo))
return tree
-def drop_index():
+def drop_index(repo):
"""drop our custom index"""
- if os.path.exists(wc_index):
- os.unlink(wc_index)
+ if os.path.exists(wc_index(repo)):
+ os.unlink(wc_index(repo))
-def clone_index():
+def clone_index(repo):
"""Copy the current index file to our custom index file"""
- indexfn = ".git/index"
+ indexfn = os.path.join(repo.git_dir, "index")
if os.path.exists(indexfn):
- shutil.copy2(indexfn, wc_index)
+ shutil.copy2(indexfn, wc_index(repo))