diff --git a/mercurial/commands.py b/mercurial/commands.py --- a/mercurial/commands.py +++ b/mercurial/commands.py @@ -690,12 +690,12 @@ def debugstate(ui, repo): def debugdata(ui, file_, rev): """dump the contents of an data file revision""" - r = hg.revlog(hg.opener(""), file_[:-2] + ".i", file_) + r = hg.revlog(file, file_[:-2] + ".i", file_) ui.write(r.revision(r.lookup(rev))) def debugindex(ui, file_): """dump the contents of an index file""" - r = hg.revlog(hg.opener(""), file_, "") + r = hg.revlog(file, file_, "") ui.write(" rev offset length base linkrev" + " nodeid p1 p2\n") for i in range(r.count()): @@ -706,7 +706,7 @@ def debugindex(ui, file_): def debugindexdot(ui, file_): """dump an index DAG as a .dot file""" - r = hg.revlog(hg.opener(""), file_, "") + r = hg.revlog(file, file_, "") ui.write("digraph G {\n") for i in range(r.count()): e = r.index[i] diff --git a/mercurial/hg.py b/mercurial/hg.py --- a/mercurial/hg.py +++ b/mercurial/hg.py @@ -13,34 +13,6 @@ from repo import * from demandload import * demandload(globals(), "localrepo httprepo sshrepo") -# used to avoid circular references so destructors work -def opener(base): - p = base - def o(path, mode="r"): - if p.startswith("http://"): - f = os.path.join(p, urllib.quote(path)) - return httprangereader.httprangereader(f) - - f = os.path.join(p, path) - - mode += "b" # for that other OS - - if mode[0] != "r": - try: - s = os.stat(f) - except OSError: - d = os.path.dirname(f) - if not os.path.isdir(d): - os.makedirs(d) - else: - if s.st_nlink > 1: - file(f + ".tmp", "wb").write(file(f, "rb").read()) - util.rename(f+".tmp", f) - - return file(f, mode) - - return o - def repository(ui, path=None, create=0): if path: if path.startswith("http://"): @@ -52,8 +24,8 @@ def repository(ui, path=None, create=0): ui, path.replace("hg://", "http://")) if path.startswith("old-http://"): return localrepo.localrepository( - ui, opener, path.replace("old-http://", "http://")) + ui, util.opener, path.replace("old-http://", "http://")) if path.startswith("ssh://"): return sshrepo.sshrepository(ui, path) - return localrepo.localrepository(ui, opener, path, create) + return localrepo.localrepository(ui, util.opener, path, create) diff --git a/mercurial/util.py b/mercurial/util.py --- a/mercurial/util.py +++ b/mercurial/util.py @@ -232,6 +232,41 @@ def copytree(src, dst, copyfile): else: pass +def opener(base): + """ + return a function that opens files relative to base + + this function is used to hide the details of COW semantics and + remote file access from higher level code. + + todo: separate remote file access into a separate function + """ + p = base + def o(path, mode="r"): + if p.startswith("http://"): + f = os.path.join(p, urllib.quote(path)) + return httprangereader.httprangereader(f) + + f = os.path.join(p, path) + + mode += "b" # for that other OS + + if mode[0] != "r": + try: + s = os.stat(f) + except OSError: + d = os.path.dirname(f) + if not os.path.isdir(d): + os.makedirs(d) + else: + if s.st_nlink > 1: + file(f + ".tmp", "wb").write(file(f, "rb").read()) + rename(f+".tmp", f) + + return file(f, mode) + + return o + def _makelock_file(info, pathname): ld = os.open(pathname, os.O_CREAT | os.O_WRONLY | os.O_EXCL) os.write(ld, info)