> git-p4 can map a "git move" operation to a Perforce "move" operation.
> But by default this is disabled. You then end up with a P4 commit
> where the file is deleted, and a fresh file is created with the same
> contents at the new location at revision #1.
>
> Rename detection gets enabled either with the "-M" option, or with
> some config variables, git-p4.detectCopies and git-p4.detectRenames.
>
> I've been tripped up by this, and I actually know about it, and I know
> other people have been as well.
>
> Should we switch the default over so that it's enabled by default? I
> can't think of any reason why you wouldn't want it enabled.
I have it enabled in my ~/.gitconfig,
so enabling it by default makes total sense to me.
Regarding potential problems,
I occasionally get a wrong "source" file detection.
(e.g. there was `cp a b ; git add b`, but some other file "c" is selected as
the source instead)
Or there is a "copy/move" detected, when there was actually none.
But I've only seen this with quite small files (like a trivial one line shell
script) or binaries,
and mostly because I have git-p4.detectCopiesHarder set as well as a pretty
aggressive git-p4.detectCopies threshold.
(normally 30%, but down to 10% at times to make sure a copy/move is really
detected)
But anyway, enabling both git-p4.detect{Copies,Renames}
with default 50% similarity index makes sense to me.
It's probably worth adding command-line options to override the new to-be
defaults though.
A more conservative approach like only enabling git-p4.detectRenames = 70% is
an option too.
>
> I think the rename code was first introduced around 2011 by Vitor.
>
> Another option is to add a warning, but people just ignore warnings!
When such a warning would be shown?
Just before `p4 submit`?
I think, It might be hard to notice for large changesets.
Thank you,
Andrey