سؤال

أحاول استخدام GIT-P4 لاستنساخ مستودع Perforce. ما زلت أواجه مشكلة في البرنامج النصي 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/...

كما ترون ، فإن القولون الخاطئ هو ملف غير موجود في عرض موكلي. أعتقد أن هذا هو مصدر المشكلة. ومع ذلك ، من الواضح أنني أقوم بتشغيل الأمر مع-استخدام العميل العميل. لقد حاولت أيضا 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
هل كانت مفيدة؟

المحلول

لقد واجهنا هذا أنفسنا. يبدو أن P4 قد أضافت بعض الأوامر الجديدة في العام الماضي بأن GIT-P4 لا يدعمه تمامًا ؛ لا سيما "Move/Delete" و "Move/Add".

من أجل العمل حول القضية ، غيرنا الخط:

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

إلى:

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

حتى الآن هذا يعمل من أجلنا ، لكنني لن أؤكد أن هذا هو الحل القوي بالضرورة.

نصائح أخرى

هذا خطأ تم إصلاحه في الإصدارات الحديثة من GIT-P4 باستخدام التصحيح الذي توفره Rbergman بشكل أساسي. نرى http://git.kernel.org/؟p=git/git.git ؛a=commit؛h=562d53fa69933b3ade2691b99cbe67722313f43c لمزيد من التفاصيل؛ ربما ظهرت هذه التصحيح في أحد إصدارات 1.6.x اللاحقة وهو بالتأكيد في إصدارات 1.7.x من GIT.

مرخصة بموجب: CC-BY-SA مع الإسناد
لا تنتمي إلى StackOverflow
scroll top