atar-axis/xpadneo

View on GitHub
configure.sh

Summary

Maintainability
Test Coverage
#!/bin/bash
# Written by CodeCanna, refined by atar-axis

cd "$(dirname "$0")" || exit 1

set -o posix

NAME="$0"

# Define Variables
MODULE="/sys/module/hid_xpadneo/"
PARAMS="/sys/module/hid_xpadneo/parameters"
CONF_FILE=$(grep -sl '^options hid_xpadneo' /etc/modprobe.d/*.conf | tail -1)
: "${CONF_FILE:="/etc/modprobe.d/99-xpadneo-options.conf"}"

# Use getopt NOT getopts to parse arguments.
OPTS=$(getopt -n "$NAME" -o h:m:r:n: -l help,version,trigger-rumble-mode:,rumble-attenuation:,ff_connect_notify: -- "$@")

## Print Help ##
function display_help {
  cat ./docs/config_help
}

## Parameter Validation ##
function check_param {
    key=$1
    value=$2

    case $key in
    "trigger_rumble_mode")
        if [[ "$value" -gt 2 ]] || [[ "$value" -lt 0 ]];
        then
            echo "$NAME: $key: Invalid value! Value must be between 0 and 2."
            exit 1
        fi
        ;;
    "rumble_attenuation")
        if [[ "$value" -gt 100 ]] || [[ "$value" -lt 0 ]];
        then
            echo "$NAME: $key: Invalid value! Value must be between 0 and 100."
            exit 1
        fi
        ;;
      "ff_connect_notify")
        if [[ "$value" -gt 2 ]] || [[ "$value" -lt 0 ]];
        then
            echo "$NAME: $key: Invalid value! Value must be 0 or 1."
            exit 1
        fi
        ;;
        
    *)
        # key not known, should not be possible
        exit 2
        ;;
    esac
}

## Parameter Setting Helpers ##
function set_modprobe_param {
  sed -i "/^[[:space:]]*options[[:space:]]\+hid_xpadneo/s/$1=[^[:space:]]*/$1=$2/g" "$CONF_FILE"
}

function set_sysfs_param {
  echo "$2" > "$PARAMS/$1"
}


## Parameter Setting ##
function set_param {

  key=$1
  value=$2

  # check for valid parameters first
  check_param "$key" "$value"

  # edit sysfs parameter if module is inserted
  if [[ -d "$MODULE" ]];
  then
    echo "$NAME: Module inserted - writing to $PARAMS"
    if ! set_sysfs_param "$key" "$value";
    then
      echo "$NAME: ERROR! Could not write to $PARAMS!"
      exit 1
    fi
  fi

  # edit modprobe config file
  if ! set_modprobe_param "$key" "$value";
  then
    echo "$NAME: ERROR! Could not write to $CONF_FILE!"
    exit 1
  fi
  echo "$NAME: $key: parameter written to $CONF_FILE"

}

## Argument Parsing ##
function parse_args {
  if [[ $1 == "" ]];
  then
    display_help
    exit 1
  fi

  if ! grep -sq 'options hid_xpadneo' "${CONF_FILE}";
  then
    # If line doesn't exist echo all of the defaults.
    mkdir -p "$(dirname "${CONF_FILE}")"
    touch "${CONF_FILE}"
    echo "options hid_xpadneo disable_deadzones=0 rumble_attenuation=0 trigger_rumble_mode=0 ff_connect_notify=1" >> "$CONF_FILE"
  fi

  eval set -- "$OPTS"

  while true;
  do
    case "$1" in
      -h | --help)
        display_help
        shift
        ;;

      -m | --trigger-rumble-mode)
        key='trigger_rumble_mode'
        value="${2#*=}"
        set_param "$key" "$value"
        shift 2
        ;;

      -r | --rumble-attenuation)
        key='rumble_attenuation'
        value="${2#*=}"
        set_param "$key" "$value"
        shift 2
        ;;

      -n | --ff_connect_notify)
        key='ff_connect_notify'
        value="${2#*=}"
        set_param "$key" "$value"
        shift 2
        ;;

      --)
        shift
        break
        ;;

      *)
        echo "$NAME: Invalid option"
        display_help
        exit 1
        ;;
    esac
  done
}


### Main Entry Point ###

PARAMETERS=( "$@" )

parse_args "${PARAMETERS[@]}"

# Check if xpadneo is installed
if lsmod | grep -vq 'hid-xpadneo';
then
    >&2 echo -e "$0: WARNING: hid-xpadneo not loaded, configured anyways"
fi