mirror of https://github.com/curusarn/resh
parent
24163b1d55
commit
92f8ec000e
@ -1,91 +0,0 @@ |
|||||||
|
|
||||||
PATH=$PATH:~/.resh/bin |
|
||||||
export __RESH_RT_SESSION=$EPOCHREALTIME |
|
||||||
export __RESH_RT_SESS_SINCE_BOOT=$(cat /proc/uptime | cut -d' ' -f1) |
|
||||||
export __RESH_SESSION_ID=$(cat /proc/sys/kernel/random/uuid) |
|
||||||
nohup resh-daemon &>/dev/null & disown |
|
||||||
|
|
||||||
preexec() { |
|
||||||
# core |
|
||||||
__RESH_COLLECT=1 |
|
||||||
__RESH_CMDLINE="$1" |
|
||||||
|
|
||||||
# posix |
|
||||||
__RESH_COLS="$COLUMNS" |
|
||||||
__RESH_HOME="$HOME" |
|
||||||
__RESH_LANG="$LANG" |
|
||||||
__RESH_LC_ALL="$LC_ALL" |
|
||||||
# other LC ? |
|
||||||
__RESH_LINES="$LINES" |
|
||||||
__RESH_LOGIN="$LOGNAME" |
|
||||||
__RESH_PATH="$PATH" |
|
||||||
__RESH_PWD="$PWD" |
|
||||||
__RESH_SHELL="$SHELL" |
|
||||||
__RESH_TERM="$TERM" |
|
||||||
|
|
||||||
# non-posix |
|
||||||
__RESH_PID="$BASHPID" # current pid |
|
||||||
__RESH_SHELL_PID="$$" # pid but subshells don't affect it |
|
||||||
__RESH_WINDOWID="$WINDOWID" # session |
|
||||||
__RESH_HOST="$HOSTNAME" |
|
||||||
__RESH_HOSTTYPE="$HOSTTYPE" |
|
||||||
__RESH_OSTYPE="$OSTYPE" |
|
||||||
__RESH_MACHTYPE="$MACHTYPE" |
|
||||||
__RESH_SHLVL="$SHLVL" |
|
||||||
__RESH_GIT_CDUP="$(git rev-parse --show-cdup 2>/dev/null)" |
|
||||||
__RESH_GIT_CDUP_EXIT_CODE=$? |
|
||||||
__RESH_GIT_REMOTE="$(git remote get-url origin 2>/dev/null)" |
|
||||||
__RESH_GIT_REMOTE_EXIT_CODE=$? |
|
||||||
#__RESH_GIT_TOPLEVEL="$(git rev-parse --show-toplevel)" |
|
||||||
#__RESH_GIT_TOPLEVEL_EXIT_CODE=$? |
|
||||||
|
|
||||||
# TODO: we should evaluate symlinks in preexec |
|
||||||
# -> maybe create resh-precollect that could handle most of preexec |
|
||||||
# maybe even move resh-collect here and send data to daemon and |
|
||||||
# send rest of the data ($?, timeAfter) to daemon in precmd |
|
||||||
# daemon will combine the data and save the record |
|
||||||
# and save the unfinnished record even if it never finishes |
|
||||||
# detect if the command died with the parent ps and save it then |
|
||||||
|
|
||||||
# time |
|
||||||
__RESH_TZ_BEFORE=$(date +%:z) |
|
||||||
__RESH_RT_BEFORE="$EPOCHREALTIME" |
|
||||||
} |
|
||||||
|
|
||||||
precmd() { |
|
||||||
__RESH_EXIT_CODE=$? |
|
||||||
__RESH_RT_AFTER=$EPOCHREALTIME |
|
||||||
__RESH_TZ_AFTER=$(date +%:z) |
|
||||||
if [ ! -z ${__RESH_COLLECT+x} ]; then |
|
||||||
resh-collect -cmdLine "$__RESH_CMDLINE" -exitCode "$__RESH_EXIT_CODE" \ |
|
||||||
-cols "$__RESH_COLS" \ |
|
||||||
-home "$__RESH_HOME" \ |
|
||||||
-lang "$__RESH_LANG" \ |
|
||||||
-lcAll "$__RESH_LC_ALL" \ |
|
||||||
-lines "$__RESH_LINES" \ |
|
||||||
-login "$__RESH_LOGIN" \ |
|
||||||
-path "$__RESH_PATH" \ |
|
||||||
-pwd "$__RESH_PWD" \ |
|
||||||
-shell "$__RESH_SHELL" \ |
|
||||||
-term "$__RESH_TERM" \ |
|
||||||
-pid "$__RESH_PID" -shellPid "$__RESH_SHELL_PID" \ |
|
||||||
-windowId "$__RESH_WINDOWID" \ |
|
||||||
-host "$__RESH_HOST" \ |
|
||||||
-hosttype "$__RESH_HOSTTYPE" \ |
|
||||||
-ostype "$__RESH_OSTYPE" \ |
|
||||||
-machtype "$__RESH_MACHTYPE" \ |
|
||||||
-shlvl "$__RESH_SHLVL" \ |
|
||||||
-gitCdup "$__RESH_GIT_CDUP" \ |
|
||||||
-gitCdupExitCode "$__RESH_GIT_CDUP_EXIT_CODE" \ |
|
||||||
-gitRemote "$__RESH_GIT_REMOTE" \ |
|
||||||
-gitRemoteExitCode "$__RESH_GIT_REMOTE_EXIT_CODE" \ |
|
||||||
-realtimeBefore "$__RESH_RT_BEFORE" \ |
|
||||||
-realtimeAfter "$__RESH_RT_AFTER" \ |
|
||||||
-realtimeSession "$__RESH_RT_SESSION" \ |
|
||||||
-realtimeSessSinceBoot "$__RESH_RT_SESS_SINCE_BOOT" \ |
|
||||||
-timezoneBefore "$__RESH_TZ_BEFORE" \ |
|
||||||
-timezoneAfter "$__RESH_TZ_AFTER" |
|
||||||
fi |
|
||||||
unset __RESH_COLLECT |
|
||||||
} |
|
||||||
|
|
||||||
Loading…
Reference in new issue