Skip to content

Commit

Permalink
Merge pull request #2315 from ROGERSM94/fix-rebase
Browse files Browse the repository at this point in the history
rebase-merges: improve --rebase-merges label generation
  • Loading branch information
dscho committed Oct 21, 2019
2 parents 8922a6f + 8021340 commit 280b610
Show file tree
Hide file tree
Showing 2 changed files with 17 additions and 1 deletion.
12 changes: 11 additions & 1 deletion sequencer.c
Expand Up @@ -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);
Expand Down
6 changes: 6 additions & 0 deletions t/t3430-rebase-merges.sh
Expand Up @@ -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

0 comments on commit 280b610

Please sign in to comment.