planner/plan/storage/storage.go

68 lines
1.2 KiB
Go

package storage
import (
"errors"
)
var (
ErrNotFound = errors.New("not found")
)
// type LocalID interface {
// FindAll() (map[string]int, error)
// FindOrNext(id string) (int, error)
// Next() (int, error)
// Store(id string, localID int) error
// Delete(id string) error
// }
// type Sync interface {
// FindAll() ([]item.Item, error)
// Store(i item.Item) error
// DeleteAll() error
// LastUpdate() (time.Time, error)
// }
// type Event interface {
// Store(event item.Event) error
// Find(id string) (item.Event, error)
// FindAll() ([]item.Event, error)
// Delete(id string) error
// }
// func NextLocalID(used []int) int {
// if len(used) == 0 {
// return 1
// }
// sort.Ints(used)
// usedMax := 1
// for _, u := range used {
// if u > usedMax {
// usedMax = u
// }
// }
// var limit int
// for limit = 1; limit <= len(used) || limit < usedMax; limit *= 10 {
// }
// newId := used[len(used)-1] + 1
// if newId < limit {
// return newId
// }
// usedMap := map[int]bool{}
// for _, u := range used {
// usedMap[u] = true
// }
// for i := 1; i < limit; i++ {
// if _, ok := usedMap[i]; !ok {
// return i
// }
// }
// return limit
// }