98 lines
3.0 KiB
Bash
Executable File
98 lines
3.0 KiB
Bash
Executable File
#!/usr/bin/env bash
|
|
|
|
# Copyright 2014 The Kubernetes Authors.
|
|
#
|
|
# 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 file is not intended to be run automatically. It is meant to be run
|
|
# immediately before exporting docs. We do not want to check these documents in
|
|
# by default.
|
|
|
|
set -o errexit
|
|
set -o nounset
|
|
set -o pipefail
|
|
|
|
KUBE_ROOT=$(dirname "${BASH_SOURCE[0]}")/..
|
|
source "${KUBE_ROOT}/hack/lib/init.sh"
|
|
|
|
kube::golang::setup_env
|
|
kube::util::ensure-temp-dir
|
|
|
|
BINS=(
|
|
./cmd/gendocs
|
|
./cmd/genkubedocs
|
|
./cmd/genman
|
|
./cmd/genyaml
|
|
)
|
|
GOPROXY=off go install "${BINS[@]}"
|
|
|
|
# Run all doc generators.
|
|
# $1 is the directory to put those generated documents
|
|
generate_docs() {
|
|
local dest="$1"
|
|
|
|
mkdir -p "${dest}/docs/user-guide/kubectl/"
|
|
gendocs "${dest}/docs/user-guide/kubectl/"
|
|
|
|
mkdir -p "${dest}/docs/admin/"
|
|
genkubedocs "${dest}/docs/admin/" "kube-apiserver"
|
|
genkubedocs "${dest}/docs/admin/" "kube-controller-manager"
|
|
genkubedocs "${dest}/docs/admin/" "kube-proxy"
|
|
genkubedocs "${dest}/docs/admin/" "kube-scheduler"
|
|
genkubedocs "${dest}/docs/admin/" "kubelet"
|
|
genkubedocs "${dest}/docs/admin/" "kubeadm"
|
|
|
|
mkdir -p "${dest}/docs/man/man1/"
|
|
genman "${dest}/docs/man/man1/" "kube-apiserver"
|
|
genman "${dest}/docs/man/man1/" "kube-controller-manager"
|
|
genman "${dest}/docs/man/man1/" "kube-proxy"
|
|
genman "${dest}/docs/man/man1/" "kube-scheduler"
|
|
genman "${dest}/docs/man/man1/" "kubelet"
|
|
genman "${dest}/docs/man/man1/" "kubectl"
|
|
genman "${dest}/docs/man/man1/" "kubeadm"
|
|
|
|
mkdir -p "${dest}/docs/yaml/kubectl/"
|
|
genyaml "${dest}/docs/yaml/kubectl/"
|
|
|
|
# create the list of generated files
|
|
pushd "${dest}" > /dev/null || return 1
|
|
touch docs/.generated_docs
|
|
find . -type f | cut -sd / -f 2- | LC_ALL=C sort > docs/.generated_docs
|
|
popd > /dev/null || return 1
|
|
}
|
|
|
|
# Removes previously generated docs-- we don't want to check them in. $KUBE_ROOT
|
|
# must be set.
|
|
remove_generated_docs() {
|
|
if [ -e "${KUBE_ROOT}/docs/.generated_docs" ]; then
|
|
# remove all of the old docs; we don't want to check them in.
|
|
while read -r file; do
|
|
rm "${KUBE_ROOT}/${file}" 2>/dev/null || true
|
|
done <"${KUBE_ROOT}/docs/.generated_docs"
|
|
# The docs/.generated_docs file lists itself, so we don't need to explicitly
|
|
# delete it.
|
|
fi
|
|
}
|
|
|
|
# generate into KUBE_TMP
|
|
generate_docs "${KUBE_TEMP}"
|
|
|
|
# remove all of the existing docs in KUBE_ROOT
|
|
remove_generated_docs
|
|
|
|
# Copy fresh docs into the repo.
|
|
# the shopt is so that we get docs/.generated_docs from the glob.
|
|
shopt -s dotglob
|
|
cp -af "${KUBE_TEMP}"/* "${KUBE_ROOT}"
|
|
shopt -u dotglob
|