Merge branch 'tb/t0027-raciness-fix'
The t0027 test for CRLF conversion was timing dependent and flaky. * tb/t0027-raciness-fix: convert: Correct NNO tests and missing `LF will be replaced by CRLF`
This commit is contained in:
commit
643b62213e
81
convert.c
81
convert.c
@ -189,35 +189,27 @@ static enum eol output_eol(enum crlf_action crlf_action)
|
|||||||
}
|
}
|
||||||
|
|
||||||
static void check_safe_crlf(const char *path, enum crlf_action crlf_action,
|
static void check_safe_crlf(const char *path, enum crlf_action crlf_action,
|
||||||
struct text_stat *stats, enum safe_crlf checksafe)
|
struct text_stat *old_stats, struct text_stat *new_stats,
|
||||||
|
enum safe_crlf checksafe)
|
||||||
{
|
{
|
||||||
if (!checksafe)
|
if (old_stats->crlf && !new_stats->crlf ) {
|
||||||
return;
|
|
||||||
|
|
||||||
if (output_eol(crlf_action) == EOL_LF) {
|
|
||||||
/*
|
/*
|
||||||
* CRLFs would not be restored by checkout:
|
* CRLFs would not be restored by checkout
|
||||||
* check if we'd remove CRLFs
|
|
||||||
*/
|
*/
|
||||||
if (stats->crlf) {
|
|
||||||
if (checksafe == SAFE_CRLF_WARN)
|
if (checksafe == SAFE_CRLF_WARN)
|
||||||
warning("CRLF will be replaced by LF in %s.\nThe file will have its original line endings in your working directory.", path);
|
warning("CRLF will be replaced by LF in %s.\nThe file will have its original line endings in your working directory.", path);
|
||||||
else /* i.e. SAFE_CRLF_FAIL */
|
else /* i.e. SAFE_CRLF_FAIL */
|
||||||
die("CRLF would be replaced by LF in %s.", path);
|
die("CRLF would be replaced by LF in %s.", path);
|
||||||
}
|
} else if (old_stats->lonelf && !new_stats->lonelf ) {
|
||||||
} else if (output_eol(crlf_action) == EOL_CRLF) {
|
|
||||||
/*
|
/*
|
||||||
* CRLFs would be added by checkout:
|
* CRLFs would be added by checkout
|
||||||
* check if we have "naked" LFs
|
|
||||||
*/
|
*/
|
||||||
if (stats->lonelf) {
|
|
||||||
if (checksafe == SAFE_CRLF_WARN)
|
if (checksafe == SAFE_CRLF_WARN)
|
||||||
warning("LF will be replaced by CRLF in %s.\nThe file will have its original line endings in your working directory.", path);
|
warning("LF will be replaced by CRLF in %s.\nThe file will have its original line endings in your working directory.", path);
|
||||||
else /* i.e. SAFE_CRLF_FAIL */
|
else /* i.e. SAFE_CRLF_FAIL */
|
||||||
die("LF would be replaced by CRLF in %s", path);
|
die("LF would be replaced by CRLF in %s", path);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
|
||||||
|
|
||||||
static int has_cr_in_index(const char *path)
|
static int has_cr_in_index(const char *path)
|
||||||
{
|
{
|
||||||
@ -233,12 +225,35 @@ static int has_cr_in_index(const char *path)
|
|||||||
return has_cr;
|
return has_cr;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
static int will_convert_lf_to_crlf(size_t len, struct text_stat *stats,
|
||||||
|
enum crlf_action crlf_action)
|
||||||
|
{
|
||||||
|
if (output_eol(crlf_action) != EOL_CRLF)
|
||||||
|
return 0;
|
||||||
|
/* No "naked" LF? Nothing to convert, regardless. */
|
||||||
|
if (!stats->lonelf)
|
||||||
|
return 0;
|
||||||
|
|
||||||
|
if (crlf_action == CRLF_AUTO || crlf_action == CRLF_AUTO_INPUT || crlf_action == CRLF_AUTO_CRLF) {
|
||||||
|
/* If we have any CR or CRLF line endings, we do not touch it */
|
||||||
|
/* This is the new safer autocrlf-handling */
|
||||||
|
if (stats->lonecr || stats->crlf)
|
||||||
|
return 0;
|
||||||
|
|
||||||
|
if (convert_is_binary(len, stats))
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
return 1;
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
static int crlf_to_git(const char *path, const char *src, size_t len,
|
static int crlf_to_git(const char *path, const char *src, size_t len,
|
||||||
struct strbuf *buf,
|
struct strbuf *buf,
|
||||||
enum crlf_action crlf_action, enum safe_crlf checksafe)
|
enum crlf_action crlf_action, enum safe_crlf checksafe)
|
||||||
{
|
{
|
||||||
struct text_stat stats;
|
struct text_stat stats;
|
||||||
char *dst;
|
char *dst;
|
||||||
|
int convert_crlf_into_lf;
|
||||||
|
|
||||||
if (crlf_action == CRLF_BINARY ||
|
if (crlf_action == CRLF_BINARY ||
|
||||||
(src && !len))
|
(src && !len))
|
||||||
@ -252,6 +267,8 @@ static int crlf_to_git(const char *path, const char *src, size_t len,
|
|||||||
return 1;
|
return 1;
|
||||||
|
|
||||||
gather_stats(src, len, &stats);
|
gather_stats(src, len, &stats);
|
||||||
|
/* Optimization: No CRLF? Nothing to convert, regardless. */
|
||||||
|
convert_crlf_into_lf = !!stats.crlf;
|
||||||
|
|
||||||
if (crlf_action == CRLF_AUTO || crlf_action == CRLF_AUTO_INPUT || crlf_action == CRLF_AUTO_CRLF) {
|
if (crlf_action == CRLF_AUTO || crlf_action == CRLF_AUTO_INPUT || crlf_action == CRLF_AUTO_CRLF) {
|
||||||
if (convert_is_binary(len, &stats))
|
if (convert_is_binary(len, &stats))
|
||||||
@ -263,12 +280,24 @@ static int crlf_to_git(const char *path, const char *src, size_t len,
|
|||||||
if (checksafe == SAFE_CRLF_RENORMALIZE)
|
if (checksafe == SAFE_CRLF_RENORMALIZE)
|
||||||
checksafe = SAFE_CRLF_FALSE;
|
checksafe = SAFE_CRLF_FALSE;
|
||||||
else if (has_cr_in_index(path))
|
else if (has_cr_in_index(path))
|
||||||
return 0;
|
convert_crlf_into_lf = 0;
|
||||||
}
|
}
|
||||||
check_safe_crlf(path, crlf_action, &stats, checksafe);
|
if (checksafe && len) {
|
||||||
|
struct text_stat new_stats;
|
||||||
/* Optimization: No CRLF? Nothing to convert, regardless. */
|
memcpy(&new_stats, &stats, sizeof(new_stats));
|
||||||
if (!stats.crlf)
|
/* simulate "git add" */
|
||||||
|
if (convert_crlf_into_lf) {
|
||||||
|
new_stats.lonelf += new_stats.crlf;
|
||||||
|
new_stats.crlf = 0;
|
||||||
|
}
|
||||||
|
/* simulate "git checkout" */
|
||||||
|
if (will_convert_lf_to_crlf(len, &new_stats, crlf_action)) {
|
||||||
|
new_stats.crlf += new_stats.lonelf;
|
||||||
|
new_stats.lonelf = 0;
|
||||||
|
}
|
||||||
|
check_safe_crlf(path, crlf_action, &stats, &new_stats, checksafe);
|
||||||
|
}
|
||||||
|
if (!convert_crlf_into_lf)
|
||||||
return 0;
|
return 0;
|
||||||
|
|
||||||
/*
|
/*
|
||||||
@ -314,21 +343,9 @@ static int crlf_to_worktree(const char *path, const char *src, size_t len,
|
|||||||
return 0;
|
return 0;
|
||||||
|
|
||||||
gather_stats(src, len, &stats);
|
gather_stats(src, len, &stats);
|
||||||
|
if (!will_convert_lf_to_crlf(len, &stats, crlf_action))
|
||||||
/* No "naked" LF? Nothing to convert, regardless. */
|
|
||||||
if (!stats.lonelf)
|
|
||||||
return 0;
|
return 0;
|
||||||
|
|
||||||
if (crlf_action == CRLF_AUTO || crlf_action == CRLF_AUTO_INPUT || crlf_action == CRLF_AUTO_CRLF) {
|
|
||||||
/* If we have any CR or CRLF line endings, we do not touch it */
|
|
||||||
/* This is the new safer autocrlf-handling */
|
|
||||||
if (stats.lonecr || stats.crlf )
|
|
||||||
return 0;
|
|
||||||
|
|
||||||
if (convert_is_binary(len, &stats))
|
|
||||||
return 0;
|
|
||||||
}
|
|
||||||
|
|
||||||
/* are we "faking" in place editing ? */
|
/* are we "faking" in place editing ? */
|
||||||
if (src == buf->buf)
|
if (src == buf->buf)
|
||||||
to_free = strbuf_detach(buf, NULL);
|
to_free = strbuf_detach(buf, NULL);
|
||||||
|
@ -119,8 +119,7 @@ commit_chk_wrnNNO () {
|
|||||||
fname=${pfx}_$f.txt &&
|
fname=${pfx}_$f.txt &&
|
||||||
cp $f $fname &&
|
cp $f $fname &&
|
||||||
printf Z >>"$fname" &&
|
printf Z >>"$fname" &&
|
||||||
git -c core.autocrlf=$crlf add $fname 2>/dev/null &&
|
git -c core.autocrlf=$crlf add $fname 2>"${pfx}_$f.err"
|
||||||
git -c core.autocrlf=$crlf commit -m "commit_$fname" $fname >"${pfx}_$f.err" 2>&1
|
|
||||||
done
|
done
|
||||||
|
|
||||||
test_expect_success "commit NNO files crlf=$crlf attr=$attr LF" '
|
test_expect_success "commit NNO files crlf=$crlf attr=$attr LF" '
|
||||||
@ -417,7 +416,8 @@ commit_chk_wrnNNO "text" "" false "$WILC" "$WICL" "$WAMIX" "$WILC
|
|||||||
commit_chk_wrnNNO "text" "" true LF_CRLF "" LF_CRLF LF_CRLF ""
|
commit_chk_wrnNNO "text" "" true LF_CRLF "" LF_CRLF LF_CRLF ""
|
||||||
commit_chk_wrnNNO "text" "" input "" CRLF_LF CRLF_LF "" CRLF_LF
|
commit_chk_wrnNNO "text" "" input "" CRLF_LF CRLF_LF "" CRLF_LF
|
||||||
|
|
||||||
test_expect_success 'create files cleanup' '
|
test_expect_success 'commit NNO and cleanup' '
|
||||||
|
git commit -m "commit files on top of NNO" &&
|
||||||
rm -f *.txt &&
|
rm -f *.txt &&
|
||||||
git -c core.autocrlf=false reset --hard
|
git -c core.autocrlf=false reset --hard
|
||||||
'
|
'
|
||||||
|
Loading…
Reference in New Issue
Block a user