189 lines
6.3 KiB
Bash
Executable File
189 lines
6.3 KiB
Bash
Executable File
#!/usr/bin/env bash
|
|
set -e
|
|
|
|
source .travis/logger.sh
|
|
source .travis/common-functions.sh
|
|
source .travis/github-releases-api.sh
|
|
source .travis/sourceforge-api.sh
|
|
source .travis/pmd-code-api.sh
|
|
|
|
function main() {
|
|
VERSION=$(get_pom_version)
|
|
log_info "Building PMD Documentation ${VERSION} on branch ${TRAVIS_BRANCH}"
|
|
|
|
#
|
|
# First step: build pmd with profile "generate-rule-docs"
|
|
# The docs should appear under "docs/pages/rules/..." for each language
|
|
# With this profile, also the checks are executed (e.g. DeadLinksChecker).
|
|
#
|
|
./mvnw clean verify -Dmaven.test.skip=true -P generate-rule-docs
|
|
|
|
if ! travis_isPush; then
|
|
log_info "Not publishing site, since this is not a push!"
|
|
exit 0
|
|
fi
|
|
|
|
#
|
|
# For pushes, we'll update the online documentation
|
|
#
|
|
generate_jekyll_doc
|
|
create_pmd-doc_archive
|
|
|
|
# Deploy to sourceforge files
|
|
sourceforge_uploadFile "${VERSION}" "docs/pmd-doc-${VERSION}.zip"
|
|
|
|
# Deploy doc to https://docs.pmd-code.org/pmd-doc-${VERSION}/
|
|
pmd_code_uploadDocumentation "${VERSION}" "docs/pmd-doc-${VERSION}.zip"
|
|
# Deploy javadoc to https://docs.pmd-code.org/apidocs/*/${VERSION}/
|
|
pmd_code_uploadJavadoc "${VERSION}" "$(pwd)"
|
|
|
|
|
|
if [[ "${VERSION}" == *-SNAPSHOT && "${TRAVIS_BRANCH}" == "master" ]]; then
|
|
# only for snapshot builds from branch master
|
|
|
|
pmd_code_createSymlink "${VERSION}" "snapshot"
|
|
|
|
# update github pages https://pmd.github.io/pmd/
|
|
publish_to_github_pages
|
|
# rsync site to https://pmd.sourceforge.io/snapshot
|
|
sourceforge_rsyncSnapshotDocumentation "${VERSION}" "snapshot"
|
|
fi
|
|
|
|
|
|
if [[ "${VERSION}" != *-SNAPSHOT && "${TRAVIS_TAG}" != "" ]]; then
|
|
log_info "This is a release documentation build for pmd ${VERSION}"
|
|
|
|
# documentation is already uploaded to https://docs.pmd-code.org/pmd-doc-${VERSION}
|
|
pmd_code_createSymlink "${VERSION}" "latest"
|
|
# remove old doc and point to the new version
|
|
pmd_code_removeDocumentation "${VERSION}-SNAPSHOT"
|
|
pmd_code_createSymlink "${VERSION}" "${VERSION}-SNAPSHOT"
|
|
# remove old javadoc
|
|
pmd_code_removeJavadoc "${VERSION}-SNAPSHOT"
|
|
|
|
# Deploy to github releases
|
|
gh_releases_getLatestDraftRelease
|
|
GH_RELEASE="$RESULT"
|
|
|
|
gh_release_uploadAsset "$GH_RELEASE" "docs/pmd-doc-${VERSION}.zip"
|
|
|
|
# updating github release text
|
|
# renders, and skips the first 6 lines - the Jekyll front-matter
|
|
RENDERED_RELEASE_NOTES=$(bundle exec .travis/render_release_notes.rb docs/pages/release_notes.md | tail -n +6)
|
|
RELEASE_NAME="PMD ${VERSION} ($(date -u +%d-%B-%Y))"
|
|
gh_release_updateRelease "$GH_RELEASE" "$RELEASE_NAME" "$RENDERED_RELEASE_NOTES"
|
|
sourceforge_uploadReleaseNotes "${VERSION}" "${RENDERED_RELEASE_NOTES}"
|
|
|
|
publish_release_documentation_github
|
|
sourceforge_rsyncSnapshotDocumentation "${VERSION}" "pmd-${VERSION}"
|
|
fi
|
|
}
|
|
|
|
#
|
|
# Executes jekyll and generates the documentation
|
|
# The documentation will be generated in the directory "docs/_site".
|
|
#
|
|
function generate_jekyll_doc() {
|
|
pushd docs
|
|
|
|
echo -e "\n\n"
|
|
log_info "Building documentation using jekyll..."
|
|
bundle config set --local path vendor/bundle
|
|
bundle install
|
|
bundle exec jekyll build
|
|
|
|
popd
|
|
}
|
|
|
|
#
|
|
# Creates the pmd-doc.zip archive. It will be placed in "docs/".
|
|
#
|
|
function create_pmd-doc_archive() {
|
|
pushd docs
|
|
|
|
echo -e "\n\n"
|
|
log_info "Creating pmd-doc archive..."
|
|
mv _site pmd-doc-${VERSION}
|
|
zip -qr pmd-doc-${VERSION}.zip pmd-doc-${VERSION}/
|
|
log_success "Successfully created pmd-doc-${VERSION}.zip"
|
|
|
|
popd
|
|
}
|
|
|
|
#
|
|
# Publishes the site to https://pmd.github.io/pmd-${VERSION} and
|
|
# https://pmd.github.io/latest/
|
|
#
|
|
function publish_release_documentation_github() {
|
|
echo -e "\n\n"
|
|
log_info "Adding the new doc to pmd.github.io..."
|
|
# clone pmd.github.io. Note: This uses the ssh key setup earlier
|
|
# In order to speed things up, we use a sparse checkout - no need to checkout all directories here
|
|
mkdir pmd.github.io
|
|
(
|
|
cd pmd.github.io
|
|
git init
|
|
git config user.name "Travis CI (pmd-bot)"
|
|
git config user.email "andreas.dangel+pmd-bot@adangel.org"
|
|
git config core.sparsecheckout true
|
|
git remote add origin git@github.com:pmd/pmd.github.io.git
|
|
echo "/latest/" > .git/info/sparse-checkout
|
|
echo "/sitemap.xml" >> .git/info/sparse-checkout
|
|
git pull --depth=1 origin master
|
|
log_info "Copying documentation from ../docs/pmd-doc-${VERSION}/ to pmd-${VERSION}/ ..."
|
|
rsync -ah --stats ../docs/pmd-doc-${VERSION}/ pmd-${VERSION}/
|
|
git status
|
|
echo "Executing: git add pmd-${VERSION}"
|
|
git add pmd-${VERSION}
|
|
echo "Executing: git commit..."
|
|
git commit -q -m "Added pmd-${VERSION}"
|
|
|
|
log_info "Copying pmd-${VERSION} to latest ..."
|
|
git rm -qr latest
|
|
cp -a pmd-${VERSION} latest
|
|
echo "Executing: git add latest"
|
|
git add latest
|
|
echo "Executing: git commit..."
|
|
git commit -q -m "Copying pmd-${VERSION} to latest"
|
|
|
|
log_info "Generating sitemap.xml"
|
|
../.travis/sitemap_generator.sh > sitemap.xml
|
|
echo "Executing: git add sitemap.xml"
|
|
git add sitemap.xml
|
|
echo "Executing: git commit..."
|
|
git commit -q -m "Generated sitemap.xml"
|
|
|
|
echo "Executing: git push origin master"
|
|
git push origin master
|
|
)
|
|
}
|
|
|
|
#
|
|
# Updates github pages of the main repository,
|
|
# so that https://pmd.github.io/pmd/ has the latest (snapshot) content
|
|
#
|
|
function publish_to_github_pages() {
|
|
echo -e "\n\n"
|
|
log_info "Pushing the new site to github pages..."
|
|
git clone --branch gh-pages --depth 1 git@github.com:pmd/pmd.git pmd-gh-pages
|
|
# clear the files first
|
|
rm -rf pmd-gh-pages/*
|
|
# copy the new site
|
|
cp -a docs/pmd-doc-${VERSION}/* pmd-gh-pages/
|
|
(
|
|
cd pmd-gh-pages
|
|
git config user.name "Travis CI (pmd-bot)"
|
|
git config user.email "andreas.dangel+pmd-bot@adangel.org"
|
|
git add -A
|
|
MSG="Update documentation
|
|
|
|
TRAVIS_JOB_NUMBER=${TRAVIS_JOB_NUMBER}
|
|
TRAVIS_COMMIT_RANGE=${TRAVIS_COMMIT_RANGE}"
|
|
git commit -q -m "$MSG"
|
|
git push git@github.com:pmd/pmd.git HEAD:gh-pages
|
|
log_success "Successfully pushed site to https://pmd.github.io/pmd/"
|
|
)
|
|
}
|
|
|
|
main
|