mirror of
https://github.com/git-for-windows/git.git
synced 2026-03-17 13:23:05 -05:00
Merge pull request #2315 from ROGERSM94/fix-rebase
rebase-merges: improve --rebase-merges label generation
This commit is contained in:
12
sequencer.c
12
sequencer.c
@@ -4598,8 +4598,18 @@ static int make_script_with_merges(struct pretty_print_context *pp,
|
||||
else
|
||||
strbuf_addbuf(&label, &oneline);
|
||||
|
||||
/*
|
||||
* Sanitize labels by replacing non-alpha-numeric characters
|
||||
* (including white-space ones) by dashes, as they might be
|
||||
* illegal in file names (and hence in ref names).
|
||||
*
|
||||
* Note that we retain non-ASCII UTF-8 characters (identified
|
||||
* via the most significant bit). They should be all acceptable
|
||||
* in file names. We do not validate the UTF-8 here, that's not
|
||||
* the job of this function.
|
||||
*/
|
||||
for (p1 = label.buf; *p1; p1++)
|
||||
if (isspace(*p1))
|
||||
if (!(*p1 & 0x80) && !isalnum(*p1))
|
||||
*(char *)p1 = '-';
|
||||
|
||||
strbuf_reset(&buf);
|
||||
|
||||
@@ -468,4 +468,10 @@ test_expect_success '--rebase-merges with strategies' '
|
||||
test_cmp expect G.t
|
||||
'
|
||||
|
||||
test_expect_success '--rebase-merges with commit that can generate bad characters for filename' '
|
||||
git checkout -b colon-in-label E &&
|
||||
git merge -m "colon: this should work" G &&
|
||||
git rebase --rebase-merges --force-rebase E
|
||||
'
|
||||
|
||||
test_done
|
||||
|
||||
Reference in New Issue
Block a user