Skip to content

Commit

Permalink
Add @MustBeDocumented to certain annotations
Browse files Browse the repository at this point in the history
Only annotations that affect code generation/add declarations on class-level were selected

Other annotations that affect mainly properties (SerialName,Required,Transient) are left for further consideration.

File-level annotations like `@UseSerializers` likely shouldn't be documented.

See #2056
  • Loading branch information
sandwwraith committed Oct 13, 2022
1 parent 182c53e commit cb6bcbb
Showing 1 changed file with 5 additions and 0 deletions.
5 changes: 5 additions & 0 deletions core/commonMain/src/kotlinx/serialization/Annotations.kt
Original file line number Diff line number Diff line change
Expand Up @@ -67,6 +67,7 @@ import kotlin.reflect.*
* @see UseSerializers
* @see Serializer
*/
@MustBeDocumented
@Target(AnnotationTarget.PROPERTY, AnnotationTarget.CLASS, AnnotationTarget.TYPE)
//@Retention(AnnotationRetention.RUNTIME) // Runtime is the default retention, also see KT-41082
public annotation class Serializable(
Expand Down Expand Up @@ -97,6 +98,7 @@ public annotation class Serializable(
* @see UseSerializers
* @see Serializer
*/
@MustBeDocumented
@Target(AnnotationTarget.ANNOTATION_CLASS)
//@Retention(AnnotationRetention.RUNTIME) // Runtime is the default retention, also see KT-41082
@ExperimentalSerializationApi
Expand All @@ -111,6 +113,7 @@ public annotation class MetaSerializable
* Changes may include additional constraints on classes and objects marked with this annotation,
* behavioural changes and even serialized shape of the class.
*/
@MustBeDocumented
@Target(AnnotationTarget.CLASS)
@Retention(AnnotationRetention.BINARY)
@ExperimentalSerializationApi
Expand Down Expand Up @@ -217,6 +220,7 @@ public annotation class EncodeDefault(val mode: Mode = Mode.ALWAYS) {
* Keep in mind that Kotlin compiler prioritizes [function parameter target][AnnotationTarget.VALUE_PARAMETER] over [property target][AnnotationTarget.PROPERTY],
* so serial info annotations used on constructor-parameters-as-properties without explicit declaration-site or use-site target are not preserved.
*/
@MustBeDocumented
@Target(AnnotationTarget.ANNOTATION_CLASS)
@Retention(AnnotationRetention.BINARY)
@ExperimentalSerializationApi
Expand Down Expand Up @@ -254,6 +258,7 @@ public annotation class SerialInfo
* fun foo(): Int = Derived.serializer().descriptor.annotations.filterIsInstance<A>().single().value
* ```
*/
@MustBeDocumented
@Target(AnnotationTarget.ANNOTATION_CLASS)
@Retention(AnnotationRetention.BINARY)
@ExperimentalSerializationApi
Expand Down

0 comments on commit cb6bcbb

Please sign in to comment.