Compare commits
7 Commits
cursortoke
...
v0.0.542
Author | SHA1 | Date | |
---|---|---|---|
8a92a6cc52
|
|||
9b2028ab54
|
|||
207fd331d5
|
|||
54b0d6701d
|
|||
fc2657179b
|
|||
d4894e31fe
|
|||
0ddfaf666b
|
@@ -11,6 +11,7 @@ import (
|
|||||||
|
|
||||||
type CursorToken interface {
|
type CursorToken interface {
|
||||||
Token() string
|
Token() string
|
||||||
|
IsEnd() bool
|
||||||
}
|
}
|
||||||
|
|
||||||
type Mode string
|
type Mode string
|
||||||
|
@@ -111,6 +111,10 @@ func (c CTKeySort) Token() string {
|
|||||||
return "tok_" + base32.StdEncoding.EncodeToString(body)
|
return "tok_" + base32.StdEncoding.EncodeToString(body)
|
||||||
}
|
}
|
||||||
|
|
||||||
|
func (c CTKeySort) IsEnd() bool {
|
||||||
|
return c.Mode == CTMEnd
|
||||||
|
}
|
||||||
|
|
||||||
func (c CTKeySort) valuePrimaryObjectId() (primitive.ObjectID, bool) {
|
func (c CTKeySort) valuePrimaryObjectId() (primitive.ObjectID, bool) {
|
||||||
if oid, err := primitive.ObjectIDFromHex(c.ValuePrimary); err == nil {
|
if oid, err := primitive.ObjectIDFromHex(c.ValuePrimary); err == nil {
|
||||||
return oid, true
|
return oid, true
|
||||||
|
@@ -31,3 +31,7 @@ func (c CTPaginated) Token() string {
|
|||||||
|
|
||||||
return "$" + strconv.Itoa(c.Page)
|
return "$" + strconv.Itoa(c.Page)
|
||||||
}
|
}
|
||||||
|
|
||||||
|
func (c CTPaginated) IsEnd() bool {
|
||||||
|
return c.Mode == CTMEnd
|
||||||
|
}
|
||||||
|
@@ -10,6 +10,14 @@ type JsonOpt[T any] struct {
|
|||||||
value T
|
value T
|
||||||
}
|
}
|
||||||
|
|
||||||
|
func NewJsonOpt[T any](v T) JsonOpt[T] {
|
||||||
|
return JsonOpt[T]{isSet: true, value: v}
|
||||||
|
}
|
||||||
|
|
||||||
|
func EmptyJsonOpt[T any]() JsonOpt[T] {
|
||||||
|
return JsonOpt[T]{isSet: false}
|
||||||
|
}
|
||||||
|
|
||||||
// MarshalJSON returns m as the JSON encoding of m.
|
// MarshalJSON returns m as the JSON encoding of m.
|
||||||
func (m JsonOpt[T]) MarshalJSON() ([]byte, error) {
|
func (m JsonOpt[T]) MarshalJSON() ([]byte, error) {
|
||||||
if !m.isSet {
|
if !m.isSet {
|
||||||
|
@@ -160,8 +160,8 @@ func (ee *ExErr) FormatLog(lvl LogPrintLevel) string {
|
|||||||
for curr := ee; curr != nil; curr = curr.OriginalError {
|
for curr := ee; curr != nil; curr = curr.OriginalError {
|
||||||
indent += " "
|
indent += " "
|
||||||
|
|
||||||
etype := ee.Type.Key
|
etype := curr.Type.Key
|
||||||
if ee.Type == TypeWrap {
|
if curr.Type == TypeWrap {
|
||||||
etype = "~"
|
etype = "~"
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -370,6 +370,14 @@ func (ee *ExErr) GetExtra(key string) (any, bool) {
|
|||||||
return nil, false
|
return nil, false
|
||||||
}
|
}
|
||||||
|
|
||||||
|
func (ee *ExErr) UniqueIDs() []string {
|
||||||
|
ids := []string{ee.UniqueID}
|
||||||
|
for curr := ee; curr != nil; curr = curr.OriginalError {
|
||||||
|
ids = append(ids, curr.UniqueID)
|
||||||
|
}
|
||||||
|
return ids
|
||||||
|
}
|
||||||
|
|
||||||
// contains test if the supplied error is contained in this error (anywhere in the chain)
|
// contains test if the supplied error is contained in this error (anywhere in the chain)
|
||||||
func (ee *ExErr) contains(original *ExErr) (*ExErr, bool) {
|
func (ee *ExErr) contains(original *ExErr) (*ExErr, bool) {
|
||||||
if original == nil {
|
if original == nil {
|
||||||
|
2
go.mod
2
go.mod
@@ -21,7 +21,7 @@ require (
|
|||||||
)
|
)
|
||||||
|
|
||||||
require (
|
require (
|
||||||
github.com/bytedance/sonic v1.12.3 // indirect
|
github.com/bytedance/sonic v1.12.4 // indirect
|
||||||
github.com/bytedance/sonic/loader v0.2.1 // indirect
|
github.com/bytedance/sonic/loader v0.2.1 // indirect
|
||||||
github.com/cloudwego/base64x v0.1.4 // indirect
|
github.com/cloudwego/base64x v0.1.4 // indirect
|
||||||
github.com/cloudwego/iasm v0.2.0 // indirect
|
github.com/cloudwego/iasm v0.2.0 // indirect
|
||||||
|
2
go.sum
2
go.sum
@@ -3,6 +3,8 @@ filippo.io/edwards25519 v1.1.0/go.mod h1:BxyFTGdWcka3PhytdK4V28tE5sGfRvvvRV7EaN4
|
|||||||
github.com/boombuler/barcode v1.0.0/go.mod h1:paBWMcWSl3LHKBqUq+rly7CNSldXjb2rDl3JlRe0mD8=
|
github.com/boombuler/barcode v1.0.0/go.mod h1:paBWMcWSl3LHKBqUq+rly7CNSldXjb2rDl3JlRe0mD8=
|
||||||
github.com/bytedance/sonic v1.12.3 h1:W2MGa7RCU1QTeYRTPE3+88mVC0yXmsRQRChiyVocVjU=
|
github.com/bytedance/sonic v1.12.3 h1:W2MGa7RCU1QTeYRTPE3+88mVC0yXmsRQRChiyVocVjU=
|
||||||
github.com/bytedance/sonic v1.12.3/go.mod h1:B8Gt/XvtZ3Fqj+iSKMypzymZxw/FVwgIGKzMzT9r/rk=
|
github.com/bytedance/sonic v1.12.3/go.mod h1:B8Gt/XvtZ3Fqj+iSKMypzymZxw/FVwgIGKzMzT9r/rk=
|
||||||
|
github.com/bytedance/sonic v1.12.4 h1:9Csb3c9ZJhfUWeMtpCDCq6BUoH5ogfDFLUgQ/jG+R0k=
|
||||||
|
github.com/bytedance/sonic v1.12.4/go.mod h1:B8Gt/XvtZ3Fqj+iSKMypzymZxw/FVwgIGKzMzT9r/rk=
|
||||||
github.com/bytedance/sonic/loader v0.1.1/go.mod h1:ncP89zfokxS5LZrJxl5z0UJcsk4M4yY2JpfqGeCtNLU=
|
github.com/bytedance/sonic/loader v0.1.1/go.mod h1:ncP89zfokxS5LZrJxl5z0UJcsk4M4yY2JpfqGeCtNLU=
|
||||||
github.com/bytedance/sonic/loader v0.2.0 h1:zNprn+lsIP06C/IqCHs3gPQIvnvpKbbxyXQP1iU4kWM=
|
github.com/bytedance/sonic/loader v0.2.0 h1:zNprn+lsIP06C/IqCHs3gPQIvnvpKbbxyXQP1iU4kWM=
|
||||||
github.com/bytedance/sonic/loader v0.2.0/go.mod h1:ncP89zfokxS5LZrJxl5z0UJcsk4M4yY2JpfqGeCtNLU=
|
github.com/bytedance/sonic/loader v0.2.0/go.mod h1:ncP89zfokxS5LZrJxl5z0UJcsk4M4yY2JpfqGeCtNLU=
|
||||||
|
@@ -1,5 +1,5 @@
|
|||||||
package goext
|
package goext
|
||||||
|
|
||||||
const GoextVersion = "0.0.536"
|
const GoextVersion = "0.0.542"
|
||||||
|
|
||||||
const GoextVersionTimestamp = "2024-10-22T09:57:06+0200"
|
const GoextVersionTimestamp = "2024-11-07T13:13:12+0100"
|
||||||
|
@@ -10,6 +10,10 @@ import (
|
|||||||
)
|
)
|
||||||
|
|
||||||
func (c *Coll[TData]) List(ctx context.Context, filter ct.Filter, pageSize *int, inTok ct.CursorToken) ([]TData, ct.CursorToken, error) {
|
func (c *Coll[TData]) List(ctx context.Context, filter ct.Filter, pageSize *int, inTok ct.CursorToken) ([]TData, ct.CursorToken, error) {
|
||||||
|
if inTok == nil {
|
||||||
|
inTok = ct.Start()
|
||||||
|
}
|
||||||
|
|
||||||
if ctks, ok := inTok.(ct.CTKeySort); ok {
|
if ctks, ok := inTok.(ct.CTKeySort); ok {
|
||||||
d, tok, err := c.listWithKSToken(ctx, filter, pageSize, ctks)
|
d, tok, err := c.listWithKSToken(ctx, filter, pageSize, ctks)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
|
Reference in New Issue
Block a user