mirror of
https://github.com/ddworken/hishtory.git
synced 2025-01-25 23:59:06 +01:00
Revert "Make history entry start times more precise (down to the nanosecond) to make the recorded runtime more accurate, since currently start times are rounded to the nearest second. Though note that 'date' on MacOS doesn't support %N, so this doesn't apply to MacOS"
This reverts commit d404a73c9b
since it appears to be causing test failures for linux
This commit is contained in:
parent
4bb0ebfb2e
commit
6281ae0601
@ -152,7 +152,9 @@ func presaveHistoryEntry(ctx context.Context) {
|
|||||||
// Don't save commands that start with a space
|
// Don't save commands that start with a space
|
||||||
return
|
return
|
||||||
}
|
}
|
||||||
entry.StartTime = parseCrossPlatformTime(os.Args[4])
|
startTime, err := parseCrossPlatformInt(os.Args[4])
|
||||||
|
lib.CheckFatalError(err)
|
||||||
|
entry.StartTime = time.Unix(startTime, 0).UTC()
|
||||||
entry.EndTime = time.Unix(0, 0).UTC()
|
entry.EndTime = time.Unix(0, 0).UTC()
|
||||||
|
|
||||||
// And persist it locally.
|
// And persist it locally.
|
||||||
@ -367,7 +369,11 @@ func buildHistoryEntry(ctx context.Context, args []string) (*data.HistoryEntry,
|
|||||||
entry.ExitCode = exitCode
|
entry.ExitCode = exitCode
|
||||||
|
|
||||||
// start time
|
// start time
|
||||||
entry.StartTime = parseCrossPlatformTime(args[5])
|
seconds, err := parseCrossPlatformInt(args[5])
|
||||||
|
if err != nil {
|
||||||
|
return nil, fmt.Errorf("failed to parse start time %s as int: %w", args[5], err)
|
||||||
|
}
|
||||||
|
entry.StartTime = time.Unix(seconds, 0).UTC()
|
||||||
|
|
||||||
// end time
|
// end time
|
||||||
entry.EndTime = time.Now().UTC()
|
entry.EndTime = time.Now().UTC()
|
||||||
@ -543,16 +549,9 @@ func maybeSkipBashHistTimePrefix(cmdLine string) (string, error) {
|
|||||||
return re.ReplaceAllLiteralString(cmdLine, ""), nil
|
return re.ReplaceAllLiteralString(cmdLine, ""), nil
|
||||||
}
|
}
|
||||||
|
|
||||||
func parseCrossPlatformTime(data string) time.Time {
|
func parseCrossPlatformInt(data string) (int64, error) {
|
||||||
data = strings.TrimSuffix(data, "N") // Trim the N suffix that is present on MacOS where the date CLI doesn't support %N
|
data = strings.TrimSuffix(data, "N")
|
||||||
startTime, err := strconv.ParseInt(data, 10, 64)
|
return strconv.ParseInt(data, 10, 64)
|
||||||
lib.CheckFatalError(err)
|
|
||||||
if len(data) >= 18 {
|
|
||||||
return time.Unix(0, startTime).UTC()
|
|
||||||
} else {
|
|
||||||
return time.Unix(startTime, 0).UTC()
|
|
||||||
}
|
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
func getLastCommand(history string) (string, error) {
|
func getLastCommand(history string) (string, error) {
|
||||||
|
@ -135,18 +135,17 @@ func TestBuildHistoryEntryWithTimestampStripping(t *testing.T) {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
func TestParseCrossPlatformTime(t *testing.T) {
|
func TestParseCrossPlatformInt(t *testing.T) {
|
||||||
res := parseCrossPlatformTime("1696715149")
|
res, err := parseCrossPlatformInt("123")
|
||||||
require.Equal(t, time.Unix(1696715149, 0).UTC(), res)
|
require.NoError(t, err)
|
||||||
|
if res != 123 {
|
||||||
res = parseCrossPlatformTime("1696715149N")
|
t.Fatalf("failed to parse cross platform int %d", res)
|
||||||
require.Equal(t, time.Unix(1696715149, 0).UTC(), res)
|
}
|
||||||
|
res, err = parseCrossPlatformInt("123N")
|
||||||
res = parseCrossPlatformTime("1696715218277655463")
|
require.NoError(t, err)
|
||||||
require.Equal(t, time.Unix(0, 1696715218277655463).UTC(), res)
|
if res != 123 {
|
||||||
|
t.Fatalf("failed to parse cross platform int %d", res)
|
||||||
res = parseCrossPlatformTime("1696715218277655463N")
|
}
|
||||||
require.Equal(t, time.Unix(0, 1696715218277655463).UTC(), res)
|
|
||||||
}
|
}
|
||||||
|
|
||||||
func TestBuildRegexFromTimeFormat(t *testing.T) {
|
func TestBuildRegexFromTimeFormat(t *testing.T) {
|
||||||
|
@ -1,7 +1,7 @@
|
|||||||
function _hishtory_post_exec --on-event fish_preexec
|
function _hishtory_post_exec --on-event fish_preexec
|
||||||
# Runs after <ENTER>, but before the command is executed
|
# Runs after <ENTER>, but before the command is executed
|
||||||
set --global _hishtory_command $argv
|
set --global _hishtory_command $argv
|
||||||
set --global _hishtory_start_time (date +%s%N)
|
set --global _hishtory_start_time (date +%s)
|
||||||
hishtory presaveHistoryEntry fish "$_hishtory_command" $_hishtory_start_time & # Background Run
|
hishtory presaveHistoryEntry fish "$_hishtory_command" $_hishtory_start_time & # Background Run
|
||||||
# hishtory presaveHistoryEntry fish "$_hishtory_command" $_hishtory_start_time # Foreground Run
|
# hishtory presaveHistoryEntry fish "$_hishtory_command" $_hishtory_start_time # Foreground Run
|
||||||
end
|
end
|
||||||
|
@ -13,7 +13,7 @@ function __hishtory_precommand() {
|
|||||||
unset HISHTORY_AT_PROMPT
|
unset HISHTORY_AT_PROMPT
|
||||||
|
|
||||||
# Run before every command
|
# Run before every command
|
||||||
HISHTORY_START_TIME=`date +%s%N`
|
HISHTORY_START_TIME=`date +%s`
|
||||||
CMD=`history 1`
|
CMD=`history 1`
|
||||||
if ! [ -z "CMD " ] ; then
|
if ! [ -z "CMD " ] ; then
|
||||||
(hishtory presaveHistoryEntry bash "$CMD" $HISHTORY_START_TIME &) # Background Run
|
(hishtory presaveHistoryEntry bash "$CMD" $HISHTORY_START_TIME &) # Background Run
|
||||||
|
@ -8,7 +8,7 @@ function _hishtory_add() {
|
|||||||
# Runs after <ENTER>, but before the command is executed
|
# Runs after <ENTER>, but before the command is executed
|
||||||
# $1 contains the command that was run
|
# $1 contains the command that was run
|
||||||
_hishtory_command=$1
|
_hishtory_command=$1
|
||||||
_hishtory_start_time=`date +%s%N`
|
_hishtory_start_time=`date +%s`
|
||||||
if ! [ -z "$_hishtory_command " ]; then
|
if ! [ -z "$_hishtory_command " ]; then
|
||||||
(hishtory presaveHistoryEntry zsh "$_hishtory_command" $_hishtory_start_time &) # Background Run
|
(hishtory presaveHistoryEntry zsh "$_hishtory_command" $_hishtory_start_time &) # Background Run
|
||||||
# hishtory presaveHistoryEntry zsh "$_hishtory_command" $_hishtory_start_time # Foreground Run
|
# hishtory presaveHistoryEntry zsh "$_hishtory_command" $_hishtory_start_time # Foreground Run
|
||||||
|
Loading…
Reference in New Issue
Block a user