Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/freesuraj/bulldog
Simple yet powerful json parser for iOS and Mac
https://github.com/freesuraj/bulldog
json json-parser swift swiftyjson
Last synced: 6 days ago
JSON representation
Simple yet powerful json parser for iOS and Mac
- Host: GitHub
- URL: https://github.com/freesuraj/bulldog
- Owner: freesuraj
- License: mit
- Created: 2016-11-19T01:26:37.000Z (over 8 years ago)
- Default Branch: master
- Last Pushed: 2019-04-03T06:20:20.000Z (almost 6 years ago)
- Last Synced: 2025-02-02T15:25:29.891Z (19 days ago)
- Topics: json, json-parser, swift, swiftyjson
- Language: Swift
- Size: 182 KB
- Stars: 5
- Watchers: 2
- Forks: 1
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
- Changelog: CHANGELOG.md
- Contributing: CONTRIBUTING.md
- License: LICENSE
Awesome Lists containing this project
README
data:image/s3,"s3://crabby-images/32670/326703f3e029d55bebe3d4329d97f2ac8c69e061" alt="Bulldog: Json Parser"
[data:image/s3,"s3://crabby-images/06218/062186f8f861731603c650d58ecb5d2670bb725f" alt="Build Status"](https://travis-ci.org/freesuraj/Bulldog)
[data:image/s3,"s3://crabby-images/6baf3/6baf3cd391c2a924e6d0e5bead215b6c8618a58c" alt="Coverage Status"](https://coveralls.io/github/freesuraj/Bulldog?branch=master)
[data:image/s3,"s3://crabby-images/d5757/d57574dad6c87fc49cc3905d34b43c06e6f6e2b9" alt="codecov"](https://codecov.io/gh/freesuraj/Bulldog)
[data:image/s3,"s3://crabby-images/2f52a/2f52a556211f384f75927e7f1124be9000d50c6b" alt="Code Climate"](https://codeclimate.com/github/freesuraj/Bulldog)
[data:image/s3,"s3://crabby-images/35309/353094db5847c60c614d454bc84559106f5ce975" alt="codebeat badge"](https://codebeat.co/projects/github-com-freesuraj-bulldog)
[data:image/s3,"s3://crabby-images/2d8f1/2d8f14e47487c3061958b958b5a04f52309e42f7" alt="Issue Count"](https://codeclimate.com/github/freesuraj/Bulldog)
[data:image/s3,"s3://crabby-images/e2404/e2404a1f65756af209cb26ed61176891c53f31e4" alt="CocoaPods Compatible"](http://cocoadocs.org/docsets/Bulldog/)
[data:image/s3,"s3://crabby-images/2d180/2d1801ae7805458b91e18c5ac4d97d63da45be3a" alt="Carthage Compatible"](https://github.com/Carthage/Carthage)
[data:image/s3,"s3://crabby-images/09d6d/09d6de2b9d8ef19d96d5752fa142ab1d489f1cc6" alt="Platform"](http://cocoadocs.org/docsets/Bulldog)
[data:image/s3,"s3://crabby-images/2c0c4/2c0c4a7eb160286ba25247ed9708d34a4e5132dc" alt="Twitter"](http://twitter.com/iosCook)
[data:image/s3,"s3://crabby-images/95be7/95be7a308e475e8765c18f92b9f2627ae6e91797" alt="GitHub forks"](https://github.com/freesuraj/bulldog)
[data:image/s3,"s3://crabby-images/43003/43003cb8bf695c1aca0d9a1b963df03ad55d17ce" alt="GitHub stars"](https://github.com/freesuraj/bulldog)# Bulldog
Bulldog is a super-fast json parser that will keep attacking until it gets the value you desire, or you give up. Just like a bulldog.## Why Bulldog?
- ✅ Super-light
- ✅ Easily extendible
- ✅ Can easily traverse through path of a json object to get the final value while ignoring the type of intermediate objects
- ✅ Utilises the apple's JSONSerialization underneath
- ✅ Well tested with 100% test coverage## Example Usage
Let's suppose we want to parse the following JSON object
### response.json
```
{
"id":123,
"first_name":"Conor",
"last_name":"McGregor",
"age":28,
"height": 171,
"weight":70.5,
"fights":[
{
"id":"UFC 205",
"opponent":"Eddie Alvarez",
"venue":"New York",
"win":true
},
{
"id":"UFC 202",
"opponent":"Nate Diaz",
"venue":"Las Vegas",
"win":true
},
{
"id":"UFC 196",
"opponent":"Nate Diaz",
"venue":"Las Vegas",
"win":false
}
]
}
```### parser.swift
Now to parse the above json file,
```swift
let json: Any = ... // Json from network
let bulldog = Bulldog(json: json)
let name = bulldog.string("first_name") + " " + bulldog.string("last_name") // Conor McGregorlet height = bulldog.int("height") // 171
let weight = bulldog.double("weight") // 70.5// Get first opponent of his fights
let firstOpponent = bulldog.string("fights", 0, "opponent") // Eddie Alvarez
// Get fights array
let fights = bulldog.array("fights") // Returns array of fights// Return the first fight dictionary
let firstFight = bulldog.dictionary("fights", 0) // Returns first fight dictionary// Check if first fight was a win
let isWin = Bulldog(json: fights[0]).boolean("win") // Returns true```
## Installation
### Carthage
Bulldog is available through [Carthage](https://github.com/Carthage/Carthage). To install
it, simply add the following line to your Cartfile:```ruby
git "freesuraj/Bulldog"
```### Cocoapods
Add the following line to your Podfile:
```ruby
pod 'Bulldog'
```
### Manual
Perhaps the easiest way to use is to just copy the file [Bulldog.swift](https://github.com/freesuraj/Bulldog/blob/master/Source/Bulldog.swift) and put it in your project. That's it !!## Example
Please check the [BulldogTests.swift](https://github.com/freesuraj/Bulldog/blob/master/Tests/BulldogTests.swift) file for all possilbe use cases
## About
[data:image/s3,"s3://crabby-images/e79f3/e79f32f2af5bfefb54a57ffa7850f45cf1c5922e" alt="GitHub followers"](https://github.com/freesuraj)
If you found this little tool useful, I'd love to hear about it. You can also follow me on Twitter at [@iosCook](https://twitter.com/ioscook)
## License
Bulldog is available under the MIT license. See the LICENSE file for more info.