1
0
mirror of https://github.com/deadc0de6/dotdrop.git synced 2026-02-04 19:09:44 +00:00

Merge branch 'dyninclude'

This commit is contained in:
deadc0de6
2019-02-27 15:55:30 +01:00
3 changed files with 143 additions and 0 deletions

View File

@@ -780,6 +780,30 @@ profiles:
```
Here profile *host1* contains all the dotfiles defined for *host2* plus `f_xinitrc`.
For more advanced use-cases variables (`variables` and `dynvariables`) can be used
to specify the profile to include in a profile
For example:
```yaml
variables:
var1: "john"
dynvariables:
d_user: "echo $USER"
profiles:
profile_john:
dotfiles:
- f_john_dotfile
profile_bill:
dotfiles:
- f_bill_dotfile
p1:
include:
- "profile_{{@@ d_user @@}}"
p2:
include:
- "profile_{{@@ var1 @@}}"
```
## Ignore empty template
It is possible to avoid having an empty rendered template being

View File

@@ -361,7 +361,11 @@ class Cfg:
if not self.lnk_profiles[profile][self.key_profiles_incl]:
# empty include found
return included
variables = self.get_variables(profile, debug=self.debug)
t = Templategen(variables=variables)
for other in self.lnk_profiles[profile][self.key_profiles_incl]:
# resolve include value
other = t.generate_string(other)
if other not in self.prodots:
# no such profile
self.log.warn('unknown included profile \"{}\"'.format(other))

115
tests-ng/dyninclude.sh Executable file
View File

@@ -0,0 +1,115 @@
#!/usr/bin/env bash
# author: deadc0de6 (https://github.com/deadc0de6)
# Copyright (c) 2017, deadc0de6
#
# test dynamic includes
# returns 1 in case of error
#
# exit on first error
set -e
# all this crap to get current path
rl="readlink -f"
if ! ${rl} "${0}" >/dev/null 2>&1; then
rl="realpath"
if ! hash ${rl}; then
echo "\"${rl}\" not found !" && exit 1
fi
fi
cur=$(dirname "$(${rl} "${0}")")
#hash dotdrop >/dev/null 2>&1
#[ "$?" != "0" ] && echo "install dotdrop to run tests" && exit 1
#echo "called with ${1}"
# dotdrop path can be pass as argument
ddpath="${cur}/../"
[ "${1}" != "" ] && ddpath="${1}"
[ ! -d ${ddpath} ] && echo "ddpath \"${ddpath}\" is not a directory" && exit 1
export PYTHONPATH="${ddpath}:${PYTHONPATH}"
bin="python3 -m dotdrop.dotdrop"
echo "dotdrop path: ${ddpath}"
echo "pythonpath: ${PYTHONPATH}"
# get the helpers
source ${cur}/helpers
echo -e "\e[96m\e[1m==> RUNNING $(basename $BASH_SOURCE) <==\e[0m"
################################################################
# this is the test
################################################################
# the dotfile source
tmps=`mktemp -d --suffix='-dotdrop-tests'`
mkdir -p ${tmps}/dotfiles
# the dotfile destination
tmpd=`mktemp -d --suffix='-dotdrop-tests'`
# create the config file
cfg="${tmps}/config.yaml"
cat > ${cfg} << _EOF
variables:
var1: "_1"
dynvariables:
dvar1: "echo _2"
config:
backup: true
create: true
dotpath: dotfiles
dotfiles:
f_abc:
dst: ${tmpd}/abc
src: abc
f_def:
dst: ${tmpd}/def
src: def
profiles:
profile_1:
dotfiles:
- f_abc
profile_2:
dotfiles:
- f_def
profile_3:
include:
- profile{{@@ var1 @@}}
profile_4:
include:
- profile{{@@ dvar1 @@}}
_EOF
cat ${cfg}
# create the dotfile
c1="content:abc"
echo "${c1}" > ${tmps}/dotfiles/abc
c2="content:def"
echo "${c2}" > ${tmps}/dotfiles/def
# install
cd ${ddpath} | ${bin} install -f -c ${cfg} -p profile_3 --verbose
# check dotfile exists
[ ! -e ${tmpd}/abc ] && exit 1
#cat ${tmpd}/abc
grep ${c1} ${tmpd}/abc >/dev/null || exit 1
# install
cd ${ddpath} | ${bin} install -f -c ${cfg} -p profile_4 --verbose
# check dotfile exists
[ ! -e ${tmpd}/def ] && exit 1
#cat ${tmpd}/def
grep ${c2} ${tmpd}/def >/dev/null || exit 1
## CLEANING
rm -rf ${tmps} ${tmpd}
echo "OK"
exit 0