1
0
mirror of https://github.com/MontFerret/ferret.git synced 2024-12-16 11:37:36 +02:00
ferret/pkg/stdlib/datetime/add_subtract.go
Tim Voronov 1af8b37a0f
New type system (#232)
* New type system

* Fixed dot notation for HTML elements
2019-02-13 12:31:18 -05:00

102 lines
2.5 KiB
Go

package datetime
import (
"context"
"github.com/MontFerret/ferret/pkg/runtime/core"
"github.com/MontFerret/ferret/pkg/runtime/values"
"github.com/MontFerret/ferret/pkg/runtime/values/types"
)
var (
sliceDateTime = []core.Type{types.DateTime}
sliceIntType = []core.Type{types.Int}
sliceStringType = []core.Type{types.String}
emptyDateTime values.DateTime
emptyInt values.Int
emptyString values.String
)
// DateAdd add amount given in unit to date.
// @params date (DateTime) - source date.
// @params amount (Int) - amount of units
// @params unit (String) - unit.
// @return (DateTime) - calculated date.
// The following units are available:
// * y, year, year
// * m, month, months
// * w, week, weeks
// * d, day, days
// * h, hour, hours
// * i, minute, minutes
// * s, second, seconds
// * f, millisecond, milliseconds
func DateAdd(_ context.Context, args ...core.Value) (core.Value, error) {
date, amount, unit, err := getArgs(args)
if err != nil {
return values.None, err
}
u, err := UnitFromString(unit.String())
if err != nil {
return values.None, err
}
tm := AddUnit(date.Time, int(amount), u)
return values.NewDateTime(tm), nil
}
// DateSubtract subtract amount given in unit to date.
// @params date (DateTime) - source date.
// @params amount (Int) - amount of units
// @params unit (String) - unit.
// @return (DateTime) - calculated date.
// The following units are available:
// * y, year, year
// * m, month, months
// * w, week, weeks
// * d, day, days
// * h, hour, hours
// * i, minute, minutes
// * s, second, seconds
// * f, millisecond, milliseconds
func DateSubtract(_ context.Context, args ...core.Value) (core.Value, error) {
date, amount, unit, err := getArgs(args)
if err != nil {
return values.None, err
}
u, err := UnitFromString(unit.String())
if err != nil {
return values.None, err
}
tm := AddUnit(date.Time, -1*int(amount), u)
return values.NewDateTime(tm), nil
}
func getArgs(args []core.Value) (values.DateTime, values.Int, values.String, error) {
err := core.ValidateArgs(args, 3, 3)
if err != nil {
return emptyDateTime, emptyInt, emptyString, err
}
err = core.ValidateValueTypePairs(
core.PairValueType{Value: args[0], Types: sliceDateTime},
core.PairValueType{Value: args[1], Types: sliceIntType},
core.PairValueType{Value: args[2], Types: sliceStringType},
)
if err != nil {
return emptyDateTime, emptyInt, emptyString, err
}
date := args[0].(values.DateTime)
amount := args[1].(values.Int)
unit := args[2].(values.String)
return date, amount, unit, nil
}