KeyDecodingStrategy
public enum KeyDecodingStrategy
The strategy to use for automatically changing the value of keys before decoding.
-
Use the keys specified by each type. This is the default strategy.
Declaration
Swift
case useDefaultKeys
-
Convert from “snake_case_keys” to “camelCaseKeys” before attempting to match a key with the one specified by each type.
The conversion to upper case uses
Locale.system
, also known as the ICU “root” locale. This means the result is consistent regardless of the current user’s locale and language preferences.Converting from snake case to camel case:
- Capitalizes the word starting after each
_
- Removes all
_
- Preserves starting and ending
_
(as these are often used to indicate private variables or other metadata). For example,one_two_three
becomesoneTwoThree
._one_two_three_
becomes_oneTwoThree_
.
Note
Using a key decoding strategy has a nominal performance cost, as each string key has to be inspected for the_
character.Declaration
Swift
case convertFromSnakeCase
- Capitalizes the word starting after each
-
Provide a custom conversion from the key in the encoded Dictionary to the keys specified by the decoded types. The full path to the current decoding position is provided for context (in case you need to locate this key within the payload). The returned key is used in place of the last component in the coding path before decoding. If the result of the conversion is a duplicate key, then only one value will be present in the container for the type to decode from.
Declaration
Swift
case custom((_ codingPath: [CodingKey]) -> CodingKey)