Bash, странная область видимости переменной при заполнении массива результатами

Я анализирую вывод команды и помещаю результаты в массив.

Работает нормально до выхода из внутреннего цикла - выходной массив пуст.

declare -a KEYS

#-----------------------------------------------------------------------------#
get_keys()
{

# this extracts key NAMES from log in format "timestamp keycode"
$glue_dir/get_keys $ip | while read line; do
    echo line: $line
    set -- $line # $1 timestamp $2 keycode
    echo 1: $1 2: $2
    key=(`egrep "\\sВывод при запуске снова выводит две строки:" "$glue_dir/keycodes"`) # tested for matching '40' against 401, 402 etc
    set -- $key # $1 key name $2 keycode
    KEYS+=("$1")
    echo key $1
    echo KEYS inside loop: "${KEYS[@]}"
done
    echo KEYS outside loop: "${KEYS[@]}"
}

Вывод при запуске снова выводит две строки:

line: 1270899320451 38
1: 1270899320451 2: 38
key UP
KEYS inside loop: UP
line: 1270899320956 40
1: 1270899320956 2: 40
key DOWN
KEYS inside loop: UP DOWN
KEYS outside loop:

Я провел час, пытаясь понять это. Пожалуйста помоги. ;-)

Ответы на вопрос(1)

Ваш ответ на вопрос