clone and sync --keep-path to keep perforce path to module.

Signed-off-by: Han-Wen Nienhuys <hanwen@google.com>
This commit is contained in:
Han-Wen Nienhuys 2007-05-23 18:20:53 -03:00
parent 6754a299d8
commit 8b41a97f8a

View File

@ -11,6 +11,7 @@
import optparse, sys, os, marshal, popen2, subprocess, shelve import optparse, sys, os, marshal, popen2, subprocess, shelve
import tempfile, getopt, sha, os.path, time, platform import tempfile, getopt, sha, os.path, time, platform
import re import re
from sets import Set; from sets import Set;
gitdir = os.environ.get("GIT_DIR", "") gitdir = os.environ.get("GIT_DIR", "")
@ -20,7 +21,6 @@ def write_pipe(c, str):
if not silent: if not silent:
sys.stderr.write('writing pipe: %s\n' % c) sys.stderr.write('writing pipe: %s\n' % c)
## todo: check return status
pipe = os.popen(c, 'w') pipe = os.popen(c, 'w')
val = pipe.write(str) val = pipe.write(str)
if pipe.close(): if pipe.close():
@ -32,7 +32,7 @@ def write_pipe(c, str):
def read_pipe(c): def read_pipe(c):
if not silent: if not silent:
sys.stderr.write('reading pipe: %s\n' % c) sys.stderr.write('reading pipe: %s\n' % c)
## todo: check return status
pipe = os.popen(c, 'rb') pipe = os.popen(c, 'rb')
val = pipe.read() val = pipe.read()
if pipe.close(): if pipe.close():
@ -60,8 +60,6 @@ def system(cmd):
if os.system(cmd) != 0: if os.system(cmd) != 0:
die("command failed: %s" % cmd) die("command failed: %s" % cmd)
def p4CmdList(cmd): def p4CmdList(cmd):
cmd = "p4 -G %s" % cmd cmd = "p4 -G %s" % cmd
pipe = os.popen(cmd, "rb") pipe = os.popen(cmd, "rb")
@ -566,7 +564,8 @@ class P4Sync(Command):
optparse.make_option("--detect-labels", dest="detectLabels", action="store_true"), optparse.make_option("--detect-labels", dest="detectLabels", action="store_true"),
optparse.make_option("--verbose", dest="verbose", action="store_true"), optparse.make_option("--verbose", dest="verbose", action="store_true"),
optparse.make_option("--import-local", dest="importIntoRemotes", action="store_false"), optparse.make_option("--import-local", dest="importIntoRemotes", action="store_false"),
optparse.make_option("--max-changes", dest="maxChanges") optparse.make_option("--max-changes", dest="maxChanges"),
optparse.make_option("--keep-path", dest="keepRepoPath")
] ]
self.description = """Imports from Perforce into a git repository.\n self.description = """Imports from Perforce into a git repository.\n
example: example:
@ -590,6 +589,7 @@ class P4Sync(Command):
self.maxChanges = "" self.maxChanges = ""
self.isWindows = (platform.system() == "Windows") self.isWindows = (platform.system() == "Windows")
self.depotPath = None self.depotPath = None
self.keepRepoPath = False
if gitConfig("git-p4.syncFromOrigin") == "false": if gitConfig("git-p4.syncFromOrigin") == "false":
self.syncWithOrigin = False self.syncWithOrigin = False
@ -617,8 +617,11 @@ class P4Sync(Command):
fnum = fnum + 1 fnum = fnum + 1
return files return files
def stripRepoPath(self, path): def stripRepoPath(self, path, prefix):
return path[len(self.depotPath):] if self.keepRepoPath:
prefix = re.sub("^(//[^/]+/).*", r'\1', prefix)
return path[len(prefix):]
def splitFilesIntoBranches(self, commit): def splitFilesIntoBranches(self, commit):
branches = {} branches = {}
@ -638,7 +641,7 @@ class P4Sync(Command):
file["type"] = commit["type%s" % fnum] file["type"] = commit["type%s" % fnum]
fnum = fnum + 1 fnum = fnum + 1
relPath = self.stripRepoPath(path) relPath = self.stripRepoPath(path, self.depotPath)
for branch in self.knownBranches.keys(): for branch in self.knownBranches.keys():
@ -687,7 +690,7 @@ class P4Sync(Command):
continue continue
rev = file["rev"] rev = file["rev"]
depotPath = path + "#" + rev depotPath = path + "#" + rev
relPath = path[len(branchPrefix):] relPath = self.stripRepoPath(path, branchPrefix)
action = file["action"] action = file["action"]
if file["type"] == "apple": if file["type"] == "apple":