alex@xxxxxxxxx wrote on Tue, 16 Apr 2013 23:31 -0500: > git-p4.py (1.8.2.1.418.gaec3f77) has at least two behaviors that > seem to be incompatible with the version of p4 that I recently > downloaded from perforce.com (P4/LINUX26X86_64/2013.1/610569). > > TLDR: Is git-p4 written for an old version of p4 CLI with different > behavior? Or for a windows or mac release of p4? Or am I missing > something? I had not done any testing beyond p4 12.2 (linux). But running the unit tests through 13.1 just now, they all pass. $ p4 -V Perforce - The Fast Software Configuration Management System. Copyright 1995-2013 Perforce Software. All rights reserved. This product includes software developed by the OpenSSL Project for use in the OpenSSL Toolkit (http://www.openssl.org/) See 'p4 help legal' for full OpenSSL license information Version of OpenSSL Libraries: OpenSSL 1.0.1c 10 May 2012 Rev. P4/LINUX26X86_64/2013.1/610569 (2013/03/19). I'm using python 2.7.3. > First issue > ----------- > > git-p4 assumes the output of 'p4 print' adds a newline to the > target. To work around this, git-p4.py strips the last char from > symlinks as shown in the following snippet: > > if type_base =3D=3D "symlink": > git_mode =3D "120000" > # p4 print on a symlink contains "target\n"; remove the newline > data =3D ''.join(contents) > contents =3D [data[:-1]] > > But my 'p4 print' does not output the newline: > > $ ls -l pcre > lrwxrwxrwx 1 user group 12 Apr 16 10:27 pcre -> ../libs/pcre > > $ p4 print -q pcre | od -t x1a > 0000000 2e 2e 2f 6c 69 62 73 2f 70 63 72 65 > . . / l i b s / p c r e > 0000014 > > If I use 'git p4 clone' the above file shows up in git as a > symlink to '../libs/pcr'. I had another symlink whose target had > a strlen of 1 and the 'git p4 clone' failed b/c after stripping > the last char the result was an empty string. There wasn't an explict test for symlinks, but I threw one together quickly and it seems to work. Can you show a bit more information about anything that potentially might be odd with your install? arf-git-test$ ls -l symlink lrwxrwxrwx 1 pw pw 14 Apr 18 20:02 symlink -> symlink-target $ p4 fstat symlink ... depotFile //depot/symlink ... clientFile /run/shm/trash directory.t9802-git-p4-filetype/cli/symlink ... isMapped ... headAction add ... headType symlink ... headTime 1366329740 ... headRev 1 ... headChange 6 ... headModTime 1366329740 ... haveRev 1 $ p4 print -q symlink | od -t x1a 0000000 73 79 6d 6c 69 6e 6b 2d 74 61 72 67 65 74 0a s y m l i n k - t a r g e t nl 0000017 No idea why I get an "nl" but you do not. If you run _without_ the "| od ...", then the shell prompt ends up on the same line as the output? Any interesting shell or shell settings? > Second issue > ------------ > > git-p4 uses 'p4 print -q -o o FILE' to print a file to stdout. > At least that is how I interpret this snippet: > > text = p4_read_pipe(['print', '-q', '-o', '-', file['depotFile']]) > > However, p4/Linux prints to stdout by default and '-o -' will save > the output in a file named '-'. > > My git and p4 versions: > > $ git --version > git version 1.8.2.1.418.gaec3f77 > > $ p4 -V > Perforce - The Fast Software Configuration Management System. > Copyright 1995-2013 Perforce Software. All rights reserved. > This product includes software developed by the OpenSSL Project > for use in the OpenSSL Toolkit (http://www.openssl.org/) > See 'p4 help legal' for full OpenSSL license information > Version of OpenSSL Libraries: OpenSSL 1.0.1c 10 May 2012 > Rev. P4/LINUX26X86_64/2013.1/610569 (2013/03/19). This code only happens on utf16 files. But running it by hand, I cannot reproduce the different behavior: $ p4 print -q //depot/f-ascii three line text $ p4 print -o - -q //depot/f-ascii three line $ ls ./- ls: cannot access ./-: No such file or directory I'm again confused. Any hints you can give would be helpful. -- Pete -- To unsubscribe from this list: send the line "unsubscribe git" in the body of a message to majordomo@xxxxxxxxxxxxxxx More majordomo info at http://vger.kernel.org/majordomo-info.html