2023-12-30 20:16:32 +03:00
|
|
|
_PARSE_ALLOWED_CHARS="_-"
|
|
|
|
_PARSE_SPLIT_CHARS="\.\ _-"
|
|
|
|
|
2023-12-07 04:02:47 +03:00
|
|
|
# Parse data and output simplified format.
|
|
|
|
# Usage: parse_simplify <STRING>
|
2023-12-07 01:44:42 +03:00
|
|
|
function parse_simplify() {
|
2023-12-30 20:16:32 +03:00
|
|
|
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/_$//"
|
2023-10-30 03:49:10 +03:00
|
|
|
}
|
|
|
|
|
2023-12-17 21:35:02 +03:00
|
|
|
# Parse to PascalCase.
|
|
|
|
# Usage: parse_pascal <STRING>
|
|
|
|
function parse_pascal() {
|
2023-12-26 07:58:37 +03:00
|
|
|
local parts=($(_get_parts ${*}))
|
2023-12-05 21:50:45 +03:00
|
|
|
local result
|
2023-11-30 04:53:57 +03:00
|
|
|
|
2023-12-05 21:50:45 +03:00
|
|
|
for part in "${parts[@]}"; do
|
2023-12-17 19:32:47 +03:00
|
|
|
local word="${part,,}"
|
|
|
|
word="${word^}"
|
2023-12-05 21:50:45 +03:00
|
|
|
result="${result}${word}"
|
|
|
|
done
|
2023-12-17 19:32:47 +03:00
|
|
|
|
2023-12-05 21:50:45 +03:00
|
|
|
echo "${result}"
|
2023-11-30 04:53:57 +03:00
|
|
|
}
|
|
|
|
|
2023-12-17 20:08:31 +03:00
|
|
|
# Parse to snake_case.
|
|
|
|
# Usage: parse_snake <STRING>
|
|
|
|
function parse_snake() {
|
2023-12-26 07:58:37 +03:00
|
|
|
local parts=($(_get_parts ${*}))
|
2023-12-17 20:08:31 +03:00
|
|
|
local result
|
|
|
|
|
|
|
|
for part in "${parts[@]}"; do
|
|
|
|
local word="${part,,}"
|
|
|
|
result="${result}_${word}"
|
|
|
|
done
|
|
|
|
|
|
|
|
echo "${result#_}"
|
|
|
|
}
|
|
|
|
|
2023-12-17 21:35:02 +03:00
|
|
|
# Parse to kebab-case.
|
|
|
|
# Usage: parse_kebab <STRING>
|
|
|
|
function parse_kebab() {
|
2023-12-26 07:58:37 +03:00
|
|
|
local parts=($(_get_parts ${*}))
|
2023-12-17 21:35:02 +03:00
|
|
|
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() {
|
2023-12-26 07:58:37 +03:00
|
|
|
local parts=($(_get_parts ${*}))
|
2023-12-17 21:35:02 +03:00
|
|
|
local result
|
|
|
|
|
|
|
|
for part in "${parts[@]}"; do
|
|
|
|
local word="${part,,}"
|
|
|
|
word="${word^}"
|
|
|
|
result="${result}${word}"
|
|
|
|
done
|
|
|
|
|
|
|
|
echo "${result,}"
|
|
|
|
}
|
|
|
|
|
|
|
|
# Parse to SNAKE_CASE_UPPERCASE.
|
|
|
|
# Usage: parse_snake_uppercase <STRING>
|
|
|
|
function parse_snake_uppercase() {
|
2023-12-26 07:58:37 +03:00
|
|
|
local parts=($(_get_parts ${*}))
|
2023-12-17 21:35:02 +03:00
|
|
|
local result
|
|
|
|
|
|
|
|
for part in "${parts[@]}"; do
|
|
|
|
local word="${part^^}"
|
|
|
|
result="${result}_${word}"
|
|
|
|
done
|
|
|
|
|
|
|
|
echo "${result#_}"
|
|
|
|
}
|
|
|
|
|
2023-12-07 04:02:47 +03:00
|
|
|
# Parse data keeping only alphanumeric characters.
|
|
|
|
# Usage: parse_alnum <STRING>
|
2023-12-07 01:44:42 +03:00
|
|
|
function parse_alnum() {
|
2023-12-05 21:50:45 +03:00
|
|
|
echo "${*}" | \
|
|
|
|
sed -e "s/[^[:alnum:]]//g"
|
2023-10-30 03:49:10 +03:00
|
|
|
}
|
2023-12-26 07:58:37 +03:00
|
|
|
|
|
|
|
# Get name parts.
|
|
|
|
# Usage: _get_parts <STRING>
|
|
|
|
function _get_parts() {
|
2023-12-30 22:02:16 +03:00
|
|
|
parse_simplify "${*}" | sed -e "s/[A-Z]/\n&/g" -e "s/[${_PARSE_SPLIT_CHARS}]/\n/g" | sed -e "/^$/d"
|
2023-12-26 07:58:37 +03:00
|
|
|
}
|