Annotations.kt 3.1 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889909192939495
  1. /*
  2. * Copyright 2019-2021 Mamoe Technologies and contributors.
  3. *
  4. * 此源代码的使用受 GNU AFFERO GENERAL PUBLIC LICENSE version 3 许可证的约束, 可以在以下链接找到该许可证.
  5. * Use of this source code is governed by the GNU AGPLv3 license that can be found through the following link.
  6. *
  7. * https://github.com/mamoe/mirai/blob/dev/LICENSE
  8. */
  9. package net.mamoe.mirai.utils
  10. import kotlin.annotation.AnnotationTarget.*
  11. /**
  12. * 标记为一个仅供 Mirai 内部使用的 API.
  13. *
  14. * 这些 API 可能会在任意时刻更改, 且不会发布任何预警.
  15. * 非常不建议在发行版本中使用这些 API.
  16. */
  17. @Retention(AnnotationRetention.BINARY)
  18. @RequiresOptIn(level = RequiresOptIn.Level.ERROR)
  19. @Target(
  20. CLASS, TYPEALIAS, FUNCTION, PROPERTY, FIELD, CONSTRUCTOR,
  21. CLASS, FUNCTION, PROPERTY
  22. )
  23. @MustBeDocumented
  24. public annotation class MiraiInternalApi(
  25. public val message: String = ""
  26. )
  27. /**
  28. * 标记为一个仅供 Mirai 内部使用的 API.
  29. *
  30. * 这些 API 可能会在任意时刻更改, 且不会发布任何预警.
  31. * 非常不建议在发行版本中使用这些 API.
  32. */
  33. @Retention(AnnotationRetention.BINARY)
  34. @Target(FILE)
  35. @MiraiInternalApi
  36. public annotation class MiraiInternalFile
  37. /**
  38. * 标记这个类, 类型, 函数, 属性, 字段, 或构造器为实验性的 API.
  39. *
  40. * 这些 API 不具有稳定性, 且可能会在任意时刻更改.
  41. * 不建议在发行版本中使用这些 API.
  42. */
  43. @Retention(AnnotationRetention.BINARY)
  44. @RequiresOptIn(level = RequiresOptIn.Level.WARNING)
  45. @Target(CLASS, TYPEALIAS, FUNCTION, PROPERTY, FIELD, CONSTRUCTOR)
  46. @MustBeDocumented
  47. public annotation class MiraiExperimentalApi(
  48. public val message: String = ""
  49. )
  50. /**
  51. * 标记一个定义在使用上是稳定的 (如果没有特殊说明), 但只应该由 mirai 内部实现.
  52. *
  53. * 用户自行实现将可能造成对未来版本的不兼容, 因为新的抽象函数或属性会在未经警告的前提下添加. 自行实现还可能因 mirai 内部实现有部分硬编码成分而不兼容.
  54. *
  55. * @since 2.7
  56. */
  57. @Retention(AnnotationRetention.BINARY)
  58. @Target(CLASS, PROPERTY, FUNCTION)
  59. @MustBeDocumented
  60. public annotation class NotStableForInheritance(
  61. public val message: String = "This declaration is not stable for inheritance."
  62. )
  63. /**
  64. * 标记一个正计划在 [version] 版本时删除 (对外隐藏) 的 API.
  65. */
  66. @Target(CLASS, PROPERTY, FIELD, CONSTRUCTOR, FUNCTION, PROPERTY_GETTER, PROPERTY_SETTER, TYPEALIAS)
  67. @Retention(AnnotationRetention.SOURCE)
  68. @MustBeDocumented
  69. internal annotation class PlannedRemoval(val version: String)
  70. /**
  71. * 该注解仅用于测试 EventHandler
  72. *
  73. * 标注了此注解的意为像处理 java 方法那样处理 kotlin 方法
  74. */
  75. @Retention(AnnotationRetention.RUNTIME)
  76. internal annotation class EventListenerLikeJava
  77. /**
  78. * 表明这个 API 是为了让 Java 使用者调用更方便.
  79. *
  80. * 一般有一定的性能损失, 且不能在 JVM/Android 以外平台使用. 不要在 Kotlin 调用它.
  81. */
  82. @RequiresOptIn(level = RequiresOptIn.Level.ERROR)
  83. @Target(PROPERTY, FUNCTION, CLASS)
  84. internal annotation class JavaFriendlyAPI