c572fcfe04
Rename the Go module path from code.gitea.io/gitea to git.mokoconsulting.tech/MokoConsulting/MokoGitea across the entire codebase. Scope: - go.mod module declaration - 2,235 Go source files (import paths) - Dockerfile WORKDIR and COPY paths - Swagger API templates - golangci.yml linter config External dependencies (code.gitea.io/gitea-vet, code.gitea.io/sdk/gitea, gitea.com/gitea/act, etc.) are intentionally NOT renamed — they are separate upstream modules. Closes #132 Co-Authored-By: Claude Opus 4.6 (1M context) <noreply@anthropic.com>
35 lines
970 B
Go
35 lines
970 B
Go
// Copyright 2023 The Gitea Authors. All rights reserved.
|
|
// SPDX-License-Identifier: MIT
|
|
|
|
package internal
|
|
|
|
import (
|
|
"math"
|
|
|
|
"git.mokoconsulting.tech/MokoConsulting/MokoGitea/models/db"
|
|
)
|
|
|
|
// ParsePaginator parses a db.Paginator into a skip and limit
|
|
func ParsePaginator(paginator *db.ListOptions, maxNums ...int) (int, int) {
|
|
// Use a very large number to indicate no limit
|
|
unlimited := math.MaxInt32
|
|
if len(maxNums) > 0 {
|
|
// Some indexer engines have a limit on the page size, respect that
|
|
unlimited = maxNums[0]
|
|
}
|
|
|
|
if paginator == nil || paginator.IsListAll() {
|
|
// It shouldn't happen. In actual usage scenarios, there should not be requests to search all.
|
|
// But if it does happen, respect it and return "unlimited".
|
|
// And it's also useful for testing.
|
|
return 0, unlimited
|
|
}
|
|
|
|
if paginator.PageSize == 0 {
|
|
// Do not return any results when searching, it's used to get the total count only.
|
|
return 0, 0
|
|
}
|
|
|
|
return paginator.GetSkipTake()
|
|
}
|