All Downloads are FREE. Search and download functionalities are using the official Maven repository.

commonMain.dev.kord.common.entity.ApplicationFlag.kt Maven / Gradle / Ivy

The newest version!
// THIS FILE IS AUTO-GENERATED, DO NOT EDIT!
@file:Suppress(names = arrayOf("IncorrectFormatting", "ReplaceArrayOfWithLiteral",
                "SpellCheckingInspection", "GrazieInspection"))

package dev.kord.common.entity

import kotlin.LazyThreadSafetyMode.PUBLICATION
import kotlin.contracts.InvocationKind.EXACTLY_ONCE
import kotlin.contracts.contract
import kotlin.jvm.JvmName
import kotlinx.serialization.KSerializer
import kotlinx.serialization.Serializable
import kotlinx.serialization.builtins.serializer
import kotlinx.serialization.descriptors.PrimitiveKind
import kotlinx.serialization.descriptors.PrimitiveSerialDescriptor
import kotlinx.serialization.descriptors.SerialDescriptor
import kotlinx.serialization.encoding.Decoder
import kotlinx.serialization.encoding.Encoder

/**
 * See [ApplicationFlag]s in the
 * [Discord Developer Documentation](https://discord.com/developers/docs/resources/application#application-object-application-flags).
 */
public sealed class ApplicationFlag(
    /**
     * The position of the bit that is set in this [ApplicationFlag]. This is always in 0..30.
     */
    public val shift: Int,
) {
    init {
        require(shift in 0..30) { """shift has to be in 0..30 but was $shift""" }
    }

    /**
     * The raw code used by Discord.
     */
    public val code: Int
        get() = 1 shl shift

    /**
     * Returns an instance of [ApplicationFlags] that has all bits set that are set in `this` and
     * [flag].
     */
    public operator fun plus(flag: ApplicationFlag): ApplicationFlags =
            ApplicationFlags(this.code or flag.code)

    /**
     * Returns an instance of [ApplicationFlags] that has all bits set that are set in `this` and
     * [flags].
     */
    public operator fun plus(flags: ApplicationFlags): ApplicationFlags =
            ApplicationFlags(this.code or flags.code)

    final override fun equals(other: Any?): Boolean = this === other ||
            (other is ApplicationFlag && this.shift == other.shift)

    final override fun hashCode(): Int = shift.hashCode()

    final override fun toString(): String =
            if (this is Unknown) "ApplicationFlag.Unknown(shift=$shift)"
            else "ApplicationFlag.${this::class.simpleName}"

    /**
     * An unknown [ApplicationFlag].
     *
     * This is used as a fallback for [ApplicationFlag]s that haven't been added to Kord yet.
     */
    public class Unknown internal constructor(
        shift: Int,
    ) : ApplicationFlag(shift)

    /**
     * Indicates if an app uses the Auto Moderation API.
     */
    public object ApplicationAutoModerationRuleCreateBadge : ApplicationFlag(6)

    /**
     * Intent required for bots in **100 or more servers** to receive `PresenceUpdate` events.
     */
    public object GatewayPresence : ApplicationFlag(12)

    /**
     * Intent required for bots in under 100 servers to receive `PresenceUpdate` events, found on
     * the **Bot** page in your app's settings.
     */
    public object GatewayPresenceLimited : ApplicationFlag(13)

    /**
     * Intent required for bots in **100 or more servers** to receive member-related events like
     * `GuildMemberAdd`.
     *
     * See the list of member-related events
     * [under `GUILD_MEMBERS`](https://discord.com/developers/docs/topics/gateway#list-of-intents).
     */
    public object GatewayGuildMembers : ApplicationFlag(14)

    /**
     * Intent required for bots in under 100 servers to receive member-related events like
     * `GuildMemberAdd`, found on the **Bot** page in your app's settings.
     *
     * See the list of member-related events
     * [under `GUILD_MEMBERS`](https://discord.com/developers/docs/topics/gateway#list-of-intents).
     */
    public object GatewayGuildMembersLimited : ApplicationFlag(15)

    /**
     * Indicates unusual growth of an app that prevents verification.
     */
    public object VerificationPendingGuildLimit : ApplicationFlag(16)

    /**
     * Indicates if an app is embedded within the Discord client (currently unavailable publicly).
     */
    public object Embedded : ApplicationFlag(17)

    /**
     * Intent required for bots in **100 or more servers** to receive
     * [message content](https://support-dev.discord.com/hc/en-us/articles/4404772028055).
     */
    public object GatewayMessageContent : ApplicationFlag(18)

    /**
     * Intent required for bots in under 100 servers to receive
     * [message content](https://support-dev.discord.com/hc/en-us/articles/4404772028055), found on the
     * **Bot** page in your app's settings.
     */
    public object GatewayMessageContentLimited : ApplicationFlag(19)

    /**
     * Indicates if an app has registered global application commands.
     */
    public object ApplicationCommandBadge : ApplicationFlag(23)

    public companion object {
        /**
         * A [List] of all known [ApplicationFlag]s.
         */
        public val entries: List by lazy(mode = PUBLICATION) {
            listOf(
                ApplicationAutoModerationRuleCreateBadge,
                GatewayPresence,
                GatewayPresenceLimited,
                GatewayGuildMembers,
                GatewayGuildMembersLimited,
                VerificationPendingGuildLimit,
                Embedded,
                GatewayMessageContent,
                GatewayMessageContentLimited,
                ApplicationCommandBadge,
            )
        }

        /**
         * Returns an instance of [ApplicationFlag] with [ApplicationFlag.shift] equal to the
         * specified [shift].
         *
         * @throws IllegalArgumentException if [shift] is not in 0..30.
         */
        public fun fromShift(shift: Int): ApplicationFlag = when (shift) {
            6 -> ApplicationAutoModerationRuleCreateBadge
            12 -> GatewayPresence
            13 -> GatewayPresenceLimited
            14 -> GatewayGuildMembers
            15 -> GatewayGuildMembersLimited
            16 -> VerificationPendingGuildLimit
            17 -> Embedded
            18 -> GatewayMessageContent
            19 -> GatewayMessageContentLimited
            23 -> ApplicationCommandBadge
            else -> Unknown(shift)
        }
    }
}

/**
 * A collection of multiple [ApplicationFlag]s.
 *
 * ## Creating an instance of [ApplicationFlags]
 *
 * You can create an instance of [ApplicationFlags] using the following methods:
 * ```kotlin
 * // from individual ApplicationFlags
 * val applicationFlags1 = ApplicationFlags(ApplicationFlag.ApplicationAutoModerationRuleCreateBadge, ApplicationFlag.GatewayPresence)
 *
 * // from an Iterable
 * val iterable: Iterable = TODO()
 * val applicationFlags2 = ApplicationFlags(iterable)
 *
 * // using a builder
 * val applicationFlags3 = ApplicationFlags {
 *     +applicationFlags2
 *     +ApplicationFlag.ApplicationAutoModerationRuleCreateBadge
 *     -ApplicationFlag.GatewayPresence
 * }
 * ```
 *
 * ## Modifying an existing instance of [ApplicationFlags]
 *
 * You can create a modified copy of an existing instance of [ApplicationFlags] using the [copy]
 * method:
 * ```kotlin
 * applicationFlags.copy {
 *     +ApplicationFlag.ApplicationAutoModerationRuleCreateBadge
 * }
 * ```
 *
 * ## Mathematical operators
 *
 * All [ApplicationFlags] objects can use `+`/`-` operators:
 * ```kotlin
 * val applicationFlags1 = applicationFlags + ApplicationFlag.ApplicationAutoModerationRuleCreateBadge
 * val applicationFlags2 = applicationFlags - ApplicationFlag.GatewayPresence
 * val applicationFlags3 = applicationFlags1 + applicationFlags2
 * ```
 *
 * ## Checking for [ApplicationFlag]s
 *
 * You can use the [contains] operator to check whether an instance of [ApplicationFlags] contains
 * specific [ApplicationFlag]s:
 * ```kotlin
 * val hasApplicationFlag = ApplicationFlag.ApplicationAutoModerationRuleCreateBadge in applicationFlags
 * val hasApplicationFlags = ApplicationFlags(ApplicationFlag.ApplicationAutoModerationRuleCreateBadge, ApplicationFlag.GatewayPresence) in applicationFlags
 * ```
 *
 * ## Unknown [ApplicationFlag]s
 *
 * Whenever [ApplicationFlag]s haven't been added to Kord yet, they will be deserialized as
 * instances of [ApplicationFlag.Unknown].
 *
 * You can also use [ApplicationFlag.fromShift] to check for [unknown][ApplicationFlag.Unknown]
 * [ApplicationFlag]s.
 * ```kotlin
 * val hasUnknownApplicationFlag = ApplicationFlag.fromShift(23) in applicationFlags
 * ```
 *
 * @see ApplicationFlag
 * @see ApplicationFlags.Builder
 */
@Serializable(with = ApplicationFlags.Serializer::class)
public class ApplicationFlags internal constructor(
    /**
     * The raw code used by Discord.
     */
    public val code: Int,
) {
    /**
     * A [Set] of all [ApplicationFlag]s contained in this instance of [ApplicationFlags].
     */
    public val values: Set
        get() = buildSet {
            var remaining = code
            var shift = 0
            while (remaining != 0) {
                if ((remaining and 1) != 0) add(ApplicationFlag.fromShift(shift))
                remaining = remaining ushr 1
                shift++
            }
        }

    /**
     * Checks if this instance of [ApplicationFlags] has all bits set that are set in [flag].
     */
    public operator fun contains(flag: ApplicationFlag): Boolean =
            this.code and flag.code == flag.code

    /**
     * Checks if this instance of [ApplicationFlags] has all bits set that are set in [flags].
     */
    public operator fun contains(flags: ApplicationFlags): Boolean =
            this.code and flags.code == flags.code

    /**
     * Returns an instance of [ApplicationFlags] that has all bits set that are set in `this` and
     * [flag].
     */
    public operator fun plus(flag: ApplicationFlag): ApplicationFlags =
            ApplicationFlags(this.code or flag.code)

    /**
     * Returns an instance of [ApplicationFlags] that has all bits set that are set in `this` and
     * [flags].
     */
    public operator fun plus(flags: ApplicationFlags): ApplicationFlags =
            ApplicationFlags(this.code or flags.code)

    /**
     * Returns an instance of [ApplicationFlags] that has all bits set that are set in `this` except
     * the bits that are set in [flag].
     */
    public operator fun minus(flag: ApplicationFlag): ApplicationFlags =
            ApplicationFlags(this.code and flag.code.inv())

    /**
     * Returns an instance of [ApplicationFlags] that has all bits set that are set in `this` except
     * the bits that are set in [flags].
     */
    public operator fun minus(flags: ApplicationFlags): ApplicationFlags =
            ApplicationFlags(this.code and flags.code.inv())

    /**
     * Returns a copy of this instance of [ApplicationFlags] modified with [builder].
     */
    public inline fun copy(builder: Builder.() -> Unit): ApplicationFlags {
        contract { callsInPlace(builder, EXACTLY_ONCE) }
        return Builder(code).apply(builder).build()
    }

    override fun equals(other: Any?): Boolean = this === other ||
            (other is ApplicationFlags && this.code == other.code)

    override fun hashCode(): Int = code.hashCode()

    override fun toString(): String = "ApplicationFlags(values=$values)"

    public class Builder(
        private var code: Int = 0,
    ) {
        /**
         * Sets all bits in the [Builder] that are set in this [ApplicationFlag].
         */
        public operator fun ApplicationFlag.unaryPlus() {
            [email protected] = [email protected] or this.code
        }

        /**
         * Sets all bits in the [Builder] that are set in this [ApplicationFlags].
         */
        public operator fun ApplicationFlags.unaryPlus() {
            [email protected] = [email protected] or this.code
        }

        /**
         * Unsets all bits in the [Builder] that are set in this [ApplicationFlag].
         */
        public operator fun ApplicationFlag.unaryMinus() {
            [email protected] = [email protected] and this.code.inv()
        }

        /**
         * Unsets all bits in the [Builder] that are set in this [ApplicationFlags].
         */
        public operator fun ApplicationFlags.unaryMinus() {
            [email protected] = [email protected] and this.code.inv()
        }

        /**
         * Returns an instance of [ApplicationFlags] that has all bits set that are currently set in
         * this [Builder].
         */
        public fun build(): ApplicationFlags = ApplicationFlags(code)
    }

    internal object Serializer : KSerializer {
        override val descriptor: SerialDescriptor =
                PrimitiveSerialDescriptor("dev.kord.common.entity.ApplicationFlags",
                PrimitiveKind.INT)

        private val `delegate`: KSerializer = Int.serializer()

        override fun serialize(encoder: Encoder, `value`: ApplicationFlags) {
            encoder.encodeSerializableValue(delegate, value.code)
        }

        override fun deserialize(decoder: Decoder): ApplicationFlags =
                ApplicationFlags(decoder.decodeSerializableValue(delegate))
    }
}

/**
 * Returns an instance of [ApplicationFlags] built with [ApplicationFlags.Builder].
 */
public inline fun ApplicationFlags(builder: ApplicationFlags.Builder.() -> Unit = {}):
        ApplicationFlags {
    contract { callsInPlace(builder, EXACTLY_ONCE) }
    return ApplicationFlags.Builder().apply(builder).build()
}

/**
 * Returns an instance of [ApplicationFlags] that has all bits set that are set in any element of
 * [flags].
 */
public fun ApplicationFlags(vararg flags: ApplicationFlag): ApplicationFlags = ApplicationFlags {
    flags.forEach { +it }
}

/**
 * Returns an instance of [ApplicationFlags] that has all bits set that are set in any element of
 * [flags].
 */
public fun ApplicationFlags(vararg flags: ApplicationFlags): ApplicationFlags = ApplicationFlags {
    flags.forEach { +it }
}

/**
 * Returns an instance of [ApplicationFlags] that has all bits set that are set in any element of
 * [flags].
 */
public fun ApplicationFlags(flags: Iterable): ApplicationFlags = ApplicationFlags {
    flags.forEach { +it }
}

/**
 * Returns an instance of [ApplicationFlags] that has all bits set that are set in any element of
 * [flags].
 */
@JvmName("ApplicationFlags0")
public fun ApplicationFlags(flags: Iterable): ApplicationFlags =
        ApplicationFlags {
    flags.forEach { +it }
}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy