# yabko #
[![Build Status](https://travis-ci.org/g-andrade/yabko.png?branch=master)](https://travis-ci.org/g-andrade/yabko)
[![Hex pm](http://img.shields.io/hexpm/v/yabko.svg?style=flat)](https://hex.pm/packages/yabko)
### <a name="yabko_-_Erlang_parser_of_Apple_Property_Lists_(.plist)">yabko - Erlang parser of Apple Property Lists (.plist)</a> ###
#### <a name="Decodable_data_types">Decodable data types</a> ####
* boolean
* null (binary format)
* integer
* real
* date
* uid
* binary data
* latin1 text (binary format)
* utf16 text (binary format)
* utf8 text (XML format)
* arrays
* sets (binary format; untested)
* dictionaries
#### <a name="Requirements">Requirements</a> ####
* Erlang/OTP 17
* rebar3
#### <a name="Example_Usage">Example Usage</a> ####
```
$ make console
```
```erlang
% 1> {ok, XmlEncoded} = file:read_file("test_data/doc_example.xml").
{ok,<<"<?xml version=\"1.0\" encoding=\"UTF-8\"?>\n<!DOCTYPE plist "...>>}
% 2> yabko:decode(XmlEncoded).
{ok,#{<<"Codswallop ratio">> => 3.14159265359,<<"Date of birth">> => {{1973,2,12},{9,18,0}},<<"Name">> => <<"John Doé"/utf8>>,<<"Owned foobars">> => 4321,<<"Pocket contents">> =>
[42,<<"Lorem ipsum">>,{uid,123456}]}}
% 3> {ok, BinEncoded} = file:read_file("test_data/float32.bin.plist").
{ok,<<98,112,108,105,115,116,48,48,209,1,2,89,101,116,99,
32,101,116,99,46,46,34,63,128,0,0,8,...>>}
% 4> yabko:decode(BinEncoded)
{ok,#{<<"etc etc..">> => 1.0}}
```
Yabko is an independent project and has not been authorized, sponsored, or otherwise approved by Apple Inc.
## Modules ##
<table width="100%" border="0" summary="list of modules">
<tr><td><a href="https://github.com/g-andrade/yabko/blob/master/doc/yabko.md" class="module">yabko</a></td></tr></table>