以下の通り、シェルスクリプトで関数経由で読み込んだ連想配列を標準出力しようとしたところ、展開されず未定義の変数としてエラーが返ってきます。
お手数ですがご見識ある方いらっしゃいましたら、解決方法をご教示くださいますよう、お願い致します。
前提・実現したいこと
シェルスクリプトで連想配列の標準出力をしようとしています。
以下の流れで実行しています。
1.test.confに連想配列を記入
2.test.shから関数を実行する
3.関数内のsourceコマンドから.confファイルを読み込み
3.同シェル内でechoを使って標準出力
発生している問題・エラーメッセージ
関数からsouceして連想配列を読み込んだ場合、展開できません。
bash -uvxでデバックすると、「未割り当ての変数です」とエラー表示し、該当の配列が展開できません。
エラーメッセージ # bash -uvx ./test.sh echo ${LOG_MESSAGE[L1_1]} test.sh: 行 xx: L1_1: 未割り当ての変数です
該当のソースコード
lang
1test.sh 2 3#!/bin/bash 4 5func_log(){ 6source ./test.conf 7 8} 9 10func_log 11echo ${LOG_MESSAGE[L1_1]} 12
test.conf declare -A LOG_MESSAGE=( ["L0_1"]="test log 01" ["L1_1"]="test log 11" )
試したこと
・展開する際に"をつけても展開されません。
例:"${LOG_MESSAGE[L1_1]}" ${LOG_MESSAGE["L1_1"]} "${LOG_MESSAGE["L1_1"]}"
・関数からではなく、直接souceを実行して読み込んだ場合、展開できます。
lang
1test.sh 2 3#!/bin/bash 4 5source ./test.conf 6echo ${LOG_MESSAGE[L1_1]}
# bash -uvx ./test.sh echo ${LOG_MESSAGE[L1_1]} + echo test log 11
補足情報(FW/ツールのバージョンなど)
Red Hat Enterprise Linux Server release 7.5 (Maipo)

回答1件
あなたの回答
tips
プレビュー
バッドをするには、ログインかつ
こちらの条件を満たす必要があります。
2018/10/25 13:03
2018/10/25 13:09
2018/10/25 13:43