#!/bin/bash # Copyright 2015 The Kubernetes 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. # Updates the docs to be ready to be used as release docs for a particular # version. # Example usage: # ./versionize-docs.sh release-1.1 set -o errexit set -o nounset set -o pipefail KUBE_ROOT=$(dirname "${BASH_SOURCE}")/.. RELEASE_BRANCH=${1-} # MAJOR_AND_MINOR_VERSION is expected to be something like "v1.1" MAJOR_AND_MINOR_VERSION="v${RELEASE_BRANCH#release-}" if [ "$#" -lt 1 ]; then echo "Usage: versionize-docs.sh , e.g., versionize-docs.sh release-1.1." echo "The is used to rewrites link URL, which should always point to a release branch, NOT a tag like v1.1.1." exit 1 fi SED=sed if which gsed &>/dev/null; then SED=gsed fi if ! ($SED --version 2>&1 | grep -q GNU); then echo "!!! GNU sed is required. If on OS X, use 'brew install gnu-sed'." exit 1 fi echo "+++ Versioning documentation and examples" # Update the docs to match this version. HTML_PREVIEW_PREFIX="https://htmlpreview.github.io/\?https://github.com/kubernetes/kubernetes/blob" # Update the include directory in definitions.md and operations.md. DIRECTORY_KEY_WORDS="" md_dirs=(docs examples) md_files=() for dir in "${md_dirs[@]}"; do md_files+=($( find "${dir}" -name "*.md" -type f )) done for doc in "${md_files[@]}"; do $SED -ri \ -e '//,//d' \ -e "s|(releases.k8s.io)/[^/]+|\1/${RELEASE_BRANCH}|g" \ "${doc}" # Replace /HEAD in html preview links with /RELEASE_BRANCH $SED -ri -e "s|(${HTML_PREVIEW_PREFIX})/HEAD|\1/${RELEASE_BRANCH}|g" "${doc}" # Replace with MAJOR_AND_MINOR_VERSION. $SED -ri -e "s|${DIRECTORY_KEY_WORDS}|${MAJOR_AND_MINOR_VERSION}|g" "${doc}" is_versioned_tag=" " if ! grep -q "${is_versioned_tag}" "${doc}"; then echo -e "\n\n${is_versioned_tag}\n\n" >> "${doc}" fi done # Update kubectl cmd files so that kubectl docs generated from them are as # expected. go_dirs=(pkg/kubectl/cmd) go_files=() for dir in "${go_dirs[@]}"; do go_files+=($( find "${dir}" -name "*.go" -type f )) done # Update API descriptions as well go_files+=(pkg/api/v[0-9]*/types.go) go_files+=(pkg/api/unversioned/types.go) go_files+=(pkg/apis/*/v[0-9]*/types.go) go_files+=(pkg/apis/*/types.go) for file in "${go_files[@]}"; do $SED -ri \ -e "s|(releases.k8s.io)/[^/]+|\1/${RELEASE_BRANCH}|g" \ -e "s|(${HTML_PREVIEW_PREFIX})/HEAD|\1/${RELEASE_BRANCH}|g" \ "${file}" done ${KUBE_ROOT}/hack/update-generated-docs.sh ${KUBE_ROOT}/hack/update-generated-swagger-docs.sh ./hack/update-api-reference-docs.sh