|
@@ -0,0 +1,732 @@
|
|
|
+//
|
|
|
+// Operators.swift
|
|
|
+// ObjectMapper
|
|
|
+//
|
|
|
+// Created by Tristan Himmelman on 2014-10-09.
|
|
|
+//
|
|
|
+// The MIT License (MIT)
|
|
|
+//
|
|
|
+// Copyright (c) 2014-2015 Hearst
|
|
|
+//
|
|
|
+// Permission is hereby granted, free of charge, to any person obtaining a copy
|
|
|
+// of this software and associated documentation files (the "Software"), to deal
|
|
|
+// in the Software without restriction, including without limitation the rights
|
|
|
+// to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
|
|
|
+// copies of the Software, and to permit persons to whom the Software is
|
|
|
+// furnished to do so, subject to the following conditions:
|
|
|
+//
|
|
|
+// The above copyright notice and this permission notice shall be included in
|
|
|
+// all copies or substantial portions of the Software.
|
|
|
+//
|
|
|
+// THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
|
|
|
+// IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
|
|
|
+// FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
|
|
|
+// AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
|
|
|
+// LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
|
|
|
+// OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN
|
|
|
+// THE SOFTWARE.
|
|
|
+
|
|
|
+/**
|
|
|
+* This file defines a new operator which is used to create a mapping between an object and a JSON key value.
|
|
|
+* There is an overloaded operator definition for each type of object that is supported in ObjectMapper.
|
|
|
+* This provides a way to add custom logic to handle specific types of objects
|
|
|
+*/
|
|
|
+
|
|
|
+infix operator <- {}
|
|
|
+
|
|
|
+// MARK:- Objects with Basic types
|
|
|
+
|
|
|
+/// Object of Basic type
|
|
|
+public func <- <T>(inout left: T, right: Map) {
|
|
|
+ switch right.mappingType {
|
|
|
+ case .FromJSON:
|
|
|
+ FromJSON.basicType(&left, object: right.value())
|
|
|
+ case .ToJSON:
|
|
|
+ ToJSON.basicType(left, map: right)
|
|
|
+ }
|
|
|
+}
|
|
|
+
|
|
|
+/// Optional object of basic type
|
|
|
+public func <- <T>(inout left: T?, right: Map) {
|
|
|
+ switch right.mappingType {
|
|
|
+ case .FromJSON:
|
|
|
+ FromJSON.optionalBasicType(&left, object: right.value())
|
|
|
+ case .ToJSON:
|
|
|
+ ToJSON.optionalBasicType(left, map: right)
|
|
|
+ }
|
|
|
+}
|
|
|
+
|
|
|
+/// Implicitly unwrapped optional object of basic type
|
|
|
+public func <- <T>(inout left: T!, right: Map) {
|
|
|
+ switch right.mappingType {
|
|
|
+ case .FromJSON:
|
|
|
+ FromJSON.optionalBasicType(&left, object: right.value())
|
|
|
+ case .ToJSON:
|
|
|
+ ToJSON.optionalBasicType(left, map: right)
|
|
|
+ }
|
|
|
+}
|
|
|
+
|
|
|
+// MARK:- Raw Representable types
|
|
|
+
|
|
|
+/// Object of Raw Representable type
|
|
|
+public func <- <T: RawRepresentable>(inout left: T, right: Map) {
|
|
|
+ left <- (right, EnumTransform())
|
|
|
+}
|
|
|
+
|
|
|
+/// Optional Object of Raw Representable type
|
|
|
+public func <- <T: RawRepresentable>(inout left: T?, right: Map) {
|
|
|
+ left <- (right, EnumTransform())
|
|
|
+}
|
|
|
+
|
|
|
+/// Implicitly Unwrapped Optional Object of Raw Representable type
|
|
|
+public func <- <T: RawRepresentable>(inout left: T!, right: Map) {
|
|
|
+ left <- (right, EnumTransform())
|
|
|
+}
|
|
|
+
|
|
|
+// MARK:- Arrays of Raw Representable type
|
|
|
+
|
|
|
+/// Array of Raw Representable object
|
|
|
+public func <- <T: RawRepresentable>(inout left: [T], right: Map) {
|
|
|
+ left <- (right, EnumTransform())
|
|
|
+}
|
|
|
+
|
|
|
+/// Array of Raw Representable object
|
|
|
+public func <- <T: RawRepresentable>(inout left: [T]?, right: Map) {
|
|
|
+ left <- (right, EnumTransform())
|
|
|
+}
|
|
|
+
|
|
|
+/// Array of Raw Representable object
|
|
|
+public func <- <T: RawRepresentable>(inout left: [T]!, right: Map) {
|
|
|
+ left <- (right, EnumTransform())
|
|
|
+}
|
|
|
+
|
|
|
+// MARK:- Dictionaries of Raw Representable type
|
|
|
+
|
|
|
+/// Dictionary of Raw Representable object
|
|
|
+public func <- <T: RawRepresentable>(inout left: [String: T], right: Map) {
|
|
|
+ left <- (right, EnumTransform())
|
|
|
+}
|
|
|
+
|
|
|
+/// Dictionary of Raw Representable object
|
|
|
+public func <- <T: RawRepresentable>(inout left: [String: T]?, right: Map) {
|
|
|
+ left <- (right, EnumTransform())
|
|
|
+}
|
|
|
+
|
|
|
+/// Dictionary of Raw Representable object
|
|
|
+public func <- <T: RawRepresentable>(inout left: [String: T]!, right: Map) {
|
|
|
+ left <- (right, EnumTransform())
|
|
|
+}
|
|
|
+
|
|
|
+// MARK:- Transforms
|
|
|
+
|
|
|
+/// Object of Basic type with Transform
|
|
|
+public func <- <Transform: TransformType>(inout left: Transform.Object, right: (Map, Transform)) {
|
|
|
+ let (map, transform) = right
|
|
|
+ switch map.mappingType {
|
|
|
+ case .FromJSON:
|
|
|
+ let value = transform.transformFromJSON(map.currentValue)
|
|
|
+ FromJSON.basicType(&left, object: value)
|
|
|
+ case .ToJSON:
|
|
|
+ let value: Transform.JSON? = transform.transformToJSON(left)
|
|
|
+ ToJSON.optionalBasicType(value, map: map)
|
|
|
+ }
|
|
|
+}
|
|
|
+
|
|
|
+/// Optional object of basic type with Transform
|
|
|
+public func <- <Transform: TransformType>(inout left: Transform.Object?, right: (Map, Transform)) {
|
|
|
+ let (map, transform) = right
|
|
|
+ switch map.mappingType {
|
|
|
+ case .FromJSON:
|
|
|
+ let value = transform.transformFromJSON(map.currentValue)
|
|
|
+ FromJSON.optionalBasicType(&left, object: value)
|
|
|
+ case .ToJSON:
|
|
|
+ let value: Transform.JSON? = transform.transformToJSON(left)
|
|
|
+ ToJSON.optionalBasicType(value, map: map)
|
|
|
+ }
|
|
|
+}
|
|
|
+
|
|
|
+/// Implicitly unwrapped optional object of basic type with Transform
|
|
|
+public func <- <Transform: TransformType>(inout left: Transform.Object!, right: (Map, Transform)) {
|
|
|
+ let (map, transform) = right
|
|
|
+ switch map.mappingType {
|
|
|
+ case .FromJSON:
|
|
|
+ let value = transform.transformFromJSON(map.currentValue)
|
|
|
+ FromJSON.optionalBasicType(&left, object: value)
|
|
|
+ case .ToJSON:
|
|
|
+ let value: Transform.JSON? = transform.transformToJSON(left)
|
|
|
+ ToJSON.optionalBasicType(value, map: map)
|
|
|
+ }
|
|
|
+}
|
|
|
+
|
|
|
+/// Array of Basic type with Transform
|
|
|
+public func <- <Transform: TransformType>(inout left: [Transform.Object], right: (Map, Transform)) {
|
|
|
+ let (map, transform) = right
|
|
|
+ switch map.mappingType {
|
|
|
+ case .FromJSON:
|
|
|
+ let values = fromJSONArrayWithTransform(map.currentValue, transform: transform)
|
|
|
+ FromJSON.basicType(&left, object: values)
|
|
|
+ case .ToJSON:
|
|
|
+ let values = toJSONArrayWithTransform(left, transform: transform)
|
|
|
+ ToJSON.optionalBasicType(values, map: map)
|
|
|
+ }
|
|
|
+}
|
|
|
+
|
|
|
+/// Optional array of Basic type with Transform
|
|
|
+public func <- <Transform: TransformType>(inout left: [Transform.Object]?, right: (Map, Transform)) {
|
|
|
+ let (map, transform) = right
|
|
|
+ switch map.mappingType {
|
|
|
+ case .FromJSON:
|
|
|
+ let values = fromJSONArrayWithTransform(map.currentValue, transform: transform)
|
|
|
+ FromJSON.optionalBasicType(&left, object: values)
|
|
|
+ case .ToJSON:
|
|
|
+ let values = toJSONArrayWithTransform(left, transform: transform)
|
|
|
+ ToJSON.optionalBasicType(values, map: map)
|
|
|
+ }
|
|
|
+}
|
|
|
+
|
|
|
+/// Implicitly unwrapped optional array of Basic type with Transform
|
|
|
+public func <- <Transform: TransformType>(inout left: [Transform.Object]!, right: (Map, Transform)) {
|
|
|
+ let (map, transform) = right
|
|
|
+ switch map.mappingType {
|
|
|
+ case .FromJSON:
|
|
|
+ let values = fromJSONArrayWithTransform(map.currentValue, transform: transform)
|
|
|
+ FromJSON.optionalBasicType(&left, object: values)
|
|
|
+ case .ToJSON:
|
|
|
+ let values = toJSONArrayWithTransform(left, transform: transform)
|
|
|
+ ToJSON.optionalBasicType(values, map: map)
|
|
|
+ }
|
|
|
+}
|
|
|
+
|
|
|
+/// Dictionary of Basic type with Transform
|
|
|
+public func <- <Transform: TransformType>(inout left: [String: Transform.Object], right: (Map, Transform)) {
|
|
|
+ let (map, transform) = right
|
|
|
+ switch map.mappingType {
|
|
|
+ case .FromJSON:
|
|
|
+ let values = fromJSONDictionaryWithTransform(map.currentValue, transform: transform)
|
|
|
+ FromJSON.basicType(&left, object: values)
|
|
|
+ case .ToJSON:
|
|
|
+ let values = toJSONDictionaryWithTransform(left, transform: transform)
|
|
|
+ ToJSON.optionalBasicType(values, map: map)
|
|
|
+ }
|
|
|
+}
|
|
|
+
|
|
|
+/// Optional dictionary of Basic type with Transform
|
|
|
+public func <- <Transform: TransformType>(inout left: [String: Transform.Object]?, right: (Map, Transform)) {
|
|
|
+ let (map, transform) = right
|
|
|
+ switch map.mappingType {
|
|
|
+ case .FromJSON:
|
|
|
+ let values = fromJSONDictionaryWithTransform(map.currentValue, transform: transform)
|
|
|
+ FromJSON.optionalBasicType(&left, object: values)
|
|
|
+ case .ToJSON:
|
|
|
+ let values = toJSONDictionaryWithTransform(left, transform: transform)
|
|
|
+ ToJSON.optionalBasicType(values, map: map)
|
|
|
+ }
|
|
|
+}
|
|
|
+
|
|
|
+/// Implicitly unwrapped optional dictionary of Basic type with Transform
|
|
|
+public func <- <Transform: TransformType>(inout left: [String: Transform.Object]!, right: (Map, Transform)) {
|
|
|
+ let (map, transform) = right
|
|
|
+ switch map.mappingType {
|
|
|
+ case .FromJSON:
|
|
|
+ let values = fromJSONDictionaryWithTransform(map.currentValue, transform: transform)
|
|
|
+ FromJSON.optionalBasicType(&left, object: values)
|
|
|
+ case .ToJSON:
|
|
|
+ let values = toJSONDictionaryWithTransform(left, transform: transform)
|
|
|
+ ToJSON.optionalBasicType(values, map: map)
|
|
|
+ }
|
|
|
+}
|
|
|
+
|
|
|
+private func fromJSONArrayWithTransform<Transform: TransformType>(input: AnyObject?, transform: Transform) -> [Transform.Object]? {
|
|
|
+ if let values = input as? [AnyObject] {
|
|
|
+ return values.flatMap { value in
|
|
|
+ return transform.transformFromJSON(value)
|
|
|
+ }
|
|
|
+ } else {
|
|
|
+ return nil
|
|
|
+ }
|
|
|
+}
|
|
|
+
|
|
|
+private func fromJSONDictionaryWithTransform<Transform: TransformType>(input: AnyObject?, transform: Transform) -> [String: Transform.Object]? {
|
|
|
+ if let values = input as? [String: AnyObject] {
|
|
|
+ return values.filterMap { value in
|
|
|
+ return transform.transformFromJSON(value)
|
|
|
+ }
|
|
|
+ } else {
|
|
|
+ return nil
|
|
|
+ }
|
|
|
+}
|
|
|
+
|
|
|
+private func toJSONArrayWithTransform<Transform: TransformType>(input: [Transform.Object]?, transform: Transform) -> [Transform.JSON]? {
|
|
|
+ return input?.flatMap { value in
|
|
|
+ return transform.transformToJSON(value)
|
|
|
+ }
|
|
|
+}
|
|
|
+
|
|
|
+private func toJSONDictionaryWithTransform<Transform: TransformType>(input: [String: Transform.Object]?, transform: Transform) -> [String: Transform.JSON]? {
|
|
|
+ return input?.filterMap { value in
|
|
|
+ return transform.transformToJSON(value)
|
|
|
+ }
|
|
|
+}
|
|
|
+
|
|
|
+// MARK:- Mappable Objects - <T: Mappable>
|
|
|
+
|
|
|
+/// Object conforming to Mappable
|
|
|
+public func <- <T: Mappable>(inout left: T, right: Map) {
|
|
|
+ switch right.mappingType {
|
|
|
+ case .FromJSON:
|
|
|
+ FromJSON.object(&left, map: right)
|
|
|
+ case .ToJSON:
|
|
|
+ ToJSON.object(left, map: right)
|
|
|
+ }
|
|
|
+}
|
|
|
+
|
|
|
+/// Optional Mappable objects
|
|
|
+public func <- <T: Mappable>(inout left: T?, right: Map) {
|
|
|
+ switch right.mappingType {
|
|
|
+ case .FromJSON:
|
|
|
+ FromJSON.optionalObject(&left, map: right)
|
|
|
+ case .ToJSON:
|
|
|
+ ToJSON.optionalObject(left, map: right)
|
|
|
+ }
|
|
|
+}
|
|
|
+
|
|
|
+/// Implicitly unwrapped optional Mappable objects
|
|
|
+public func <- <T: Mappable>(inout left: T!, right: Map) {
|
|
|
+ switch right.mappingType {
|
|
|
+ case .FromJSON:
|
|
|
+ FromJSON.optionalObject(&left, map: right)
|
|
|
+ case .ToJSON:
|
|
|
+ ToJSON.optionalObject(left, map: right)
|
|
|
+ }
|
|
|
+}
|
|
|
+
|
|
|
+// MARK:- Transforms of Mappable Objects - <T: Mappable>
|
|
|
+
|
|
|
+/// Object conforming to Mappable that have transforms
|
|
|
+public func <- <Transform: TransformType where Transform.Object: Mappable>(inout left: Transform.Object, right: (Map, Transform)) {
|
|
|
+ let (map, transform) = right
|
|
|
+ switch map.mappingType {
|
|
|
+ case .FromJSON:
|
|
|
+ let value: Transform.Object? = transform.transformFromJSON(map.currentValue)
|
|
|
+ FromJSON.basicType(&left, object: value)
|
|
|
+ case .ToJSON:
|
|
|
+ let value: Transform.JSON? = transform.transformToJSON(left)
|
|
|
+ ToJSON.optionalBasicType(value, map: map)
|
|
|
+ }
|
|
|
+}
|
|
|
+
|
|
|
+/// Optional Mappable objects that have transforms
|
|
|
+public func <- <Transform: TransformType where Transform.Object: Mappable>(inout left: Transform.Object?, right: (Map, Transform)) {
|
|
|
+ let (map, transform) = right
|
|
|
+ switch map.mappingType {
|
|
|
+ case .FromJSON:
|
|
|
+ let value: Transform.Object? = transform.transformFromJSON(map.currentValue)
|
|
|
+ FromJSON.optionalBasicType(&left, object: value)
|
|
|
+ case .ToJSON:
|
|
|
+ let value: Transform.JSON? = transform.transformToJSON(left)
|
|
|
+ ToJSON.optionalBasicType(value, map: map)
|
|
|
+ }
|
|
|
+}
|
|
|
+
|
|
|
+/// Implicitly unwrapped optional Mappable objects that have transforms
|
|
|
+public func <- <Transform: TransformType where Transform.Object: Mappable>(inout left: Transform.Object!, right: (Map, Transform)) {
|
|
|
+ let (map, transform) = right
|
|
|
+ switch map.mappingType {
|
|
|
+ case .FromJSON:
|
|
|
+ let value: Transform.Object? = transform.transformFromJSON(map.currentValue)
|
|
|
+ FromJSON.optionalBasicType(&left, object: value)
|
|
|
+ case .ToJSON:
|
|
|
+ let value: Transform.JSON? = transform.transformToJSON(left)
|
|
|
+ ToJSON.optionalBasicType(value, map: map)
|
|
|
+ }
|
|
|
+}
|
|
|
+
|
|
|
+// MARK:- Dictionary of Mappable objects - Dictionary<String, T: Mappable>
|
|
|
+
|
|
|
+/// Dictionary of Mappable objects <String, T: Mappable>
|
|
|
+public func <- <T: Mappable>(inout left: Dictionary<String, T>, right: Map) {
|
|
|
+ switch right.mappingType {
|
|
|
+ case .FromJSON:
|
|
|
+ FromJSON.objectDictionary(&left, map: right)
|
|
|
+ case .ToJSON:
|
|
|
+ ToJSON.objectDictionary(left, map: right)
|
|
|
+ }
|
|
|
+}
|
|
|
+
|
|
|
+/// Optional Dictionary of Mappable object <String, T: Mappable>
|
|
|
+public func <- <T: Mappable>(inout left: Dictionary<String, T>?, right: Map) {
|
|
|
+ switch right.mappingType {
|
|
|
+ case .FromJSON:
|
|
|
+ FromJSON.optionalObjectDictionary(&left, map: right)
|
|
|
+ case .ToJSON:
|
|
|
+ ToJSON.optionalObjectDictionary(left, map: right)
|
|
|
+ }
|
|
|
+}
|
|
|
+
|
|
|
+/// Implicitly unwrapped Optional Dictionary of Mappable object <String, T: Mappable>
|
|
|
+public func <- <T: Mappable>(inout left: Dictionary<String, T>!, right: Map) {
|
|
|
+ switch right.mappingType {
|
|
|
+ case .FromJSON:
|
|
|
+ FromJSON.optionalObjectDictionary(&left, map: right)
|
|
|
+ case .ToJSON:
|
|
|
+ ToJSON.optionalObjectDictionary(left, map: right)
|
|
|
+ }
|
|
|
+}
|
|
|
+
|
|
|
+/// Dictionary of Mappable objects <String, T: Mappable>
|
|
|
+public func <- <T: Mappable>(inout left: Dictionary<String, [T]>, right: Map) {
|
|
|
+ switch right.mappingType {
|
|
|
+ case .FromJSON:
|
|
|
+ FromJSON.objectDictionaryOfArrays(&left, map: right)
|
|
|
+ case .ToJSON:
|
|
|
+ ToJSON.objectDictionaryOfArrays(left, map: right)
|
|
|
+ }
|
|
|
+}
|
|
|
+
|
|
|
+/// Optional Dictionary of Mappable object <String, T: Mappable>
|
|
|
+public func <- <T: Mappable>(inout left: Dictionary<String, [T]>?, right: Map) {
|
|
|
+ switch right.mappingType {
|
|
|
+ case .FromJSON:
|
|
|
+ FromJSON.optionalObjectDictionaryOfArrays(&left, map: right)
|
|
|
+ case .ToJSON:
|
|
|
+ ToJSON.optionalObjectDictionaryOfArrays(left, map: right)
|
|
|
+ }
|
|
|
+}
|
|
|
+
|
|
|
+/// Implicitly unwrapped Optional Dictionary of Mappable object <String, T: Mappable>
|
|
|
+public func <- <T: Mappable>(inout left: Dictionary<String, [T]>!, right: Map) {
|
|
|
+ switch right.mappingType {
|
|
|
+ case .FromJSON:
|
|
|
+ FromJSON.optionalObjectDictionaryOfArrays(&left, map: right)
|
|
|
+ case .ToJSON:
|
|
|
+ ToJSON.optionalObjectDictionaryOfArrays(left, map: right)
|
|
|
+ }
|
|
|
+}
|
|
|
+
|
|
|
+// MARK:- Dictionary of Mappable objects with a transform - Dictionary<String, T: Mappable>
|
|
|
+
|
|
|
+/// Dictionary of Mappable objects <String, T: Mappable> with a transform
|
|
|
+public func <- <Transform: TransformType where Transform.Object: Mappable>(inout left: Dictionary<String, Transform.Object>, right: (Map, Transform)) {
|
|
|
+ let (map, transform) = right
|
|
|
+ if let object = map.currentValue as? [String : AnyObject] where map.mappingType == .FromJSON {
|
|
|
+ let value = fromJSONDictionaryWithTransform(object, transform: transform) ?? left
|
|
|
+ FromJSON.basicType(&left, object: value)
|
|
|
+ } else if map.mappingType == .ToJSON {
|
|
|
+ let value = toJSONDictionaryWithTransform(left, transform: transform)
|
|
|
+ ToJSON.basicType(value, map: map)
|
|
|
+ }
|
|
|
+}
|
|
|
+
|
|
|
+/// Optional Dictionary of Mappable object <String, T: Mappable> with a transform
|
|
|
+public func <- <Transform: TransformType where Transform.Object: Mappable>(inout left: Dictionary<String, Transform.Object>?, right: (Map, Transform)) {
|
|
|
+ let (map, transform) = right
|
|
|
+ if let object = map.currentValue as? [String : AnyObject] where map.mappingType == .FromJSON {
|
|
|
+ let value = fromJSONDictionaryWithTransform(object, transform: transform) ?? left
|
|
|
+ FromJSON.optionalBasicType(&left, object: value)
|
|
|
+ } else if map.mappingType == .ToJSON {
|
|
|
+ let value = toJSONDictionaryWithTransform(left, transform: transform)
|
|
|
+ ToJSON.optionalBasicType(value, map: map)
|
|
|
+ }
|
|
|
+}
|
|
|
+
|
|
|
+/// Implicitly unwrapped Optional Dictionary of Mappable object <String, T: Mappable> with a transform
|
|
|
+public func <- <Transform: TransformType where Transform.Object: Mappable>(inout left: Dictionary<String, Transform.Object>!, right: (Map, Transform)) {
|
|
|
+ let (map, transform) = right
|
|
|
+ if let dictionary = map.currentValue as? [String : AnyObject] where map.mappingType == .FromJSON {
|
|
|
+ let transformedDictionary = fromJSONDictionaryWithTransform(dictionary, transform: transform) ?? left
|
|
|
+ FromJSON.optionalBasicType(&left, object: transformedDictionary)
|
|
|
+ } else if map.mappingType == .ToJSON {
|
|
|
+ let value = toJSONDictionaryWithTransform(left, transform: transform)
|
|
|
+ ToJSON.optionalBasicType(value, map: map)
|
|
|
+ }
|
|
|
+}
|
|
|
+
|
|
|
+/// Dictionary of Mappable objects <String, T: Mappable> with a transform
|
|
|
+public func <- <Transform: TransformType where Transform.Object: Mappable>(inout left: Dictionary<String, [Transform.Object]>, right: (Map, Transform)) {
|
|
|
+ let (map, transform) = right
|
|
|
+ if let dictionary = map.currentValue as? [String : [AnyObject]] where map.mappingType == .FromJSON {
|
|
|
+ let transformedDictionary = dictionary.map { (key, values) in
|
|
|
+ return (key, fromJSONArrayWithTransform(values, transform: transform) ?? left[key] ?? [])
|
|
|
+ }
|
|
|
+ FromJSON.basicType(&left, object: transformedDictionary)
|
|
|
+ } else if map.mappingType == .ToJSON {
|
|
|
+ let transformedDictionary = left.map { (key, values) in
|
|
|
+ return (key, toJSONArrayWithTransform(values, transform: transform) ?? [])
|
|
|
+ }
|
|
|
+
|
|
|
+ ToJSON.basicType(transformedDictionary, map: map)
|
|
|
+ }
|
|
|
+}
|
|
|
+
|
|
|
+/// Optional Dictionary of Mappable object <String, T: Mappable> with a transform
|
|
|
+public func <- <Transform: TransformType where Transform.Object: Mappable>(inout left: Dictionary<String, [Transform.Object]>?, right: (Map, Transform)) {
|
|
|
+ let (map, transform) = right
|
|
|
+ if let dictionary = map.currentValue as? [String : [AnyObject]] where map.mappingType == .FromJSON {
|
|
|
+ let transformedDictionary = dictionary.map { (key, values) in
|
|
|
+ return (key, fromJSONArrayWithTransform(values, transform: transform) ?? left?[key] ?? [])
|
|
|
+ }
|
|
|
+ FromJSON.optionalBasicType(&left, object: transformedDictionary)
|
|
|
+ } else if map.mappingType == .ToJSON {
|
|
|
+ let transformedDictionary = left?.map { (key, values) in
|
|
|
+ return (key, toJSONArrayWithTransform(values, transform: transform) ?? [])
|
|
|
+ }
|
|
|
+
|
|
|
+ ToJSON.optionalBasicType(transformedDictionary, map: map)
|
|
|
+ }
|
|
|
+}
|
|
|
+
|
|
|
+/// Implicitly unwrapped Optional Dictionary of Mappable object <String, T: Mappable> with a transform
|
|
|
+public func <- <Transform: TransformType where Transform.Object: Mappable>(inout left: Dictionary<String, [Transform.Object]>!, right: (Map, Transform)) {
|
|
|
+ let (map, transform) = right
|
|
|
+ if let dictionary = map.currentValue as? [String : [AnyObject]] where map.mappingType == .FromJSON {
|
|
|
+ let transformedDictionary = dictionary.map { (key, values) in
|
|
|
+ return (key, fromJSONArrayWithTransform(values, transform: transform) ?? left?[key] ?? [])
|
|
|
+ }
|
|
|
+ FromJSON.optionalBasicType(&left, object: transformedDictionary)
|
|
|
+ } else if map.mappingType == .ToJSON {
|
|
|
+ let transformedDictionary = left?.map { (key, values) in
|
|
|
+ return (key, toJSONArrayWithTransform(values, transform: transform) ?? [])
|
|
|
+ }
|
|
|
+
|
|
|
+ ToJSON.optionalBasicType(transformedDictionary, map: map)
|
|
|
+ }
|
|
|
+}
|
|
|
+
|
|
|
+// MARK:- Array of Mappable objects - Array<T: Mappable>
|
|
|
+
|
|
|
+/// Array of Mappable objects
|
|
|
+public func <- <T: Mappable>(inout left: Array<T>, right: Map) {
|
|
|
+ switch right.mappingType {
|
|
|
+ case .FromJSON:
|
|
|
+ FromJSON.objectArray(&left, map: right)
|
|
|
+ case .ToJSON:
|
|
|
+ ToJSON.objectArray(left, map: right)
|
|
|
+ }
|
|
|
+}
|
|
|
+
|
|
|
+/// Optional array of Mappable objects
|
|
|
+public func <- <T: Mappable>(inout left: Array<T>?, right: Map) {
|
|
|
+ switch right.mappingType {
|
|
|
+ case .FromJSON:
|
|
|
+ FromJSON.optionalObjectArray(&left, map: right)
|
|
|
+ case .ToJSON:
|
|
|
+ ToJSON.optionalObjectArray(left, map: right)
|
|
|
+ }
|
|
|
+}
|
|
|
+
|
|
|
+/// Implicitly unwrapped Optional array of Mappable objects
|
|
|
+public func <- <T: Mappable>(inout left: Array<T>!, right: Map) {
|
|
|
+ switch right.mappingType {
|
|
|
+ case .FromJSON:
|
|
|
+ FromJSON.optionalObjectArray(&left, map: right)
|
|
|
+ case .ToJSON:
|
|
|
+ ToJSON.optionalObjectArray(left, map: right)
|
|
|
+ }
|
|
|
+}
|
|
|
+
|
|
|
+// MARK:- Array of Mappable objects with transforms - Array<T: Mappable>
|
|
|
+
|
|
|
+/// Array of Mappable objects
|
|
|
+public func <- <Transform: TransformType where Transform.Object: Mappable>(inout left: Array<Transform.Object>, right: (Map, Transform)) {
|
|
|
+ let (map, transform) = right
|
|
|
+ switch map.mappingType {
|
|
|
+ case .FromJSON:
|
|
|
+ if let transformedValues = fromJSONArrayWithTransform(map.currentValue, transform: transform) {
|
|
|
+ FromJSON.basicType(&left, object: transformedValues)
|
|
|
+ }
|
|
|
+ case .ToJSON:
|
|
|
+ let transformedValues = toJSONArrayWithTransform(left, transform: transform)
|
|
|
+ ToJSON.optionalBasicType(transformedValues, map: map)
|
|
|
+ }
|
|
|
+}
|
|
|
+
|
|
|
+/// Optional array of Mappable objects
|
|
|
+public func <- <Transform: TransformType where Transform.Object: Mappable>(inout left: Array<Transform.Object>?, right: (Map, Transform)) {
|
|
|
+ let (map, transform) = right
|
|
|
+ switch map.mappingType {
|
|
|
+ case .FromJSON:
|
|
|
+ let transformedValues = fromJSONArrayWithTransform(map.currentValue, transform: transform)
|
|
|
+ FromJSON.optionalBasicType(&left, object: transformedValues)
|
|
|
+ case .ToJSON:
|
|
|
+ let transformedValues = toJSONArrayWithTransform(left, transform: transform)
|
|
|
+ ToJSON.optionalBasicType(transformedValues, map: map)
|
|
|
+ }
|
|
|
+}
|
|
|
+
|
|
|
+/// Implicitly unwrapped Optional array of Mappable objects
|
|
|
+public func <- <Transform: TransformType where Transform.Object: Mappable>(inout left: Array<Transform.Object>!, right: (Map, Transform)) {
|
|
|
+ let (map, transform) = right
|
|
|
+ switch map.mappingType {
|
|
|
+ case .FromJSON:
|
|
|
+ let transformedValues = fromJSONArrayWithTransform(map.currentValue, transform: transform)
|
|
|
+ FromJSON.optionalBasicType(&left, object: transformedValues)
|
|
|
+ case .ToJSON:
|
|
|
+ let transformedValues = toJSONArrayWithTransform(left, transform: transform)
|
|
|
+ ToJSON.optionalBasicType(transformedValues, map: map)
|
|
|
+ }
|
|
|
+}
|
|
|
+
|
|
|
+// MARK:- Array of Array of Mappable objects - Array<Array<T: Mappable>>
|
|
|
+
|
|
|
+/// Array of Array Mappable objects
|
|
|
+public func <- <T: Mappable>(inout left: Array<Array<T>>, right: Map) {
|
|
|
+ switch right.mappingType {
|
|
|
+ case .FromJSON:
|
|
|
+ FromJSON.twoDimensionalObjectArray(&left, map: right)
|
|
|
+ case .ToJSON:
|
|
|
+ ToJSON.twoDimensionalObjectArray(left, map: right)
|
|
|
+ }
|
|
|
+}
|
|
|
+
|
|
|
+/// Optional array of Mappable objects
|
|
|
+public func <- <T: Mappable>(inout left:Array<Array<T>>?, right: Map) {
|
|
|
+ switch right.mappingType {
|
|
|
+ case .FromJSON:
|
|
|
+ FromJSON.optionalTwoDimensionalObjectArray(&left, map: right)
|
|
|
+ case .ToJSON:
|
|
|
+ ToJSON.optionalTwoDimensionalObjectArray(left, map: right)
|
|
|
+ }
|
|
|
+}
|
|
|
+
|
|
|
+/// Implicitly unwrapped Optional array of Mappable objects
|
|
|
+public func <- <T: Mappable>(inout left: Array<Array<T>>!, right: Map) {
|
|
|
+ switch right.mappingType {
|
|
|
+ case .FromJSON:
|
|
|
+ FromJSON.optionalTwoDimensionalObjectArray(&left, map: right)
|
|
|
+ case .ToJSON:
|
|
|
+ ToJSON.optionalTwoDimensionalObjectArray(left, map: right)
|
|
|
+ }
|
|
|
+}
|
|
|
+
|
|
|
+// MARK:- Array of Array of Mappable objects - Array<Array<T: Mappable>> with transforms
|
|
|
+
|
|
|
+/// Array of Array Mappable objects with transform
|
|
|
+public func <- <Transform: TransformType where Transform.Object: Mappable>(inout left: Array<Array<Transform.Object>>, right: (Map, Transform)) {
|
|
|
+ let (map, transform) = right
|
|
|
+ if let original2DArray = map.currentValue as? [[AnyObject]] where map.mappingType == .FromJSON {
|
|
|
+ let transformed2DArray = original2DArray.flatMap { values in
|
|
|
+ fromJSONArrayWithTransform(values, transform: transform)
|
|
|
+ }
|
|
|
+ FromJSON.basicType(&left, object: transformed2DArray)
|
|
|
+ } else if map.mappingType == .ToJSON {
|
|
|
+ let transformed2DArray = left.flatMap { values in
|
|
|
+ toJSONArrayWithTransform(values, transform: transform)
|
|
|
+ }
|
|
|
+ ToJSON.basicType(transformed2DArray, map: map)
|
|
|
+ }
|
|
|
+}
|
|
|
+
|
|
|
+/// Optional array of Mappable objects with transform
|
|
|
+public func <- <Transform: TransformType where Transform.Object: Mappable>(inout left:Array<Array<Transform.Object>>?, right: (Map, Transform)) {
|
|
|
+ let (map, transform) = right
|
|
|
+ if let original2DArray = map.currentValue as? [[AnyObject]] where map.mappingType == .FromJSON {
|
|
|
+ let transformed2DArray = original2DArray.flatMap { values in
|
|
|
+ fromJSONArrayWithTransform(values, transform: transform)
|
|
|
+ }
|
|
|
+ FromJSON.optionalBasicType(&left, object: transformed2DArray)
|
|
|
+ } else if map.mappingType == .ToJSON {
|
|
|
+ let transformed2DArray = left?.flatMap { values in
|
|
|
+ toJSONArrayWithTransform(values, transform: transform)
|
|
|
+ }
|
|
|
+ ToJSON.optionalBasicType(transformed2DArray, map: map)
|
|
|
+ }
|
|
|
+}
|
|
|
+
|
|
|
+/// Implicitly unwrapped Optional array of Mappable objects with transform
|
|
|
+public func <- <Transform: TransformType where Transform.Object: Mappable>(inout left: Array<Array<Transform.Object>>!, right: (Map, Transform)) {
|
|
|
+ let (map, transform) = right
|
|
|
+ if let original2DArray = map.currentValue as? [[AnyObject]] where map.mappingType == .FromJSON {
|
|
|
+ let transformed2DArray = original2DArray.flatMap { values in
|
|
|
+ fromJSONArrayWithTransform(values, transform: transform)
|
|
|
+ }
|
|
|
+ FromJSON.optionalBasicType(&left, object: transformed2DArray)
|
|
|
+ } else if map.mappingType == .ToJSON {
|
|
|
+ let transformed2DArray = left?.flatMap { values in
|
|
|
+ toJSONArrayWithTransform(values, transform: transform)
|
|
|
+ }
|
|
|
+ ToJSON.optionalBasicType(transformed2DArray, map: map)
|
|
|
+ }
|
|
|
+}
|
|
|
+
|
|
|
+// MARK:- Set of Mappable objects - Set<T: Mappable where T: Hashable>
|
|
|
+
|
|
|
+/// Set of Mappable objects
|
|
|
+public func <- <T: Mappable where T: Hashable>(inout left: Set<T>, right: Map) {
|
|
|
+ switch right.mappingType {
|
|
|
+ case .FromJSON:
|
|
|
+ FromJSON.objectSet(&left, map: right)
|
|
|
+ case .ToJSON:
|
|
|
+ ToJSON.objectSet(left, map: right)
|
|
|
+ }
|
|
|
+}
|
|
|
+
|
|
|
+
|
|
|
+/// Optional Set of Mappable objects
|
|
|
+public func <- <T: Mappable where T: Hashable>(inout left: Set<T>?, right: Map) {
|
|
|
+ switch right.mappingType {
|
|
|
+ case .FromJSON:
|
|
|
+ FromJSON.optionalObjectSet(&left, map: right)
|
|
|
+ case .ToJSON:
|
|
|
+ ToJSON.optionalObjectSet(left, map: right)
|
|
|
+ }
|
|
|
+}
|
|
|
+
|
|
|
+/// Implicitly unwrapped Optional Set of Mappable objects
|
|
|
+public func <- <T: Mappable where T: Hashable>(inout left: Set<T>!, right: Map) {
|
|
|
+ switch right.mappingType {
|
|
|
+ case .FromJSON:
|
|
|
+ FromJSON.optionalObjectSet(&left, map: right)
|
|
|
+ case .ToJSON:
|
|
|
+ ToJSON.optionalObjectSet(left, map: right)
|
|
|
+ }
|
|
|
+}
|
|
|
+
|
|
|
+
|
|
|
+// MARK:- Set of Mappable objects with a transform - Set<T: Mappable where T: Hashable>
|
|
|
+
|
|
|
+/// Set of Mappable objects with transform
|
|
|
+public func <- <Transform: TransformType where Transform.Object: protocol<Hashable, Mappable>>(inout left: Set<Transform.Object>, right: (Map, Transform)) {
|
|
|
+ let (map, transform) = right
|
|
|
+ switch map.mappingType {
|
|
|
+ case .FromJSON:
|
|
|
+ if let transformedValues = fromJSONArrayWithTransform(map.currentValue, transform: transform) {
|
|
|
+ FromJSON.basicType(&left, object: Set(transformedValues))
|
|
|
+ }
|
|
|
+ case .ToJSON:
|
|
|
+ let transformedValues = toJSONArrayWithTransform(Array(left), transform: transform)
|
|
|
+ ToJSON.optionalBasicType(transformedValues, map: map)
|
|
|
+ }
|
|
|
+}
|
|
|
+
|
|
|
+
|
|
|
+/// Optional Set of Mappable objects with transform
|
|
|
+public func <- <Transform: TransformType where Transform.Object: protocol<Hashable, Mappable>>(inout left: Set<Transform.Object>?, right: (Map, Transform)) {
|
|
|
+ let (map, transform) = right
|
|
|
+ switch map.mappingType {
|
|
|
+ case .FromJSON:
|
|
|
+ if let transformedValues = fromJSONArrayWithTransform(map.currentValue, transform: transform) {
|
|
|
+ FromJSON.basicType(&left, object: Set(transformedValues))
|
|
|
+ }
|
|
|
+ case .ToJSON:
|
|
|
+ if let values = left {
|
|
|
+ let transformedValues = toJSONArrayWithTransform(Array(values), transform: transform)
|
|
|
+ ToJSON.optionalBasicType(transformedValues, map: map)
|
|
|
+ }
|
|
|
+ }
|
|
|
+}
|
|
|
+
|
|
|
+/// Implicitly unwrapped Optional set of Mappable objects with transform
|
|
|
+public func <- <Transform: TransformType where Transform.Object: protocol<Hashable, Mappable>>(inout left: Set<Transform.Object>!, right: (Map, Transform)) {
|
|
|
+ let (map, transform) = right
|
|
|
+ switch map.mappingType {
|
|
|
+ case .FromJSON:
|
|
|
+ if let transformedValues = fromJSONArrayWithTransform(map.currentValue, transform: transform) {
|
|
|
+ FromJSON.basicType(&left, object: Set(transformedValues))
|
|
|
+ }
|
|
|
+ case .ToJSON:
|
|
|
+ if let values = left {
|
|
|
+ let transformedValues = toJSONArrayWithTransform(Array(values), transform: transform)
|
|
|
+ ToJSON.optionalBasicType(transformedValues, map: map)
|
|
|
+ }
|
|
|
+ }
|
|
|
+}
|