123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141 |
- #!/bin/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.
- # -----------------------------------------------------------------------------
- # Version management helpers. These functions help to set, save and load the
- # following variables:
- #
- # KUBE_GIT_COMMIT - The git commit id corresponding to this
- # source code.
- # KUBE_GIT_TREE_STATE - "clean" indicates no changes since the git commit id
- # "dirty" indicates source code changes after the git commit id
- # KUBE_GIT_VERSION - "vX.Y" used to indicate the last release version.
- # KUBE_GIT_MAJOR - The major part of the version
- # KUBE_GIT_MINOR - The minor component of the version
- # Grovels through git to set a set of env variables.
- #
- # If KUBE_GIT_VERSION_FILE, this function will load from that file instead of
- # querying git.
- kube::version::get_version_vars() {
- if [[ -n ${KUBE_GIT_VERSION_FILE-} ]]; then
- kube::version::load_version_vars "${KUBE_GIT_VERSION_FILE}"
- return
- fi
- local git=(git --work-tree "${KUBE_ROOT}")
- if [[ -n ${KUBE_GIT_COMMIT-} ]] || KUBE_GIT_COMMIT=$("${git[@]}" rev-parse "HEAD^{commit}" 2>/dev/null); then
- if [[ -z ${KUBE_GIT_TREE_STATE-} ]]; then
- # Check if the tree is dirty. default to dirty
- if git_status=$("${git[@]}" status --porcelain 2>/dev/null) && [[ -z ${git_status} ]]; then
- KUBE_GIT_TREE_STATE="clean"
- else
- KUBE_GIT_TREE_STATE="dirty"
- fi
- fi
- # Use git describe to find the version based on annotated tags.
- if [[ -n ${KUBE_GIT_VERSION-} ]] || KUBE_GIT_VERSION=$("${git[@]}" describe --tags --abbrev=14 "${KUBE_GIT_COMMIT}^{commit}" 2>/dev/null); then
- # This translates the "git describe" to an actual semver.org
- # compatible semantic version that looks something like this:
- # v1.1.0-alpha.0.6+84c76d1142ea4d
- #
- # TODO: We continue calling this "git version" because so many
- # downstream consumers are expecting it there.
- KUBE_GIT_VERSION=$(echo "${KUBE_GIT_VERSION}" | sed "s/-\([0-9]\{1,\}\)-g\([0-9a-f]\{14\}\)$/.\1\+\2/")
- if [[ "${KUBE_GIT_TREE_STATE}" == "dirty" ]]; then
- # git describe --dirty only considers changes to existing files, but
- # that is problematic since new untracked .go files affect the build,
- # so use our idea of "dirty" from git status instead.
- KUBE_GIT_VERSION+="-dirty"
- fi
- # Try to match the "git describe" output to a regex to try to extract
- # the "major" and "minor" versions and whether this is the exact tagged
- # version or whether the tree is between two tagged versions.
- if [[ "${KUBE_GIT_VERSION}" =~ ^v([0-9]+)\.([0-9]+)(\.[0-9]+)?([-].*)?$ ]]; then
- KUBE_GIT_MAJOR=${BASH_REMATCH[1]}
- KUBE_GIT_MINOR=${BASH_REMATCH[2]}
- if [[ -n "${BASH_REMATCH[4]}" ]]; then
- KUBE_GIT_MINOR+="+"
- fi
- fi
- fi
- fi
- }
- # Saves the environment flags to $1
- kube::version::save_version_vars() {
- local version_file=${1-}
- [[ -n ${version_file} ]] || {
- echo "!!! Internal error. No file specified in kube::version::save_version_vars"
- return 1
- }
- cat <<EOF >"${version_file}"
- KUBE_GIT_COMMIT='${KUBE_GIT_COMMIT-}'
- KUBE_GIT_TREE_STATE='${KUBE_GIT_TREE_STATE-}'
- KUBE_GIT_VERSION='${KUBE_GIT_VERSION-}'
- KUBE_GIT_MAJOR='${KUBE_GIT_MAJOR-}'
- KUBE_GIT_MINOR='${KUBE_GIT_MINOR-}'
- EOF
- }
- # Loads up the version variables from file $1
- kube::version::load_version_vars() {
- local version_file=${1-}
- [[ -n ${version_file} ]] || {
- echo "!!! Internal error. No file specified in kube::version::load_version_vars"
- return 1
- }
- source "${version_file}"
- }
- kube::version::ldflag() {
- local key=${1}
- local val=${2}
- echo "-X ${KUBE_GO_PACKAGE}/pkg/version.${key}=${val}"
- }
- # Prints the value that needs to be passed to the -ldflags parameter of go build
- # in order to set the Kubernetes based on the git tree status.
- kube::version::ldflags() {
- kube::version::get_version_vars
- local -a ldflags=($(kube::version::ldflag "buildDate" "$(date -u +'%Y-%m-%dT%H:%M:%SZ')"))
- if [[ -n ${KUBE_GIT_COMMIT-} ]]; then
- ldflags+=($(kube::version::ldflag "gitCommit" "${KUBE_GIT_COMMIT}"))
- ldflags+=($(kube::version::ldflag "gitTreeState" "${KUBE_GIT_TREE_STATE}"))
- fi
- if [[ -n ${KUBE_GIT_VERSION-} ]]; then
- ldflags+=($(kube::version::ldflag "gitVersion" "${KUBE_GIT_VERSION}"))
- fi
- if [[ -n ${KUBE_GIT_MAJOR-} && -n ${KUBE_GIT_MINOR-} ]]; then
- ldflags+=(
- $(kube::version::ldflag "gitMajor" "${KUBE_GIT_MAJOR}")
- $(kube::version::ldflag "gitMinor" "${KUBE_GIT_MINOR}")
- )
- fi
- # The -ldflags parameter takes a single string, so join the output.
- echo "${ldflags[*]-}"
- }
|