|
|
|
#!/bin/sh
|
|
|
|
|
|
|
|
test_description='git p4 rcs keywords'
|
|
|
|
|
|
|
|
. ./lib-git-p4.sh
|
|
|
|
|
git-p4: resolve RCS keywords in bytes not utf-8
RCS keywords are strings that are replaced with information from
Perforce. Examples include $Date$, $Author$, $File$, $Change$ etc.
Perforce resolves these by expanding them with their expanded values
when files are synced, but Git's data model requires these expanded
values to be converted back into their unexpanded form.
Previously, git-p4.py would implement this behaviour through the use of
regular expressions. However, the regular expression substitution was
applied using decoded strings i.e. the content of incoming commit diffs
was first decoded from bytes into UTF-8, processed with regular
expressions, then converted back to bytes.
Not only is this behaviour inefficient, but it is also a cause of a
common issue caused by text files containing invalid UTF-8 data. For
files created in Windows, CP1252 Smart Quote Characters (0x93 and 0x94)
are seen fairly frequently. These codes are invalid in UTF-8, so if the
script encountered any file containing them, on Python 2 the symbols
will be corrupted, and on Python 3 the script will fail with an
exception.
This patch replaces this decoding/encoding with bytes object regular
expressions, so that the substitution is performed directly upon the
source data with no conversions.
A test for smart quote handling has been added to the
t9810-git-p4-rcs.sh test suite.
Signed-off-by: Joel Holdsworth <jholdsworth@nvidia.com>
Signed-off-by: Junio C Hamano <gitster@pobox.com>
3 years ago
|
|
|
CP1252="\223\224"
|
|
|
|
|
|
|
|
test_expect_success 'start p4d' '
|
|
|
|
start_p4d
|
|
|
|
'
|
|
|
|
|
|
|
|
#
|
|
|
|
# Make one file with keyword lines at the top, and
|
|
|
|
# enough plain text to be able to test modifications
|
|
|
|
# far away from the keywords.
|
|
|
|
#
|
|
|
|
test_expect_success 'init depot' '
|
|
|
|
(
|
|
|
|
cd "$cli" &&
|
|
|
|
cat <<-\EOF >filek &&
|
|
|
|
$Id$
|
|
|
|
/* $Revision$ */
|
|
|
|
# $Change$
|
|
|
|
line4
|
|
|
|
line5
|
|
|
|
line6
|
|
|
|
line7
|
|
|
|
line8
|
|
|
|
EOF
|
|
|
|
sed "s/Revision/Revision: do not scrub me/" <filek >fileko &&
|
|
|
|
sed "s/Id/Id: do not scrub me/" <fileko >file_text &&
|
|
|
|
p4 add -t text+k filek &&
|
|
|
|
p4 submit -d "filek" &&
|
|
|
|
p4 add -t text+ko fileko &&
|
|
|
|
p4 submit -d "fileko" &&
|
git-p4: resolve RCS keywords in bytes not utf-8
RCS keywords are strings that are replaced with information from
Perforce. Examples include $Date$, $Author$, $File$, $Change$ etc.
Perforce resolves these by expanding them with their expanded values
when files are synced, but Git's data model requires these expanded
values to be converted back into their unexpanded form.
Previously, git-p4.py would implement this behaviour through the use of
regular expressions. However, the regular expression substitution was
applied using decoded strings i.e. the content of incoming commit diffs
was first decoded from bytes into UTF-8, processed with regular
expressions, then converted back to bytes.
Not only is this behaviour inefficient, but it is also a cause of a
common issue caused by text files containing invalid UTF-8 data. For
files created in Windows, CP1252 Smart Quote Characters (0x93 and 0x94)
are seen fairly frequently. These codes are invalid in UTF-8, so if the
script encountered any file containing them, on Python 2 the symbols
will be corrupted, and on Python 3 the script will fail with an
exception.
This patch replaces this decoding/encoding with bytes object regular
expressions, so that the substitution is performed directly upon the
source data with no conversions.
A test for smart quote handling has been added to the
t9810-git-p4-rcs.sh test suite.
Signed-off-by: Joel Holdsworth <jholdsworth@nvidia.com>
Signed-off-by: Junio C Hamano <gitster@pobox.com>
3 years ago
|
|
|
printf "$CP1252" >fileko_cp1252 &&
|
|
|
|
p4 add -t text+ko fileko_cp1252 &&
|
|
|
|
p4 submit -d "fileko_cp1252" &&
|
|
|
|
p4 add -t text file_text &&
|
|
|
|
p4 submit -d "file_text"
|
|
|
|
)
|
|
|
|
'
|
|
|
|
|
|
|
|
#
|
|
|
|
# Generate these in a function to make it easy to use single quote marks.
|
|
|
|
#
|
|
|
|
write_scrub_scripts () {
|
|
|
|
cat >"$TRASH_DIRECTORY/scrub_k.py" <<-\EOF &&
|
|
|
|
import re, sys
|
|
|
|
sys.stdout.write(re.sub(r'(?i)\$(Id|Header|Author|Date|DateTime|Change|File|Revision):[^$]*\$', r'$\1$', sys.stdin.read()))
|
|
|
|
EOF
|
|
|
|
cat >"$TRASH_DIRECTORY/scrub_ko.py" <<-\EOF
|
|
|
|
import re, sys
|
|
|
|
sys.stdout.write(re.sub(r'(?i)\$(Id|Header):[^$]*\$', r'$\1$', sys.stdin.read()))
|
|
|
|
EOF
|
|
|
|
}
|
|
|
|
|
|
|
|
test_expect_success 'scrub scripts' '
|
|
|
|
write_scrub_scripts
|
|
|
|
'
|
|
|
|
|
|
|
|
#
|
|
|
|
# Compare $cli/file to its scrubbed version, should be different.
|
|
|
|
# Compare scrubbed $cli/file to $git/file, should be same.
|
|
|
|
#
|
|
|
|
scrub_k_check () {
|
|
|
|
file="$1" &&
|
|
|
|
scrub="$TRASH_DIRECTORY/$file" &&
|
|
|
|
"$PYTHON_PATH" "$TRASH_DIRECTORY/scrub_k.py" <"$git/$file" >"$scrub" &&
|
|
|
|
! test_cmp "$cli/$file" "$scrub" &&
|
|
|
|
test_cmp "$git/$file" "$scrub" &&
|
|
|
|
rm "$scrub"
|
|
|
|
}
|
|
|
|
scrub_ko_check () {
|
|
|
|
file="$1" &&
|
|
|
|
scrub="$TRASH_DIRECTORY/$file" &&
|
|
|
|
"$PYTHON_PATH" "$TRASH_DIRECTORY/scrub_ko.py" <"$git/$file" >"$scrub" &&
|
|
|
|
! test_cmp "$cli/$file" "$scrub" &&
|
|
|
|
test_cmp "$git/$file" "$scrub" &&
|
|
|
|
rm "$scrub"
|
|
|
|
}
|
|
|
|
|
|
|
|
#
|
|
|
|
# Modify far away from keywords. If no RCS lines show up
|
|
|
|
# in the diff, there is no conflict.
|
|
|
|
#
|
|
|
|
test_expect_success 'edit far away from RCS lines' '
|
|
|
|
test_when_finished cleanup_git &&
|
|
|
|
git p4 clone --dest="$git" //depot &&
|
|
|
|
(
|
|
|
|
cd "$git" &&
|
|
|
|
git config git-p4.skipSubmitEdit true &&
|
|
|
|
sed "s/^line7/line7 edit/" <filek >filek.tmp &&
|
|
|
|
mv -f filek.tmp filek &&
|
|
|
|
git commit -m "filek line7 edit" filek &&
|
|
|
|
git p4 submit &&
|
|
|
|
scrub_k_check filek
|
|
|
|
)
|
|
|
|
'
|
|
|
|
|
|
|
|
#
|
|
|
|
# Modify near the keywords. This will require RCS scrubbing.
|
|
|
|
#
|
|
|
|
test_expect_success 'edit near RCS lines' '
|
|
|
|
test_when_finished cleanup_git &&
|
|
|
|
git p4 clone --dest="$git" //depot &&
|
|
|
|
(
|
|
|
|
cd "$git" &&
|
|
|
|
git config git-p4.skipSubmitEdit true &&
|
|
|
|
git config git-p4.attemptRCSCleanup true &&
|
|
|
|
sed "s/^line4/line4 edit/" <filek >filek.tmp &&
|
|
|
|
mv -f filek.tmp filek &&
|
|
|
|
git commit -m "filek line4 edit" filek &&
|
|
|
|
git p4 submit &&
|
|
|
|
scrub_k_check filek
|
|
|
|
)
|
|
|
|
'
|
|
|
|
|
|
|
|
#
|
|
|
|
# Modify the keywords themselves. This also will require RCS scrubbing.
|
|
|
|
#
|
|
|
|
test_expect_success 'edit keyword lines' '
|
|
|
|
test_when_finished cleanup_git &&
|
|
|
|
git p4 clone --dest="$git" //depot &&
|
|
|
|
(
|
|
|
|
cd "$git" &&
|
|
|
|
git config git-p4.skipSubmitEdit true &&
|
|
|
|
git config git-p4.attemptRCSCleanup true &&
|
|
|
|
sed "/Revision/d" <filek >filek.tmp &&
|
|
|
|
mv -f filek.tmp filek &&
|
|
|
|
git commit -m "filek remove Revision line" filek &&
|
|
|
|
git p4 submit &&
|
|
|
|
scrub_k_check filek
|
|
|
|
)
|
|
|
|
'
|
|
|
|
|
|
|
|
#
|
|
|
|
# Scrubbing text+ko files should not alter all keywords, just Id, Header.
|
|
|
|
#
|
|
|
|
test_expect_success 'scrub ko files differently' '
|
|
|
|
test_when_finished cleanup_git &&
|
|
|
|
git p4 clone --dest="$git" //depot &&
|
|
|
|
(
|
|
|
|
cd "$git" &&
|
|
|
|
git config git-p4.skipSubmitEdit true &&
|
|
|
|
git config git-p4.attemptRCSCleanup true &&
|
|
|
|
sed "s/^line4/line4 edit/" <fileko >fileko.tmp &&
|
|
|
|
mv -f fileko.tmp fileko &&
|
|
|
|
git commit -m "fileko line4 edit" fileko &&
|
|
|
|
git p4 submit &&
|
|
|
|
scrub_ko_check fileko &&
|
|
|
|
! scrub_k_check fileko
|
|
|
|
)
|
|
|
|
'
|
|
|
|
|
|
|
|
# hack; git p4 submit should do it on its own
|
|
|
|
test_expect_success 'cleanup after failure' '
|
|
|
|
(
|
|
|
|
cd "$cli" &&
|
|
|
|
p4 revert ...
|
|
|
|
)
|
|
|
|
'
|
|
|
|
|
|
|
|
# perl $File:: bug check
|
|
|
|
test_expect_success 'ktext expansion should not expand multi-line $File::' '
|
|
|
|
(
|
|
|
|
cd "$cli" &&
|
|
|
|
cat >lv.pm <<-\EOF &&
|
|
|
|
my $wanted = sub { my $f = $File::Find::name;
|
|
|
|
if ( -f && $f =~ /foo/ ) {
|
|
|
|
EOF
|
|
|
|
p4 add -t ktext lv.pm &&
|
|
|
|
p4 submit -d "lv.pm"
|
|
|
|
) &&
|
|
|
|
test_when_finished cleanup_git &&
|
|
|
|
git p4 clone --dest="$git" //depot &&
|
|
|
|
(
|
|
|
|
cd "$git" &&
|
|
|
|
test_cmp "$cli/lv.pm" lv.pm
|
|
|
|
)
|
|
|
|
'
|
|
|
|
|
|
|
|
#
|
|
|
|
# Do not scrub anything but +k or +ko files. Sneak a change into
|
|
|
|
# the cli file so that submit will get a conflict. Make sure that
|
|
|
|
# scrubbing doesn't make a mess of things.
|
|
|
|
#
|
|
|
|
# This might happen only if the git repo is behind the p4 repo at
|
|
|
|
# submit time, and there is a conflict.
|
|
|
|
#
|
|
|
|
test_expect_success 'do not scrub plain text' '
|
|
|
|
test_when_finished cleanup_git &&
|
|
|
|
git p4 clone --dest="$git" //depot &&
|
|
|
|
(
|
|
|
|
cd "$git" &&
|
|
|
|
git config git-p4.skipSubmitEdit true &&
|
|
|
|
git config git-p4.attemptRCSCleanup true &&
|
|
|
|
sed "s/^line4/line4 edit/" <file_text >file_text.tmp &&
|
|
|
|
mv -f file_text.tmp file_text &&
|
|
|
|
git commit -m "file_text line4 edit" file_text &&
|
|
|
|
(
|
|
|
|
cd "$cli" &&
|
|
|
|
p4 open file_text &&
|
|
|
|
sed "s/^line5/line5 p4 edit/" <file_text >file_text.tmp &&
|
|
|
|
mv -f file_text.tmp file_text &&
|
|
|
|
p4 submit -d "file5 p4 edit"
|
|
|
|
) &&
|
git p4: gracefully fail if some commits could not be applied
If a commit fails to apply cleanly to the p4 tree, an interactive
prompt asks what to do next. In all cases (skip, apply, write),
the behavior after the prompt had a few problems.
Change it so that it does not claim erroneously that all commits
were applied. Instead list the set of the patches under
consideration, and mark with an asterisk those that were
applied successfully. Like this example:
Applying 592f1f9 line5 in file1 will conflict
...
Unfortunately applying the change failed!
What do you want to do?
[s]kip this patch / [a]pply the patch forcibly and with .rej files / [w]rite the patch to a file (patch.txt) s
Skipping! Good luck with the next patches...
//depot/file1#4 - was edit, reverted
Applying b8db1c6 okay_commit_after_skip
...
Change 6 submitted.
Applied only the commits marked with '*':
592f1f9 line5 in file1 will conflict
* b8db1c6 okay_commit_after_skip
Do not try to sync and rebase unless all patches were applied.
If there was a conflict during the submit, there is sure to be one
at the rebase. Let the user to do the sync and rebase manually.
This changes how a couple tets in t9810-git-p4-rcs.sh behave:
- git p4 now does not leave files open and edited in the
client
- If a git commit contains a change to a file that was
deleted in p4, the test used to check that the sync/rebase
loop happened after the failure to apply the change. Since
now sync/rebase does not happen after failure, do not test
this. Normal rebase machinery, outside of git p4, will let
rebase --skip work.
Signed-off-by: Pete Wyckoff <pw@padd.com>
Acked-by: Luke Diamand <luke@diamand.org>
Signed-off-by: Junio C Hamano <gitster@pobox.com>
13 years ago
|
|
|
echo s | test_expect_code 1 git p4 submit &&
|
|
|
|
(
|
git p4: gracefully fail if some commits could not be applied
If a commit fails to apply cleanly to the p4 tree, an interactive
prompt asks what to do next. In all cases (skip, apply, write),
the behavior after the prompt had a few problems.
Change it so that it does not claim erroneously that all commits
were applied. Instead list the set of the patches under
consideration, and mark with an asterisk those that were
applied successfully. Like this example:
Applying 592f1f9 line5 in file1 will conflict
...
Unfortunately applying the change failed!
What do you want to do?
[s]kip this patch / [a]pply the patch forcibly and with .rej files / [w]rite the patch to a file (patch.txt) s
Skipping! Good luck with the next patches...
//depot/file1#4 - was edit, reverted
Applying b8db1c6 okay_commit_after_skip
...
Change 6 submitted.
Applied only the commits marked with '*':
592f1f9 line5 in file1 will conflict
* b8db1c6 okay_commit_after_skip
Do not try to sync and rebase unless all patches were applied.
If there was a conflict during the submit, there is sure to be one
at the rebase. Let the user to do the sync and rebase manually.
This changes how a couple tets in t9810-git-p4-rcs.sh behave:
- git p4 now does not leave files open and edited in the
client
- If a git commit contains a change to a file that was
deleted in p4, the test used to check that the sync/rebase
loop happened after the failure to apply the change. Since
now sync/rebase does not happen after failure, do not test
this. Normal rebase machinery, outside of git p4, will let
rebase --skip work.
Signed-off-by: Pete Wyckoff <pw@padd.com>
Acked-by: Luke Diamand <luke@diamand.org>
Signed-off-by: Junio C Hamano <gitster@pobox.com>
13 years ago
|
|
|
# make sure the file is not left open
|
|
|
|
cd "$cli" &&
|
git p4: gracefully fail if some commits could not be applied
If a commit fails to apply cleanly to the p4 tree, an interactive
prompt asks what to do next. In all cases (skip, apply, write),
the behavior after the prompt had a few problems.
Change it so that it does not claim erroneously that all commits
were applied. Instead list the set of the patches under
consideration, and mark with an asterisk those that were
applied successfully. Like this example:
Applying 592f1f9 line5 in file1 will conflict
...
Unfortunately applying the change failed!
What do you want to do?
[s]kip this patch / [a]pply the patch forcibly and with .rej files / [w]rite the patch to a file (patch.txt) s
Skipping! Good luck with the next patches...
//depot/file1#4 - was edit, reverted
Applying b8db1c6 okay_commit_after_skip
...
Change 6 submitted.
Applied only the commits marked with '*':
592f1f9 line5 in file1 will conflict
* b8db1c6 okay_commit_after_skip
Do not try to sync and rebase unless all patches were applied.
If there was a conflict during the submit, there is sure to be one
at the rebase. Let the user to do the sync and rebase manually.
This changes how a couple tets in t9810-git-p4-rcs.sh behave:
- git p4 now does not leave files open and edited in the
client
- If a git commit contains a change to a file that was
deleted in p4, the test used to check that the sync/rebase
loop happened after the failure to apply the change. Since
now sync/rebase does not happen after failure, do not test
this. Normal rebase machinery, outside of git p4, will let
rebase --skip work.
Signed-off-by: Pete Wyckoff <pw@padd.com>
Acked-by: Luke Diamand <luke@diamand.org>
Signed-off-by: Junio C Hamano <gitster@pobox.com>
13 years ago
|
|
|
! p4 fstat -T action file_text
|
|
|
|
)
|
|
|
|
)
|
|
|
|
'
|
|
|
|
|
|
|
|
# hack; git p4 submit should do it on its own
|
|
|
|
test_expect_success 'cleanup after failure 2' '
|
|
|
|
(
|
|
|
|
cd "$cli" &&
|
|
|
|
p4 revert ...
|
|
|
|
)
|
|
|
|
'
|
|
|
|
|
|
|
|
create_kw_file () {
|
|
|
|
cat <<\EOF >"$1"
|
|
|
|
/* A file
|
|
|
|
Id: $Id$
|
|
|
|
Revision: $Revision$
|
|
|
|
File: $File$
|
|
|
|
*/
|
|
|
|
int main(int argc, const char **argv) {
|
|
|
|
return 0;
|
|
|
|
}
|
|
|
|
EOF
|
|
|
|
}
|
|
|
|
|
|
|
|
test_expect_success 'add kwfile' '
|
|
|
|
(
|
|
|
|
cd "$cli" &&
|
|
|
|
echo file1 >file1 &&
|
|
|
|
p4 add file1 &&
|
|
|
|
p4 submit -d "file 1" &&
|
|
|
|
create_kw_file kwfile1.c &&
|
|
|
|
p4 add kwfile1.c &&
|
|
|
|
p4 submit -d "Add rcw kw file" kwfile1.c
|
|
|
|
)
|
|
|
|
'
|
|
|
|
|
|
|
|
p4_append_to_file () {
|
|
|
|
f="$1" &&
|
|
|
|
p4 edit -t ktext "$f" &&
|
|
|
|
echo "/* $(date) */" >>"$f" &&
|
|
|
|
p4 submit -d "appending a line in p4"
|
|
|
|
}
|
|
|
|
|
|
|
|
# Create some files with RCS keywords. If they get modified
|
|
|
|
# elsewhere then the version number gets bumped which then
|
|
|
|
# results in a merge conflict if we touch the RCS kw lines,
|
|
|
|
# even though the change itself would otherwise apply cleanly.
|
|
|
|
test_expect_success 'cope with rcs keyword expansion damage' '
|
|
|
|
test_when_finished cleanup_git &&
|
|
|
|
git p4 clone --dest="$git" //depot &&
|
|
|
|
(
|
|
|
|
cd "$git" &&
|
|
|
|
git config git-p4.skipSubmitEdit true &&
|
|
|
|
git config git-p4.attemptRCSCleanup true &&
|
|
|
|
(cd "$cli" && p4_append_to_file kwfile1.c) &&
|
|
|
|
old_lines=$(wc -l <kwfile1.c) &&
|
|
|
|
perl -n -i -e "print unless m/Revision:/" kwfile1.c &&
|
|
|
|
new_lines=$(wc -l <kwfile1.c) &&
|
|
|
|
test $new_lines = $(($old_lines - 1)) &&
|
|
|
|
|
|
|
|
git add kwfile1.c &&
|
|
|
|
git commit -m "Zap an RCS kw line" &&
|
|
|
|
git p4 submit &&
|
|
|
|
git p4 rebase &&
|
|
|
|
git diff p4/master &&
|
|
|
|
git p4 commit &&
|
|
|
|
echo "try modifying in both" &&
|
|
|
|
cd "$cli" &&
|
|
|
|
p4 edit kwfile1.c &&
|
|
|
|
echo "line from p4" >>kwfile1.c &&
|
|
|
|
p4 submit -d "add a line in p4" kwfile1.c &&
|
|
|
|
cd "$git" &&
|
|
|
|
echo "line from git at the top" | cat - kwfile1.c >kwfile1.c.new &&
|
|
|
|
mv kwfile1.c.new kwfile1.c &&
|
|
|
|
git commit -m "Add line in git at the top" kwfile1.c &&
|
|
|
|
git p4 rebase &&
|
|
|
|
git p4 submit
|
|
|
|
)
|
|
|
|
'
|
|
|
|
|
|
|
|
test_expect_success 'cope with rcs keyword file deletion' '
|
|
|
|
test_when_finished cleanup_git &&
|
|
|
|
(
|
|
|
|
cd "$cli" &&
|
|
|
|
echo "\$Revision\$" >kwdelfile.c &&
|
|
|
|
p4 add -t ktext kwdelfile.c &&
|
|
|
|
p4 submit -d "Add file to be deleted" &&
|
|
|
|
grep 1 kwdelfile.c
|
|
|
|
) &&
|
|
|
|
git p4 clone --dest="$git" //depot &&
|
|
|
|
(
|
|
|
|
cd "$git" &&
|
|
|
|
grep Revision kwdelfile.c &&
|
|
|
|
git rm -f kwdelfile.c &&
|
|
|
|
git commit -m "Delete a file containing RCS keywords" &&
|
|
|
|
git config git-p4.skipSubmitEdit true &&
|
|
|
|
git config git-p4.attemptRCSCleanup true &&
|
|
|
|
git p4 submit
|
|
|
|
) &&
|
|
|
|
(
|
|
|
|
cd "$cli" &&
|
|
|
|
p4 sync &&
|
|
|
|
! test -f kwdelfile.c
|
|
|
|
)
|
|
|
|
'
|
|
|
|
|
|
|
|
# If you add keywords in git of the form $Header$ then everything should
|
|
|
|
# work fine without any special handling.
|
|
|
|
test_expect_success 'Add keywords in git which match the default p4 values' '
|
|
|
|
test_when_finished cleanup_git &&
|
|
|
|
git p4 clone --dest="$git" //depot &&
|
|
|
|
(
|
|
|
|
cd "$git" &&
|
|
|
|
echo "NewKW: \$Revision\$" >>kwfile1.c &&
|
|
|
|
git add kwfile1.c &&
|
|
|
|
git commit -m "Adding RCS keywords in git" &&
|
|
|
|
git config git-p4.skipSubmitEdit true &&
|
|
|
|
git config git-p4.attemptRCSCleanup true &&
|
|
|
|
git p4 submit
|
|
|
|
) &&
|
|
|
|
(
|
|
|
|
cd "$cli" &&
|
|
|
|
p4 sync &&
|
|
|
|
test -f kwfile1.c &&
|
|
|
|
grep "NewKW.*Revision.*[0-9]" kwfile1.c
|
|
|
|
|
|
|
|
)
|
|
|
|
'
|
|
|
|
|
|
|
|
# If you add keywords in git of the form $Header:#1$ then things will fail
|
|
|
|
# unless git-p4 takes steps to scrub the *git* commit.
|
|
|
|
#
|
|
|
|
test_expect_failure 'Add keywords in git which do not match the default p4 values' '
|
|
|
|
test_when_finished cleanup_git &&
|
|
|
|
git p4 clone --dest="$git" //depot &&
|
|
|
|
(
|
|
|
|
cd "$git" &&
|
|
|
|
echo "NewKW2: \$Revision:1\$" >>kwfile1.c &&
|
|
|
|
git add kwfile1.c &&
|
|
|
|
git commit -m "Adding RCS keywords in git" &&
|
|
|
|
git config git-p4.skipSubmitEdit true &&
|
|
|
|
git config git-p4.attemptRCSCleanup true &&
|
|
|
|
git p4 submit
|
|
|
|
) &&
|
|
|
|
(
|
|
|
|
cd "$cli" &&
|
|
|
|
p4 sync &&
|
|
|
|
grep "NewKW2.*Revision.*[0-9]" kwfile1.c
|
|
|
|
|
|
|
|
)
|
|
|
|
'
|
|
|
|
|
git-p4: resolve RCS keywords in bytes not utf-8
RCS keywords are strings that are replaced with information from
Perforce. Examples include $Date$, $Author$, $File$, $Change$ etc.
Perforce resolves these by expanding them with their expanded values
when files are synced, but Git's data model requires these expanded
values to be converted back into their unexpanded form.
Previously, git-p4.py would implement this behaviour through the use of
regular expressions. However, the regular expression substitution was
applied using decoded strings i.e. the content of incoming commit diffs
was first decoded from bytes into UTF-8, processed with regular
expressions, then converted back to bytes.
Not only is this behaviour inefficient, but it is also a cause of a
common issue caused by text files containing invalid UTF-8 data. For
files created in Windows, CP1252 Smart Quote Characters (0x93 and 0x94)
are seen fairly frequently. These codes are invalid in UTF-8, so if the
script encountered any file containing them, on Python 2 the symbols
will be corrupted, and on Python 3 the script will fail with an
exception.
This patch replaces this decoding/encoding with bytes object regular
expressions, so that the substitution is performed directly upon the
source data with no conversions.
A test for smart quote handling has been added to the
t9810-git-p4-rcs.sh test suite.
Signed-off-by: Joel Holdsworth <jholdsworth@nvidia.com>
Signed-off-by: Junio C Hamano <gitster@pobox.com>
3 years ago
|
|
|
test_expect_success 'check cp1252 smart quote are preserved through RCS keyword processing' '
|
|
|
|
test_when_finished cleanup_git &&
|
|
|
|
git p4 clone --dest="$git" //depot &&
|
|
|
|
(
|
|
|
|
cd "$git" &&
|
|
|
|
printf "$CP1252" >expect &&
|
|
|
|
test_cmp_bin expect fileko_cp1252
|
|
|
|
)
|
|
|
|
'
|
|
|
|
|
|
|
|
test_done
|