Compare commits

...

10 commits

Author SHA1 Message Date
67e8f3a89c
fix
All checks were successful
/ job (push) Successful in 2m59s
2025-07-08 21:35:30 +02:00
b62edad33c
match/module
All checks were successful
/ job (push) Successful in 2m59s
2025-07-08 21:25:44 +02:00
359726e070
match/command 2025-07-08 21:23:49 +02:00
ab53ee87e1
match/alias 2025-07-08 21:21:49 +02:00
94eb3d2585
task/completion 2025-07-08 21:19:41 +02:00
278dd75556
command function 2025-07-08 21:18:50 +02:00
ffdfe0fc90
commands/eval 2025-07-08 20:57:42 +02:00
d80b61f490
fix
All checks were successful
/ job (push) Successful in 3m3s
2025-07-08 20:43:24 +02:00
faeda4feb9
awk/eval 2025-07-08 20:37:33 +02:00
23c0c18797
awk/↕ 2025-07-08 17:01:10 +02:00
3 changed files with 43 additions and 45 deletions

View file

@ -116,6 +116,7 @@ Two interpreted languages for flexibility.
* tmux * tmux
* get unresolved path for new panes & windows * get unresolved path for new panes & windows
* source code * source code
* bash completion
* doc parsing algorithm * doc parsing algorithm
* install commands * install commands
* remove existing before * remove existing before

View file

@ -5,6 +5,10 @@ function append(line) {
doc = doc line doc = doc line
} }
function eval(alias, target) {
print alias "() { " target " \"${@}\"; }"
}
function output(name, type) { function output(name, type) {
print "↙ " type print "↙ " type
print name print name
@ -20,13 +24,14 @@ function reset() {
BEGIN { BEGIN {
RE_ANY = "(.*)" RE_ANY = "(.*)"
RE_BEGIN = "^"
RE_CONST = "([_A-Z][_0-9A-Z]*)" RE_CONST = "([_A-Z][_0-9A-Z]*)"
RE_SET = "=.*" RE_SET = "=.*"
RE_SPACE = "[[:space:]]" RE_SPACE = "[[:space:]]"
RE_SPACES = RE_SPACE "*"
RE_VAR = "([_a-z][_0-9a-z]*)" RE_VAR = "([_a-z][_0-9a-z]*)"
RE_BEGIN = "^" RE_SPACES = RE_SPACE "*"
RE_END = RE_SPACES "$" RE_END = RE_SPACES "$"
RE_FUNC = RE_SPACES "\\(" RE_SPACES "\\)" RE_SPACES "{" RE_FUNC = RE_SPACES "\\(" RE_SPACES "\\)" RE_SPACES "{"
@ -41,11 +46,11 @@ BEGIN {
RE_SHEBANG = RE_BEGIN "#!" RE_SPACES RE_ANY RE_END RE_SHEBANG = RE_BEGIN "#!" RE_SPACES RE_ANY RE_END
RE_VARIABLE = RE_BEGIN RE_VAR RE_SET RE_END RE_VARIABLE = RE_BEGIN RE_VAR RE_SET RE_END
alias = 0
command = 0
f = "" f = ""
match_alias = 0
match_command = 0
match_module = 0
reset() reset()
module = 0
} }
{ {
@ -79,7 +84,7 @@ BEGIN {
} else if (match($0, RE_FUNCTION, m)) { } else if (match($0, RE_FUNCTION, m)) {
split(doc, array, "\n") split(doc, array, "\n")
for (item in array) { for (item in array) {
print array[item] " " m[1] eval(array[item], m[1])
} }
reset() reset()
} else { } else {
@ -91,7 +96,22 @@ BEGIN {
} else if (match($0, RE_FUNCTION, m)) { } else if (match($0, RE_FUNCTION, m)) {
split(doc, array, "\n") split(doc, array, "\n")
for (item in array) { for (item in array) {
print array[item] " " m[1] eval(array[item], m[1])
}
reset()
} else {
reset()
}
} else if (action == "command function") {
if (match($0, RE_COMMAND, m)) {
append(m[1])
} else if (match($0, RE_FUNCTION, m)) {
split(doc, array, "\n")
for (item in array) {
if (array[item] == target) {
print m[1]
exit
}
} }
reset() reset()
} else { } else {
@ -110,12 +130,12 @@ BEGIN {
} else if (match($0, RE_ALIAS, m)) { } else if (match($0, RE_ALIAS, m)) {
append("= " m[1]) append("= " m[1])
if (m[1] == target) { if (m[1] == target) {
alias = 1 match_alias = 1
} }
} else if (match($0, RE_COMMAND, m)) { } else if (match($0, RE_COMMAND, m)) {
append("/ " m[1]) append("/ " m[1])
if (m[1] == target) { if (m[1] == target) {
command = 1 match_command = 1
} }
# set # set
} else if (match($0, RE_CONSTANT, m)) { } else if (match($0, RE_CONSTANT, m)) {
@ -134,15 +154,15 @@ BEGIN {
} else if (match($0, RE_MODULE, m)) { } else if (match($0, RE_MODULE, m)) {
reset() reset()
if (m[1] == target) { if (m[1] == target) {
module = 1 match_module = 1
} }
} else if (match($0, RE_FUNCTION, m)) { } else if (match($0, RE_FUNCTION, m)) {
f = m[1] f = m[1]
} else if (match($0, RE_CLOSE, m)) { } else if (match($0, RE_CLOSE, m)) {
if (alias) { if (match_alias) {
print "= " target print "= " target
output(f, "function") output(f, "function")
} else if (command) { } else if (match_command) {
print "/ " target print "/ " target
output(f, "function") output(f, "function")
} else if (f == target) { } else if (f == target) {
@ -152,7 +172,7 @@ BEGIN {
reset() reset()
} }
} else { } else {
if (module) { if (match_module) {
output(target, "module") output(target, "module")
} else { } else {
reset() reset()

View file

@ -103,34 +103,15 @@ rwx_code_aliases() {
echo "${_rwx_code_aliases}" echo "${_rwx_code_aliases}"
} }
# find alias function
rwx_code_alias_function() {
local target="${1}"
local line name
while IFS= read -r line; do
name="$(echo "${line}" | awk "{print \$1}")"
if [ "${name}" = "${target}" ]; then
echo "${line}" |
awk "{print \$2}"
fi
done <<EOF
${_rwx_code_aliases_functions}
EOF
}
# find command function # find command function
rwx_code_command_function() { rwx_code_command_function() {
local target="${1}" local name="${1}"
local line name [ -n "${name}" ] || return
while IFS= read -r line; do rwx_code |
name="$(echo "${line}" | awk "{print \$1}")" awk \
if [ "${name}" = "${target}" ]; then --assign action="command function" \
echo "${line}" | --assign target="${name}" \
awk "{print \$2}" "${_rwx_code_awk}"
fi
done <<EOF
${_rwx_code_commands_functions}
EOF
} }
# show the cached aliases and functions # show the cached aliases and functions
@ -204,18 +185,14 @@ rwx_code_load() {
# parse aliases functions # parse aliases functions
_rwx_code_aliases_functions="$(rwx_code_parse "aliases functions")" _rwx_code_aliases_functions="$(rwx_code_parse "aliases functions")"
while IFS= read -r line; do while IFS= read -r line; do
text="$(echo "${line}" | sed "s| |() { |")" eval "${line}"
text="${text} \"\${@}\"; }"
eval "${text}"
done <<EOF done <<EOF
${_rwx_code_aliases_functions} ${_rwx_code_aliases_functions}
EOF EOF
# parse commands functions # parse commands functions
_rwx_code_commands_functions="$(rwx_code_parse "commands functions")" _rwx_code_commands_functions="$(rwx_code_parse "commands functions")"
while IFS= read -r line; do while IFS= read -r line; do
text="$(echo "${line}" | sed "s| |() { |")" eval "${line}"
text="${text} \"\${@}\"; }"
eval "${text}"
done <<EOF done <<EOF
${_rwx_code_commands_functions} ${_rwx_code_commands_functions}
EOF EOF