Skip to content

Commit

Permalink
Partially complete new README
Browse files Browse the repository at this point in the history
  • Loading branch information
isair committed Apr 18, 2016
1 parent 087baa0 commit bad687f
Showing 1 changed file with 39 additions and 150 deletions.
189 changes: 39 additions & 150 deletions README.md
Original file line number Diff line number Diff line change
@@ -1,187 +1,76 @@

#JSONHelper [![CocoaPods](https://img.shields.io/cocoapods/l/JSONHelper.svg)](https://github.com/isair/JSONHelper/blob/master/LICENSE) ![CocoaPods](https://img.shields.io/cocoapods/p/JSONHelper.svg)

# JSONHelper
[![CocoaPods](https://img.shields.io/cocoapods/l/JSONHelper.svg)](https://github.com/isair/JSONHelper/blob/master/LICENSE)
![CocoaPods](https://img.shields.io/cocoapods/p/JSONHelper.svg)
[![Build Status](https://travis-ci.org/isair/JSONHelper.svg?branch=master)](https://travis-ci.org/isair/JSONHelper)
[![CocoaPods](https://img.shields.io/cocoapods/v/JSONHelper.svg)](https://cocoapods.org/pods/JSONHelper)
[![Stories in Ready](https://badge.waffle.io/isair/JSONHelper.png?label=ready&title=Ready)](https://waffle.io/isair/JSONHelper)

[![Gratipay](https://img.shields.io/gratipay/bsencan91.svg)](https://gratipay.com/bsencan91/)
[![Gitter](https://badges.gitter.im/JOIN CHAT.svg)](https://gitter.im/isair/JSONHelper?utm_source=badge&utm_medium=badge&utm_campaign=pr-badge&utm_content=badge)

Lightning fast JSON deserialization for iOS, OS X, and tvOS written in Swift. A much improved version, and a rewrite, is under development in branch [dev-2.0.0](https://github.com/isair/JSONHelper/tree/dev-2.0.0) and any contributions to it are welcome as my personal time is currently very limited.

##Table of Contents

1. [Introduction](#introduction)
2. [Installation](#installation)
3. [Operator List](#operator-list)
4. [Simple Tutorial](#simple-tutorial)
5. [Assigning Default Values](#assigning-default-values)
6. [NSDate and NSURL Deserialization](#nsdate-and-nsurl-deserialization)
7. [JSON String Deserialization](#json-string-deserialization)

##Introduction

JSONHelper is a library written to make sure that deserializing data obtained from an API is as easy as possible. It doesn't depend on any networking libraries, and works equally well with any of them.
Convert anything into anything in one line; hex strings into UIColor/NSColor, JSON strings into class instances, numbers to strings, etc, anything you can make sense of!

__Requires iOS 7 or later and Xcode 6.1+__
__Latest version requires iOS 8+ and Xcode 7.3+__

##Installation
## Table of Contents

###[Carthage](https://github.com/Carthage/Carthage#installing-carthage)
1. [Installation](#installation)
2. [The <-- Operator](#the-<---operator)
- [Overview](#overview)
- [Convertible Protocol](#convertible-protocol)
- [Deserializable Protocol](#deserializable-protocol)
- [Serializable Protocol](#serializable-protocol)
3. [JSON Deserialization Example](#simple-tutorial)

Add the following line to your [Cartfile](https://github.com/Carthage/Carthage/blob/master/Documentation/Artifacts.md#cartfile).

```
github "isair/JSONHelper"
```

Then do `carthage update`. After that, add the framework to your project.
## Installation

###[CocoaPods](https://github.com/CocoaPods/CocoaPods)
### [CocoaPods](https://github.com/CocoaPods/CocoaPods)

Add the following line in your `Podfile`.

```
pod "JSONHelper"
```

###Drag & Drop

You can also add [JSONHelper.swift](https://raw.githubusercontent.com/isair/JSONHelper/master/JSONHelper/JSONHelper.swift) directly into your project.

##Basic Tutorial

First of all I'm going to assume you use [AFNetworking](https://github.com/AFNetworking/AFNetworking) as your networking library; for simplicity. Let's say we have an endpoint at __http://yoursite.com/movies/__ which gives the following response when a simple __GET__ request is sent to it.

```json
{
"movies": [
{
"name": "Filth",
"release_date": "2014-05-30",
"cast": {
"Bruce": "James McAvoy",
"Lennox": "Jamie Bell"
}
},
{
"name": "American Psycho",
"release_date": "2000-04-14",
"cast": {
"Patrick Bateman": "Christian Bale",
"Timothy Bryce": "Justin Theroux"
}
}
]
}
```

From this response it is clear that we have a movie model similar to the implementation below.
### [Carthage](https://github.com/Carthage/Carthage#installing-carthage)

```swift
struct Movie {
var name: String?
var releaseDate: NSDate?
var cast: [String: String]?
}
```

We now have to make it extend the protocol __Deserializable__ and implement the __required init(data: [String: AnyObject])__ initializer and use our deserialization operator (`<--`) in it. The complete model should look like this:
Add the following line to your [Cartfile](https://github.com/Carthage/Carthage/blob/master/Documentation/Artifacts.md#cartfile).

```swift
struct Movie: Deserializable {
var name: String?
var releaseDate: NSDate?
var cast: [String: String]?

init(data: [String: AnyObject]) {
name <-- data["name"]
releaseDate <-- (data["release_date"], "yyyy-MM-dd") // Refer to the next section for more info.
cast <-- data["cast"]
}
}
```

And finally, requesting and deserializing the response from our endpoint becomes as easy as the following piece of code.

```swift
AFHTTPRequestOperationManager().GET(
"http://yoursite.com/movies/"
parameters: nil,
success: { operation, data in
var movies: [Movie]?
movies <-- data["movies"]

if let movies = movies {
// Response contained a movies array, and we deserialized it. Do what you want here.
} else {
// Server gave us a response but there was no "movies" key in it, so the movies variable
// is equal to nil. Do some error handling here.
}
},
failure: { operation, error in
// Handle error.
})
github "isair/JSONHelper"
```

##Assigning Default Values

You can easily assign default values to variables in cases where you want them to have a certain value when deserialization fails.

````swift
struct User: Deserializable {
var name = "Guest"

init(data: [String: AnyObject]) {
name <-- data["name"]
}
}
````
Then do `carthage update`. After that, add the framework to your project.

##NSDate and NSURL Deserialization
## The <-- Operator

NSURL deserialization works very much like a primitive type deserialization.
### Overview

````swift
let website: NSURL?
let imageURLs: [NSURL]?
The `<--` operator takes the value on its right hand side and tries to convert it into the type of the value on its left hand side. If the conversion fails, an error is thrown. If it's successful, the value of the left hand side variable is overwritten. It's chainable as well.

website <-- "http://mywebsite.com"
imageURLs <-- ["http://mywebsite.com/image.png", "http://mywebsite.com/anotherImage.png"]
````
If the right hand side value is nil, and the left hand side variable is an optional, then nil is assigned to it. When the left hand side is non-optional, in the case where the right hand side value is nil, the current value of the left hand side variable is left untouched.

NSDate deserialization however, requires a format to be provided most of the time.
Using this specification let's assume you have a dictionary response that you retrieved from some API with hex color strings in it, under the key `colors`, that you want to convert into an array of UIColor instances. Also, to fully use everything we know, let's also assume that we want to have a default value for our color array in case the value for the key we're looking for does not exist (is nil).

````swift
let meetingDate: NSDate?
let partyDates: [NSDate]?
```swift
var colors = [UIColor.blackColor()]
// Assume we have response { "colors": ["#fff"] }
try colors <-- response[colorsKey]
```

meetingDate <-- ("2014-09-18", "yyyy-MM-dd")
partyDates <-- (["2014-09-19", "2014-09-20"], "yyyy-MM-dd")
It's really that simple.

let myDayOff: NSDate?
myDayOff <-- 1414172803 // You can also use unix timestamps.
````
### Convertible Protocol

##JSON String Deserialization
// TODO

You can deserialize instances and arrays of instances directly from a JSON string as well. Here is a quick example.
### Deserializable Protocol

````swift
struct Person: Deserializable {
var name = ""
// TODO

init(data: [String: AnyObject]) {
name <-- data["name"]
}
}
### Serializable Protocol

let jsonString = "[{\"name\": \"Rocket Raccoon\"}, {\"name\": \"Groot\"}]"
var people = [Person]()
// TODO

people <-- jsonString
## JSON Deserialization Example

for person in people {
println(person.name)
}
````
// TODO

0 comments on commit bad687f

Please sign in to comment.