Bash
Шаблоны проектирования
Поиск…
Вступление
Выполнение некоторых общих шаблонов проектирования в Bash
Шаблон публикации / подписки (паб / суб)
Когда проект Bash превращается в библиотеку, становится сложно добавлять новые функции. Названия функций, переменные и параметры обычно должны быть изменены в сценариях, которые их используют. В таких сценариях полезно отделить код и использовать шаблон проектирования, управляемый событиями. В указанном шаблоне внешний скрипт может подписаться на событие. Когда это событие запускается (публикуется), скрипт может выполнять код, который он зарегистрировал в событии.
pubsub.sh:
#!/usr/bin/env bash
#
# Save the path to this script's directory in a global env variable
#
DIR="$( cd "$( dirname "${BASH_SOURCE[0]}" )" && pwd )"
#
# Array that will contain all registered events
#
EVENTS=()
function action1() {
echo "Action #1 was performed ${2}"
}
function action2() {
echo "Action #2 was performed"
}
#
# @desc :: Registers an event
# @param :: string $1 - The name of the event. Basically an alias for a function name
# @param :: string $2 - The name of the function to be called
# @param :: string $3 - Full path to script that includes the function being called
#
function subscribe() {
EVENTS+=("${1};${2};${3}")
}
#
# @desc :: Public an event
# @param :: string $1 - The name of the event being published
#
function publish() {
for event in ${EVENTS[@]}; do
local IFS=";"
read -r -a event <<< "$event"
if [[ "${event[0]}" == "${1}" ]]; then
${event[1]} "$@"
fi
done
}
#
# Register our events and the functions that handle them
#
subscribe "/do/work" "action1" "${DIR}"
subscribe "/do/more/work" "action2" "${DIR}"
subscribe "/do/even/more/work" "action1" "${DIR}"
#
# Execute our events
#
publish "/do/work"
publish "/do/more/work"
publish "/do/even/more/work" "again"
Бежать:
chmod +x pubsub.sh
./pubsub.sh
Modified text is an extract of the original Stack Overflow Documentation
Лицензировано согласно CC BY-SA 3.0
Не связан с Stack Overflow