rebase -r: let `label` generate safer labels
commitcd5522271f6b985114b33332e148bff2283b0440
authorMatthew Rogers <mattr94@gmail.com>
Sun, 17 Nov 2019 23:16:10 +0000 (17 23:16 +0000)
committerJunio C Hamano <gitster@pobox.com>
Mon, 18 Nov 2019 03:49:17 +0000 (18 12:49 +0900)
tree82824b8da5b4d71776b43c8755f939c4a7f85b40
parent867bc1d236b8955414b3dbacf28c7f0c2e337cf4
rebase -r: let `label` generate safer labels

The `label` todo command in interactive rebases creates temporary refs
in the `refs/rewritten/` namespace. These refs are stored as loose refs,
i.e. as files in `.git/refs/rewritten/`, therefore they have to conform
with file name limitations on the current filesystem in addition to the
accepted ref format.

This poses a problem in particular on NTFS/FAT, where e.g. the colon,
double-quote and pipe characters are disallowed as part of a file name.

Let's safeguard against this by replacing not only white-space
characters by dashes, but all non-alpha-numeric ones.

However, we exempt non-ASCII UTF-8 characters from that, as it should be
quite possible to reflect branch names such as `↯↯↯` in refs/file names.

Signed-off-by: Matthew Rogers <mattr94@gmail.com>
Signed-off-by: Johannes Schindelin <johannes.schindelin@gmx.de>
Signed-off-by: Junio C Hamano <gitster@pobox.com>
sequencer.c
t/t3430-rebase-merges.sh