2018-06-15 04:40:53 +03:00
|
|
|
#require no-fsmonitor
|
|
|
|
|
2010-09-26 22:41:32 +04:00
|
|
|
Test EOL extension
|
|
|
|
|
2011-03-01 19:01:17 +03:00
|
|
|
$ cat >> $HGRCPATH <<EOF
|
2010-09-26 22:41:32 +04:00
|
|
|
> [diff]
|
|
|
|
> git = True
|
|
|
|
> EOF
|
|
|
|
|
|
|
|
Set up helpers
|
|
|
|
|
|
|
|
$ cat > switch-eol.py <<EOF
|
2017-08-22 22:51:06 +03:00
|
|
|
> from __future__ import absolute_import
|
|
|
|
> import os
|
2010-09-26 22:41:32 +04:00
|
|
|
> import sys
|
|
|
|
> try:
|
2017-08-22 22:51:06 +03:00
|
|
|
> import msvcrt
|
2010-09-26 22:41:32 +04:00
|
|
|
> msvcrt.setmode(sys.stdin.fileno(), os.O_BINARY)
|
|
|
|
> msvcrt.setmode(sys.stdout.fileno(), os.O_BINARY)
|
|
|
|
> except ImportError:
|
|
|
|
> pass
|
|
|
|
> (old, new) = sys.argv[1] == 'LF' and ('\n', '\r\n') or ('\r\n', '\n')
|
2017-06-15 21:22:25 +03:00
|
|
|
> print("%% switching encoding from %r to %r" % (old, new))
|
2010-09-26 22:41:32 +04:00
|
|
|
> for path in sys.argv[2:]:
|
|
|
|
> data = file(path, 'rb').read()
|
|
|
|
> data = data.replace(old, new)
|
|
|
|
> file(path, 'wb').write(data)
|
|
|
|
> EOF
|
|
|
|
|
|
|
|
$ seteol () {
|
|
|
|
> if [ $1 = "LF" ]; then
|
|
|
|
> EOL='\n'
|
|
|
|
> else
|
|
|
|
> EOL='\r\n'
|
|
|
|
> fi
|
|
|
|
> }
|
|
|
|
|
|
|
|
$ makerepo () {
|
|
|
|
> seteol $1
|
|
|
|
> echo "% setup $1 repository"
|
|
|
|
> hg init repo
|
|
|
|
> cd repo
|
|
|
|
> cat > .hgeol <<EOF
|
|
|
|
> [repository]
|
|
|
|
> native = $1
|
|
|
|
> [patterns]
|
|
|
|
> mixed.txt = BIN
|
|
|
|
> **.txt = native
|
|
|
|
> EOF
|
|
|
|
> printf "first${EOL}second${EOL}third${EOL}" > a.txt
|
|
|
|
> hg commit --addremove -m 'checkin'
|
|
|
|
> echo
|
|
|
|
> cd ..
|
|
|
|
> }
|
|
|
|
|
|
|
|
$ dotest () {
|
|
|
|
> seteol $1
|
|
|
|
> echo "% hg clone repo repo-$1"
|
|
|
|
> hg clone --noupdate repo repo-$1
|
|
|
|
> cd repo-$1
|
|
|
|
> cat > .hg/hgrc <<EOF
|
|
|
|
> [extensions]
|
|
|
|
> eol =
|
|
|
|
> [eol]
|
|
|
|
> native = $1
|
|
|
|
> EOF
|
|
|
|
> hg update
|
2010-11-08 03:41:42 +03:00
|
|
|
> echo '% a.txt'
|
|
|
|
> cat a.txt
|
2010-09-26 22:41:32 +04:00
|
|
|
> echo '% hg cat a.txt'
|
2010-11-08 03:41:42 +03:00
|
|
|
> hg cat a.txt
|
2010-09-26 22:41:32 +04:00
|
|
|
> printf "fourth${EOL}" >> a.txt
|
2010-11-08 03:41:42 +03:00
|
|
|
> echo '% a.txt'
|
|
|
|
> cat a.txt
|
|
|
|
> hg diff
|
2017-06-20 16:45:02 +03:00
|
|
|
> $PYTHON ../switch-eol.py $1 a.txt
|
2010-09-26 22:41:32 +04:00
|
|
|
> echo '% hg diff only reports a single changed line:'
|
2010-11-08 03:41:42 +03:00
|
|
|
> hg diff
|
2010-09-26 22:41:32 +04:00
|
|
|
> echo "% reverting back to $1 format"
|
|
|
|
> hg revert a.txt
|
2010-11-08 03:41:42 +03:00
|
|
|
> cat a.txt
|
2010-09-26 22:41:32 +04:00
|
|
|
> printf "first\r\nsecond\n" > mixed.txt
|
|
|
|
> hg add mixed.txt
|
|
|
|
> echo "% hg commit of inconsistent .txt file marked as binary (should work)"
|
|
|
|
> hg commit -m 'binary file'
|
|
|
|
> echo "% hg commit of inconsistent .txt file marked as native (should fail)"
|
|
|
|
> printf "first\nsecond\r\nthird\nfourth\r\n" > a.txt
|
|
|
|
> hg commit -m 'inconsistent file'
|
|
|
|
> echo "% hg commit --config eol.only-consistent=False (should work)"
|
|
|
|
> hg commit --config eol.only-consistent=False -m 'inconsistent file'
|
|
|
|
> echo "% hg commit of binary .txt file marked as native (binary files always okay)"
|
|
|
|
> printf "first${EOL}\0${EOL}third${EOL}" > a.txt
|
|
|
|
> hg commit -m 'binary file'
|
|
|
|
> cd ..
|
|
|
|
> rm -r repo-$1
|
|
|
|
> }
|
|
|
|
|
|
|
|
$ makemixedrepo () {
|
|
|
|
> echo
|
|
|
|
> echo "# setup $1 repository"
|
|
|
|
> hg init mixed
|
|
|
|
> cd mixed
|
|
|
|
> printf "foo\r\nbar\r\nbaz\r\n" > win.txt
|
|
|
|
> printf "foo\nbar\nbaz\n" > unix.txt
|
|
|
|
> #printf "foo\r\nbar\nbaz\r\n" > mixed.txt
|
|
|
|
> hg commit --addremove -m 'created mixed files'
|
|
|
|
> echo "# setting repository-native EOLs to $1"
|
|
|
|
> cat > .hgeol <<EOF
|
|
|
|
> [repository]
|
|
|
|
> native = $1
|
|
|
|
> [patterns]
|
|
|
|
> **.txt = native
|
|
|
|
> EOF
|
|
|
|
> hg commit --addremove -m 'added .hgeol'
|
|
|
|
> cd ..
|
|
|
|
> }
|
|
|
|
|
|
|
|
$ testmixed () {
|
|
|
|
> echo
|
|
|
|
> echo "% hg clone mixed mixed-$1"
|
|
|
|
> hg clone mixed mixed-$1
|
|
|
|
> cd mixed-$1
|
|
|
|
> echo '% hg status (eol extension not yet activated)'
|
|
|
|
> hg status
|
|
|
|
> cat > .hg/hgrc <<EOF
|
|
|
|
> [extensions]
|
|
|
|
> eol =
|
|
|
|
> [eol]
|
|
|
|
> native = $1
|
|
|
|
> EOF
|
|
|
|
> echo '% hg status (eol activated)'
|
|
|
|
> hg status
|
|
|
|
> echo '% hg commit'
|
|
|
|
> hg commit -m 'synchronized EOLs'
|
|
|
|
> echo '% hg status'
|
|
|
|
> hg status
|
|
|
|
> cd ..
|
|
|
|
> rm -r mixed-$1
|
|
|
|
> }
|
|
|
|
|
|
|
|
Basic tests
|
|
|
|
|
|
|
|
$ makerepo LF
|
|
|
|
% setup LF repository
|
|
|
|
adding .hgeol
|
|
|
|
adding a.txt
|
|
|
|
|
|
|
|
$ dotest LF
|
|
|
|
% hg clone repo repo-LF
|
|
|
|
2 files updated, 0 files merged, 0 files removed, 0 files unresolved
|
2010-11-08 03:41:42 +03:00
|
|
|
% a.txt
|
2010-09-26 22:41:32 +04:00
|
|
|
first
|
|
|
|
second
|
|
|
|
third
|
|
|
|
% hg cat a.txt
|
|
|
|
first
|
|
|
|
second
|
|
|
|
third
|
2010-11-08 03:41:42 +03:00
|
|
|
% a.txt
|
2010-09-26 22:41:32 +04:00
|
|
|
first
|
|
|
|
second
|
|
|
|
third
|
|
|
|
fourth
|
|
|
|
diff --git a/a.txt b/a.txt
|
|
|
|
--- a/a.txt
|
|
|
|
+++ b/a.txt
|
|
|
|
@@ -1,3 +1,4 @@
|
|
|
|
first
|
|
|
|
second
|
|
|
|
third
|
|
|
|
+fourth
|
|
|
|
% switching encoding from '\n' to '\r\n'
|
|
|
|
% hg diff only reports a single changed line:
|
|
|
|
diff --git a/a.txt b/a.txt
|
|
|
|
--- a/a.txt
|
|
|
|
+++ b/a.txt
|
|
|
|
@@ -1,3 +1,4 @@
|
|
|
|
first
|
|
|
|
second
|
|
|
|
third
|
|
|
|
+fourth
|
|
|
|
% reverting back to LF format
|
|
|
|
first
|
|
|
|
second
|
|
|
|
third
|
|
|
|
% hg commit of inconsistent .txt file marked as binary (should work)
|
|
|
|
% hg commit of inconsistent .txt file marked as native (should fail)
|
|
|
|
abort: inconsistent newline style in a.txt
|
|
|
|
|
|
|
|
% hg commit --config eol.only-consistent=False (should work)
|
|
|
|
% hg commit of binary .txt file marked as native (binary files always okay)
|
|
|
|
$ dotest CRLF
|
|
|
|
% hg clone repo repo-CRLF
|
|
|
|
2 files updated, 0 files merged, 0 files removed, 0 files unresolved
|
2010-11-08 03:41:42 +03:00
|
|
|
% a.txt
|
|
|
|
first\r (esc)
|
|
|
|
second\r (esc)
|
|
|
|
third\r (esc)
|
2010-09-26 22:41:32 +04:00
|
|
|
% hg cat a.txt
|
|
|
|
first
|
|
|
|
second
|
|
|
|
third
|
2010-11-08 03:41:42 +03:00
|
|
|
% a.txt
|
|
|
|
first\r (esc)
|
|
|
|
second\r (esc)
|
|
|
|
third\r (esc)
|
|
|
|
fourth\r (esc)
|
2010-09-26 22:41:32 +04:00
|
|
|
diff --git a/a.txt b/a.txt
|
|
|
|
--- a/a.txt
|
|
|
|
+++ b/a.txt
|
|
|
|
@@ -1,3 +1,4 @@
|
|
|
|
first
|
|
|
|
second
|
|
|
|
third
|
|
|
|
+fourth
|
|
|
|
% switching encoding from '\r\n' to '\n'
|
|
|
|
% hg diff only reports a single changed line:
|
|
|
|
diff --git a/a.txt b/a.txt
|
|
|
|
--- a/a.txt
|
|
|
|
+++ b/a.txt
|
|
|
|
@@ -1,3 +1,4 @@
|
|
|
|
first
|
|
|
|
second
|
|
|
|
third
|
|
|
|
+fourth
|
|
|
|
% reverting back to CRLF format
|
2010-11-08 03:41:42 +03:00
|
|
|
first\r (esc)
|
|
|
|
second\r (esc)
|
|
|
|
third\r (esc)
|
2010-09-26 22:41:32 +04:00
|
|
|
% hg commit of inconsistent .txt file marked as binary (should work)
|
|
|
|
% hg commit of inconsistent .txt file marked as native (should fail)
|
|
|
|
abort: inconsistent newline style in a.txt
|
|
|
|
|
|
|
|
% hg commit --config eol.only-consistent=False (should work)
|
|
|
|
% hg commit of binary .txt file marked as native (binary files always okay)
|
|
|
|
$ rm -r repo
|
|
|
|
$ makerepo CRLF
|
|
|
|
% setup CRLF repository
|
|
|
|
adding .hgeol
|
|
|
|
adding a.txt
|
|
|
|
|
|
|
|
$ dotest LF
|
|
|
|
% hg clone repo repo-LF
|
|
|
|
2 files updated, 0 files merged, 0 files removed, 0 files unresolved
|
2010-11-08 03:41:42 +03:00
|
|
|
% a.txt
|
2010-09-26 22:41:32 +04:00
|
|
|
first
|
|
|
|
second
|
|
|
|
third
|
|
|
|
% hg cat a.txt
|
2010-11-08 03:41:42 +03:00
|
|
|
first\r (esc)
|
|
|
|
second\r (esc)
|
|
|
|
third\r (esc)
|
|
|
|
% a.txt
|
2010-09-26 22:41:32 +04:00
|
|
|
first
|
|
|
|
second
|
|
|
|
third
|
|
|
|
fourth
|
|
|
|
diff --git a/a.txt b/a.txt
|
|
|
|
--- a/a.txt
|
|
|
|
+++ b/a.txt
|
|
|
|
@@ -1,3 +1,4 @@
|
2010-11-08 03:41:42 +03:00
|
|
|
first\r (esc)
|
|
|
|
second\r (esc)
|
|
|
|
third\r (esc)
|
|
|
|
+fourth\r (esc)
|
2010-09-26 22:41:32 +04:00
|
|
|
% switching encoding from '\n' to '\r\n'
|
|
|
|
% hg diff only reports a single changed line:
|
|
|
|
diff --git a/a.txt b/a.txt
|
|
|
|
--- a/a.txt
|
|
|
|
+++ b/a.txt
|
|
|
|
@@ -1,3 +1,4 @@
|
2010-11-08 03:41:42 +03:00
|
|
|
first\r (esc)
|
|
|
|
second\r (esc)
|
|
|
|
third\r (esc)
|
|
|
|
+fourth\r (esc)
|
2010-09-26 22:41:32 +04:00
|
|
|
% reverting back to LF format
|
|
|
|
first
|
|
|
|
second
|
|
|
|
third
|
|
|
|
% hg commit of inconsistent .txt file marked as binary (should work)
|
|
|
|
% hg commit of inconsistent .txt file marked as native (should fail)
|
|
|
|
abort: inconsistent newline style in a.txt
|
|
|
|
|
|
|
|
% hg commit --config eol.only-consistent=False (should work)
|
|
|
|
% hg commit of binary .txt file marked as native (binary files always okay)
|
|
|
|
$ dotest CRLF
|
|
|
|
% hg clone repo repo-CRLF
|
|
|
|
2 files updated, 0 files merged, 0 files removed, 0 files unresolved
|
2010-11-08 03:41:42 +03:00
|
|
|
% a.txt
|
|
|
|
first\r (esc)
|
|
|
|
second\r (esc)
|
|
|
|
third\r (esc)
|
2010-09-26 22:41:32 +04:00
|
|
|
% hg cat a.txt
|
2010-11-08 03:41:42 +03:00
|
|
|
first\r (esc)
|
|
|
|
second\r (esc)
|
|
|
|
third\r (esc)
|
|
|
|
% a.txt
|
|
|
|
first\r (esc)
|
|
|
|
second\r (esc)
|
|
|
|
third\r (esc)
|
|
|
|
fourth\r (esc)
|
2010-09-26 22:41:32 +04:00
|
|
|
diff --git a/a.txt b/a.txt
|
|
|
|
--- a/a.txt
|
|
|
|
+++ b/a.txt
|
|
|
|
@@ -1,3 +1,4 @@
|
2010-11-08 03:41:42 +03:00
|
|
|
first\r (esc)
|
|
|
|
second\r (esc)
|
|
|
|
third\r (esc)
|
|
|
|
+fourth\r (esc)
|
2010-09-26 22:41:32 +04:00
|
|
|
% switching encoding from '\r\n' to '\n'
|
|
|
|
% hg diff only reports a single changed line:
|
|
|
|
diff --git a/a.txt b/a.txt
|
|
|
|
--- a/a.txt
|
|
|
|
+++ b/a.txt
|
|
|
|
@@ -1,3 +1,4 @@
|
2010-11-08 03:41:42 +03:00
|
|
|
first\r (esc)
|
|
|
|
second\r (esc)
|
|
|
|
third\r (esc)
|
|
|
|
+fourth\r (esc)
|
2010-09-26 22:41:32 +04:00
|
|
|
% reverting back to CRLF format
|
2010-11-08 03:41:42 +03:00
|
|
|
first\r (esc)
|
|
|
|
second\r (esc)
|
|
|
|
third\r (esc)
|
2010-09-26 22:41:32 +04:00
|
|
|
% hg commit of inconsistent .txt file marked as binary (should work)
|
|
|
|
% hg commit of inconsistent .txt file marked as native (should fail)
|
|
|
|
abort: inconsistent newline style in a.txt
|
|
|
|
|
|
|
|
% hg commit --config eol.only-consistent=False (should work)
|
|
|
|
% hg commit of binary .txt file marked as native (binary files always okay)
|
|
|
|
$ rm -r repo
|
|
|
|
|
|
|
|
Mixed tests
|
|
|
|
|
|
|
|
$ makemixedrepo LF
|
|
|
|
|
|
|
|
# setup LF repository
|
|
|
|
adding unix.txt
|
|
|
|
adding win.txt
|
|
|
|
# setting repository-native EOLs to LF
|
|
|
|
adding .hgeol
|
|
|
|
$ testmixed LF
|
|
|
|
|
|
|
|
% hg clone mixed mixed-LF
|
|
|
|
updating to branch default
|
|
|
|
3 files updated, 0 files merged, 0 files removed, 0 files unresolved
|
|
|
|
% hg status (eol extension not yet activated)
|
|
|
|
% hg status (eol activated)
|
|
|
|
M win.txt
|
|
|
|
% hg commit
|
|
|
|
% hg status
|
|
|
|
$ testmixed CRLF
|
|
|
|
|
|
|
|
% hg clone mixed mixed-CRLF
|
|
|
|
updating to branch default
|
|
|
|
3 files updated, 0 files merged, 0 files removed, 0 files unresolved
|
|
|
|
% hg status (eol extension not yet activated)
|
|
|
|
% hg status (eol activated)
|
|
|
|
M win.txt
|
|
|
|
% hg commit
|
|
|
|
% hg status
|
|
|
|
$ rm -r mixed
|
|
|
|
$ makemixedrepo CRLF
|
|
|
|
|
|
|
|
# setup CRLF repository
|
|
|
|
adding unix.txt
|
|
|
|
adding win.txt
|
|
|
|
# setting repository-native EOLs to CRLF
|
|
|
|
adding .hgeol
|
|
|
|
$ testmixed LF
|
|
|
|
|
|
|
|
% hg clone mixed mixed-LF
|
|
|
|
updating to branch default
|
|
|
|
3 files updated, 0 files merged, 0 files removed, 0 files unresolved
|
|
|
|
% hg status (eol extension not yet activated)
|
|
|
|
% hg status (eol activated)
|
|
|
|
M unix.txt
|
|
|
|
% hg commit
|
|
|
|
% hg status
|
|
|
|
$ testmixed CRLF
|
|
|
|
|
|
|
|
% hg clone mixed mixed-CRLF
|
|
|
|
updating to branch default
|
|
|
|
3 files updated, 0 files merged, 0 files removed, 0 files unresolved
|
|
|
|
% hg status (eol extension not yet activated)
|
|
|
|
% hg status (eol activated)
|
|
|
|
M unix.txt
|
|
|
|
% hg commit
|
|
|
|
% hg status
|
|
|
|
$ rm -r mixed
|
2011-02-25 14:32:15 +03:00
|
|
|
|
|
|
|
$ echo '[extensions]' >> $HGRCPATH
|
|
|
|
$ echo 'eol =' >> $HGRCPATH
|
2012-06-19 03:43:41 +04:00
|
|
|
|
|
|
|
#if unix-permissions
|
|
|
|
|
|
|
|
Test issue2569 -- eol extension takes write lock on reading:
|
|
|
|
|
2011-02-25 14:32:15 +03:00
|
|
|
$ hg init repo
|
|
|
|
$ cd repo
|
|
|
|
$ touch .hgeol
|
|
|
|
$ hg status
|
|
|
|
? .hgeol
|
|
|
|
$ chmod -R -w .hg
|
|
|
|
$ sleep 1
|
|
|
|
$ touch .hgeol
|
|
|
|
$ hg status --traceback
|
|
|
|
? .hgeol
|
2011-03-12 13:06:40 +03:00
|
|
|
$ chmod -R u+w .hg
|
2011-02-28 13:31:36 +03:00
|
|
|
$ cd ..
|
|
|
|
|
2012-06-19 03:43:41 +04:00
|
|
|
#endif
|
|
|
|
|
2011-02-28 13:31:36 +03:00
|
|
|
Test cleverencode: and cleverdecode: aliases for win32text extension
|
|
|
|
|
2014-11-04 17:41:46 +03:00
|
|
|
$ cat <<EOF >> $HGRCPATH
|
|
|
|
> [encode]
|
|
|
|
> **.txt = cleverencode:
|
|
|
|
> [decode]
|
|
|
|
> **.txt = cleverdecode:
|
|
|
|
> EOF
|
2011-02-28 13:31:36 +03:00
|
|
|
|
|
|
|
$ hg init win32compat
|
|
|
|
$ cd win32compat
|
|
|
|
$ printf "foo\r\nbar\r\nbaz\r\n" > win.txt
|
|
|
|
$ printf "foo\nbar\nbaz\n" > unix.txt
|
|
|
|
$ hg add
|
|
|
|
adding unix.txt
|
|
|
|
adding win.txt
|
|
|
|
$ hg commit -m checkin
|
|
|
|
|
|
|
|
Check that both files have LF line-endings in the repository:
|
|
|
|
|
|
|
|
$ hg cat win.txt
|
|
|
|
foo
|
|
|
|
bar
|
|
|
|
baz
|
|
|
|
$ hg cat unix.txt
|
|
|
|
foo
|
|
|
|
bar
|
|
|
|
baz
|
2011-02-28 17:46:48 +03:00
|
|
|
|
|
|
|
Test handling of a broken .hgeol file:
|
|
|
|
|
|
|
|
$ touch .hgeol
|
|
|
|
$ hg add .hgeol
|
|
|
|
$ hg commit -m 'clean version'
|
|
|
|
$ echo "bad" > .hgeol
|
|
|
|
$ hg status
|
|
|
|
warning: ignoring .hgeol file due to parse error at .hgeol:1: bad
|
|
|
|
M .hgeol
|
|
|
|
$ hg revert .hgeol
|
|
|
|
warning: ignoring .hgeol file due to parse error at .hgeol:1: bad
|
|
|
|
$ hg status
|
|
|
|
? .hgeol.orig
|
2011-07-01 22:53:58 +04:00
|
|
|
|
|
|
|
Test eol.only-consistent can be specified in .hgeol
|
|
|
|
|
|
|
|
$ cd $TESTTMP
|
|
|
|
$ hg init only-consistent
|
|
|
|
$ cd only-consistent
|
|
|
|
$ printf "first\nsecond\r\n" > a.txt
|
|
|
|
$ hg add a.txt
|
|
|
|
$ cat > .hgeol << EOF
|
|
|
|
> [eol]
|
|
|
|
> only-consistent = True
|
|
|
|
> EOF
|
|
|
|
$ hg commit -m 'inconsistent'
|
|
|
|
abort: inconsistent newline style in a.txt
|
|
|
|
|
|
|
|
[255]
|
|
|
|
$ cat > .hgeol << EOF
|
|
|
|
> [eol]
|
|
|
|
> only-consistent = False
|
|
|
|
> EOF
|
|
|
|
$ hg commit -m 'consistent'
|
|
|
|
|
subrepo: run the repo decoders when archiving
The decoders were already run by default for the main repo, so this seemed like
an oversight.
The extdiff extension has been using 'archive' since a80ec1ea2694 to support -S,
and a colleague noticed that after diffing, making changes, and closing it, the
line endings were wrong for the diff-tool modified files in the subrepository.
(Files in the parent repo were correct, with the same .hgeol settings.) The
editor (Visual Studio in this case) reloads the file, but doesn't notice the EOL
change. It still adds new lines with the original EOL setting, and the file
ends up inconsistent.
Without this change, the first file `cat`d in the test prints '\r (esc)' EOL,
but the second doesn't on Windows or Linux.
2017-02-26 05:13:59 +03:00
|
|
|
$ hg init subrepo
|
|
|
|
$ hg -R subrepo pull -qu .
|
|
|
|
$ echo "subrepo = subrepo" > .hgsub
|
|
|
|
$ hg ci -Am "add subrepo"
|
|
|
|
adding .hgeol
|
|
|
|
adding .hgsub
|
2019-03-11 20:37:29 +03:00
|
|
|
$ hg archive ../archive
|
subrepo: run the repo decoders when archiving
The decoders were already run by default for the main repo, so this seemed like
an oversight.
The extdiff extension has been using 'archive' since a80ec1ea2694 to support -S,
and a colleague noticed that after diffing, making changes, and closing it, the
line endings were wrong for the diff-tool modified files in the subrepository.
(Files in the parent repo were correct, with the same .hgeol settings.) The
editor (Visual Studio in this case) reloads the file, but doesn't notice the EOL
change. It still adds new lines with the original EOL setting, and the file
ends up inconsistent.
Without this change, the first file `cat`d in the test prints '\r (esc)' EOL,
but the second doesn't on Windows or Linux.
2017-02-26 05:13:59 +03:00
|
|
|
$ find ../archive/* | sort
|
|
|
|
../archive/a.txt
|
2019-03-11 20:37:29 +03:00
|
|
|
$ cat ../archive/a.txt
|
subrepo: run the repo decoders when archiving
The decoders were already run by default for the main repo, so this seemed like
an oversight.
The extdiff extension has been using 'archive' since a80ec1ea2694 to support -S,
and a colleague noticed that after diffing, making changes, and closing it, the
line endings were wrong for the diff-tool modified files in the subrepository.
(Files in the parent repo were correct, with the same .hgeol settings.) The
editor (Visual Studio in this case) reloads the file, but doesn't notice the EOL
change. It still adds new lines with the original EOL setting, and the file
ends up inconsistent.
Without this change, the first file `cat`d in the test prints '\r (esc)' EOL,
but the second doesn't on Windows or Linux.
2017-02-26 05:13:59 +03:00
|
|
|
first\r (esc)
|
|
|
|
second\r (esc)
|
2011-07-01 23:12:52 +04:00
|
|
|
|
|
|
|
Test trailing newline
|
|
|
|
|
|
|
|
$ cat >> $HGRCPATH <<EOF
|
|
|
|
> [extensions]
|
|
|
|
> eol=
|
|
|
|
> EOF
|
|
|
|
|
|
|
|
setup repository
|
|
|
|
|
|
|
|
$ cd $TESTTMP
|
|
|
|
$ hg init trailing
|
|
|
|
$ cd trailing
|
|
|
|
$ cat > .hgeol <<EOF
|
|
|
|
> [patterns]
|
|
|
|
> **.txt = native
|
|
|
|
> [eol]
|
|
|
|
> fix-trailing-newline = False
|
|
|
|
> EOF
|
|
|
|
|
|
|
|
add text without trailing newline
|
|
|
|
|
|
|
|
$ printf "first\nsecond" > a.txt
|
|
|
|
$ hg commit --addremove -m 'checking in'
|
|
|
|
adding .hgeol
|
|
|
|
adding a.txt
|
|
|
|
$ rm a.txt
|
|
|
|
$ hg update -C -q
|
|
|
|
$ cat a.txt
|
|
|
|
first
|
|
|
|
second (no-eol)
|
|
|
|
|
|
|
|
$ cat > .hgeol <<EOF
|
|
|
|
> [patterns]
|
|
|
|
> **.txt = native
|
|
|
|
> [eol]
|
|
|
|
> fix-trailing-newline = True
|
|
|
|
> EOF
|
|
|
|
$ printf "third\nfourth" > a.txt
|
|
|
|
$ hg commit -m 'checking in with newline fix'
|
|
|
|
$ rm a.txt
|
|
|
|
$ hg update -C -q
|
|
|
|
$ cat a.txt
|
|
|
|
third
|
|
|
|
fourth
|
|
|
|
|
|
|
|
append a line without trailing newline
|
|
|
|
|
|
|
|
$ printf "fifth" >> a.txt
|
|
|
|
$ hg commit -m 'adding another line line'
|
|
|
|
$ rm a.txt
|
|
|
|
$ hg update -C -q
|
|
|
|
$ cat a.txt
|
|
|
|
third
|
|
|
|
fourth
|
|
|
|
fifth
|
|
|
|
|
2014-10-22 18:10:23 +04:00
|
|
|
amend of changesets with renamed/deleted files expose new code paths
|
|
|
|
|
|
|
|
$ hg mv a.txt b.txt
|
|
|
|
$ hg ci --amend -q
|
|
|
|
$ hg diff -c.
|
|
|
|
diff --git a/a.txt b/b.txt
|
|
|
|
rename from a.txt
|
|
|
|
rename to b.txt
|
|
|
|
--- a/a.txt
|
|
|
|
+++ b/b.txt
|
|
|
|
@@ -1,2 +1,3 @@
|
|
|
|
third
|
|
|
|
fourth
|
|
|
|
+fifth
|
|
|
|
|
2012-06-11 03:40:51 +04:00
|
|
|
$ cd ..
|