export _PARSE_ALLOWED_CHARS="_-" export _PARSE_SPLIT_CHARS="\.\ _-" # Parse data and output simplified format. # Usage: parse_simple <STRING> function parse_simple() { echo "${*}" | sed \ -e "s/[${_PARSE_SPLIT_CHARS}]/_/g" \ -e "s/[^[:alnum:]${_PARSE_ALLOWED_CHARS}]//g" \ -e "s/_\+/_/g" -e "s/-\+/-/g" \ -e "s/_-/_/g" -e "s/-_/_/g" \ -e "s/_\+/_/g" \ -e "s/^_//" -e "s/_$//" } # Parse to PascalCase. # Usage: parse_pascal <STRING> function parse_pascal() { local parts=($(_get_parts $(parse_simple "${*}"))) local result for part in "${parts[@]}"; do local word="${part,,}" word="${word^}" result="${result}${word}" done echo "${result}" } # Parse to snake_case. # Usage: parse_snake <STRING> function parse_snake() { local parts=($(_get_parts $(parse_simple "${*}"))) local result for part in "${parts[@]}"; do local word="${part,,}" result="${result}_${word}" done echo "${result#_}" } # Parse to kebab-case. # Usage: parse_kebab <STRING> function parse_kebab() { local parts=($(_get_parts $(parse_simple "${*}"))) local result for part in "${parts[@]}"; do local word="${part,,}" result="${result}-${word}" done echo "${result#-}" } # Parse to camelCase. # Usage: parse_camel <STRING> function parse_camel() { local parts=($(_get_parts $(parse_simple "${*}"))) local result for part in "${parts[@]}"; do local word="${part,,}" word="${word^}" result="${result}${word}" done echo "${result,}" } # Parse to SNAKE_CASE_UPPERCASE. **NOT STABLE! Repeating results in different output.** # Usage: parse_snake_uppercase <STRING> function parse_snake_uppercase() { local parts=($(_get_parts $(parse_simple "${*}"))) local result for part in "${parts[@]}"; do local word="${part^^}" result="${result}_${word}" done echo "${result#_}" } # Parse data keeping only alphanumeric characters. # Usage: parse_alnum <STRING> function parse_alnum() { echo "${*}" | sed -e "s/[^[:alnum:]]//g" } # Parse integers from mixed string. # Usage: parse_ints <STRING> function parse_ints() { echo "${*}" | tr '\n' ' ' | sed -e 's/[^0-9]/ /g' -e 's/^ *//g' -e 's/ *$//g' | tr -s ' ' | sed 's/ /\n/g' } # Parse string to lowercase. # Usage: parse_lowercase <STRING> function parse_lowercase() { echo "${*,,}" } # Parse string to uppercase. # Usage: parse_uppercase <STRING> function parse_uppercase() { echo "${*^^}" } # Parse string to title case. # Usage: parse_titlecase <STRING> function parse_titlecase() { local IFS=$'\n' local parts=($(_parse_split ${@})) local minors=("is" "at" "of" "to" "in" "for" "the" "a" "an" "and" "but" "or" "on" "was" "were" "been" "be" "do" "did" "does") echo -n "$(parse_sentencecase ${parts[0]})" for part in ${parts[@]:1}; do if _contains $(echo ${part,,} | sed -e "s/[${_PARSE_SPLIT_CHARS}]//g") ${minors[@]}; then echo -n "${part,,}" else echo -n "$(parse_sentencecase ${part})" fi done echo } # Parse string to sentence case. # Usage: parse_sentencecase <STRING> function parse_sentencecase() { local lower="${*,,}" echo "${lower^}" } # Parse string to start case. # Usage: parse_startcase <STRING> function parse_startcase() { local IFS=$'\n' local lower="${*,,}" local parts=($(_parse_split ${lower})) for part in ${parts[@]}; do echo -n "${part^}" done echo } # Parse string to pretty Json. # Usage: parse_json <STRING> function parse_json() { echo "${*}" | jq } # Split string by separators. # Usage: _parse_split <STRING> function _parse_split() { echo "${*}" | sed -e "s/[A-Z]\+/\n&/g" -e "s/[0-9]\+/\n&\n/g" -e "s/[${_PARSE_SPLIT_CHARS}]/&\n/g" | sed -e "/^$/d" } # Get name parts. # Usage: _get_parts <STRING> function _get_parts() { _parse_split "${*}" | sed -e "s/[${_PARSE_SPLIT_CHARS}]//g" | sed -e "/^$/d" }