Bump org.jetbrains.kotlinx:kotlinx-serialization-json from 1.8.1 to 1.10.0 by dependabot[bot] · Pull Request #620 · ShiftHackZ/Stable-Diffusion-Android
Bumps org.jetbrains.kotlinx:kotlinx-serialization-json from 1.8.1 to 1.10.0.
Release notes
Sourced from org.jetbrains.kotlinx:kotlinx-serialization-json's releases.
1.10.0
This release is based on Kotlin 2.3.0 and contains all of the changes from 1.10.0-RC. The only additional change is a fix for ProtoBuf packing of Kotlin unsigned types (#3079). Big thanks to KosmX for contributing the fix.
For your convenience, the changelog for 1.10.0-RC is duplicated below:
Stabilization of APIs
kotlinx-serialization 1.10 and subsequent releases will be focused on stabilization of existing APIs. The following APIs and configuration options are no longer experimental because they're widely used without any known major issues:
Jsonconfiguration options:decodeEnumsCaseInsensitive,allowTrailingComma,allowComments, andprettyPrintIndent. (#3100)@EncodeDefaultannotation and its modes. (#3106)JsonUnquotedLiteralconstructor function (#2900)JsonPrimitiveconstructor function overloads that accept unsigned types. (#3117)- JSON DSL functions on
JsonElementwithNothing?overloads. (#3117)Readiness for return value checker
Kotlin 2.3.0 introduces a new feature aimed at helping you to catch bugs related to the accidentally ignored return value of the function. kotlinx-serialization 1.10.0-RC code is fully marked for this feature, meaning that you can get warnings for unused function calls like
Json.encodeToString(...). To get the warnings, the feature has to be enabled in your project as described here.Polymorphism improvements
Polymorphic serialization received a couple of improvements in this release:
New
subclassesOfSealedutility to automatically register sealed subclasses serializers in polymorphic modules (#2201).Use it in your
SerializersModulewhen configuring a polymorphic hierarchy which contains both abstract and sealed classes. For example, when root of your hierarchy is aninterface, but most of your inheritors aresealedclasses. The new function will register all known sealed subclasses for you, so you don’t need to list them one by one. This makes writing yourSerializerModules much faster and simpler. Big thanks to Paul de Vrieze for contributing this feature.Class discriminator conflict check rework (#3105).
If a payload already contains a property with the same name as the configured discriminator (for example,
type), it is called a class discriminator conflict. To produce a correct output and allow more inputs to be deserialized at the same time, the following changes were made:
- Conflicts introduced by
JsonNamingStrategytransformations are now detected during serialization as well and will causeSerializationException. It also affects non-polymorphic classes.- Conflicts from
ClassDisciminatorMode.ALL_JSON_OBJECTSandSerializersModuleBuilder.polymorphicDefaultSerializerare also detected.- It is allowed to deserialize such a conflicting key for both sealed and open polymorphic hierarchies. Previously, it was possible in the sealed hierarchies alone due to missing assertion. See #1664 for details.
General improvements
- Add
.serialNametoMissingFieldExceptionfor clearer diagnostics. (#3114)- Generate unique
Automatic-Module-Nameentries for metadata JARs. (#3109)- Revised ProGuard rules and added R8 tests. (#3041)
- CBOR: Improved error message when a byte string/array type mismatch is encountered. (#3052)
Bugfixes
... (truncated)
Changelog
Sourced from org.jetbrains.kotlinx:kotlinx-serialization-json's changelog.
1.10.0 / 2026-01-21
This release is based on Kotlin 2.3.0 and contains all of the changes from 1.10.0-RC. The only additional change is a fix for ProtoBuf packing of Kotlin unsigned types (#3079). Big thanks to KosmX for contributing the fix.
For your convenience, the changelog for 1.10.0-RC is duplicated below:
Stabilization of APIs
kotlinx-serialization 1.10 and subsequent releases will be focused on stabilization of existing APIs. The following APIs and configuration options are no longer experimental because they're widely used without any known major issues:
Jsonconfiguration options:decodeEnumsCaseInsensitive,allowTrailingComma,allowComments, andprettyPrintIndent. (#3100)@EncodeDefaultannotation and its modes. (#3106)JsonUnquotedLiteralconstructor function (#2900)JsonPrimitiveconstructor function overloads that accept unsigned types. (#3117)- JSON DSL functions on
JsonElementwithNothing?overloads. (#3117)Readiness for return value checker
Kotlin 2.3.0 introduces a new feature aimed at helping you to catch bugs related to the accidentally ignored return value of the function. kotlinx-serialization 1.10.0-RC code is fully marked for this feature, meaning that you can get warnings for unused function calls like
Json.encodeToString(...). To get the warnings, the feature has to be enabled in your project as described here.Polymorphism improvements
Polymorphic serialization received a couple of improvements in this release:
New
subclassesOfSealedutility to automatically register sealed subclasses serializers in polymorphic modules (#2201). Use it in yourSerializersModulewhen configuring a polymorphic hierarchy which contains both abstract and sealed classes. For example, when root of your hierarchy is aninterface, but most of your inheritors aresealedclasses. The new function will register all known sealed subclasses for you, so you don’t need to list them one by one. This makes writing yourSerializerModules much faster and simpler. Big thanks to Paul de Vrieze for contributing this feature.Class discriminator conflict check rework (#3105). If a payload already contains a property with the same name as the configured discriminator (for example,
type), it is called a class discriminator conflict. To produce a correct output and allow more inputs to be deserialized at the same time, the following changes were made:
- Conflicts introduced by
JsonNamingStrategytransformations are now detected during serialization as well and will causeSerializationException. It also affects non-polymorphic classes.- Conflicts from
ClassDisciminatorMode.ALL_JSON_OBJECTSandSerializersModuleBuilder.polymorphicDefaultSerializerare also detected.- It is allowed to deserialize such a conflicting key for both sealed and open polymorphic hierarchies. Previously, it was possible in the sealed hierarchies alone due to missing assertion. See #1664 for details.
General improvements
... (truncated)
Commits
370c4e3Prepare 1.10.0 release (#3142)eaa4b0bMerge remote-tracking branch 'origin/master' into dev0311f16Fix ProtoBuf packing for kotlin unsigned types (#3079)a19df8cAdd a disclaimer to "Other community-supported formats" section and slightly ...2f8a874Add JSON5 to community-supported formats (#3134)975af2cActualize releasing process documente8be81fPrepare 1.10.0-RC releasee334d1c[CBOR] Fix various bugs in the decoder implementationd7ca108Merge remote-tracking branch 'origin/master' into deva5a3c97IR inliner: Enable intra-module mode for kotlinx.serialization (#3128)- Additional commits viewable in compare view
Dependabot will resolve any conflicts with this PR as long as you don't alter it yourself. You can also trigger a rebase manually by commenting @dependabot rebase.
Dependabot commands and options
You can trigger Dependabot actions by commenting on this PR:
@dependabot rebasewill rebase this PR@dependabot recreatewill recreate this PR, overwriting any edits that have been made to it@dependabot mergewill merge this PR after your CI passes on it@dependabot squash and mergewill squash and merge this PR after your CI passes on it@dependabot cancel mergewill cancel a previously requested merge and block automerging@dependabot reopenwill reopen this PR if it is closed@dependabot closewill close this PR and stop Dependabot recreating it. You can achieve the same result by closing it manually@dependabot show <dependency name> ignore conditionswill show all of the ignore conditions of the specified dependency@dependabot ignore this major versionwill close this PR and stop Dependabot creating any more for this major version (unless you reopen the PR or upgrade to it yourself)@dependabot ignore this minor versionwill close this PR and stop Dependabot creating any more for this minor version (unless you reopen the PR or upgrade to it yourself)@dependabot ignore this dependencywill close this PR and stop Dependabot creating any more for this dependency (unless you reopen the PR or upgrade to it yourself)