![JAR search and dependency download from the Maven repository](/logo.png)
commonMain.options.common.LimitOption.kt Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of dsl Show documentation
Show all versions of dsl Show documentation
Kotlin-first DSL for writing expressive and typesafe MongoDB queries
/*
* Copyright (c) 2024, OpenSavvy and contributors.
*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/
package opensavvy.ktmongo.dsl.options.common
import opensavvy.ktmongo.bson.BsonContext
import opensavvy.ktmongo.bson.BsonFieldWriter
import opensavvy.ktmongo.dsl.DangerousMongoApi
import opensavvy.ktmongo.dsl.LowLevelApi
import opensavvy.ktmongo.dsl.expr.common.AbstractExpression
/**
* Maximum number of elements analyzed by this operation.
*
* For more information, see [WithLimit].
*/
class LimitOption(
val limit: Long,
context: BsonContext,
) : AbstractExpression(context), Option {
override val value: Long
get() = limit
@LowLevelApi
override fun write(writer: BsonFieldWriter) {
writer.writeInt64("limit", limit)
}
}
/**
* Limits the number of elements returned by a query.
*
* See [limit].
*/
interface WithLimit : Options {
/**
* The maximum number of matching documents to return.
*
* ```kotlin
* collections.count {
* options {
* limit(99)
* }
* }
* ```
*/
fun limit(limit: Int) {
limit(limit.toLong())
}
/**
* The maximum number of matching documents to return.
*
* ```kotlin
* collections.count {
* options {
* limit(99L)
* }
* }
* ```
*
* Note that not all drivers support specifying a limit larger than an `Int`.
*/
@OptIn(DangerousMongoApi::class, LowLevelApi::class)
fun limit(limit: Long) {
accept(LimitOption(limit, context))
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy