|
|
|
#!/bin/bash -x
|
|
|
|
|
|
|
|
git remote set-url --push origin `git config remote.origin.url | sed -e 's/^git:/https:/'`
|
|
|
|
|
|
|
|
if ! (git remote set-branches --add origin gh-pages && git fetch -q); then
|
|
|
|
echo "No gh-pages, so not syncing"
|
|
|
|
exit 0
|
|
|
|
fi
|
|
|
|
|
|
|
|
if ! [ -d docs/target/generated-docs ]; then
|
|
|
|
echo "No gh-pages sources in docs/target/generated-docs, so not syncing"
|
|
|
|
exit 0
|
|
|
|
fi
|
|
|
|
|
|
|
|
# The script should be executed from the root folder
|
|
|
|
|
|
|
|
ROOT_FOLDER=`pwd`
|
|
|
|
echo "Current folder is ${ROOT_FOLDER}"
|
|
|
|
|
|
|
|
if [[ ! -e "${ROOT_FOLDER}/.git" ]]; then
|
|
|
|
echo "You're not in the root folder of the project!"
|
|
|
|
exit 1
|
|
|
|
fi
|
|
|
|
|
|
|
|
# Retrieve properties
|
|
|
|
###################################################################
|
|
|
|
|
|
|
|
# Prop that will let commit the changes
|
|
|
|
COMMIT_CHANGES="no"
|
|
|
|
|
|
|
|
# Get the name of the `docs.main` property
|
|
|
|
MAIN_ADOC_VALUE=$(mvn -q \
|
|
|
|
-Dexec.executable="echo" \
|
|
|
|
-Dexec.args='${docs.main}' \
|
|
|
|
--non-recursive \
|
|
|
|
org.codehaus.mojo:exec-maven-plugin:1.3.1:exec)
|
|
|
|
echo "Extracted 'main.adoc' from Maven build [${MAIN_ADOC_VALUE}]"
|
|
|
|
|
|
|
|
# Get whitelisted branches - assumes that a `docs` module is available under `docs` profile
|
|
|
|
WHITELIST_PROPERTY="docs.whitelisted.branches"
|
|
|
|
WHITELISTED_BRANCHES_VALUE=$(mvn -q \
|
|
|
|
-Dexec.executable="echo" \
|
|
|
|
-Dexec.args="\${${WHITELIST_PROPERTY}}" \
|
|
|
|
org.codehaus.mojo:exec-maven-plugin:1.3.1:exec \
|
|
|
|
-P docs \
|
|
|
|
-pl docs)
|
|
|
|
echo "Extracted '${WHITELIST_PROPERTY}' from Maven build [${WHITELISTED_BRANCHES_VALUE}]"
|
|
|
|
|
|
|
|
# Code getting the name of the current branch. For master we want to publish as we did until now
|
|
|
|
# http://stackoverflow.com/questions/1593051/how-to-programmatically-determine-the-current-checked-out-git-branch
|
|
|
|
CURRENT_BRANCH=$(git symbolic-ref -q HEAD)
|
|
|
|
CURRENT_BRANCH=${CURRENT_BRANCH##refs/heads/}
|
|
|
|
CURRENT_BRANCH=${CURRENT_BRANCH:-HEAD}
|
|
|
|
echo "Current branch is [${CURRENT_BRANCH}]"
|
|
|
|
|
|
|
|
# Stash any outstanding changes
|
|
|
|
###################################################################
|
|
|
|
git diff-index --quiet HEAD
|
|
|
|
dirty=$?
|
|
|
|
if [ "$dirty" != "0" ]; then git stash; fi
|
|
|
|
|
|
|
|
# Switch to gh-pages branch to sync it with master
|
|
|
|
###################################################################
|
|
|
|
git checkout gh-pages
|
|
|
|
git pull origin gh-pages
|
|
|
|
|
|
|
|
# Add git branches
|
|
|
|
###################################################################
|
|
|
|
mkdir -p ${ROOT_FOLDER}/${CURRENT_BRANCH}
|
|
|
|
if [[ "${CURRENT_BRANCH}" == "master" ]] ; then
|
|
|
|
echo -e "Current branch is master - will copy the current docs only to the root folder"
|
|
|
|
for f in docs/target/generated-docs/*; do
|
|
|
|
file=${f#docs/target/generated-docs/*}
|
|
|
|
if ! git ls-files -i -o --exclude-standard --directory | grep -q ^$file$; then
|
|
|
|
# Not ignored...
|
|
|
|
cp -rf $f ${ROOT_FOLDER}/
|
|
|
|
git add -A ${ROOT_FOLDER}/$file
|
|
|
|
fi
|
|
|
|
done
|
|
|
|
COMMIT_CHANGES="yes"
|
|
|
|
else
|
|
|
|
echo -e "Current branch is [${CURRENT_BRANCH}]"
|
|
|
|
# http://stackoverflow.com/questions/29300806/a-bash-script-to-check-if-a-string-is-present-in-a-comma-separated-list-of-strin
|
|
|
|
if [[ ",${WHITELISTED_BRANCHES_VALUE}," = *",${CURRENT_BRANCH},"* ]] ; then
|
|
|
|
echo -e "Branch [${CURRENT_BRANCH}] is whitelisted! Will copy the current docs to the [${CURRENT_BRANCH}] folder"
|
|
|
|
for f in docs/target/generated-docs/*; do
|
|
|
|
file=${f#docs/target/generated-docs/*}
|
|
|
|
if ! git ls-files -i -o --exclude-standard --directory | grep -q ^$file$; then
|
|
|
|
# Not ignored...
|
|
|
|
# We want users to access 1.0.0.RELEASE/ instead of 1.0.0.RELEASE/spring-cloud.sleuth.html
|
|
|
|
if [[ "${file}" == "${MAIN_ADOC_VALUE}.html" ]] ; then
|
|
|
|
# We don't want to copy the spring-cloud-sleuth.html
|
|
|
|
# we want it to be converted to index.html
|
|
|
|
cp -rf $f ${ROOT_FOLDER}/${CURRENT_BRANCH}/index.html
|
|
|
|
git add -A ${ROOT_FOLDER}/${CURRENT_BRANCH}/index.html
|
|
|
|
else
|
|
|
|
cp -rf $f ${ROOT_FOLDER}/${CURRENT_BRANCH}
|
|
|
|
git add -A ${ROOT_FOLDER}/${CURRENT_BRANCH}/$file
|
|
|
|
fi
|
|
|
|
fi
|
|
|
|
done
|
|
|
|
COMMIT_CHANGES="yes"
|
|
|
|
else
|
|
|
|
echo -e "Branch [${CURRENT_BRANCH}] is not on the white list! Check out the Maven [${WHITELIST_PROPERTY}] property in
|
|
|
|
[docs] module available under [docs] profile. Won't commit any changes to gh-pages for this branch."
|
|
|
|
fi
|
|
|
|
fi
|
|
|
|
|
|
|
|
if [[ "${COMMIT_CHANGES}" == "yes" ]] ; then
|
|
|
|
git commit -a -m "Sync docs from ${CURRENT_BRANCH} to gh-pages"
|
|
|
|
|
|
|
|
# Uncomment the following push if you want to auto push to
|
|
|
|
# the gh-pages branch whenever you commit to master locally.
|
|
|
|
# This is a little extreme. Use with care!
|
|
|
|
###################################################################
|
|
|
|
git push origin gh-pages
|
|
|
|
fi
|
|
|
|
|
|
|
|
# Finally, switch back to the master branch and exit block
|
|
|
|
git checkout ${CURRENT_BRANCH}
|
|
|
|
if [ "$dirty" != "0" ]; then git stash pop; fi
|
|
|
|
|
|
|
|
exit 0
|