mirror of https://github.com/k3s-io/k3s
103 lines
3.3 KiB
Bash
Executable File
103 lines
3.3 KiB
Bash
Executable File
#!/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 <release-branch>, e.g., versionize-docs.sh release-1.1."
|
|
echo "The <release-branch> 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"
|
|
# Update the include directory in definitions.md and operations.md.
|
|
DIRECTORY_KEY_WORDS="<REPLACE-WITH-RELEASE-VERSION>"
|
|
|
|
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 '/<!-- BEGIN STRIP_FOR_RELEASE -->/,/<!-- END STRIP_FOR_RELEASE -->/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 <REPLACE-WITH-RELEASE-VERSION> with MAJOR_AND_MINOR_VERSION.
|
|
$SED -ri -e "s|${DIRECTORY_KEY_WORDS}|${MAJOR_AND_MINOR_VERSION}|g" "${doc}"
|
|
|
|
is_versioned_tag="<!-- BEGIN MUNGE: IS_VERSIONED -->
|
|
<!-- TAG IS_VERSIONED -->
|
|
<!-- END MUNGE: IS_VERSIONED -->"
|
|
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
|