1
0
mirror of https://github.com/facebook/zstd.git synced 2025-03-06 16:56:49 +02:00

Merge pull request #3963 from felixhandte/also-handle-hidden-files-output-dir-mirror

Remove Erroneous Exclusion of Hidden Files and Folders in `--output-dir-mirror`
This commit is contained in:
Felix Handte 2024-03-14 10:21:00 -04:00 committed by GitHub
commit 490163ac73
No known key found for this signature in database
GPG Key ID: B5690EEEBB952194
4 changed files with 49 additions and 3 deletions

View File

@ -1135,9 +1135,6 @@ static char* mallocAndJoin2Dir(const char *dir1, const char *dir2)
memcpy(outDirBuffer, dir1, dir1Size);
outDirBuffer[dir1Size] = '\0';
if (dir2[0] == '.')
return outDirBuffer;
buffer = outDirBuffer + dir1Size;
if (dir1Size > 0 && *(buffer - 1) != PATH_SEP) {
*buffer = PATH_SEP;

View File

@ -0,0 +1,49 @@
#!/bin/sh
set -e
# setup
mkdir -p src/.hidden src/dir
mkdir mid dst
echo "file1" > src/file1
echo "file2" > src/.file2
echo "file3" > src/.hidden/.file3
echo "file4" > src/dir/.file4
# relative paths
zstd -q -r --output-dir-mirror mid/ src/
zstd -q -d -r --output-dir-mirror dst/ mid/src/
diff --brief --recursive --new-file src/ dst/mid/src/
# reset
rm -rf mid dst
mkdir mid dst
# from inside the directory
(cd src; zstd -q -r --output-dir-mirror ../mid/ ./)
(cd mid; zstd -q -d -r --output-dir-mirror ../dst/ ./)
diff --brief --recursive --new-file src/ dst/
# reset
rm -rf mid dst
mkdir mid dst
# absolute paths
export BASE_PATH="$(pwd)"
zstd -q -r --output-dir-mirror mid/ "${BASE_PATH}/src/"
zstd -q -d -r --output-dir-mirror dst/ "${BASE_PATH}/mid/${BASE_PATH}/src/"
diff --brief --recursive --new-file src/ "dst/${BASE_PATH}/mid/${BASE_PATH}/src/"
# reset
rm -rf mid dst
mkdir mid dst
# dots
zstd -q -r --output-dir-mirror mid/ ./src/./
zstd -q -d -r --output-dir-mirror dst/ ./mid/./src/./
diff --brief --recursive --new-file src/ dst/mid/src/