| #!/bin/bash |
| # Copyright 2016 The Bazel Authors. All rights reserved. |
| # |
| # Licensed under the Apache License, Version 2.0 (the "License"); |
| # you may not use this file except in compliance with the License. |
| # You may obtain a copy of the License at |
| # |
| # http://www.apache.org/licenses/LICENSE-2.0 |
| # |
| # Unless required by applicable law or agreed to in writing, software |
| # distributed under the License is distributed on an "AS IS" BASIS, |
| # WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. |
| # See the License for the specific language governing permissions and |
| # limitations under the License. |
| |
| # This script constructs the final Jekyll tree by combining the static Jekyll |
| # site files with generated documentation, such as the Build Encyclopedia and |
| # Starlark Library. It then constructs the site directory structure for |
| # Bazel documentation at HEAD by moving all documentation into the |
| # /versions/$VERSION directory and adding redirects from the root of the site to |
| # the latest released version. This way, URLs of the form |
| # https://docs.bazel.build/foo.html will be redirected to |
| # https://docs.bazel.build/versions/$LATEST_RELEASE_VERSION/foo.html. |
| |
| set -eu |
| |
| readonly OUTPUT=${PWD}/$1 |
| shift |
| readonly LATEST_RELEASE_VERSION=$1 |
| shift |
| readonly JEKYLL_BASE=${PWD}/$1 |
| shift |
| readonly STARLARK_RULE_DOCS=${PWD}/$1 |
| shift |
| readonly BE_ZIP=${PWD}/$1 |
| shift |
| readonly SL_ZIP=${PWD}/$1 |
| shift |
| readonly CLR_HTML=${PWD}/$1 |
| shift |
| readonly REPO_TAR="${PWD}/$1" |
| |
| # Create temporary directory that is removed when this script exits. |
| readonly TMP=$(mktemp -d "${TMPDIR:-/tmp}/tmp.XXXXXXXX") |
| readonly OUT_DIR="$TMP/out" |
| trap "rm -rf ${TMP}" EXIT |
| |
| readonly VERSION="${DOC_VERSION:-master}" |
| readonly VERSION_DIR="$OUT_DIR/versions/$VERSION" |
| |
| # Unpacks the base Jekyll tree, Build Encyclopedia, etc. |
| function setup { |
| mkdir -p "$OUT_DIR" |
| cd "$OUT_DIR" |
| tar -xf "${JEKYLL_BASE}" |
| |
| mkdir -p "$VERSION_DIR" |
| mv "$OUT_DIR"/docs/* "$VERSION_DIR" |
| rm -r "$OUT_DIR"/docs |
| |
| # Unpack the Build Encyclopedia into versions/$VERSION/be |
| local be_dir="$VERSION_DIR/be" |
| mkdir -p "$be_dir" |
| unzip -qq "$BE_ZIP" -d "$be_dir" |
| mv "$be_dir/be-nav.html" "$OUT_DIR/_includes" |
| |
| # Unpack the Starlark Library into versions/$VERSION/skylark/lib |
| local sl_dir="$VERSION_DIR/skylark/lib" |
| mkdir -p "$sl_dir" |
| unzip -qq "$SL_ZIP" -d "$sl_dir" |
| mv "$sl_dir/skylark-nav.html" "$OUT_DIR/_includes" |
| |
| # Unpack the documentation for the repository rules to versions/$VERSION/repo |
| local repo_dir="${VERSION_DIR}/repo" |
| mkdir -p "${repo_dir}" |
| tar -C "${repo_dir}" -xf "${REPO_TAR}" |
| |
| # Copy the command line reference. |
| cp "$CLR_HTML" "$VERSION_DIR" |
| } |
| |
| # Helper function for copying a Starlark rule doc. |
| function copy_skylark_rule_doc { |
| local rule_family=$1 |
| local rule_family_name=$2 |
| local be_dir="$VERSION_DIR/be" |
| |
| ( cat <<EOF |
| --- |
| layout: documentation |
| title: ${rule_family_name} Rules |
| --- |
| EOF |
| cat "$TMP/skylark/$rule_family/README.md"; ) > "$be_dir/${rule_family}.md" |
| } |
| |
| # Copies the READMEs for Starlark rules bundled with Bazel. |
| function unpack_skylark_rule_docs { |
| local tmp_dir=$TMP/skylark |
| mkdir -p $tmp_dir |
| cd "$tmp_dir" |
| tar -xf "${STARLARK_RULE_DOCS}" |
| copy_skylark_rule_doc pkg "Packaging" |
| } |
| |
| # Processes a documentation page, such as replacing Blaze with Bazel. |
| function process_doc { |
| local f=$1 |
| local tempf=$(mktemp -t bazel-doc-XXXXXX) |
| |
| chmod +w $f |
| # Replace .md with .html only in relative links to other Bazel docs. |
| # sed regexp explanation: |
| # \( and \) delimits a capturing group |
| # \1 inserts the capture |
| # [( "'\''] character preceding a url in markdown syntax (open paren |
| # or space) or html syntax (a quote); note that '\'' embeds |
| # a single quote in a bash single-quoted string. |
| # [a-zA-Z0-9/._-]* zero or more legal url characters but not ':' - meaning |
| # that the url is not absolute. |
| cat "$f" | \ |
| sed -e 's,\([( "'\''][a-zA-Z0-9/._-]*\)\.md,\1.html,g' \ |
| -e 's,Blaze,Bazel,g;s,blaze,bazel,g' > "$tempf" |
| cat "$tempf" > "$f" |
| } |
| |
| # Performs fixup on each doc, such as replacing instances of 'blaze' with |
| # 'bazel'. |
| function process_docs { |
| for f in $(find "$VERSION_DIR" -name "*.html"); do |
| process_doc $f |
| done |
| for f in $(find "$VERSION_DIR" -name "*.md"); do |
| process_doc $f |
| done |
| } |
| |
| # Generates a redirect for a documentation page under |
| # /versions/$LATEST_RELEASE_VERSION. |
| function gen_redirect { |
| local output_dir=$OUT_DIR/$(dirname $f) |
| if [[ ! -d "$output_dir" ]]; then |
| mkdir -p "$output_dir" |
| fi |
| |
| local src_basename=$(basename $f) |
| local md_basename="${src_basename%.*}.md" |
| local html_file="${f%.*}.html" |
| local redirect_file="$output_dir/$md_basename" |
| if [[ -e "$redirect_file" ]]; then |
| echo "Cannot create redirect file $redirect_file. File exists." |
| exit 1 |
| fi |
| cat > "$redirect_file" <<EOF |
| --- |
| layout: redirect |
| redirect: /versions/$LATEST_RELEASE_VERSION/$html_file |
| --- |
| EOF |
| } |
| |
| # During setup, all documentation under docs are moved to the /versions/$VERSION |
| # directory. This leaves nothing in the root directory. |
| # |
| # As a fix, when generating the master tarball, this function generates a |
| # redirect from the root of the site for the given doc page under |
| # /versions/$LATEST_RELEASE_VERSION so that |
| # https://docs.bazel.build/foo.html will be redirected to |
| # https://docs.bazel.build/versions/$LATEST_RELEASE_VERSION/foo.html |
| function gen_redirects { |
| if [[ "$VERSION" == "master" ]]; then |
| pushd "$VERSION_DIR" > /dev/null |
| for f in $(find . -name "*.html" -type f); do |
| gen_redirect $f |
| done |
| for f in $(find . -name "*.md" -type f); do |
| gen_redirect $f |
| done |
| popd > /dev/null |
| fi |
| } |
| |
| # Creates a tar archive containing the final Jekyll tree. |
| function package_output { |
| cd "$OUT_DIR" |
| tar -hcf $OUTPUT $(find . -type f | sort) |
| } |
| |
| function main { |
| setup |
| unpack_skylark_rule_docs |
| process_docs |
| gen_redirects |
| package_output |
| } |
| main |