INFO_SETTINGS="HOOK PORT_PARENTS PORT_CHILDREN"
+HOOK_PORT_PATTERN="${PORT_PATTERN}"
+
# This function is called after a device has been plugged
# into the system and got its correct name.
# The function is intended to create child ports and things
exit ${EXIT_FALSE}
}
-hook_add() {
- cmd_not_implemented
+hook_default_new() {
+ local ${HOOK_SETTINGS}
+ if ! hook_parse_cmdline "$@"; then
+ return ${EXIT_ERROR}
+ fi
+
+ assert isset HOOK_PORT_PATTERN
+
+ local port=$(port_find_free ${HOOK_PORT_PATTERN})
+ assert isset port
+
+ port_settings_write "${port}" ${HOOK_SETTINGS}
+
+ exit ${EXIT_OK}
}
-hook_edit() {
+hook_new() {
+ hook_default_new "$@"
+}
+
+hook_default_edit() {
local port=${1}
assert isset port
shift
- port_settings_read "${port}" ${HOOK_SETTINGS}
-
- if ! hook_parse_cmdline $@; then
+ # Read settings
+ if ! port_settings_read "${port}" ${HOOK_SETTINGS}; then
+ error "Could not read settings for port ${port}"
return ${EXIT_ERROR}
fi
- port_settings_write "${port}" ${HOOK_SETTINGS}
+ # Parse command line arguments
+ if ! hook_parse_cmdline "$@"; then
+ return ${EXIT_ERROR}
+ fi
- exit ${EXIT_OK}
-}
+ # Save settings
+ if ! port_settings_write "${port}" ${HOOK_SETTINGS}; then
+ error "Could not write settings for port ${port}"
+ return ${EXIT_ERROR}
+ fi
-hook_info() {
- local port="${1}"
- assert isset port
- shift
+ # Apply settings
+ port_restart "${port}"
- settings_read "$(port_file ${port})"
+ return ${EXIT_OK}
+}
- local key val
- for key in PORT_PARENTS PORT_CHILDREN; do
- val="${key}_VAR"
- val=${!val}
+hook_edit() {
+ hook_default_edit "$@"
+}
- assign "${key}" "${!val}"
- done
+# Returns a list of all children of this port
+hook_children() {
+ local port="${1}"
- for key in ${INFO_SETTINGS}; do
- echo "${key}=\"${!key}\""
- done
+ if ! port_settings_read "${port}" ${HOOK_SETTINGS}; then
+ log ERROR "Could not read port settings: ${port}"
+ return ${EXIT_OK}
+ fi
- exit ${ERROR_OK}
+ print "${SLAVES}"
}
hook_status() {
done
}
+# Depends on the port existing
hook_up() {
- hook_default_up $@
+ hook_default_up "$@"
}
hook_default_down() {
}
hook_down() {
- hook_default_down $@
+ hook_default_down "$@"
}