2017-12-11 12:37:04 +08:00
// Copyright 2017 The Gitea Authors. All rights reserved.
// Use of this source code is governed by a MIT-style
// license that can be found in the LICENSE file.
2019-08-15 22:46:21 +08:00
package timeutil
2017-12-11 12:37:04 +08:00
2017-12-14 07:45:31 +08:00
import (
"time"
"code.gitea.io/gitea/modules/setting"
)
2017-12-11 12:37:04 +08:00
// TimeStamp defines a timestamp
type TimeStamp int64
// TimeStampNow returns now int64
func TimeStampNow ( ) TimeStamp {
return TimeStamp ( time . Now ( ) . Unix ( ) )
}
// Add adds seconds and return sum
func ( ts TimeStamp ) Add ( seconds int64 ) TimeStamp {
return ts + TimeStamp ( seconds )
}
// AddDuration adds time.Duration and return sum
func ( ts TimeStamp ) AddDuration ( interval time . Duration ) TimeStamp {
return ts + TimeStamp ( interval / time . Second )
}
// Year returns the time's year
func ( ts TimeStamp ) Year ( ) int {
return ts . AsTime ( ) . Year ( )
}
// AsTime convert timestamp as time.Time in Local locale
func ( ts TimeStamp ) AsTime ( ) ( tm time . Time ) {
2019-08-15 22:46:21 +08:00
return ts . AsTimeInLocation ( setting . DefaultUILocation )
}
// AsTimeInLocation convert timestamp as time.Time in Local locale
func ( ts TimeStamp ) AsTimeInLocation ( loc * time . Location ) ( tm time . Time ) {
tm = time . Unix ( int64 ( ts ) , 0 ) . In ( loc )
2017-12-11 12:37:04 +08:00
return
}
// AsTimePtr convert timestamp as *time.Time in Local locale
func ( ts TimeStamp ) AsTimePtr ( ) * time . Time {
2019-08-15 22:46:21 +08:00
return ts . AsTimePtrInLocation ( setting . DefaultUILocation )
}
// AsTimePtrInLocation convert timestamp as *time.Time in customize location
func ( ts TimeStamp ) AsTimePtrInLocation ( loc * time . Location ) * time . Time {
tm := time . Unix ( int64 ( ts ) , 0 ) . In ( loc )
2017-12-11 12:37:04 +08:00
return & tm
}
2019-08-15 22:46:21 +08:00
// Format formats timestamp as given format
2017-12-11 12:37:04 +08:00
func ( ts TimeStamp ) Format ( f string ) string {
2019-08-15 22:46:21 +08:00
return ts . FormatInLocation ( f , setting . DefaultUILocation )
}
// FormatInLocation formats timestamp as given format with spiecific location
func ( ts TimeStamp ) FormatInLocation ( f string , loc * time . Location ) string {
return ts . AsTimeInLocation ( loc ) . Format ( f )
2017-12-11 12:37:04 +08:00
}
// FormatLong formats as RFC1123Z
func ( ts TimeStamp ) FormatLong ( ) string {
return ts . Format ( time . RFC1123Z )
}
// FormatShort formats as short
func ( ts TimeStamp ) FormatShort ( ) string {
return ts . Format ( "Jan 02, 2006" )
}
2018-02-26 18:25:45 +08:00
// IsZero is zero time
func ( ts TimeStamp ) IsZero ( ) bool {
2019-08-15 22:46:21 +08:00
return ts . AsTimeInLocation ( time . Local ) . IsZero ( )
2018-02-26 18:25:45 +08:00
}