Skip to content
This repository has been archived by the owner on Jun 18, 2019. It is now read-only.

Commit

Permalink
Remove underscores from switch case, and use do-catch pattern matchin…
Browse files Browse the repository at this point in the history
…g for slightly cleaner code
  • Loading branch information
Kevin Lundberg committed Jan 17, 2018
1 parent 58bbccf commit 5bacfa2
Show file tree
Hide file tree
Showing 2 changed files with 16 additions and 20 deletions.
34 changes: 15 additions & 19 deletions Sources/Unboxer.swift
Original file line number Diff line number Diff line change
Expand Up @@ -244,26 +244,22 @@ private extension Unboxer {

throw UnboxPathError.emptyKeyPath
}
} catch {
if case UnboxError.pathError(let pathError, let partialPath) = error {
switch pathError {
case .emptyKeyPath,
.invalidCollectionElementType(_),
.invalidDictionaryKey(_):
throw UnboxError.pathError(pathError, partialPath)
case .missingKey(_),
.invalidValue(_, _, _),
.invalidDictionaryKeyType(_),
.invalidDictionaryValue(_, _, _):
throw UnboxError.pathError(pathError, "\(path).\(partialPath)")
case let .invalidArrayElement(_, index, _):
throw UnboxError.pathError(pathError, "\(path).\(index).\(partialPath)")
}
} else if let pathError = error as? UnboxPathError {
throw UnboxError.pathError(pathError, path.description)
} catch UnboxError.pathError(let pathError, let partialPath) {
switch pathError {
case .emptyKeyPath,
.invalidCollectionElementType,
.invalidDictionaryKey:
throw UnboxError.pathError(pathError, partialPath)
case .missingKey,
.invalidValue,
.invalidDictionaryKeyType,
.invalidDictionaryValue:
throw UnboxError.pathError(pathError, "\(path).\(partialPath)")
case let .invalidArrayElement(_, index, _):
throw UnboxError.pathError(pathError, "\(path).\(index).\(partialPath)")
}

throw error
} catch let pathError as UnboxPathError {
throw UnboxError.pathError(pathError, path.description)
}
}

Expand Down
2 changes: 1 addition & 1 deletion Tests/UnboxTests/UnboxTests.swift
Original file line number Diff line number Diff line change
Expand Up @@ -1635,7 +1635,7 @@ class UnboxTests: XCTestCase {
_ = try unbox(dictionary: dictionary) as Model
XCTFail("Should have thrown")
} catch {
XCTAssertEqual("\(error)", "[UnboxError] An error occurred while unboxing path \"array\": Invalid array element ([:]) at index 0.")
XCTAssertEqual("\(error)", "[UnboxError] An error occurred while unboxing path \"array\": Invalid array element ([:]) at index 0, JSON type Dictionary<AnyHashable, Any> cannot be unboxed as String")
}
}

Expand Down

0 comments on commit 5bacfa2

Please sign in to comment.