README.md

# yabko

[![](https://img.shields.io/hexpm/v/yabko.svg?style=flat)](https://hex.pm/packages/yabko)
[![](https://github.com/g-andrade/yabko/workflows/build/badge.svg)](https://github.com/g-andrade/yabko/actions?query=workflow%3Abuild)

`yabko` is an Erlang parser of Apple Property Lists (.plist)

### Decodable data types

-   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

### Example Usage

    $ 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.

------------------------------------------------------------------------

*Generated by EDoc*