mirror of
				https://github.com/k3s-io/kubernetes.git
				synced 2025-11-04 07:49:35 +00:00 
			
		
		
		
	
		
			
				
	
	
		
			105 lines
		
	
	
		
			3.3 KiB
		
	
	
	
		
			Bash
		
	
	
		
			Executable File
		
	
	
	
	
			
		
		
	
	
			105 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/blob"
 | 
						|
# 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-munge-docs.sh
 | 
						|
${KUBE_ROOT}/hack/update-generated-swagger-docs.sh
 | 
						|
${KUBE_ROOT}/hack/update-swagger-spec.sh
 | 
						|
${KUBE_ROOT}/hack/update-generated-protobuf.sh
 | 
						|
./hack/update-api-reference-docs.sh
 |