Skip to content

Commit b28083e

Browse files
authored
Merge pull request #24700 from tengqm/improve-lsync
Improve the lsync script
2 parents fe00518 + d80a20e commit b28083e

File tree

1 file changed

+17
-7
lines changed

1 file changed

+17
-7
lines changed

scripts/lsync.sh

Lines changed: 17 additions & 7 deletions
Original file line numberDiff line numberDiff line change
@@ -3,27 +3,37 @@
33
# This script checks if the English version of a page has changed since a localized
44
# page has been committed.
55

6-
if [ "$#" -ne 1 ] || ! [ -f "$1" ]; then
7-
echo -e "\nThis script checks if the English version of a page has changed since a "
8-
echo -e "localized page has been committed.\n"
6+
if [ "$#" -ne 1 ] ; then
7+
echo -e "\nThis script checks if the English version of a page has changed since a " >&2
8+
echo -e "localized page has been committed.\n" >&2
99
echo -e "Usage:\n\t$0 <PATH>\n" >&2
1010
echo -e "Example:\n\t$0 content/zh/docs/concepts/_index.md\n" >&2
1111
exit 1
1212
fi
1313

14+
# Check if path exists, and whether it is a directory or a file
15+
if [ ! -e "$1" ] ; then
16+
echo "Path not found: '$1'" >&2
17+
exit 2
18+
elif [ -d "$1" ] ; then
19+
IS_DIR=1
20+
EXTRA_FLAGS="--stat"
21+
else
22+
IS_DIR=0
23+
fi
1424
LOCALIZED="$1"
1525

1626
# Try get the English version
1727
EN_VERSION=`echo $LOCALIZED | sed "s/content\/..\//content\/en\//g"`
18-
if ! [ -f $EN_VERSION ]; then
28+
if [ $IS_DIR -eq 1 -a ! -e $EN_VERSION ]; then
1929
echo "$EN_VERSION has been removed."
20-
exit 2
30+
exit 3
2131
fi
2232

23-
# Last commit for the localized file
33+
# Last commit for the localized path
2434
LASTCOMMIT=`git log -n 1 --pretty=format:%h -- $LOCALIZED`
2535

26-
git diff --exit-code $LASTCOMMIT...HEAD $EN_VERSION
36+
git diff --exit-code $EXTRA_FLAGS $LASTCOMMIT...HEAD $EN_VERSION
2737

2838
if [ "$?" -eq 0 ]; then
2939
echo "$LOCALIZED is still in sync"

0 commit comments

Comments
 (0)