git-p4同步不起作用 - 神秘的堆栈跟踪

时间:2010-04-27 18:56:46

标签: git perforce git-p4

我正在尝试使用git-p4克隆perforce depot。我一直在git-p4脚本中遇到问题,git-p4尝试访问未定义的dict键并抛出跟踪。

[~/p4/prod@ernie02] (master) $ 
git p4 sync --verbose --use-client-spec //depot/prod/
Reading pipe: git config git-p4.user
Reading pipe: git config git-p4.password
Reading pipe: git config git-p4.port
Reading pipe: git config git-p4.host
Reading pipe: git config git-p4.client
p4 -u mkramer -c mkramer -G client -o
Opening pipe: p4 -u mkramer -c mkramer -G client -o
None
Doing initial import of //depot/prod/ from revision #head into refs/remotes/p4/master
p4 -u mkramer -c mkramer -G files //depot/prod/...#head
Opening pipe: p4 -u mkramer -c mkramer -G files //depot/prod/...#head
commit into refs/remotes/p4/master
p4 -u mkramer -c mkramer -G -x - print
Opening pipe: p4 -u mkramer -c mkramer -G -x - print
p4 -u mkramer -c mkramer -G users
Opening pipe: p4 -u mkramer -c mkramer -G users
Traceback (most recent call last):
  File "/home/mkramer/git/bin/git-p4", line 1922, in <module>
    main()
  File "/home/mkramer/git/bin/git-p4", line 1917, in main
    if not cmd.run(args):
  File "/home/mkramer/git/bin/git-p4", line 1651, in run
    self.importHeadRevision(revision)
  File "/home/mkramer/git/bin/git-p4", line 1461, in importHeadRevision
    self.commit(details, self.extractFilesFromCommit(details), self.branch, self.depotPaths)
  File "/home/mkramer/git/bin/git-p4", line 1063, in commit
    data = file['data']
KeyError: 'data'

我进入剧本并在那时打印出文件字典并获得了更多细节,为了清晰起见,我将对其进行修改。匿名。错误的词典看起来像这样:

{'action': 'move/delete', 'path': '//depot/prod/foo/bar', 'rev': '3', 'type': 'xtext'}

我的p4客户端看起来像这样:

Client: mkramer
Update: 2010/04/27 14:46:10
Access: 2010/04/27 14:51:29

Owner:  mkramer
Description:
        Created by mkramer.
Root:   z:\p4
AltRoots:
        z:\p4
        /home/mkramer/p4
Options:        noallwrite noclobber nocompress unlocked nomodtime normdir
SubmitOptions:  submitunchanged
LineEnd:        share
View:

        //depot/prod/... //mkramer/prod/...
        -//depot/.../foo/... //mkramer/.../foo/...

如您所见,错误的dict是我的客户端视图中不存在的文件。我相信这是问题的根源。但是,我显然使用--use-client-spec运行命令。我也试过git config git-p4.useclientspec true 详细的输出使它看起来像是拉出了我的观点

Opening pipe: p4 -u mkramer -c mkramer -G client -o.  

如果我运行p4 -u mkramer -c mkramer client -o,我会看到正确的观点。

如果我运行p4 -u mkramer -c mkramer files //depot/prod/...#head,我会看到不在我视野中的文件。

我的软件版本:

[~/p4/prod@ernie02] (master) $ p4 -V
Perforce - The Fast Software Configuration Management System.
Copyright 1995-2009 Perforce Software.  All rights reserved.
Rev. P4/LINUX26X86_64/2009.1/205670 (2009/06/29).
[~/p4/prod@ernie02] (master) $ git --version
git version 1.7.0.5
[~/p4/prod@ernie02] (master) $ python -V
Python 2.6.5

2 个答案:

答案 0 :(得分:3)

我们自己也碰到了这个。 P4似乎在去年添加了一些git-p4不完全支持的新命令;特别是“移动/删除”和“移动/添加”。

为了解决这个问题,我们更改了一行:

if file["action"] in ("delete", "purge"):

为:

if file["action"] in ("delete", "purge", "move/delete"):

到目前为止,这对我们有用,但我不会断言这必然是一个强有力的解决方案。

答案 1 :(得分:1)

这是一个在最近版本的git-p4中使用rbergman提供的补丁修复的错误。有关详细信息,请参阅http://git.kernel.org/?p=git/git.git;a=commit;h=562d53fa69933b3ade2691b99cbe67722313f43c;这个补丁可能出现在后来的1.6.x版本中,并且绝对是在git的1.7.x版本中。