diff options
author | David Brown <git@davidb.org> | 2007-09-19 13:12:48 -0700 |
---|---|---|
committer | Junio C Hamano <gitster@pobox.com> | 2007-09-22 15:41:50 -0700 |
commit | b9fc6ea9efdc988d851666d45d80076839d9c225 (patch) | |
tree | 5e86bde5e4bb679e5297c1d3085817fedd00867d | |
parent | 9c2d28c74e374174de01901238159b63a96a04ba (diff) | |
download | git-b9fc6ea9efdc988d851666d45d80076839d9c225.tar.gz git-b9fc6ea9efdc988d851666d45d80076839d9c225.tar.xz |
Detect exec bit in more cases.
git-p4 was missing the execute bit setting if the file had other attribute
bits set.
Acked-By: Simon Hausmann <simon@lst.de>
-rwxr-xr-x | contrib/fast-import/git-p4 | 10 |
1 files changed, 9 insertions, 1 deletions
diff --git a/contrib/fast-import/git-p4 b/contrib/fast-import/git-p4 index 55778c577..65c57ac4d 100755 --- a/contrib/fast-import/git-p4 +++ b/contrib/fast-import/git-p4 @@ -63,6 +63,14 @@ def system(cmd): if os.system(cmd) != 0: die("command failed: %s" % cmd) +def isP4Exec(kind): + """Determine if a Perforce 'kind' should have execute permission + + 'p4 help filetypes' gives a list of the types. If it starts with 'x', + or x follows one of a few letters. Otherwise, if there is an 'x' after + a plus sign, it is also executable""" + return (re.search(r"(^[cku]?x)|\+.*x", kind) != None) + def p4CmdList(cmd, stdin=None, stdin_mode='w+b'): cmd = "p4 -G %s" % cmd if verbose: @@ -916,7 +924,7 @@ class P4Sync(Command): data = file['data'] mode = "644" - if file["type"].startswith("x"): + if isP4Exec(file["type"]): mode = "755" elif file["type"] == "symlink": mode = "120000" |