Protocols
The following protocols are available globally.
- 
                  
                  A protocol that your Codable type can adopt, in order to supply values for fields that are validated during decoding. The TypeDecoder operates by constructing a ‘dummy’ instance of a type, via the init(from: Decoder)initializer. As there is no real data to be decoded, dummy values (such as0and"") are provided. This may cause an initializer that requires specific valid values to fail.To enable such a type to work with TypeDecoder, define an extension that conforms the type to the ValidKeyedCodingValueProviderprotocol. ThevalidCodingValue(forKey:)function should return a valid value for fields that requires validation.Usage Example:
 See morepublic class YoungAdult: Codable { let name: String let age: Int required public init(from decoder: Decoder) throws { let container = try decoder.container(keyedBy: CodingKeys.self) self.name = try container.decode(String.self, forKey: CodingKeys.name) self.age = try container.decode(Int.self, forKey: CodingKeys.age) // Validate the age field guard self.age >= 18, self.age <= 30 else { throw DecodingError.dataCorrupted(DecodingError.Context(codingPath: [], debugDescription: "Age is outside the permitted range")) } } } // Provide a value for 'age' which is within the acceptable range extension YoungAdult: ValidKeyedCodingValueProvider { public static func validCodingValue(forKey key: CodingKey) -> Any? { switch key.stringValue { case self.CodingKeys.age.stringValue: return 20 default: // For any fields that are not validated, you may return nil. // The TypeDecoder will use a standard dummy value. return nil } } }DeclarationSwift public protocol ValidKeyedCodingValueProvider
- 
                  
                  A protocol that your Codable type can adopt, in order to supply a valid value during decoding. This protocol is suitable for types that are represented by a single encoded value, such as an enum. The TypeDecoder operates by constructing a ‘dummy’ instance of a type, via the init(from: Decoder)initializer. As there is no real data to be decoded, a dummy value (such as0or"") is provided. This may cause an initializer that requires a specific valid value to fail.To enable such a type to work with TypeDecoder, define an extension that conforms the type to the ValidSingleCodingValueProviderprotocol. ThevalidCodingValue()function should return a valid encoded representation of that type.Usage Example:
 See morepublic enum Fruit: String, Codable { case apple, banana, orange, pear } // Provide an acceptable value during decoding extension Fruit: ValidSingleCodingValueProvider { public static func validCodingValue() -> Any? { // Returns the string "apple" return self.apple.rawValue } }DeclarationSwift public protocol ValidSingleCodingValueProvider
 View on GitHub
            View on GitHub
           Protocols  Reference
      Protocols  Reference