major refactor

This commit is contained in:
accel 2022-01-11 19:41:36 +03:00
parent fde1305d96
commit 036e88bbfa
2 changed files with 14 additions and 154 deletions

View File

@ -13,91 +13,9 @@ if [[ -z $globaldots_path ]]; then
echo 'functions require $globaldots_path to be set!' echo 'functions require $globaldots_path to be set!'
fi fi
#### BASIC ZSHLIBS TOOLS # ZCONFIG
function zshlibs_update()
{
zshlibs_log zlibs_update "preparing self update …"
if [[ -n "$zshlibs_install" ]]
then
zshlibs_log zlibs_update "cd into '$zshlibs_install' …"
pushd $zshlibs_install 2>&1 > /dev/null
zshlibs_log zlibs_update "git pull …"
(
git pull 2>&1 |zshlibs_log zlibs_update & # > "${HOME}/.log/z_zshlibs_update" &
)
zshlibs_log zlibs_update "update done"
popd 2>&1 > /dev/null
else
echo "\$zshlibs_install not set!"
return 1
zlibs_install
fi
}
function zshlibs_ensure()
{
target=${2}
typ=${1}
if ! test -e ${target}
then
zshlibs_log zshlibs_ensure "creating '${target}' ($typ) …"
case $typ in
-d)
mkdir -p ${target} \
|| zshlibs_log $0 "unable to create directory '${target}'" \
&& return 2
;;
-f)
touch ${target} \
|| zshlibs_log $0 "unable to create file '${target}'" \
&& return 2
esac
zshlibs_log zshlibs_ensure "target '${target}' created"
elif test ${typ} ${target}
then
zshlibs_log zshlibs_ensure "target '${target}' ($typ) present"
return 0
else
zshlibs_log zshlibs_ensure "target '${target}' already exists and it is not a directory"
return 1
fi
}
function zshlibs_log()
{
local facility=$1
shift
if [[ -n "${@}" ]]
then
echo "$(date -Ins) ${@}" >> "${HOME}/.log/z_$facility.log"
else
echo "$(date -Ins) $(cat)" >> "${HOME}/.log/z_$facility.log"
fi
}
function zshlibs_path_add()
{
local pathtoadd="${1}"
zshlibs_log $0 "adding path '$pathtoadd' to \$PATH"
if [[ ! ${path[(r)${pathtoadd}]} ]]
then
path+=(${pathtoadd})
fi
}
function zshlibs_fpath_add()
{
local fpathtoadd="${1}"
zshlibs_log $0 "adding fpath '$fpathtoadd' to \$fpath"
if [[ ! ${fpath[(r)${fpathtoadd}]} ]]
then
path+=(${fpathtoadd})
fi
}
##### GLOBAL BUCKET STUFF
## stuff for global dotfiles
function global_path_expand() function global_path_expand()
{ {
@ -115,84 +33,24 @@ function global_fpath_expand()
done; done;
} }
##### CONFIGURATION function global_set_useropts()
function zconfig_checkload()
{ {
typeset -a -g zconfig_loaded
if [[ ! ${zconfig_loaded[(r)${1}]} ]]
then
zshlibs_log zbootstrap "sourcing config '$1'"
. -- $1 2>&1 >(zshlibs_log zbootstrap) # >> "${HOME}/.log/z_zbootstrap.log"
zconfig_loaded+=("$1")
zshlibs_log zbootstrap "end sourcing config '$1'"
else
zshlibs_log zbootstrap "config '$1' already loaded"
fi
}
function zconfigs_load()
{
for configfile in ${*}; do
zconfig_checkload $configfile
done
}
function zconfigs_local_load()
{
if [[ ! -a ${zconfig_local_path} ]]; then
zshlibs_log $0 "local config missing, recreating from '${zconfig_shared_path}/zshconfig.example'"
mkdir -p -m 700 ${zconfig_local_path}
cp ${zconfig_shared_path}/zshconfig.example ${zconfig_local_path}/local.config.zsh
fi
if [[ ! -d ${zconfig_local_path} ]]; then
zshlibs_log zconfigs ""
zconfig_checkload ${zconfig_local_path}
else
zconfigs_load ${zconfig_local_path}/*.config.zsh;
fi
}
function zshlibs_boot()
{
# ensure log directory
zshlibs_log zbootstrap "ensure directory '${HOME}/.log/'"
zshlibs_ensure -d "${HOME}/.log/"
# loading configs
typeset -a -g zconfig_loaded
typeset -a -g path_extra typeset -a -g path_extra
typeset -a -g config_extra
typeset -g zconfig_shared_path="${zshlibs_install}/config"
typeset -g zconfig_local_path="${HOME}/.config/zsh"
} }
function zbootstrap_noninteractive() function global_configure()
{ {
zshlibs_log zbootstrap 'load global config' }
zconfig_checkload ${zconfig_shared_path}/global.config.zsh
zshlibs_log zbootstrap 'load local configs' function global_config_setup()
zconfigs_local_load {
for zconfig in $config_extra; do zshlibs_log global "expanding path with '$path_extra'"
zshlibs_log zbootstrap 'load config extra $zconfig'
zconfig_checkload ${zconfig_shared_path}/${zconfig}.config.zsh
done
# expanding settings
zshlibs_log zbootstrap "expanding path with '$path_extra'"
global_path_expand $path_extra global_path_expand $path_extra
zshlibs_log zbootstrap "expanding fpath with '$fpath_extra'" zshlibs_log global "expanding fpath with '$fpath_extra'"
global_fpath_expand vanilla global_fpath_expand vanilla
zshlibs_log zbootstrap "done loading noninteractive config" zshlibs_log global "done loading noninteractive config"
} }
function zbootstrap () ## normal functions
{
zshlibs_boot
zbootstrap_noninteractive
zconfig_checkload ${zconfig_shared_path}/global.style.zsh
zshlibs_update
zshlibs_log zbootstrap "done loading interactive config"
}

View File

@ -28,6 +28,8 @@ if ! [[ -d ${zshlibs_install} ]]
then then
zlibs_install zlibs_install
fi fi
source ${zshlibs_install}/tools.funcs.zsh
source ${zshlibs_install}/zconfig.funcs.zsh
source ${zshlibs_install}/global.funcs.zsh source ${zshlibs_install}/global.funcs.zsh
source ${zshlibs_install}/zssh.funcs.zsh source ${zshlibs_install}/zssh.funcs.zsh