oh-my-posh/src/segment_executiontime.go

209 lines
5.6 KiB
Go
Raw Normal View History

2020-12-06 13:03:40 -08:00
package main
import (
2020-12-10 07:02:45 -08:00
"fmt"
"strconv"
lang "golang.org/x/text/language"
"golang.org/x/text/message"
2020-12-06 13:03:40 -08:00
)
type executiontime struct {
2021-11-26 01:37:33 -08:00
props properties
env environmentInfo
FormattedMs string
Ms int64
2020-12-06 13:03:40 -08:00
}
2020-12-12 03:53:53 -08:00
// DurationStyle how to display the time
2020-12-10 07:02:45 -08:00
type DurationStyle string
2020-12-06 13:03:40 -08:00
const (
// ThresholdProperty represents minimum duration (milliseconds) required to enable this segment
ThresholdProperty Property = "threshold"
2020-12-12 03:53:53 -08:00
// Austin milliseconds short
Austin DurationStyle = "austin"
// Roundrock milliseconds long
2020-12-10 07:02:45 -08:00
Roundrock DurationStyle = "roundrock"
2020-12-12 03:53:53 -08:00
// Dallas milliseconds full
Dallas DurationStyle = "dallas"
// Galveston hour
2020-12-10 07:02:45 -08:00
Galveston DurationStyle = "galveston"
2020-12-12 03:53:53 -08:00
// Houston hour and milliseconds
Houston DurationStyle = "houston"
// Amarillo seconds
Amarillo DurationStyle = "amarillo"
2021-05-20 10:53:42 -07:00
// Round will round the output of the format
Round DurationStyle = "round"
2020-12-10 07:02:45 -08:00
second = 1000
minute = 60000
hour = 3600000
day = 86400000
secondsPerMinute = 60
minutesPerHour = 60
hoursPerDay = 24
2020-12-06 13:03:40 -08:00
)
func (t *executiontime) enabled() bool {
alwaysEnabled := t.props.getBool(AlwaysEnabled, false)
2020-12-06 13:03:40 -08:00
executionTimeMs := t.env.executionTime()
thresholdMs := t.props.getFloat64(ThresholdProperty, float64(500))
if !alwaysEnabled && executionTimeMs < thresholdMs {
2020-12-06 13:03:40 -08:00
return false
}
2020-12-10 07:02:45 -08:00
style := DurationStyle(t.props.getString(Style, string(Austin)))
t.Ms = int64(executionTimeMs)
t.FormattedMs = t.formatDuration(style)
return t.FormattedMs != ""
2020-12-06 13:03:40 -08:00
}
func (t *executiontime) string() string {
return t.FormattedMs
2020-12-06 13:03:40 -08:00
}
2021-11-26 01:37:33 -08:00
func (t *executiontime) init(props properties, env environmentInfo) {
2020-12-06 13:03:40 -08:00
t.props = props
t.env = env
}
2020-12-10 07:02:45 -08:00
func (t *executiontime) formatDuration(style DurationStyle) string {
2020-12-10 07:02:45 -08:00
switch style {
case Austin:
return t.formatDurationAustin()
2020-12-10 07:02:45 -08:00
case Roundrock:
return t.formatDurationRoundrock()
2020-12-10 07:02:45 -08:00
case Dallas:
return t.formatDurationDallas()
2020-12-10 07:02:45 -08:00
case Galveston:
return t.formatDurationGalveston()
2020-12-10 07:02:45 -08:00
case Houston:
return t.formatDurationHouston()
2020-12-10 07:02:45 -08:00
case Amarillo:
return t.formatDurationAmarillo()
2021-05-20 10:53:42 -07:00
case Round:
return t.formatDurationRound()
2020-12-10 07:02:45 -08:00
default:
return fmt.Sprintf("Style: %s is not available", style)
}
}
func (t *executiontime) formatDurationAustin() string {
if t.Ms < second {
return fmt.Sprintf("%dms", t.Ms%second)
2020-12-10 07:02:45 -08:00
}
seconds := float64(t.Ms%minute) / second
2020-12-10 07:02:45 -08:00
result := strconv.FormatFloat(seconds, 'f', -1, 64) + "s"
if t.Ms >= minute {
result = fmt.Sprintf("%dm %s", t.Ms/minute%secondsPerMinute, result)
2020-12-10 07:02:45 -08:00
}
if t.Ms >= hour {
result = fmt.Sprintf("%dh %s", t.Ms/hour%hoursPerDay, result)
2020-12-10 07:02:45 -08:00
}
if t.Ms >= day {
result = fmt.Sprintf("%dd %s", t.Ms/day, result)
2020-12-10 07:02:45 -08:00
}
return result
}
func (t *executiontime) formatDurationRoundrock() string {
result := fmt.Sprintf("%dms", t.Ms%second)
if t.Ms >= second {
result = fmt.Sprintf("%ds %s", t.Ms/second%secondsPerMinute, result)
2020-12-10 07:02:45 -08:00
}
if t.Ms >= minute {
result = fmt.Sprintf("%dm %s", t.Ms/minute%minutesPerHour, result)
2020-12-10 07:02:45 -08:00
}
if t.Ms >= hour {
result = fmt.Sprintf("%dh %s", t.Ms/hour%hoursPerDay, result)
2020-12-10 07:02:45 -08:00
}
if t.Ms >= day {
result = fmt.Sprintf("%dd %s", t.Ms/day, result)
2020-12-10 07:02:45 -08:00
}
return result
}
func (t *executiontime) formatDurationDallas() string {
seconds := float64(t.Ms%minute) / second
2020-12-10 07:02:45 -08:00
result := strconv.FormatFloat(seconds, 'f', -1, 64)
if t.Ms >= minute {
result = fmt.Sprintf("%d:%s", t.Ms/minute%minutesPerHour, result)
2020-12-10 07:02:45 -08:00
}
if t.Ms >= hour {
result = fmt.Sprintf("%d:%s", t.Ms/hour%hoursPerDay, result)
2020-12-10 07:02:45 -08:00
}
if t.Ms >= day {
result = fmt.Sprintf("%d:%s", t.Ms/day, result)
2020-12-10 07:02:45 -08:00
}
return result
}
func (t *executiontime) formatDurationGalveston() string {
result := fmt.Sprintf("%02d:%02d:%02d", t.Ms/hour, t.Ms/minute%minutesPerHour, t.Ms%minute/second)
2020-12-10 07:02:45 -08:00
return result
}
func (t *executiontime) formatDurationHouston() string {
2020-12-10 07:02:45 -08:00
milliseconds := ".0"
if t.Ms%second > 0 {
2020-12-10 07:02:45 -08:00
// format milliseconds as a string with truncated trailing zeros
milliseconds = strconv.FormatFloat(float64(t.Ms%second)/second, 'f', -1, 64)
2020-12-10 07:02:45 -08:00
// at this point milliseconds looks like "0.5". remove the leading "0"
milliseconds = milliseconds[1:]
}
result := fmt.Sprintf("%02d:%02d:%02d%s", t.Ms/hour, t.Ms/minute%minutesPerHour, t.Ms%minute/second, milliseconds)
2020-12-10 07:02:45 -08:00
return result
}
func (t *executiontime) formatDurationAmarillo() string {
2020-12-10 07:02:45 -08:00
// wholeNumber represents the value to the left of the decimal point (seconds)
wholeNumber := t.Ms / second
2020-12-10 07:02:45 -08:00
// decimalNumber represents the value to the right of the decimal point (milliseconds)
decimalNumber := float64(t.Ms%second) / second
2020-12-10 07:02:45 -08:00
// format wholeNumber as a string with thousands separators
printer := message.NewPrinter(lang.English)
result := printer.Sprintf("%d", wholeNumber)
if decimalNumber > 0 {
// format decimalNumber as a string with truncated trailing zeros
decimalResult := strconv.FormatFloat(decimalNumber, 'f', -1, 64)
// at this point decimalResult looks like "0.5"
// remove the leading "0" and append
result += decimalResult[1:]
}
result += "s"
return result
}
2021-05-20 10:53:42 -07:00
func (t *executiontime) formatDurationRound() string {
toRoundString := func(one, two int64, oneText, twoText string) string {
if two == 0 {
return fmt.Sprintf("%d%s", one, oneText)
}
return fmt.Sprintf("%d%s %d%s", one, oneText, two, twoText)
}
hours := t.Ms / hour % hoursPerDay
if t.Ms >= day {
return toRoundString(t.Ms/day, hours, "d", "h")
2021-05-20 10:53:42 -07:00
}
minutes := t.Ms / minute % secondsPerMinute
if t.Ms >= hour {
return toRoundString(hours, minutes, "h", "m")
2021-05-20 10:53:42 -07:00
}
seconds := (t.Ms % minute) / second
if t.Ms >= minute {
return toRoundString(minutes, seconds, "m", "s")
2021-05-20 10:53:42 -07:00
}
if t.Ms >= second {
return fmt.Sprintf("%ds", seconds)
2021-05-20 10:53:42 -07:00
}
return fmt.Sprintf("%dms", t.Ms%second)
2021-05-20 10:53:42 -07:00
}