From 21311a61b3cb26ddbc30a3587588bacc6c2fb309 Mon Sep 17 00:00:00 2001 From: Leonid Startsev Date: Wed, 18 Sep 2024 18:50:06 +0200 Subject: [PATCH] Clarify example for SerializationException (#2806) --- .../src/kotlinx/serialization/SerializationExceptions.kt | 6 ++++-- 1 file changed, 4 insertions(+), 2 deletions(-) diff --git a/core/commonMain/src/kotlinx/serialization/SerializationExceptions.kt b/core/commonMain/src/kotlinx/serialization/SerializationExceptions.kt index 99f7d0a76a..5ca4805f08 100644 --- a/core/commonMain/src/kotlinx/serialization/SerializationExceptions.kt +++ b/core/commonMain/src/kotlinx/serialization/SerializationExceptions.kt @@ -22,12 +22,14 @@ import kotlinx.serialization.descriptors.* * It is also an established pattern to validate input in user's classes in the following manner: * ``` * @Serializable - * class Foo(...) { + * class User(val age: Int, val name: String) { * init { - * required(age > 0) { ... } + * require(age > 0) { ... } * require(name.isNotBlank()) { ... } * } * } + * + * Json.decodeFromString("""{"age": -100, "name": ""}""") // throws IllegalArgumentException from require() * ``` * While clearly being serialization error (when compromised data was deserialized), * Kotlin way is to throw `IllegalArgumentException` here instead of using library-specific `SerializationException`.