mirror of
https://github.com/ahmetb/kubectx.git
synced 2025-06-22 13:41:11 +00:00
separate local declarations and function calls
Suggested by SC2155 (https://github.com/koalaman/shellcheck/wiki/SC2155). It captures some of the errors from kubectl that were previously described in #5. However, this doesn't completely address that. Signed-off-by: Ahmet Alp Balkan <ahmetb@google.com>
This commit is contained in:
parent
80336137bd
commit
6610d70ca8
25
kubectx
25
kubectx
@ -45,10 +45,13 @@ get_contexts() {
|
|||||||
|
|
||||||
list_contexts() {
|
list_contexts() {
|
||||||
set -u pipefail
|
set -u pipefail
|
||||||
local cur="$(current_context)"
|
local cur
|
||||||
local yellow=$(tput setaf 3)
|
cur="$(current_context)"
|
||||||
local darkbg=$(tput setab 0)
|
|
||||||
local normal=$(tput sgr0)
|
local yellow darkbg normal
|
||||||
|
yellow=$(tput setaf 3)
|
||||||
|
darkbg=$(tput setab 0)
|
||||||
|
normal=$(tput sgr0)
|
||||||
|
|
||||||
for c in $(get_contexts); do
|
for c in $(get_contexts); do
|
||||||
if [[ "${c}" = "${cur}" ]]; then
|
if [[ "${c}" = "${cur}" ]]; then
|
||||||
@ -66,7 +69,8 @@ read_context() {
|
|||||||
}
|
}
|
||||||
|
|
||||||
save_context() {
|
save_context() {
|
||||||
local saved="$(read_context)"
|
local saved
|
||||||
|
saved="$(read_context)"
|
||||||
|
|
||||||
if [[ "${saved}" != "${1}" ]]; then
|
if [[ "${saved}" != "${1}" ]]; then
|
||||||
printf %s "${1}" > "${KUBECTX}"
|
printf %s "${1}" > "${KUBECTX}"
|
||||||
@ -78,7 +82,8 @@ switch_context() {
|
|||||||
}
|
}
|
||||||
|
|
||||||
set_context() {
|
set_context() {
|
||||||
local prev="$(current_context)"
|
local prev
|
||||||
|
prev="$(current_context)"
|
||||||
|
|
||||||
switch_context "${1}"
|
switch_context "${1}"
|
||||||
|
|
||||||
@ -88,7 +93,8 @@ set_context() {
|
|||||||
}
|
}
|
||||||
|
|
||||||
swap_context() {
|
swap_context() {
|
||||||
local ctx="$(read_context)"
|
local ctx
|
||||||
|
ctx="$(read_context)"
|
||||||
if [[ -z "${ctx}" ]]; then
|
if [[ -z "${ctx}" ]]; then
|
||||||
echo "error: No previous context found." >&2
|
echo "error: No previous context found." >&2
|
||||||
exit 1
|
exit 1
|
||||||
@ -110,8 +116,9 @@ rename_context() {
|
|||||||
local old_name="${1}"
|
local old_name="${1}"
|
||||||
local new_name="${2}"
|
local new_name="${2}"
|
||||||
|
|
||||||
local old_user="$(user_of_context "${old_name}")"
|
local old_user old_cluster
|
||||||
local old_cluster="$(cluster_of_context "${old_name}")"
|
old_user="$(user_of_context "${old_name}")"
|
||||||
|
old_cluster="$(cluster_of_context "${old_name}")"
|
||||||
|
|
||||||
if [[ -z "$old_user" || -z "$old_cluster" ]]; then
|
if [[ -z "$old_user" || -z "$old_cluster" ]]; then
|
||||||
echo "error: Cannot retrieve context ${old_name}." >&2
|
echo "error: Cannot retrieve context ${old_name}." >&2
|
||||||
|
35
kubens
35
kubens
@ -35,7 +35,8 @@ EOF
|
|||||||
}
|
}
|
||||||
|
|
||||||
current_namespace() {
|
current_namespace() {
|
||||||
local cur_ctx=$(current_context)
|
local cur_ctx
|
||||||
|
cur_ctx="$(current_context)"
|
||||||
ns="$(kubectl config view -o=jsonpath="{.contexts[?(@.name==\"${cur_ctx}\")].context.namespace}")"
|
ns="$(kubectl config view -o=jsonpath="{.contexts[?(@.name==\"${cur_ctx}\")].context.namespace}")"
|
||||||
if [[ -z "${ns}" ]]; then
|
if [[ -z "${ns}" ]]; then
|
||||||
echo "default"
|
echo "default"
|
||||||
@ -58,14 +59,16 @@ namespace_file() {
|
|||||||
}
|
}
|
||||||
|
|
||||||
read_namespace() {
|
read_namespace() {
|
||||||
local f="$(namespace_file "${1}")"
|
local f
|
||||||
|
f="$(namespace_file "${1}")"
|
||||||
[[ -f "${f}" ]] && cat "${f}"
|
[[ -f "${f}" ]] && cat "${f}"
|
||||||
}
|
}
|
||||||
|
|
||||||
save_namespace() {
|
save_namespace() {
|
||||||
mkdir -p "${KUBENS_DIR}"
|
mkdir -p "${KUBENS_DIR}"
|
||||||
local f="$(namespace_file "${1}")"
|
local f saved
|
||||||
local saved="$(read_namespace "${1}")"
|
f="$(namespace_file "${1}")"
|
||||||
|
saved="$(read_namespace "${1}")"
|
||||||
|
|
||||||
if [[ "${saved}" != "${2}" ]]; then
|
if [[ "${saved}" != "${2}" ]]; then
|
||||||
printf %s "${2}" > "${f}"
|
printf %s "${2}" > "${f}"
|
||||||
@ -79,8 +82,9 @@ switch_namespace() {
|
|||||||
}
|
}
|
||||||
|
|
||||||
set_namespace() {
|
set_namespace() {
|
||||||
local ctx="$(current_context)"
|
local ctx prev
|
||||||
local prev="$(current_namespace)"
|
ctx="$(current_context)"
|
||||||
|
prev="$(current_namespace)"
|
||||||
|
|
||||||
if grep -q ^"${1}"\$ <(get_namespaces); then
|
if grep -q ^"${1}"\$ <(get_namespaces); then
|
||||||
switch_namespace "${ctx}" "${1}"
|
switch_namespace "${ctx}" "${1}"
|
||||||
@ -95,13 +99,15 @@ set_namespace() {
|
|||||||
}
|
}
|
||||||
|
|
||||||
list_namespaces() {
|
list_namespaces() {
|
||||||
local cur="$(current_namespace)"
|
local yellow darkbg normal
|
||||||
|
yellow=$(tput setaf 3)
|
||||||
|
darkbg=$(tput setab 0)
|
||||||
|
normal=$(tput sgr0)
|
||||||
|
|
||||||
local yellow=$(tput setaf 3)
|
local cur ns_list
|
||||||
local darkbg=$(tput setab 0)
|
cur="$(current_namespace)"
|
||||||
local normal=$(tput sgr0)
|
ns_list=$(get_namespaces)
|
||||||
|
for c in $ns_list; do
|
||||||
for c in $(get_namespaces); do
|
|
||||||
if [[ "${c}" = "${cur}" ]]; then
|
if [[ "${c}" = "${cur}" ]]; then
|
||||||
echo "${darkbg}${yellow}${c}${normal}"
|
echo "${darkbg}${yellow}${c}${normal}"
|
||||||
else
|
else
|
||||||
@ -111,8 +117,9 @@ list_namespaces() {
|
|||||||
}
|
}
|
||||||
|
|
||||||
swap_namespace() {
|
swap_namespace() {
|
||||||
local ctx="$(current_context)"
|
local ctx ns
|
||||||
local ns="$(read_namespace "${ctx}")"
|
ctx="$(current_context)"
|
||||||
|
ns="$(read_namespace "${ctx}")"
|
||||||
if [[ -z "${ns}" ]]; then
|
if [[ -z "${ns}" ]]; then
|
||||||
echo "error: No previous namespace found for current context." >&2
|
echo "error: No previous namespace found for current context." >&2
|
||||||
exit 1
|
exit 1
|
||||||
|
Loading…
Reference in New Issue
Block a user