これが私の問題の最も単純な蒸留バージョンです。ここで自明ではないにしても、残っている複雑さには正当な理由があります。さらに、スクリプトは内部的なものであり、悪意のあるコードを実行する可能性がないため、eval はまったく問題ありません。それがどれほど邪悪であるかについて聞く必要はありません... ;) とりあえず、キー文字列のパイプとコロンが必須の区切り文字であると仮定します。
key="target|platform|repo:revision"
hashname="hashmap"
declare -A $hashname
eval $hashname[$key]=0
echo $(eval $hashname[$key])
もちろん、最後の 2 行には問題があります。これは、eval が $key 変数内のパイプとコロンに作用しているためです。私の質問は、このような文字列を評価から保護するにはどうすればよいですか? また、ハッシュマップ自体ではなく、ハッシュマップの名前を参照しているため、eval が必要です。前もって感謝します。
================================================== ================================
わかりました、私の問題はパイプとコロンと eval にあるのではないと実際に考え始めています。それでは、実際のコードを貼り付けてみましょう
function print_hashmap()
{
local hashname=$1
for key in `eval echo \$\{\!$hashname[@]\}`; do
local deref="$hashname[$key]"
local value=${!deref}
echo "key=${key} value=${value}"
done
}
function create_permutations2()
{
local hashname=$1 ; shift
local builds=$1 ; shift
local items=$1 ; shift
local separators=$@
echo "create_permutations(hashname=${hashname}, builds=${builds}, items=${items}, separators=${separators})"
if [ NULL != "${builds}" ]; then
for build in `echo $builds | tr ',' ' '`; do
local target="${build%%:*}"
local platforms="${build##*:}"
for platform in `echo $platforms | tr '|' ' '`; do
local key=
local ref=
if [ NULL != "${items}" ]; then
if [ NULL == "${separators}" ]; then separators=' '; fi
for separator in $separators; do
items=`echo $items | tr $separator ' '`
done
for item in $items; do
key="${target}|${platform}|${item}"
ref="$hashname[$key]"
declare "$ref"=0
done
else
key="${target}|${platform}"
ref="$hashname[$key]"
declare "$ref"=0
fi
done
done
fi
echo "created the following permutations:"
print_hashmap $hashname
}
builds="k:r|s|w,l:r|s|w"
repos="c:master,m:master"
hashname="hashmap"
declare -A $hashname
create_permutations2 $hashname $builds $repos ","
print_hashmap $hashname
最近、eval の代わりに ref を使用するという FatalError の提案に準拠するようにコードを変更しましたが、エラーは同じです: 式の構文エラー (:master の近くのエラー トークン)