Files
ts/cmd/times.go

134 lines
3.0 KiB
Go
Raw Normal View History

2025-09-24 11:29:13 +02:00
/*
Copyright © 2025 Thomas von Dein
This program is free software: you can redistribute it and/or modify
it under the terms of the GNU General Public License as published by
the Free Software Foundation, either version 3 of the License, or
(at your option) any later version.
This program is distributed in the hope that it will be useful,
but WITHOUT ANY WARRANTY; without even the implied warranty of
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
GNU General Public License for more details.
You should have received a copy of the GNU General Public License
along with this program. If not, see <http://www.gnu.org/licenses/>.
*/
2025-09-24 00:01:06 +02:00
package cmd
import (
"fmt"
"log"
"time"
"github.com/ijt/go-anytime"
"github.com/itlightning/dateparse"
modnow "github.com/jinzhu/now"
2025-09-24 00:01:06 +02:00
)
type TimestampProccessor struct {
Config
2025-09-24 11:29:13 +02:00
Reference time.Time
2025-09-24 00:01:06 +02:00
}
2025-09-24 11:29:13 +02:00
func NewTP(conf *Config, ref ...time.Time) *TimestampProccessor {
// we add some pre-defined formats to modnow
2025-09-24 00:01:06 +02:00
formats := []string{
time.UnixDate, time.RubyDate,
time.RFC1123, time.RFC1123Z, time.RFC3339, time.RFC3339Nano,
time.RFC822, time.RFC822Z, time.RFC850,
"Mon Jan 02 15:04:05 PM MST 2006", // linux date
}
modnow.TimeFormats = append(modnow.TimeFormats, formats...)
2025-09-24 00:01:06 +02:00
2025-09-24 11:29:13 +02:00
tp := &TimestampProccessor{Config: *conf, Reference: time.Now()}
if len(ref) == 1 {
tp.Reference = ref[0]
}
return tp
2025-09-24 00:01:06 +02:00
}
func (tp *TimestampProccessor) ProcessTimestamps() error {
switch len(tp.Args) {
case 1:
return tp.SingleTimestamp(tp.Args[0])
case 2:
return tp.Calc(tp.Args[0], tp.Args[1])
}
return nil
}
func (tp *TimestampProccessor) SingleTimestamp(timestamp string) error {
ts, err := tp.Parse(timestamp)
if err != nil {
return err
}
tp.Print(ts)
return nil
}
2025-09-24 11:29:13 +02:00
// Parse uses 3 different timestamp parser modules to provide maximum flexibility
2025-09-24 00:01:06 +02:00
func (tp *TimestampProccessor) Parse(timestamp string) (time.Time, error) {
2025-09-24 11:29:13 +02:00
ts, err := anytime.Parse(timestamp, tp.Reference)
2025-09-24 00:01:06 +02:00
if err == nil {
return ts, nil
}
// anytime failed, try module modnow
ts, err = modnow.Parse(timestamp)
2025-09-24 00:01:06 +02:00
if err == nil {
return ts, nil
}
// modnow failed, try module dateparse
2025-09-24 00:07:00 +02:00
return dateparse.ParseAny(timestamp)
2025-09-24 00:01:06 +02:00
}
func (tp *TimestampProccessor) Calc(timestampA, timestampB string) error {
tsA, err := tp.Parse(timestampA)
2025-09-24 00:01:06 +02:00
if err != nil {
return err
}
tsB, err := tp.Parse(timestampB)
2025-09-24 00:01:06 +02:00
if err != nil {
return err
}
switch tp.Mode {
case ModeDiff:
var diff time.Duration
2025-09-24 11:29:13 +02:00
// avoid negative results
2025-09-24 00:01:06 +02:00
if tsA.Unix() > tsB.Unix() {
diff = tsA.Sub(tsB)
} else {
diff = tsB.Sub(tsA)
}
2025-09-24 11:29:13 +02:00
tp.Print(TPduration{TimestampProccessor: *tp, Data: diff})
2025-09-24 00:01:06 +02:00
case ModeAdd:
seconds := (tsB.Hour() * 3600) + (tsB.Minute() * 60) + tsB.Second()
sum := tsA.Add(time.Duration(seconds) * time.Second)
2025-09-24 11:29:13 +02:00
tp.Print(TPdatetime{TimestampProccessor: *tp, Data: sum})
2025-09-24 00:01:06 +02:00
}
return nil
}
func (tp *TimestampProccessor) Print(ts TimestampWriter) {
_, err := fmt.Fprintln(tp.Output, ts.String())
2025-09-24 00:01:06 +02:00
if err != nil {
log.Fatalf("failed to print to given output handle: %s", err)
}
}