diff options
author | Evgeniy Khramtsov <ekhramtsov@process-one.net> | 2013-04-08 11:12:54 +0200 |
---|---|---|
committer | Christophe Romain <christophe.romain@process-one.net> | 2013-06-13 11:11:02 +0200 |
commit | 4d8f7706240a1603468968f47fc7b150b788d62f (patch) | |
tree | 92d55d789cc7ac979b3c9e161ffb7f908eba043a /tools/xmpp_codec.erl | |
parent | Fix Guide: ejabberd_service expects a shaper_rule, not a shaper (diff) |
Switch to rebar build tool
Use dynamic Rebar configuration
Make iconv dependency optional
Disable transient_supervisors compile option
Add hipe compilation support
Only compile ibrowse and lhttpc when needed
Make it possible to generate an OTP application release
Add --enable-debug compile option
Add --enable-all compiler option
Add --enable-tools configure option
Add --with-erlang configure option.
Add --enable-erlang-version-check configure option.
Add lager support
Improve the test suite
Diffstat (limited to 'tools/xmpp_codec.erl')
-rw-r--r-- | tools/xmpp_codec.erl | 10301 |
1 files changed, 10301 insertions, 0 deletions
diff --git a/tools/xmpp_codec.erl b/tools/xmpp_codec.erl new file mode 100644 index 000000000..37ea49dd8 --- /dev/null +++ b/tools/xmpp_codec.erl @@ -0,0 +1,10301 @@ +-module(xmpp_codec). + +-export([decode/1, encode/1]). + +decode({xmlel, _name, _attrs, _} = _el) -> + case {_name, xml:get_attr_s(<<"xmlns">>, _attrs)} of + {<<"delay">>, <<"urn:xmpp:delay">>} -> + decode_delay_delay(_el); + {<<"pubsub">>, + <<"http://jabber.org/protocol/pubsub">>} -> + decode_pubsub_pubsub(_el); + {<<"event">>, + <<"http://jabber.org/protocol/pubsub#event">>} -> + decode_pubsub_event_event(_el); + {<<"items">>, <<>>} -> decode_pubsub_items_items(_el); + {<<"item">>, <<>>} -> decode_pubsub_item_item(_el); + {<<"affiliation">>, <<>>} -> + decode_pubsub_affiliation_affiliation(_el); + {<<"subscription">>, <<>>} -> + decode_pubsub_subscription_subscription(_el); + {<<"x">>, <<"jabber:x:data">>} -> decode_xdata_x(_el); + {<<"field">>, <<>>} -> decode_xfield_field(_el); + {<<"vCard">>, <<"vcard-temp">>} -> + decode_vcard_vCard(_el); + {<<"KEY">>, <<>>} -> decode_vcard_key_KEY(_el); + {<<"SOUND">>, <<>>} -> decode_vcard_sound_SOUND(_el); + {<<"ORG">>, <<>>} -> decode_vcard_org_ORG(_el); + {<<"PHOTO">>, <<>>} -> decode_vcard_photo_PHOTO(_el); + {<<"LOGO">>, <<>>} -> decode_vcard_logo_LOGO(_el); + {<<"EXTVAL">>, <<>>} -> decode_vcard_extval_EXTVAL(_el); + {<<"BINVAL">>, <<>>} -> decode_vcard_binval_BINVAL(_el); + {<<"TYPE">>, <<>>} -> decode_vcard_type_TYPE(_el); + {<<"GEO">>, <<>>} -> decode_vcard_geo_GEO(_el); + {<<"EMAIL">>, <<>>} -> decode_vcard_email_EMAIL(_el); + {<<"TEL">>, <<>>} -> decode_vcard_tel_TEL(_el); + {<<"LABEL">>, <<>>} -> decode_vcard_label_LABEL(_el); + {<<"ADR">>, <<>>} -> decode_vcard_adr_ADR(_el); + {<<"N">>, <<>>} -> decode_vcard_name_N(_el); + {<<"stream:error">>, <<>>} -> + 'decode_stream_error_stream:error'(_el); + {<<"time">>, <<"urn:xmpp:time">>} -> + decode_time_time(_el); + {<<"ping">>, <<"urn:xmpp:ping">>} -> + decode_ping_ping(_el); + {<<"session">>, + <<"urn:ietf:params:xml:ns:xmpp-session">>} -> + decode_session_session(_el); + {<<"register">>, + <<"http://jabber.org/features/iq-register">>} -> + decode_register_register(_el); + {<<"c">>, <<"http://jabber.org/protocol/caps">>} -> + decode_caps_c(_el); + {<<"ack">>, <<"p1:ack">>} -> decode_p1_ack_ack(_el); + {<<"rebind">>, <<"p1:rebind">>} -> + decode_p1_rebind_rebind(_el); + {<<"push">>, <<"p1:push">>} -> decode_p1_push_push(_el); + {<<"stream:features">>, <<>>} -> + 'decode_stream_features_stream:features'(_el); + {<<"failure">>, + <<"urn:ietf:params:xml:ns:xmpp-tls">>} -> + decode_starttls_failure_failure(_el); + {<<"proceed">>, + <<"urn:ietf:params:xml:ns:xmpp-tls">>} -> + decode_starttls_proceed_proceed(_el); + {<<"starttls">>, + <<"urn:ietf:params:xml:ns:xmpp-tls">>} -> + decode_starttls_starttls(_el); + {<<"mechanisms">>, + <<"urn:ietf:params:xml:ns:xmpp-sasl">>} -> + decode_sasl_mechanisms_mechanisms(_el); + {<<"mechanism">>, <<>>} -> + decode_sasl_mechanism_mechanism(_el); + {<<"failure">>, + <<"urn:ietf:params:xml:ns:xmpp-sasl">>} -> + decode_sasl_failure_failure(_el); + {<<"success">>, + <<"urn:ietf:params:xml:ns:xmpp-sasl">>} -> + decode_sasl_success_success(_el); + {<<"response">>, + <<"urn:ietf:params:xml:ns:xmpp-sasl">>} -> + decode_sasl_response_response(_el); + {<<"challenge">>, + <<"urn:ietf:params:xml:ns:xmpp-sasl">>} -> + decode_sasl_challenge_challenge(_el); + {<<"abort">>, <<"urn:ietf:params:xml:ns:xmpp-sasl">>} -> + decode_sasl_abort_abort(_el); + {<<"auth">>, <<"urn:ietf:params:xml:ns:xmpp-sasl">>} -> + decode_sasl_auth_auth(_el); + {<<"bind">>, <<"urn:ietf:params:xml:ns:xmpp-bind">>} -> + decode_bind_bind(_el); + {<<"error">>, <<>>} -> decode_error_error(_el); + {<<"presence">>, <<>>} -> decode_presence_presence(_el); + {<<"message">>, <<>>} -> decode_message_message(_el); + {<<"iq">>, <<>>} -> decode_iq_iq(_el); + {<<"query">>, <<"http://jabber.org/protocol/stats">>} -> + decode_stats_query(_el); + {<<"storage">>, <<"storage:bookmarks">>} -> + decode_storage_bookmarks_storage(_el); + {<<"conference">>, <<>>} -> + decode_bookmark_conference_conference(_el); + {<<"query">>, <<"jabber:iq:private">>} -> + decode_private_query(_el); + {<<"query">>, + <<"http://jabber.org/protocol/disco#items">>} -> + decode_disco_items_query(_el); + {<<"query">>, + <<"http://jabber.org/protocol/disco#info">>} -> + decode_disco_info_query(_el); + {<<"blocklist">>, <<"urn:xmpp:blocking">>} -> + decode_block_list_blocklist(_el); + {<<"unblock">>, <<"urn:xmpp:blocking">>} -> + decode_unblock_unblock(_el); + {<<"block">>, <<"urn:xmpp:blocking">>} -> + decode_block_block(_el); + {<<"item">>, <<>>} -> decode_block_item_item(_el); + {<<"query">>, <<"jabber:iq:privacy">>} -> + decode_privacy_query(_el); + {<<"item">>, <<>>} -> decode_privacy_item_item(_el); + {<<"query">>, <<"jabber:iq:roster">>} -> + decode_roster_query(_el); + {<<"query">>, <<"jabber:iq:version">>} -> + decode_version_query(_el); + {<<"query">>, <<"jabber:iq:last">>} -> + decode_last_query(_el); + {_name, _xmlns} -> + erlang:error({unknown_tag, _name, _xmlns}) + end. + +encode({delay, _, _} = _r) -> + hd(encode_delay_delay(_r, [])); +encode({pubsub, _, _, _, _} = _r) -> + hd(encode_pubsub_pubsub(_r, [])); +encode({pubsub_event, _} = _r) -> + hd(encode_pubsub_event_event(_r, [])); +encode({pubsub_items, _, _, _, _} = _r) -> + hd(encode_pubsub_items_items(_r, [])); +encode({pubsub_item, _, _} = _r) -> + hd(encode_pubsub_item_item(_r, [])); +encode({pubsub_affiliation, _, _} = _r) -> + hd(encode_pubsub_affiliation_affiliation(_r, [])); +encode({pubsub_subscription, _, _, _, _} = _r) -> + hd(encode_pubsub_subscription_subscription(_r, [])); +encode({xdata, _, _, _, _, _, _} = _r) -> + hd(encode_xdata_x(_r, [])); +encode({xfield, _, _, _, _, _, _, _} = _r) -> + hd(encode_xfield_field(_r, [])); +encode({vcard, _, _, _, _, _, _, _, _, _, _, _, _, _, _, + _, _, _, _, _, _, _, _, _, _, _, _, _, _, _} = + _r) -> + hd(encode_vcard_vCard(_r, [])); +encode({vcard_key, _, _} = _r) -> + hd(encode_vcard_key_KEY(_r, [])); +encode({vcard_sound, _, _, _} = _r) -> + hd(encode_vcard_sound_SOUND(_r, [])); +encode({vcard_org, _, _} = _r) -> + hd(encode_vcard_org_ORG(_r, [])); +encode({vcard_photo, _, _, _} = _r) -> + hd(encode_vcard_photo_PHOTO(_r, [])); +encode({vcard_logo, _, _, _} = _r) -> + hd(encode_vcard_logo_LOGO(_r, [])); +encode({vcard_geo, _, _} = _r) -> + hd(encode_vcard_geo_GEO(_r, [])); +encode({vcard_email, _, _, _, _, _, _} = _r) -> + hd(encode_vcard_email_EMAIL(_r, [])); +encode({vcard_tel, _, _, _, _, _, _, _, _, _, _, _, _, + _, _} = + _r) -> + hd(encode_vcard_tel_TEL(_r, [])); +encode({vcard_label, _, _, _, _, _, _, _, _} = _r) -> + hd(encode_vcard_label_LABEL(_r, [])); +encode({vcard_adr, _, _, _, _, _, _, _, _, _, _, _, _, + _, _} = + _r) -> + hd(encode_vcard_adr_ADR(_r, [])); +encode({vcard_name, _, _, _, _, _} = _r) -> + hd(encode_vcard_name_N(_r, [])); +encode({stream_error, _, _} = _r) -> + hd('encode_stream_error_stream:error'(_r, [])); +encode({time, _, _} = _r) -> + hd(encode_time_time(_r, [])); +encode({ping} = _r) -> hd(encode_ping_ping(_r, [])); +encode({session} = _r) -> + hd(encode_session_session(_r, [])); +encode({register} = _r) -> + hd(encode_register_register(_r, [])); +encode({caps, _, _, _} = _r) -> + hd(encode_caps_c(_r, [])); +encode({p1_ack} = _r) -> hd(encode_p1_ack_ack(_r, [])); +encode({p1_rebind} = _r) -> + hd(encode_p1_rebind_rebind(_r, [])); +encode({p1_push} = _r) -> + hd(encode_p1_push_push(_r, [])); +encode({stream_features, _} = _r) -> + hd('encode_stream_features_stream:features'(_r, [])); +encode({starttls_failure} = _r) -> + hd(encode_starttls_failure_failure(_r, [])); +encode({starttls_proceed} = _r) -> + hd(encode_starttls_proceed_proceed(_r, [])); +encode({starttls, _} = _r) -> + hd(encode_starttls_starttls(_r, [])); +encode({sasl_mechanisms, _} = _r) -> + hd(encode_sasl_mechanisms_mechanisms(_r, [])); +encode({sasl_failure, _, _} = _r) -> + hd(encode_sasl_failure_failure(_r, [])); +encode({sasl_success, _} = _r) -> + hd(encode_sasl_success_success(_r, [])); +encode({sasl_response, _} = _r) -> + hd(encode_sasl_response_response(_r, [])); +encode({sasl_challenge, _} = _r) -> + hd(encode_sasl_challenge_challenge(_r, [])); +encode({sasl_abort} = _r) -> + hd(encode_sasl_abort_abort(_r, [])); +encode({sasl_auth, _, _} = _r) -> + hd(encode_sasl_auth_auth(_r, [])); +encode({bind, _, _} = _r) -> + hd(encode_bind_bind(_r, [])); +encode({error, _, _, _, _} = _r) -> + hd(encode_error_error(_r, [])); +encode({presence, _, _, _, _, _, _, _, _, _, _} = _r) -> + hd(encode_presence_presence(_r, [])); +encode({message, _, _, _, _, _, _, _, _, _, _} = _r) -> + hd(encode_message_message(_r, [])); +encode({iq, _, _, _, _, _, _, _} = _r) -> + hd(encode_iq_iq(_r, [])); +encode({stats, _} = _r) -> + hd(encode_stats_query(_r, [])); +encode({bookmark_storage, _, _} = _r) -> + hd(encode_storage_bookmarks_storage(_r, [])); +encode({bookmark_conference, _, _, _, _, _} = _r) -> + hd(encode_bookmark_conference_conference(_r, [])); +encode({private, _} = _r) -> + hd(encode_private_query(_r, [])); +encode({disco_items, _, _} = _r) -> + hd(encode_disco_items_query(_r, [])); +encode({disco_info, _, _, _, _} = _r) -> + hd(encode_disco_info_query(_r, [])); +encode({block_list} = _r) -> + hd(encode_block_list_blocklist(_r, [])); +encode({unblock, _} = _r) -> + hd(encode_unblock_unblock(_r, [])); +encode({block, _} = _r) -> + hd(encode_block_block(_r, [])); +encode({privacy, _, _, _} = _r) -> + hd(encode_privacy_query(_r, [])); +encode({privacy_item, _, _, _, _, _} = _r) -> + hd(encode_privacy_item_item(_r, [])); +encode({roster, _, _} = _r) -> + hd(encode_roster_query(_r, [])); +encode({version, _, _, _} = _r) -> + hd(encode_version_query(_r, [])); +encode({last, _, _} = _r) -> + hd(encode_last_query(_r, [])). + +enc_bool(false) -> <<"false">>; +enc_bool(true) -> <<"true">>. + +dec_bool(<<"false">>) -> false; +dec_bool(<<"true">>) -> true. + +resourceprep(R) -> + case jlib:resourceprep(R) of + error -> erlang:error(badarg); + R1 -> R1 + end. + +enc_jid(J) -> jlib:jid_to_string(J). + +dec_jid(Val) -> + case jlib:string_to_jid(Val) of + error -> erlang:error(badarg); + J -> J + end. + +enc_utc(Val) -> jlib:now_to_utc_string(Val). + +dec_utc(Val) -> + {_, _, _} = jlib:datetime_string_to_timestamp(Val). + +enc_tzo({H, M}) -> + Sign = if H >= 0 -> <<>>; + true -> <<"-">> + end, + list_to_binary([Sign, + io_lib:format("~2..0w:~2..0w", [H, M])]). + +dec_tzo(Val) -> + [H1, M1] = str:tokens(Val, <<":">>), + H = erlang:binary_to_integer(H1), + M = erlang:binary_to_integer(M1), + if H >= -12, H =< 12, M >= 0, M < 60 -> {H, M} end. + +decode_last_query({xmlel, _, _attrs, _els}) -> + Seconds = decode_last_query_attrs(_attrs, undefined), + Text = decode_last_query_els(_els, <<>>), + {last, Seconds, Text}. + +decode_last_query_els([{xmlcdata, _data} | _els], + Text) -> + decode_last_query_els(_els, + <<Text/binary, _data/binary>>); +decode_last_query_els([_ | _els], Text) -> + decode_last_query_els(_els, Text); +decode_last_query_els([], Text) -> + decode_last_query_cdata(Text). + +decode_last_query_attrs([{<<"seconds">>, _val} + | _attrs], + _Seconds) -> + decode_last_query_attrs(_attrs, _val); +decode_last_query_attrs([_ | _attrs], Seconds) -> + decode_last_query_attrs(_attrs, Seconds); +decode_last_query_attrs([], Seconds) -> + decode_last_query_seconds(Seconds). + +encode_last_query(undefined, _acc) -> _acc; +encode_last_query({last, Seconds, Text}, _acc) -> + _els = encode_last_query_cdata(Text, []), + _attrs = encode_last_query_seconds(Seconds, + [{<<"xmlns">>, <<"jabber:iq:last">>}]), + [{xmlel, <<"query">>, _attrs, _els} | _acc]. + +decode_last_query_seconds(undefined) -> undefined; +decode_last_query_seconds(_val) -> + case catch xml_gen:dec_int(_val, 0, infinity) of + {'EXIT', _} -> + erlang:error({bad_attr_value, <<"seconds">>, + <<"query">>, <<"jabber:iq:last">>}); + _res -> _res + end. + +encode_last_query_seconds(undefined, _acc) -> _acc; +encode_last_query_seconds(_val, _acc) -> + [{<<"seconds">>, xml_gen:enc_int(_val)} | _acc]. + +decode_last_query_cdata(<<>>) -> undefined; +decode_last_query_cdata(_val) -> _val. + +encode_last_query_cdata(undefined, _acc) -> _acc; +encode_last_query_cdata(_val, _acc) -> + [{xmlcdata, _val} | _acc]. + +decode_version_query({xmlel, _, _attrs, _els}) -> + {Os, Version, Name} = decode_version_query_els(_els, + undefined, undefined, + undefined), + {version, Name, Version, Os}. + +decode_version_query_els([{xmlel, <<"os">>, _attrs, _} = + _el + | _els], + Os, Version, Name) -> + case xml:get_attr_s(<<"xmlns">>, _attrs) of + <<>> -> + decode_version_query_els(_els, + decode_version_query_os(_el), Version, Name); + _ -> decode_version_query_els(_els, Os, Version, Name) + end; +decode_version_query_els([{xmlel, <<"version">>, _attrs, + _} = + _el + | _els], + Os, Version, Name) -> + case xml:get_attr_s(<<"xmlns">>, _attrs) of + <<>> -> + decode_version_query_els(_els, Os, + decode_version_query_version(_el), Name); + _ -> decode_version_query_els(_els, Os, Version, Name) + end; +decode_version_query_els([{xmlel, <<"name">>, _attrs, + _} = + _el + | _els], + Os, Version, Name) -> + case xml:get_attr_s(<<"xmlns">>, _attrs) of + <<>> -> + decode_version_query_els(_els, Os, Version, + decode_version_query_name(_el)); + _ -> decode_version_query_els(_els, Os, Version, Name) + end; +decode_version_query_els([_ | _els], Os, Version, + Name) -> + decode_version_query_els(_els, Os, Version, Name); +decode_version_query_els([], Os, Version, Name) -> + {Os, Version, Name}. + +encode_version_query(undefined, _acc) -> _acc; +encode_version_query({version, Name, Version, Os}, + _acc) -> + _els = encode_version_query_name(Name, + encode_version_query_version(Version, + encode_version_query_os(Os, + []))), + _attrs = [{<<"xmlns">>, <<"jabber:iq:version">>}], + [{xmlel, <<"query">>, _attrs, _els} | _acc]. + +decode_version_query_os({xmlel, _, _attrs, _els}) -> + Cdata = decode_version_query_os_els(_els, <<>>), Cdata. + +decode_version_query_os_els([{xmlcdata, _data} | _els], + Cdata) -> + decode_version_query_os_els(_els, + <<Cdata/binary, _data/binary>>); +decode_version_query_os_els([_ | _els], Cdata) -> + decode_version_query_os_els(_els, Cdata); +decode_version_query_os_els([], Cdata) -> + decode_version_query_os_cdata(Cdata). + +encode_version_query_os(undefined, _acc) -> _acc; +encode_version_query_os(Cdata, _acc) -> + _els = encode_version_query_os_cdata(Cdata, []), + _attrs = [], + [{xmlel, <<"os">>, _attrs, _els} | _acc]. + +decode_version_query_os_cdata(<<>>) -> + erlang:error({missing_cdata, <<>>, <<"os">>, <<>>}); +decode_version_query_os_cdata(_val) -> _val. + +encode_version_query_os_cdata(_val, _acc) -> + [{xmlcdata, _val} | _acc]. + +decode_version_query_version({xmlel, _, _attrs, + _els}) -> + Cdata = decode_version_query_version_els(_els, <<>>), + Cdata. + +decode_version_query_version_els([{xmlcdata, _data} + | _els], + Cdata) -> + decode_version_query_version_els(_els, + <<Cdata/binary, _data/binary>>); +decode_version_query_version_els([_ | _els], Cdata) -> + decode_version_query_version_els(_els, Cdata); +decode_version_query_version_els([], Cdata) -> + decode_version_query_version_cdata(Cdata). + +encode_version_query_version(undefined, _acc) -> _acc; +encode_version_query_version(Cdata, _acc) -> + _els = encode_version_query_version_cdata(Cdata, []), + _attrs = [], + [{xmlel, <<"version">>, _attrs, _els} | _acc]. + +decode_version_query_version_cdata(<<>>) -> + erlang:error({missing_cdata, <<>>, <<"version">>, + <<>>}); +decode_version_query_version_cdata(_val) -> _val. + +encode_version_query_version_cdata(_val, _acc) -> + [{xmlcdata, _val} | _acc]. + +decode_version_query_name({xmlel, _, _attrs, _els}) -> + Cdata = decode_version_query_name_els(_els, <<>>), + Cdata. + +decode_version_query_name_els([{xmlcdata, _data} + | _els], + Cdata) -> + decode_version_query_name_els(_els, + <<Cdata/binary, _data/binary>>); +decode_version_query_name_els([_ | _els], Cdata) -> + decode_version_query_name_els(_els, Cdata); +decode_version_query_name_els([], Cdata) -> + decode_version_query_name_cdata(Cdata). + +encode_version_query_name(undefined, _acc) -> _acc; +encode_version_query_name(Cdata, _acc) -> + _els = encode_version_query_name_cdata(Cdata, []), + _attrs = [], + [{xmlel, <<"name">>, _attrs, _els} | _acc]. + +decode_version_query_name_cdata(<<>>) -> + erlang:error({missing_cdata, <<>>, <<"name">>, <<>>}); +decode_version_query_name_cdata(_val) -> _val. + +encode_version_query_name_cdata(_val, _acc) -> + [{xmlcdata, _val} | _acc]. + +decode_roster_query({xmlel, _, _attrs, _els}) -> + Ver = decode_roster_query_attrs(_attrs, undefined), + Item = decode_roster_query_els(_els, []), + {roster, Item, Ver}. + +decode_roster_query_els([{xmlel, <<"item">>, _attrs, + _} = + _el + | _els], + Item) -> + case xml:get_attr_s(<<"xmlns">>, _attrs) of + <<>> -> + decode_roster_query_els(_els, + [decode_roster_query_item(_el) | Item]); + _ -> decode_roster_query_els(_els, Item) + end; +decode_roster_query_els([_ | _els], Item) -> + decode_roster_query_els(_els, Item); +decode_roster_query_els([], Item) -> + lists:reverse(Item). + +decode_roster_query_attrs([{<<"ver">>, _val} | _attrs], + _Ver) -> + decode_roster_query_attrs(_attrs, _val); +decode_roster_query_attrs([_ | _attrs], Ver) -> + decode_roster_query_attrs(_attrs, Ver); +decode_roster_query_attrs([], Ver) -> + decode_roster_query_ver(Ver). + +encode_roster_query(undefined, _acc) -> _acc; +encode_roster_query({roster, Item, Ver}, _acc) -> + _els = encode_roster_query_item(Item, []), + _attrs = encode_roster_query_ver(Ver, + [{<<"xmlns">>, <<"jabber:iq:roster">>}]), + [{xmlel, <<"query">>, _attrs, _els} | _acc]. + +decode_roster_query_ver(undefined) -> undefined; +decode_roster_query_ver(_val) -> _val. + +encode_roster_query_ver(undefined, _acc) -> _acc; +encode_roster_query_ver(_val, _acc) -> + [{<<"ver">>, _val} | _acc]. + +decode_roster_query_item({xmlel, _, _attrs, _els}) -> + {Ask, Subscription, Name, Jid} = + decode_roster_query_item_attrs(_attrs, undefined, + undefined, undefined, undefined), + Groups = decode_roster_query_item_els(_els, []), + {roster_item, Jid, Name, Groups, Subscription, Ask}. + +decode_roster_query_item_els([{xmlel, <<"group">>, + _attrs, _} = + _el + | _els], + Groups) -> + case xml:get_attr_s(<<"xmlns">>, _attrs) of + <<>> -> + decode_roster_query_item_els(_els, + [decode_roster_query_item_group(_el) + | Groups]); + _ -> decode_roster_query_item_els(_els, Groups) + end; +decode_roster_query_item_els([_ | _els], Groups) -> + decode_roster_query_item_els(_els, Groups); +decode_roster_query_item_els([], Groups) -> + lists:reverse(Groups). + +decode_roster_query_item_attrs([{<<"ask">>, _val} + | _attrs], + _Ask, Subscription, Name, Jid) -> + decode_roster_query_item_attrs(_attrs, _val, + Subscription, Name, Jid); +decode_roster_query_item_attrs([{<<"subscription">>, + _val} + | _attrs], + Ask, _Subscription, Name, Jid) -> + decode_roster_query_item_attrs(_attrs, Ask, _val, Name, + Jid); +decode_roster_query_item_attrs([{<<"name">>, _val} + | _attrs], + Ask, Subscription, _Name, Jid) -> + decode_roster_query_item_attrs(_attrs, Ask, + Subscription, _val, Jid); +decode_roster_query_item_attrs([{<<"jid">>, _val} + | _attrs], + Ask, Subscription, Name, _Jid) -> + decode_roster_query_item_attrs(_attrs, Ask, + Subscription, Name, _val); +decode_roster_query_item_attrs([_ | _attrs], Ask, + Subscription, Name, Jid) -> + decode_roster_query_item_attrs(_attrs, Ask, + Subscription, Name, Jid); +decode_roster_query_item_attrs([], Ask, Subscription, + Name, Jid) -> + {decode_roster_query_item_ask(Ask), + decode_roster_query_item_subscription(Subscription), + decode_roster_query_item_name(Name), + decode_roster_query_item_jid(Jid)}. + +encode_roster_query_item([], _acc) -> _acc; +encode_roster_query_item([{roster_item, Jid, Name, + Groups, Subscription, Ask} + | _tail], + _acc) -> + _els = encode_roster_query_item_group(Groups, []), + _attrs = encode_roster_query_item_jid(Jid, + encode_roster_query_item_name(Name, + encode_roster_query_item_subscription(Subscription, + encode_roster_query_item_ask(Ask, + [])))), + encode_roster_query_item(_tail, + [{xmlel, <<"item">>, _attrs, _els} | _acc]). + +decode_roster_query_item_jid(undefined) -> + erlang:error({missing_attr, <<"jid">>, <<"item">>, + <<>>}); +decode_roster_query_item_jid(_val) -> + case catch dec_jid(_val) of + {'EXIT', _} -> + erlang:error({bad_attr_value, <<"jid">>, <<"item">>, + <<>>}); + _res -> _res + end. + +encode_roster_query_item_jid(_val, _acc) -> + [{<<"jid">>, enc_jid(_val)} | _acc]. + +decode_roster_query_item_name(undefined) -> undefined; +decode_roster_query_item_name(_val) -> _val. + +encode_roster_query_item_name(undefined, _acc) -> _acc; +encode_roster_query_item_name(_val, _acc) -> + [{<<"name">>, _val} | _acc]. + +decode_roster_query_item_subscription(undefined) -> + none; +decode_roster_query_item_subscription(_val) -> + case catch xml_gen:dec_enum(_val, + [none, to, from, both, remove]) + of + {'EXIT', _} -> + erlang:error({bad_attr_value, <<"subscription">>, + <<"item">>, <<>>}); + _res -> _res + end. + +encode_roster_query_item_subscription(none, _acc) -> + _acc; +encode_roster_query_item_subscription(_val, _acc) -> + [{<<"subscription">>, xml_gen:enc_enum(_val)} | _acc]. + +decode_roster_query_item_ask(undefined) -> undefined; +decode_roster_query_item_ask(_val) -> + case catch xml_gen:dec_enum(_val, [subscribe]) of + {'EXIT', _} -> + erlang:error({bad_attr_value, <<"ask">>, <<"item">>, + <<>>}); + _res -> _res + end. + +encode_roster_query_item_ask(undefined, _acc) -> _acc; +encode_roster_query_item_ask(_val, _acc) -> + [{<<"ask">>, xml_gen:enc_enum(_val)} | _acc]. + +decode_roster_query_item_group({xmlel, _, _attrs, + _els}) -> + Cdata = decode_roster_query_item_group_els(_els, <<>>), + Cdata. + +decode_roster_query_item_group_els([{xmlcdata, _data} + | _els], + Cdata) -> + decode_roster_query_item_group_els(_els, + <<Cdata/binary, _data/binary>>); +decode_roster_query_item_group_els([_ | _els], Cdata) -> + decode_roster_query_item_group_els(_els, Cdata); +decode_roster_query_item_group_els([], Cdata) -> + decode_roster_query_item_group_cdata(Cdata). + +encode_roster_query_item_group([], _acc) -> _acc; +encode_roster_query_item_group([Cdata | _tail], _acc) -> + _els = encode_roster_query_item_group_cdata(Cdata, []), + _attrs = [], + encode_roster_query_item_group(_tail, + [{xmlel, <<"group">>, _attrs, _els} | _acc]). + +decode_roster_query_item_group_cdata(<<>>) -> + erlang:error({missing_cdata, <<>>, <<"group">>, <<>>}); +decode_roster_query_item_group_cdata(_val) -> _val. + +encode_roster_query_item_group_cdata(_val, _acc) -> + [{xmlcdata, _val} | _acc]. + +decode_privacy_item_item({xmlel, _, _attrs, _els}) -> + {Value, Type, Action, Order} = + decode_privacy_item_item_attrs(_attrs, undefined, + undefined, undefined, undefined), + Stanza = decode_privacy_item_item_els(_els, undefined), + {privacy_item, Order, Action, Type, Value, Stanza}. + +decode_privacy_item_item_els([{xmlel, + <<"presence-out">>, _attrs, _} = + _el + | _els], + Stanza) -> + case xml:get_attr_s(<<"xmlns">>, _attrs) of + <<>> -> + decode_privacy_item_item_els(_els, + 'decode_privacy_item_item_presence-out'(_el)); + _ -> decode_privacy_item_item_els(_els, Stanza) + end; +decode_privacy_item_item_els([{xmlel, <<"presence-in">>, + _attrs, _} = + _el + | _els], + Stanza) -> + case xml:get_attr_s(<<"xmlns">>, _attrs) of + <<>> -> + decode_privacy_item_item_els(_els, + 'decode_privacy_item_item_presence-in'(_el)); + _ -> decode_privacy_item_item_els(_els, Stanza) + end; +decode_privacy_item_item_els([{xmlel, <<"iq">>, _attrs, + _} = + _el + | _els], + Stanza) -> + case xml:get_attr_s(<<"xmlns">>, _attrs) of + <<>> -> + decode_privacy_item_item_els(_els, + decode_privacy_item_item_iq(_el)); + _ -> decode_privacy_item_item_els(_els, Stanza) + end; +decode_privacy_item_item_els([{xmlel, <<"message">>, + _attrs, _} = + _el + | _els], + Stanza) -> + case xml:get_attr_s(<<"xmlns">>, _attrs) of + <<>> -> + decode_privacy_item_item_els(_els, + decode_privacy_item_item_message(_el)); + _ -> decode_privacy_item_item_els(_els, Stanza) + end; +decode_privacy_item_item_els([_ | _els], Stanza) -> + decode_privacy_item_item_els(_els, Stanza); +decode_privacy_item_item_els([], Stanza) -> Stanza. + +decode_privacy_item_item_attrs([{<<"value">>, _val} + | _attrs], + _Value, Type, Action, Order) -> + decode_privacy_item_item_attrs(_attrs, _val, Type, + Action, Order); +decode_privacy_item_item_attrs([{<<"type">>, _val} + | _attrs], + Value, _Type, Action, Order) -> + decode_privacy_item_item_attrs(_attrs, Value, _val, + Action, Order); +decode_privacy_item_item_attrs([{<<"action">>, _val} + | _attrs], + Value, Type, _Action, Order) -> + decode_privacy_item_item_attrs(_attrs, Value, Type, + _val, Order); +decode_privacy_item_item_attrs([{<<"order">>, _val} + | _attrs], + Value, Type, Action, _Order) -> + decode_privacy_item_item_attrs(_attrs, Value, Type, + Action, _val); +decode_privacy_item_item_attrs([_ | _attrs], Value, + Type, Action, Order) -> + decode_privacy_item_item_attrs(_attrs, Value, Type, + Action, Order); +decode_privacy_item_item_attrs([], Value, Type, Action, + Order) -> + {decode_privacy_item_item_value(Value), + decode_privacy_item_item_type(Type), + decode_privacy_item_item_action(Action), + decode_privacy_item_item_order(Order)}. + +'encode_privacy_item_item_$stanza'(undefined, _acc) -> + _acc; +'encode_privacy_item_item_$stanza'('presence-out' = _r, + _acc) -> + 'encode_privacy_item_item_presence-out'(_r, _acc); +'encode_privacy_item_item_$stanza'('presence-in' = _r, + _acc) -> + 'encode_privacy_item_item_presence-in'(_r, _acc); +'encode_privacy_item_item_$stanza'(iq = _r, _acc) -> + encode_privacy_item_item_iq(_r, _acc); +'encode_privacy_item_item_$stanza'(message = _r, + _acc) -> + encode_privacy_item_item_message(_r, _acc). + +encode_privacy_item_item([], _acc) -> _acc; +encode_privacy_item_item([{privacy_item, Order, Action, + Type, Value, Stanza} + | _tail], + _acc) -> + _els = 'encode_privacy_item_item_$stanza'(Stanza, []), + _attrs = encode_privacy_item_item_order(Order, + encode_privacy_item_item_action(Action, + encode_privacy_item_item_type(Type, + encode_privacy_item_item_value(Value, + [])))), + encode_privacy_item_item(_tail, + [{xmlel, <<"item">>, _attrs, _els} | _acc]). + +decode_privacy_item_item_action(undefined) -> + erlang:error({missing_attr, <<"action">>, <<"item">>, + <<>>}); +decode_privacy_item_item_action(_val) -> + case catch xml_gen:dec_enum(_val, [allow, deny]) of + {'EXIT', _} -> + erlang:error({bad_attr_value, <<"action">>, <<"item">>, + <<>>}); + _res -> _res + end. + +encode_privacy_item_item_action(_val, _acc) -> + [{<<"action">>, xml_gen:enc_enum(_val)} | _acc]. + +decode_privacy_item_item_order(undefined) -> + erlang:error({missing_attr, <<"order">>, <<"item">>, + <<>>}); +decode_privacy_item_item_order(_val) -> + case catch xml_gen:dec_int(_val, 0, infinity) of + {'EXIT', _} -> + erlang:error({bad_attr_value, <<"order">>, <<"item">>, + <<>>}); + _res -> _res + end. + +encode_privacy_item_item_order(_val, _acc) -> + [{<<"order">>, xml_gen:enc_int(_val)} | _acc]. + +decode_privacy_item_item_type(undefined) -> undefined; +decode_privacy_item_item_type(_val) -> + case catch xml_gen:dec_enum(_val, + [group, jid, subscription]) + of + {'EXIT', _} -> + erlang:error({bad_attr_value, <<"type">>, <<"item">>, + <<>>}); + _res -> _res + end. + +encode_privacy_item_item_type(undefined, _acc) -> _acc; +encode_privacy_item_item_type(_val, _acc) -> + [{<<"type">>, xml_gen:enc_enum(_val)} | _acc]. + +decode_privacy_item_item_value(undefined) -> undefined; +decode_privacy_item_item_value(_val) -> _val. + +encode_privacy_item_item_value(undefined, _acc) -> _acc; +encode_privacy_item_item_value(_val, _acc) -> + [{<<"value">>, _val} | _acc]. + +'decode_privacy_item_item_presence-out'({xmlel, _, + _attrs, _els}) -> + 'presence-out'. + +'encode_privacy_item_item_presence-out'(undefined, + _acc) -> + _acc; +'encode_privacy_item_item_presence-out'('presence-out', + _acc) -> + _els = [], + _attrs = [], + [{xmlel, <<"presence-out">>, _attrs, _els} | _acc]. + +'decode_privacy_item_item_presence-in'({xmlel, _, + _attrs, _els}) -> + 'presence-in'. + +'encode_privacy_item_item_presence-in'(undefined, + _acc) -> + _acc; +'encode_privacy_item_item_presence-in'('presence-in', + _acc) -> + _els = [], + _attrs = [], + [{xmlel, <<"presence-in">>, _attrs, _els} | _acc]. + +decode_privacy_item_item_iq({xmlel, _, _attrs, _els}) -> + iq. + +encode_privacy_item_item_iq(undefined, _acc) -> _acc; +encode_privacy_item_item_iq(iq, _acc) -> + _els = [], + _attrs = [], + [{xmlel, <<"iq">>, _attrs, _els} | _acc]. + +decode_privacy_item_item_message({xmlel, _, _attrs, + _els}) -> + message. + +encode_privacy_item_item_message(undefined, _acc) -> + _acc; +encode_privacy_item_item_message(message, _acc) -> + _els = [], + _attrs = [], + [{xmlel, <<"message">>, _attrs, _els} | _acc]. + +decode_privacy_query({xmlel, _, _attrs, _els}) -> + {Active, Default, List} = decode_privacy_query_els(_els, + undefined, undefined, + []), + {privacy, List, Default, Active}. + +decode_privacy_query_els([{xmlel, <<"active">>, _attrs, + _} = + _el + | _els], + Active, Default, List) -> + case xml:get_attr_s(<<"xmlns">>, _attrs) of + <<>> -> + decode_privacy_query_els(_els, + decode_privacy_query_active(_el), Default, + List); + _ -> + decode_privacy_query_els(_els, Active, Default, List) + end; +decode_privacy_query_els([{xmlel, <<"default">>, _attrs, + _} = + _el + | _els], + Active, Default, List) -> + case xml:get_attr_s(<<"xmlns">>, _attrs) of + <<>> -> + decode_privacy_query_els(_els, Active, + decode_privacy_query_default(_el), List); + _ -> + decode_privacy_query_els(_els, Active, Default, List) + end; +decode_privacy_query_els([{xmlel, <<"list">>, _attrs, + _} = + _el + | _els], + Active, Default, List) -> + case xml:get_attr_s(<<"xmlns">>, _attrs) of + <<>> -> + decode_privacy_query_els(_els, Active, Default, + [decode_privacy_query_list(_el) | List]); + _ -> + decode_privacy_query_els(_els, Active, Default, List) + end; +decode_privacy_query_els([_ | _els], Active, Default, + List) -> + decode_privacy_query_els(_els, Active, Default, List); +decode_privacy_query_els([], Active, Default, List) -> + {Active, Default, lists:reverse(List)}. + +encode_privacy_query(undefined, _acc) -> _acc; +encode_privacy_query({privacy, List, Default, Active}, + _acc) -> + _els = encode_privacy_query_list(List, + encode_privacy_query_default(Default, + encode_privacy_query_active(Active, + []))), + _attrs = [{<<"xmlns">>, <<"jabber:iq:privacy">>}], + [{xmlel, <<"query">>, _attrs, _els} | _acc]. + +decode_privacy_query_active({xmlel, _, _attrs, _els}) -> + Name = decode_privacy_query_active_attrs(_attrs, + undefined), + Name. + +decode_privacy_query_active_attrs([{<<"name">>, _val} + | _attrs], + _Name) -> + decode_privacy_query_active_attrs(_attrs, _val); +decode_privacy_query_active_attrs([_ | _attrs], Name) -> + decode_privacy_query_active_attrs(_attrs, Name); +decode_privacy_query_active_attrs([], Name) -> + decode_privacy_query_active_name(Name). + +encode_privacy_query_active(undefined, _acc) -> _acc; +encode_privacy_query_active(Name, _acc) -> + _els = [], + _attrs = encode_privacy_query_active_name(Name, []), + [{xmlel, <<"active">>, _attrs, _els} | _acc]. + +decode_privacy_query_active_name(undefined) -> none; +decode_privacy_query_active_name(_val) -> _val. + +encode_privacy_query_active_name(none, _acc) -> _acc; +encode_privacy_query_active_name(_val, _acc) -> + [{<<"name">>, _val} | _acc]. + +decode_privacy_query_default({xmlel, _, _attrs, + _els}) -> + Name = decode_privacy_query_default_attrs(_attrs, + undefined), + Name. + +decode_privacy_query_default_attrs([{<<"name">>, _val} + | _attrs], + _Name) -> + decode_privacy_query_default_attrs(_attrs, _val); +decode_privacy_query_default_attrs([_ | _attrs], + Name) -> + decode_privacy_query_default_attrs(_attrs, Name); +decode_privacy_query_default_attrs([], Name) -> + decode_privacy_query_default_name(Name). + +encode_privacy_query_default(undefined, _acc) -> _acc; +encode_privacy_query_default(Name, _acc) -> + _els = [], + _attrs = encode_privacy_query_default_name(Name, []), + [{xmlel, <<"default">>, _attrs, _els} | _acc]. + +decode_privacy_query_default_name(undefined) -> none; +decode_privacy_query_default_name(_val) -> _val. + +encode_privacy_query_default_name(none, _acc) -> _acc; +encode_privacy_query_default_name(_val, _acc) -> + [{<<"name">>, _val} | _acc]. + +decode_privacy_query_list({xmlel, _, _attrs, _els}) -> + Name = decode_privacy_query_list_attrs(_attrs, + undefined), + Privacy_item = decode_privacy_query_list_els(_els, []), + {privacy_list, Name, Privacy_item}. + +decode_privacy_query_list_els([{xmlel, <<"item">>, + _attrs, _} = + _el + | _els], + Privacy_item) -> + case xml:get_attr_s(<<"xmlns">>, _attrs) of + <<>> -> + decode_privacy_query_list_els(_els, + [decode_privacy_item_item(_el) + | Privacy_item]); + _ -> decode_privacy_query_list_els(_els, Privacy_item) + end; +decode_privacy_query_list_els([_ | _els], + Privacy_item) -> + decode_privacy_query_list_els(_els, Privacy_item); +decode_privacy_query_list_els([], Privacy_item) -> + lists:reverse(Privacy_item). + +decode_privacy_query_list_attrs([{<<"name">>, _val} + | _attrs], + _Name) -> + decode_privacy_query_list_attrs(_attrs, _val); +decode_privacy_query_list_attrs([_ | _attrs], Name) -> + decode_privacy_query_list_attrs(_attrs, Name); +decode_privacy_query_list_attrs([], Name) -> + decode_privacy_query_list_name(Name). + +encode_privacy_query_list([], _acc) -> _acc; +encode_privacy_query_list([{privacy_list, Name, + Privacy_item} + | _tail], + _acc) -> + _els = encode_privacy_item_item(Privacy_item, []), + _attrs = encode_privacy_query_list_name(Name, []), + encode_privacy_query_list(_tail, + [{xmlel, <<"list">>, _attrs, _els} | _acc]). + +decode_privacy_query_list_name(undefined) -> + erlang:error({missing_attr, <<"name">>, <<"list">>, + <<>>}); +decode_privacy_query_list_name(_val) -> _val. + +encode_privacy_query_list_name(_val, _acc) -> + [{<<"name">>, _val} | _acc]. + +decode_block_item_item({xmlel, _, _attrs, _els}) -> + Jid = decode_block_item_item_attrs(_attrs, undefined), + Jid. + +decode_block_item_item_attrs([{<<"jid">>, _val} + | _attrs], + _Jid) -> + decode_block_item_item_attrs(_attrs, _val); +decode_block_item_item_attrs([_ | _attrs], Jid) -> + decode_block_item_item_attrs(_attrs, Jid); +decode_block_item_item_attrs([], Jid) -> + decode_block_item_item_jid(Jid). + +encode_block_item_item([], _acc) -> _acc; +encode_block_item_item([Jid | _tail], _acc) -> + _els = [], + _attrs = encode_block_item_item_jid(Jid, []), + encode_block_item_item(_tail, + [{xmlel, <<"item">>, _attrs, _els} | _acc]). + +decode_block_item_item_jid(undefined) -> + erlang:error({missing_attr, <<"jid">>, <<"item">>, + <<>>}); +decode_block_item_item_jid(_val) -> + case catch dec_jid(_val) of + {'EXIT', _} -> + erlang:error({bad_attr_value, <<"jid">>, <<"item">>, + <<>>}); + _res -> _res + end. + +encode_block_item_item_jid(_val, _acc) -> + [{<<"jid">>, enc_jid(_val)} | _acc]. + +decode_block_block({xmlel, _, _attrs, _els}) -> + Block_item = decode_block_block_els(_els, []), + {block, Block_item}. + +decode_block_block_els([{xmlel, <<"item">>, _attrs, _} = + _el + | _els], + Block_item) -> + case xml:get_attr_s(<<"xmlns">>, _attrs) of + <<>> -> + decode_block_block_els(_els, + [decode_block_item_item(_el) | Block_item]); + _ -> decode_block_block_els(_els, Block_item) + end; +decode_block_block_els([_ | _els], Block_item) -> + decode_block_block_els(_els, Block_item); +decode_block_block_els([], Block_item) -> + lists:reverse(Block_item). + +encode_block_block(undefined, _acc) -> _acc; +encode_block_block({block, Block_item}, _acc) -> + _els = encode_block_item_item(Block_item, []), + _attrs = [{<<"xmlns">>, <<"urn:xmpp:blocking">>}], + [{xmlel, <<"block">>, _attrs, _els} | _acc]. + +decode_unblock_unblock({xmlel, _, _attrs, _els}) -> + Block_item = decode_unblock_unblock_els(_els, []), + {unblock, Block_item}. + +decode_unblock_unblock_els([{xmlel, <<"item">>, _attrs, + _} = + _el + | _els], + Block_item) -> + case xml:get_attr_s(<<"xmlns">>, _attrs) of + <<>> -> + decode_unblock_unblock_els(_els, + [decode_block_item_item(_el) + | Block_item]); + _ -> decode_unblock_unblock_els(_els, Block_item) + end; +decode_unblock_unblock_els([_ | _els], Block_item) -> + decode_unblock_unblock_els(_els, Block_item); +decode_unblock_unblock_els([], Block_item) -> + lists:reverse(Block_item). + +encode_unblock_unblock(undefined, _acc) -> _acc; +encode_unblock_unblock({unblock, Block_item}, _acc) -> + _els = encode_block_item_item(Block_item, []), + _attrs = [{<<"xmlns">>, <<"urn:xmpp:blocking">>}], + [{xmlel, <<"unblock">>, _attrs, _els} | _acc]. + +decode_block_list_blocklist({xmlel, _, _attrs, _els}) -> + {block_list}. + +encode_block_list_blocklist(undefined, _acc) -> _acc; +encode_block_list_blocklist({block_list}, _acc) -> + _els = [], + _attrs = [{<<"xmlns">>, <<"urn:xmpp:blocking">>}], + [{xmlel, <<"blocklist">>, _attrs, _els} | _acc]. + +decode_disco_info_query({xmlel, _, _attrs, _els}) -> + Node = decode_disco_info_query_attrs(_attrs, undefined), + {Xdata, Feature, Identity} = + decode_disco_info_query_els(_els, [], [], []), + {disco_info, Node, Identity, Feature, Xdata}. + +decode_disco_info_query_els([{xmlel, <<"x">>, _attrs, + _} = + _el + | _els], + Xdata, Feature, Identity) -> + case xml:get_attr_s(<<"xmlns">>, _attrs) of + <<"jabber:x:data">> -> + decode_disco_info_query_els(_els, + [decode_xdata_x(_el) | Xdata], Feature, + Identity); + _ -> + decode_disco_info_query_els(_els, Xdata, Feature, + Identity) + end; +decode_disco_info_query_els([{xmlel, <<"feature">>, + _attrs, _} = + _el + | _els], + Xdata, Feature, Identity) -> + case xml:get_attr_s(<<"xmlns">>, _attrs) of + <<>> -> + decode_disco_info_query_els(_els, Xdata, + [decode_disco_info_query_feature(_el) + | Feature], + Identity); + _ -> + decode_disco_info_query_els(_els, Xdata, Feature, + Identity) + end; +decode_disco_info_query_els([{xmlel, <<"identity">>, + _attrs, _} = + _el + | _els], + Xdata, Feature, Identity) -> + case xml:get_attr_s(<<"xmlns">>, _attrs) of + <<>> -> + decode_disco_info_query_els(_els, Xdata, Feature, + [decode_disco_info_query_identity(_el) + | Identity]); + _ -> + decode_disco_info_query_els(_els, Xdata, Feature, + Identity) + end; +decode_disco_info_query_els([_ | _els], Xdata, Feature, + Identity) -> + decode_disco_info_query_els(_els, Xdata, Feature, + Identity); +decode_disco_info_query_els([], Xdata, Feature, + Identity) -> + {lists:reverse(Xdata), lists:reverse(Feature), + lists:reverse(Identity)}. + +decode_disco_info_query_attrs([{<<"node">>, _val} + | _attrs], + _Node) -> + decode_disco_info_query_attrs(_attrs, _val); +decode_disco_info_query_attrs([_ | _attrs], Node) -> + decode_disco_info_query_attrs(_attrs, Node); +decode_disco_info_query_attrs([], Node) -> + decode_disco_info_query_node(Node). + +encode_disco_info_query(undefined, _acc) -> _acc; +encode_disco_info_query({disco_info, Node, Identity, + Feature, Xdata}, + _acc) -> + _els = encode_disco_info_query_identity(Identity, + encode_disco_info_query_feature(Feature, + encode_xdata_x(Xdata, + []))), + _attrs = encode_disco_info_query_node(Node, + [{<<"xmlns">>, + <<"http://jabber.org/protocol/disco#info">>}]), + [{xmlel, <<"query">>, _attrs, _els} | _acc]. + +decode_disco_info_query_node(undefined) -> undefined; +decode_disco_info_query_node(_val) -> _val. + +encode_disco_info_query_node(undefined, _acc) -> _acc; +encode_disco_info_query_node(_val, _acc) -> + [{<<"node">>, _val} | _acc]. + +decode_disco_info_query_feature({xmlel, _, _attrs, + _els}) -> + Var = decode_disco_info_query_feature_attrs(_attrs, + undefined), + Var. + +decode_disco_info_query_feature_attrs([{<<"var">>, _val} + | _attrs], + _Var) -> + decode_disco_info_query_feature_attrs(_attrs, _val); +decode_disco_info_query_feature_attrs([_ | _attrs], + Var) -> + decode_disco_info_query_feature_attrs(_attrs, Var); +decode_disco_info_query_feature_attrs([], Var) -> + decode_disco_info_query_feature_var(Var). + +encode_disco_info_query_feature([], _acc) -> _acc; +encode_disco_info_query_feature([Var | _tail], _acc) -> + _els = [], + _attrs = encode_disco_info_query_feature_var(Var, []), + encode_disco_info_query_feature(_tail, + [{xmlel, <<"feature">>, _attrs, _els} + | _acc]). + +decode_disco_info_query_feature_var(undefined) -> + erlang:error({missing_attr, <<"var">>, <<"feature">>, + <<>>}); +decode_disco_info_query_feature_var(_val) -> _val. + +encode_disco_info_query_feature_var(_val, _acc) -> + [{<<"var">>, _val} | _acc]. + +decode_disco_info_query_identity({xmlel, _, _attrs, + _els}) -> + {Name, Type, Category} = + decode_disco_info_query_identity_attrs(_attrs, + undefined, undefined, undefined), + {Category, Type, Name}. + +decode_disco_info_query_identity_attrs([{<<"name">>, + _val} + | _attrs], + _Name, Type, Category) -> + decode_disco_info_query_identity_attrs(_attrs, _val, + Type, Category); +decode_disco_info_query_identity_attrs([{<<"type">>, + _val} + | _attrs], + Name, _Type, Category) -> + decode_disco_info_query_identity_attrs(_attrs, Name, + _val, Category); +decode_disco_info_query_identity_attrs([{<<"category">>, + _val} + | _attrs], + Name, Type, _Category) -> + decode_disco_info_query_identity_attrs(_attrs, Name, + Type, _val); +decode_disco_info_query_identity_attrs([_ | _attrs], + Name, Type, Category) -> + decode_disco_info_query_identity_attrs(_attrs, Name, + Type, Category); +decode_disco_info_query_identity_attrs([], Name, Type, + Category) -> + {decode_disco_info_query_identity_name(Name), + decode_disco_info_query_identity_type(Type), + decode_disco_info_query_identity_category(Category)}. + +encode_disco_info_query_identity([], _acc) -> _acc; +encode_disco_info_query_identity([{Category, Type, Name} + | _tail], + _acc) -> + _els = [], + _attrs = + encode_disco_info_query_identity_category(Category, + encode_disco_info_query_identity_type(Type, + encode_disco_info_query_identity_name(Name, + []))), + encode_disco_info_query_identity(_tail, + [{xmlel, <<"identity">>, _attrs, _els} + | _acc]). + +decode_disco_info_query_identity_category(undefined) -> + erlang:error({missing_attr, <<"category">>, + <<"identity">>, <<>>}); +decode_disco_info_query_identity_category(_val) -> _val. + +encode_disco_info_query_identity_category(_val, _acc) -> + [{<<"category">>, _val} | _acc]. + +decode_disco_info_query_identity_type(undefined) -> + erlang:error({missing_attr, <<"type">>, <<"identity">>, + <<>>}); +decode_disco_info_query_identity_type(_val) -> _val. + +encode_disco_info_query_identity_type(_val, _acc) -> + [{<<"type">>, _val} | _acc]. + +decode_disco_info_query_identity_name(undefined) -> + undefined; +decode_disco_info_query_identity_name(_val) -> _val. + +encode_disco_info_query_identity_name(undefined, + _acc) -> + _acc; +encode_disco_info_query_identity_name(_val, _acc) -> + [{<<"name">>, _val} | _acc]. + +decode_disco_items_query({xmlel, _, _attrs, _els}) -> + Node = decode_disco_items_query_attrs(_attrs, + undefined), + Items = decode_disco_items_query_els(_els, []), + {disco_items, Node, Items}. + +decode_disco_items_query_els([{xmlel, <<"item">>, + _attrs, _} = + _el + | _els], + Items) -> + case xml:get_attr_s(<<"xmlns">>, _attrs) of + <<>> -> + decode_disco_items_query_els(_els, + [decode_disco_items_query_item(_el) + | Items]); + _ -> decode_disco_items_query_els(_els, Items) + end; +decode_disco_items_query_els([_ | _els], Items) -> + decode_disco_items_query_els(_els, Items); +decode_disco_items_query_els([], Items) -> + lists:reverse(Items). + +decode_disco_items_query_attrs([{<<"node">>, _val} + | _attrs], + _Node) -> + decode_disco_items_query_attrs(_attrs, _val); +decode_disco_items_query_attrs([_ | _attrs], Node) -> + decode_disco_items_query_attrs(_attrs, Node); +decode_disco_items_query_attrs([], Node) -> + decode_disco_items_query_node(Node). + +encode_disco_items_query(undefined, _acc) -> _acc; +encode_disco_items_query({disco_items, Node, Items}, + _acc) -> + _els = encode_disco_items_query_item(Items, []), + _attrs = encode_disco_items_query_node(Node, + [{<<"xmlns">>, + <<"http://jabber.org/protocol/disco#items">>}]), + [{xmlel, <<"query">>, _attrs, _els} | _acc]. + +decode_disco_items_query_node(undefined) -> undefined; +decode_disco_items_query_node(_val) -> _val. + +encode_disco_items_query_node(undefined, _acc) -> _acc; +encode_disco_items_query_node(_val, _acc) -> + [{<<"node">>, _val} | _acc]. + +decode_disco_items_query_item({xmlel, _, _attrs, + _els}) -> + {Node, Name, Jid} = + decode_disco_items_query_item_attrs(_attrs, undefined, + undefined, undefined), + {disco_item, Jid, Name, Node}. + +decode_disco_items_query_item_attrs([{<<"node">>, _val} + | _attrs], + _Node, Name, Jid) -> + decode_disco_items_query_item_attrs(_attrs, _val, Name, + Jid); +decode_disco_items_query_item_attrs([{<<"name">>, _val} + | _attrs], + Node, _Name, Jid) -> + decode_disco_items_query_item_attrs(_attrs, Node, _val, + Jid); +decode_disco_items_query_item_attrs([{<<"jid">>, _val} + | _attrs], + Node, Name, _Jid) -> + decode_disco_items_query_item_attrs(_attrs, Node, Name, + _val); +decode_disco_items_query_item_attrs([_ | _attrs], Node, + Name, Jid) -> + decode_disco_items_query_item_attrs(_attrs, Node, Name, + Jid); +decode_disco_items_query_item_attrs([], Node, Name, + Jid) -> + {decode_disco_items_query_item_node(Node), + decode_disco_items_query_item_name(Name), + decode_disco_items_query_item_jid(Jid)}. + +encode_disco_items_query_item([], _acc) -> _acc; +encode_disco_items_query_item([{disco_item, Jid, Name, + Node} + | _tail], + _acc) -> + _els = [], + _attrs = encode_disco_items_query_item_jid(Jid, + encode_disco_items_query_item_name(Name, + encode_disco_items_query_item_node(Node, + []))), + encode_disco_items_query_item(_tail, + [{xmlel, <<"item">>, _attrs, _els} | _acc]). + +decode_disco_items_query_item_jid(undefined) -> + erlang:error({missing_attr, <<"jid">>, <<"item">>, + <<>>}); +decode_disco_items_query_item_jid(_val) -> + case catch dec_jid(_val) of + {'EXIT', _} -> + erlang:error({bad_attr_value, <<"jid">>, <<"item">>, + <<>>}); + _res -> _res + end. + +encode_disco_items_query_item_jid(_val, _acc) -> + [{<<"jid">>, enc_jid(_val)} | _acc]. + +decode_disco_items_query_item_name(undefined) -> + undefined; +decode_disco_items_query_item_name(_val) -> _val. + +encode_disco_items_query_item_name(undefined, _acc) -> + _acc; +encode_disco_items_query_item_name(_val, _acc) -> + [{<<"name">>, _val} | _acc]. + +decode_disco_items_query_item_node(undefined) -> + undefined; +decode_disco_items_query_item_node(_val) -> _val. + +encode_disco_items_query_item_node(undefined, _acc) -> + _acc; +encode_disco_items_query_item_node(_val, _acc) -> + [{<<"node">>, _val} | _acc]. + +decode_private_query({xmlel, _, _attrs, _els}) -> + __Els = decode_private_query_els(_els, []), + {private, __Els}. + +decode_private_query_els([{xmlel, _, _, _} = _el + | _els], + __Els) -> + decode_private_query_els(_els, [decode(_el) | __Els]); +decode_private_query_els([_ | _els], __Els) -> + decode_private_query_els(_els, __Els); +decode_private_query_els([], __Els) -> + lists:reverse(__Els). + +encode_private_query(undefined, _acc) -> _acc; +encode_private_query({private, __Els}, _acc) -> + _els = [encode(_subel) || _subel <- __Els] ++ [], + _attrs = [{<<"xmlns">>, <<"jabber:iq:private">>}], + [{xmlel, <<"query">>, _attrs, _els} | _acc]. + +decode_bookmark_conference_conference({xmlel, _, _attrs, + _els}) -> + {Autojoin, Jid, Name} = + decode_bookmark_conference_conference_attrs(_attrs, + undefined, undefined, + undefined), + {Password, Nick} = + decode_bookmark_conference_conference_els(_els, + undefined, undefined), + {bookmark_conference, Name, Jid, Autojoin, Nick, + Password}. + +decode_bookmark_conference_conference_els([{xmlel, + <<"password">>, _attrs, _} = + _el + | _els], + Password, Nick) -> + case xml:get_attr_s(<<"xmlns">>, _attrs) of + <<>> -> + decode_bookmark_conference_conference_els(_els, + decode_bookmark_conference_conference_password(_el), + Nick); + _ -> + decode_bookmark_conference_conference_els(_els, + Password, Nick) + end; +decode_bookmark_conference_conference_els([{xmlel, + <<"nick">>, _attrs, _} = + _el + | _els], + Password, Nick) -> + case xml:get_attr_s(<<"xmlns">>, _attrs) of + <<>> -> + decode_bookmark_conference_conference_els(_els, + Password, + decode_bookmark_conference_conference_nick(_el)); + _ -> + decode_bookmark_conference_conference_els(_els, + Password, Nick) + end; +decode_bookmark_conference_conference_els([_ | _els], + Password, Nick) -> + decode_bookmark_conference_conference_els(_els, + Password, Nick); +decode_bookmark_conference_conference_els([], Password, + Nick) -> + {Password, Nick}. + +decode_bookmark_conference_conference_attrs([{<<"autojoin">>, + _val} + | _attrs], + _Autojoin, Jid, Name) -> + decode_bookmark_conference_conference_attrs(_attrs, + _val, Jid, Name); +decode_bookmark_conference_conference_attrs([{<<"jid">>, + _val} + | _attrs], + Autojoin, _Jid, Name) -> + decode_bookmark_conference_conference_attrs(_attrs, + Autojoin, _val, Name); +decode_bookmark_conference_conference_attrs([{<<"name">>, + _val} + | _attrs], + Autojoin, Jid, _Name) -> + decode_bookmark_conference_conference_attrs(_attrs, + Autojoin, Jid, _val); +decode_bookmark_conference_conference_attrs([_ + | _attrs], + Autojoin, Jid, Name) -> + decode_bookmark_conference_conference_attrs(_attrs, + Autojoin, Jid, Name); +decode_bookmark_conference_conference_attrs([], + Autojoin, Jid, Name) -> + {decode_bookmark_conference_conference_autojoin(Autojoin), + decode_bookmark_conference_conference_jid(Jid), + decode_bookmark_conference_conference_name(Name)}. + +encode_bookmark_conference_conference([], _acc) -> _acc; +encode_bookmark_conference_conference([{bookmark_conference, + Name, Jid, Autojoin, Nick, Password} + | _tail], + _acc) -> + _els = encode_bookmark_conference_conference_nick(Nick, + encode_bookmark_conference_conference_password(Password, + [])), + _attrs = + encode_bookmark_conference_conference_name(Name, + encode_bookmark_conference_conference_jid(Jid, + encode_bookmark_conference_conference_autojoin(Autojoin, + []))), + encode_bookmark_conference_conference(_tail, + [{xmlel, <<"conference">>, _attrs, + _els} + | _acc]). + +decode_bookmark_conference_conference_name(undefined) -> + erlang:error({missing_attr, <<"name">>, + <<"conference">>, <<>>}); +decode_bookmark_conference_conference_name(_val) -> + _val. + +encode_bookmark_conference_conference_name(_val, + _acc) -> + [{<<"name">>, _val} | _acc]. + +decode_bookmark_conference_conference_jid(undefined) -> + erlang:error({missing_attr, <<"jid">>, <<"conference">>, + <<>>}); +decode_bookmark_conference_conference_jid(_val) -> + case catch dec_jid(_val) of + {'EXIT', _} -> + erlang:error({bad_attr_value, <<"jid">>, + <<"conference">>, <<>>}); + _res -> _res + end. + +encode_bookmark_conference_conference_jid(_val, _acc) -> + [{<<"jid">>, enc_jid(_val)} | _acc]. + +decode_bookmark_conference_conference_autojoin(undefined) -> + false; +decode_bookmark_conference_conference_autojoin(_val) -> + case catch dec_bool(_val) of + {'EXIT', _} -> + erlang:error({bad_attr_value, <<"autojoin">>, + <<"conference">>, <<>>}); + _res -> _res + end. + +encode_bookmark_conference_conference_autojoin(false, + _acc) -> + _acc; +encode_bookmark_conference_conference_autojoin(_val, + _acc) -> + [{<<"autojoin">>, enc_bool(_val)} | _acc]. + +decode_bookmark_conference_conference_password({xmlel, + _, _attrs, _els}) -> + Cdata = + decode_bookmark_conference_conference_password_els(_els, + <<>>), + Cdata. + +decode_bookmark_conference_conference_password_els([{xmlcdata, + _data} + | _els], + Cdata) -> + decode_bookmark_conference_conference_password_els(_els, + <<Cdata/binary, + _data/binary>>); +decode_bookmark_conference_conference_password_els([_ + | _els], + Cdata) -> + decode_bookmark_conference_conference_password_els(_els, + Cdata); +decode_bookmark_conference_conference_password_els([], + Cdata) -> + decode_bookmark_conference_conference_password_cdata(Cdata). + +encode_bookmark_conference_conference_password(undefined, + _acc) -> + _acc; +encode_bookmark_conference_conference_password(Cdata, + _acc) -> + _els = + encode_bookmark_conference_conference_password_cdata(Cdata, + []), + _attrs = [], + [{xmlel, <<"password">>, _attrs, _els} | _acc]. + +decode_bookmark_conference_conference_password_cdata(<<>>) -> + undefined; +decode_bookmark_conference_conference_password_cdata(_val) -> + _val. + +encode_bookmark_conference_conference_password_cdata(undefined, + _acc) -> + _acc; +encode_bookmark_conference_conference_password_cdata(_val, + _acc) -> + [{xmlcdata, _val} | _acc]. + +decode_bookmark_conference_conference_nick({xmlel, _, + _attrs, _els}) -> + Cdata = + decode_bookmark_conference_conference_nick_els(_els, + <<>>), + Cdata. + +decode_bookmark_conference_conference_nick_els([{xmlcdata, + _data} + | _els], + Cdata) -> + decode_bookmark_conference_conference_nick_els(_els, + <<Cdata/binary, + _data/binary>>); +decode_bookmark_conference_conference_nick_els([_ + | _els], + Cdata) -> + decode_bookmark_conference_conference_nick_els(_els, + Cdata); +decode_bookmark_conference_conference_nick_els([], + Cdata) -> + decode_bookmark_conference_conference_nick_cdata(Cdata). + +encode_bookmark_conference_conference_nick(undefined, + _acc) -> + _acc; +encode_bookmark_conference_conference_nick(Cdata, + _acc) -> + _els = + encode_bookmark_conference_conference_nick_cdata(Cdata, + []), + _attrs = [], + [{xmlel, <<"nick">>, _attrs, _els} | _acc]. + +decode_bookmark_conference_conference_nick_cdata(<<>>) -> + undefined; +decode_bookmark_conference_conference_nick_cdata(_val) -> + _val. + +encode_bookmark_conference_conference_nick_cdata(undefined, + _acc) -> + _acc; +encode_bookmark_conference_conference_nick_cdata(_val, + _acc) -> + [{xmlcdata, _val} | _acc]. + +decode_storage_bookmarks_storage({xmlel, _, _attrs, + _els}) -> + {Url, Conference} = + decode_storage_bookmarks_storage_els(_els, [], []), + {bookmark_storage, Conference, Url}. + +decode_storage_bookmarks_storage_els([{xmlel, <<"url">>, + _attrs, _} = + _el + | _els], + Url, Conference) -> + case xml:get_attr_s(<<"xmlns">>, _attrs) of + <<>> -> + decode_storage_bookmarks_storage_els(_els, + [decode_storage_bookmarks_storage_url(_el) + | Url], + Conference); + _ -> + decode_storage_bookmarks_storage_els(_els, Url, + Conference) + end; +decode_storage_bookmarks_storage_els([{xmlel, + <<"conference">>, _attrs, _} = + _el + | _els], + Url, Conference) -> + case xml:get_attr_s(<<"xmlns">>, _attrs) of + <<>> -> + decode_storage_bookmarks_storage_els(_els, Url, + [decode_bookmark_conference_conference(_el) + | Conference]); + _ -> + decode_storage_bookmarks_storage_els(_els, Url, + Conference) + end; +decode_storage_bookmarks_storage_els([_ | _els], Url, + Conference) -> + decode_storage_bookmarks_storage_els(_els, Url, + Conference); +decode_storage_bookmarks_storage_els([], Url, + Conference) -> + {lists:reverse(Url), lists:reverse(Conference)}. + +encode_storage_bookmarks_storage(undefined, _acc) -> + _acc; +encode_storage_bookmarks_storage({bookmark_storage, + Conference, Url}, + _acc) -> + _els = encode_bookmark_conference_conference(Conference, + encode_storage_bookmarks_storage_url(Url, + [])), + _attrs = [{<<"xmlns">>, <<"storage:bookmarks">>}], + [{xmlel, <<"storage">>, _attrs, _els} | _acc]. + +decode_storage_bookmarks_storage_url({xmlel, _, _attrs, + _els}) -> + {Url, Name} = + decode_storage_bookmarks_storage_url_attrs(_attrs, + undefined, undefined), + {bookmark_url, Name, Url}. + +decode_storage_bookmarks_storage_url_attrs([{<<"url">>, + _val} + | _attrs], + _Url, Name) -> + decode_storage_bookmarks_storage_url_attrs(_attrs, _val, + Name); +decode_storage_bookmarks_storage_url_attrs([{<<"name">>, + _val} + | _attrs], + Url, _Name) -> + decode_storage_bookmarks_storage_url_attrs(_attrs, Url, + _val); +decode_storage_bookmarks_storage_url_attrs([_ | _attrs], + Url, Name) -> + decode_storage_bookmarks_storage_url_attrs(_attrs, Url, + Name); +decode_storage_bookmarks_storage_url_attrs([], Url, + Name) -> + {decode_storage_bookmarks_storage_url_url(Url), + decode_storage_bookmarks_storage_url_name(Name)}. + +encode_storage_bookmarks_storage_url([], _acc) -> _acc; +encode_storage_bookmarks_storage_url([{bookmark_url, + Name, Url} + | _tail], + _acc) -> + _els = [], + _attrs = encode_storage_bookmarks_storage_url_name(Name, + encode_storage_bookmarks_storage_url_url(Url, + [])), + encode_storage_bookmarks_storage_url(_tail, + [{xmlel, <<"url">>, _attrs, _els} + | _acc]). + +decode_storage_bookmarks_storage_url_name(undefined) -> + erlang:error({missing_attr, <<"name">>, <<"url">>, + <<>>}); +decode_storage_bookmarks_storage_url_name(_val) -> _val. + +encode_storage_bookmarks_storage_url_name(_val, _acc) -> + [{<<"name">>, _val} | _acc]. + +decode_storage_bookmarks_storage_url_url(undefined) -> + erlang:error({missing_attr, <<"url">>, <<"url">>, + <<>>}); +decode_storage_bookmarks_storage_url_url(_val) -> _val. + +encode_storage_bookmarks_storage_url_url(_val, _acc) -> + [{<<"url">>, _val} | _acc]. + +decode_stats_query({xmlel, _, _attrs, _els}) -> + Stat = decode_stats_query_els(_els, []), {stats, Stat}. + +decode_stats_query_els([{xmlel, <<"stat">>, _attrs, _} = + _el + | _els], + Stat) -> + case xml:get_attr_s(<<"xmlns">>, _attrs) of + <<>> -> + decode_stats_query_els(_els, + [decode_stats_query_stat(_el) | Stat]); + _ -> decode_stats_query_els(_els, Stat) + end; +decode_stats_query_els([_ | _els], Stat) -> + decode_stats_query_els(_els, Stat); +decode_stats_query_els([], Stat) -> lists:reverse(Stat). + +encode_stats_query(undefined, _acc) -> _acc; +encode_stats_query({stats, Stat}, _acc) -> + _els = encode_stats_query_stat(Stat, []), + _attrs = [{<<"xmlns">>, + <<"http://jabber.org/protocol/stats">>}], + [{xmlel, <<"query">>, _attrs, _els} | _acc]. + +decode_stats_query_stat({xmlel, _, _attrs, _els}) -> + {Value, Units, Name} = + decode_stats_query_stat_attrs(_attrs, undefined, + undefined, undefined), + Error = decode_stats_query_stat_els(_els, []), + {stat, Name, Units, Value, Error}. + +decode_stats_query_stat_els([{xmlel, <<"error">>, + _attrs, _} = + _el + | _els], + Error) -> + case xml:get_attr_s(<<"xmlns">>, _attrs) of + <<>> -> + decode_stats_query_stat_els(_els, + [decode_stats_query_stat_error(_el) + | Error]); + _ -> decode_stats_query_stat_els(_els, Error) + end; +decode_stats_query_stat_els([_ | _els], Error) -> + decode_stats_query_stat_els(_els, Error); +decode_stats_query_stat_els([], Error) -> + lists:reverse(Error). + +decode_stats_query_stat_attrs([{<<"value">>, _val} + | _attrs], + _Value, Units, Name) -> + decode_stats_query_stat_attrs(_attrs, _val, Units, + Name); +decode_stats_query_stat_attrs([{<<"units">>, _val} + | _attrs], + Value, _Units, Name) -> + decode_stats_query_stat_attrs(_attrs, Value, _val, + Name); +decode_stats_query_stat_attrs([{<<"name">>, _val} + | _attrs], + Value, Units, _Name) -> + decode_stats_query_stat_attrs(_attrs, Value, Units, + _val); +decode_stats_query_stat_attrs([_ | _attrs], Value, + Units, Name) -> + decode_stats_query_stat_attrs(_attrs, Value, Units, + Name); +decode_stats_query_stat_attrs([], Value, Units, Name) -> + {decode_stats_query_stat_value(Value), + decode_stats_query_stat_units(Units), + decode_stats_query_stat_name(Name)}. + +encode_stats_query_stat([], _acc) -> _acc; +encode_stats_query_stat([{stat, Name, Units, Value, + Error} + | _tail], + _acc) -> + _els = encode_stats_query_stat_error(Error, []), + _attrs = encode_stats_query_stat_name(Name, + encode_stats_query_stat_units(Units, + encode_stats_query_stat_value(Value, + []))), + encode_stats_query_stat(_tail, + [{xmlel, <<"stat">>, _attrs, _els} | _acc]). + +decode_stats_query_stat_name(undefined) -> + erlang:error({missing_attr, <<"name">>, <<"stat">>, + <<>>}); +decode_stats_query_stat_name(_val) -> _val. + +encode_stats_query_stat_name(_val, _acc) -> + [{<<"name">>, _val} | _acc]. + +decode_stats_query_stat_units(undefined) -> undefined; +decode_stats_query_stat_units(_val) -> _val. + +encode_stats_query_stat_units(undefined, _acc) -> _acc; +encode_stats_query_stat_units(_val, _acc) -> + [{<<"units">>, _val} | _acc]. + +decode_stats_query_stat_value(undefined) -> undefined; +decode_stats_query_stat_value(_val) -> _val. + +encode_stats_query_stat_value(undefined, _acc) -> _acc; +encode_stats_query_stat_value(_val, _acc) -> + [{<<"value">>, _val} | _acc]. + +decode_stats_query_stat_error({xmlel, _, _attrs, + _els}) -> + Code = decode_stats_query_stat_error_attrs(_attrs, + undefined), + Cdata = decode_stats_query_stat_error_els(_els, <<>>), + {Code, Cdata}. + +decode_stats_query_stat_error_els([{xmlcdata, _data} + | _els], + Cdata) -> + decode_stats_query_stat_error_els(_els, + <<Cdata/binary, _data/binary>>); +decode_stats_query_stat_error_els([_ | _els], Cdata) -> + decode_stats_query_stat_error_els(_els, Cdata); +decode_stats_query_stat_error_els([], Cdata) -> + decode_stats_query_stat_error_cdata(Cdata). + +decode_stats_query_stat_error_attrs([{<<"code">>, _val} + | _attrs], + _Code) -> + decode_stats_query_stat_error_attrs(_attrs, _val); +decode_stats_query_stat_error_attrs([_ | _attrs], + Code) -> + decode_stats_query_stat_error_attrs(_attrs, Code); +decode_stats_query_stat_error_attrs([], Code) -> + decode_stats_query_stat_error_code(Code). + +encode_stats_query_stat_error([], _acc) -> _acc; +encode_stats_query_stat_error([{Code, Cdata} | _tail], + _acc) -> + _els = encode_stats_query_stat_error_cdata(Cdata, []), + _attrs = encode_stats_query_stat_error_code(Code, []), + encode_stats_query_stat_error(_tail, + [{xmlel, <<"error">>, _attrs, _els} | _acc]). + +decode_stats_query_stat_error_code(undefined) -> + erlang:error({missing_attr, <<"code">>, <<"error">>, + <<>>}); +decode_stats_query_stat_error_code(_val) -> + case catch xml_gen:dec_int(_val) of + {'EXIT', _} -> + erlang:error({bad_attr_value, <<"code">>, <<"error">>, + <<>>}); + _res -> _res + end. + +encode_stats_query_stat_error_code(_val, _acc) -> + [{<<"code">>, xml_gen:enc_int(_val)} | _acc]. + +decode_stats_query_stat_error_cdata(<<>>) -> undefined; +decode_stats_query_stat_error_cdata(_val) -> _val. + +encode_stats_query_stat_error_cdata(undefined, _acc) -> + _acc; +encode_stats_query_stat_error_cdata(_val, _acc) -> + [{xmlcdata, _val} | _acc]. + +decode_iq_iq({xmlel, _, _attrs, _els}) -> + {To, From, Lang, Type, Id} = decode_iq_iq_attrs(_attrs, + undefined, undefined, + undefined, undefined, + undefined), + {__Els, Error} = decode_iq_iq_els(_els, [], undefined), + {iq, Id, Type, Lang, From, To, Error, __Els}. + +decode_iq_iq_els([{xmlel, <<"error">>, _attrs, _} = _el + | _els], + __Els, Error) -> + case xml:get_attr_s(<<"xmlns">>, _attrs) of + <<>> -> + decode_iq_iq_els(_els, __Els, decode_error_error(_el)); + _ -> + decode_iq_iq_els(_els, [decode(_el) | __Els], Error) + end; +decode_iq_iq_els([{xmlel, _, _, _} = _el | _els], __Els, + Error) -> + decode_iq_iq_els(_els, [decode(_el) | __Els], Error); +decode_iq_iq_els([_ | _els], __Els, Error) -> + decode_iq_iq_els(_els, __Els, Error); +decode_iq_iq_els([], __Els, Error) -> + {lists:reverse(__Els), Error}. + +decode_iq_iq_attrs([{<<"to">>, _val} | _attrs], _To, + From, Lang, Type, Id) -> + decode_iq_iq_attrs(_attrs, _val, From, Lang, Type, Id); +decode_iq_iq_attrs([{<<"from">>, _val} | _attrs], To, + _From, Lang, Type, Id) -> + decode_iq_iq_attrs(_attrs, To, _val, Lang, Type, Id); +decode_iq_iq_attrs([{<<"xml:lang">>, _val} | _attrs], + To, From, _Lang, Type, Id) -> + decode_iq_iq_attrs(_attrs, To, From, _val, Type, Id); +decode_iq_iq_attrs([{<<"type">>, _val} | _attrs], To, + From, Lang, _Type, Id) -> + decode_iq_iq_attrs(_attrs, To, From, Lang, _val, Id); +decode_iq_iq_attrs([{<<"id">>, _val} | _attrs], To, + From, Lang, Type, _Id) -> + decode_iq_iq_attrs(_attrs, To, From, Lang, Type, _val); +decode_iq_iq_attrs([_ | _attrs], To, From, Lang, Type, + Id) -> + decode_iq_iq_attrs(_attrs, To, From, Lang, Type, Id); +decode_iq_iq_attrs([], To, From, Lang, Type, Id) -> + {decode_iq_iq_to(To), decode_iq_iq_from(From), + 'decode_iq_iq_xml:lang'(Lang), decode_iq_iq_type(Type), + decode_iq_iq_id(Id)}. + +encode_iq_iq(undefined, _acc) -> _acc; +encode_iq_iq({iq, Id, Type, Lang, From, To, Error, + __Els}, + _acc) -> + _els = encode_error_error(Error, + [encode(_subel) || _subel <- __Els] ++ []), + _attrs = encode_iq_iq_id(Id, + encode_iq_iq_type(Type, + 'encode_iq_iq_xml:lang'(Lang, + encode_iq_iq_from(From, + encode_iq_iq_to(To, + []))))), + [{xmlel, <<"iq">>, _attrs, _els} | _acc]. + +decode_iq_iq_id(undefined) -> + erlang:error({missing_attr, <<"id">>, <<"iq">>, <<>>}); +decode_iq_iq_id(_val) -> _val. + +encode_iq_iq_id(_val, _acc) -> + [{<<"id">>, _val} | _acc]. + +decode_iq_iq_type(undefined) -> + erlang:error({missing_attr, <<"type">>, <<"iq">>, + <<>>}); +decode_iq_iq_type(_val) -> + case catch xml_gen:dec_enum(_val, + [get, set, result, error]) + of + {'EXIT', _} -> + erlang:error({bad_attr_value, <<"type">>, <<"iq">>, + <<>>}); + _res -> _res + end. + +encode_iq_iq_type(_val, _acc) -> + [{<<"type">>, xml_gen:enc_enum(_val)} | _acc]. + +decode_iq_iq_from(undefined) -> undefined; +decode_iq_iq_from(_val) -> + case catch dec_jid(_val) of + {'EXIT', _} -> + erlang:error({bad_attr_value, <<"from">>, <<"iq">>, + <<>>}); + _res -> _res + end. + +encode_iq_iq_from(undefined, _acc) -> _acc; +encode_iq_iq_from(_val, _acc) -> + [{<<"from">>, enc_jid(_val)} | _acc]. + +decode_iq_iq_to(undefined) -> undefined; +decode_iq_iq_to(_val) -> + case catch dec_jid(_val) of + {'EXIT', _} -> + erlang:error({bad_attr_value, <<"to">>, <<"iq">>, + <<>>}); + _res -> _res + end. + +encode_iq_iq_to(undefined, _acc) -> _acc; +encode_iq_iq_to(_val, _acc) -> + [{<<"to">>, enc_jid(_val)} | _acc]. + +'decode_iq_iq_xml:lang'(undefined) -> undefined; +'decode_iq_iq_xml:lang'(_val) -> _val. + +'encode_iq_iq_xml:lang'(undefined, _acc) -> _acc; +'encode_iq_iq_xml:lang'(_val, _acc) -> + [{<<"xml:lang">>, _val} | _acc]. + +decode_message_message({xmlel, _, _attrs, _els}) -> + {To, From, Lang, Type, Id} = + decode_message_message_attrs(_attrs, undefined, + undefined, undefined, undefined, + undefined), + {__Els, Error, Thread, Body, Subject} = + decode_message_message_els(_els, [], undefined, + undefined, [], []), + {message, Id, Type, Lang, From, To, Subject, Body, + Thread, Error, __Els}. + +decode_message_message_els([{xmlel, <<"error">>, _attrs, + _} = + _el + | _els], + __Els, Error, Thread, Body, Subject) -> + case xml:get_attr_s(<<"xmlns">>, _attrs) of + <<>> -> + decode_message_message_els(_els, __Els, + decode_error_error(_el), Thread, Body, + Subject); + _ -> + decode_message_message_els(_els, [decode(_el) | __Els], + Error, Thread, Body, Subject) + end; +decode_message_message_els([{xmlel, <<"thread">>, + _attrs, _} = + _el + | _els], + __Els, Error, Thread, Body, Subject) -> + case xml:get_attr_s(<<"xmlns">>, _attrs) of + <<>> -> + decode_message_message_els(_els, __Els, Error, + decode_message_message_thread(_el), Body, + Subject); + _ -> + decode_message_message_els(_els, [decode(_el) | __Els], + Error, Thread, Body, Subject) + end; +decode_message_message_els([{xmlel, <<"body">>, _attrs, + _} = + _el + | _els], + __Els, Error, Thread, Body, Subject) -> + case xml:get_attr_s(<<"xmlns">>, _attrs) of + <<>> -> + decode_message_message_els(_els, __Els, Error, Thread, + [decode_message_message_body(_el) | Body], + Subject); + _ -> + decode_message_message_els(_els, [decode(_el) | __Els], + Error, Thread, Body, Subject) + end; +decode_message_message_els([{xmlel, <<"subject">>, + _attrs, _} = + _el + | _els], + __Els, Error, Thread, Body, Subject) -> + case xml:get_attr_s(<<"xmlns">>, _attrs) of + <<>> -> + decode_message_message_els(_els, __Els, Error, Thread, + Body, + [decode_message_message_subject(_el) + | Subject]); + _ -> + decode_message_message_els(_els, [decode(_el) | __Els], + Error, Thread, Body, Subject) + end; +decode_message_message_els([{xmlel, _, _, _} = _el + | _els], + __Els, Error, Thread, Body, Subject) -> + decode_message_message_els(_els, [decode(_el) | __Els], + Error, Thread, Body, Subject); +decode_message_message_els([_ | _els], __Els, Error, + Thread, Body, Subject) -> + decode_message_message_els(_els, __Els, Error, Thread, + Body, Subject); +decode_message_message_els([], __Els, Error, Thread, + Body, Subject) -> + {lists:reverse(__Els), Error, Thread, + lists:reverse(Body), lists:reverse(Subject)}. + +decode_message_message_attrs([{<<"to">>, _val} + | _attrs], + _To, From, Lang, Type, Id) -> + decode_message_message_attrs(_attrs, _val, From, Lang, + Type, Id); +decode_message_message_attrs([{<<"from">>, _val} + | _attrs], + To, _From, Lang, Type, Id) -> + decode_message_message_attrs(_attrs, To, _val, Lang, + Type, Id); +decode_message_message_attrs([{<<"xml:lang">>, _val} + | _attrs], + To, From, _Lang, Type, Id) -> + decode_message_message_attrs(_attrs, To, From, _val, + Type, Id); +decode_message_message_attrs([{<<"type">>, _val} + | _attrs], + To, From, Lang, _Type, Id) -> + decode_message_message_attrs(_attrs, To, From, Lang, + _val, Id); +decode_message_message_attrs([{<<"id">>, _val} + | _attrs], + To, From, Lang, Type, _Id) -> + decode_message_message_attrs(_attrs, To, From, Lang, + Type, _val); +decode_message_message_attrs([_ | _attrs], To, From, + Lang, Type, Id) -> + decode_message_message_attrs(_attrs, To, From, Lang, + Type, Id); +decode_message_message_attrs([], To, From, Lang, Type, + Id) -> + {decode_message_message_to(To), + decode_message_message_from(From), + 'decode_message_message_xml:lang'(Lang), + decode_message_message_type(Type), + decode_message_message_id(Id)}. + +encode_message_message(undefined, _acc) -> _acc; +encode_message_message({message, Id, Type, Lang, From, + To, Subject, Body, Thread, Error, __Els}, + _acc) -> + _els = encode_message_message_subject(Subject, + encode_message_message_body(Body, + encode_message_message_thread(Thread, + encode_error_error(Error, + [encode(_subel) + || _subel + <- __Els] + ++ + [])))), + _attrs = encode_message_message_id(Id, + encode_message_message_type(Type, + 'encode_message_message_xml:lang'(Lang, + encode_message_message_from(From, + encode_message_message_to(To, + []))))), + [{xmlel, <<"message">>, _attrs, _els} | _acc]. + +decode_message_message_id(undefined) -> undefined; +decode_message_message_id(_val) -> _val. + +encode_message_message_id(undefined, _acc) -> _acc; +encode_message_message_id(_val, _acc) -> + [{<<"id">>, _val} | _acc]. + +decode_message_message_type(undefined) -> normal; +decode_message_message_type(_val) -> + case catch xml_gen:dec_enum(_val, + [chat, normal, groupchat, headline, error]) + of + {'EXIT', _} -> + erlang:error({bad_attr_value, <<"type">>, <<"message">>, + <<>>}); + _res -> _res + end. + +encode_message_message_type(normal, _acc) -> _acc; +encode_message_message_type(_val, _acc) -> + [{<<"type">>, xml_gen:enc_enum(_val)} | _acc]. + +decode_message_message_from(undefined) -> undefined; +decode_message_message_from(_val) -> + case catch dec_jid(_val) of + {'EXIT', _} -> + erlang:error({bad_attr_value, <<"from">>, <<"message">>, + <<>>}); + _res -> _res + end. + +encode_message_message_from(undefined, _acc) -> _acc; +encode_message_message_from(_val, _acc) -> + [{<<"from">>, enc_jid(_val)} | _acc]. + +decode_message_message_to(undefined) -> undefined; +decode_message_message_to(_val) -> + case catch dec_jid(_val) of + {'EXIT', _} -> + erlang:error({bad_attr_value, <<"to">>, <<"message">>, + <<>>}); + _res -> _res + end. + +encode_message_message_to(undefined, _acc) -> _acc; +encode_message_message_to(_val, _acc) -> + [{<<"to">>, enc_jid(_val)} | _acc]. + +'decode_message_message_xml:lang'(undefined) -> + undefined; +'decode_message_message_xml:lang'(_val) -> _val. + +'encode_message_message_xml:lang'(undefined, _acc) -> + _acc; +'encode_message_message_xml:lang'(_val, _acc) -> + [{<<"xml:lang">>, _val} | _acc]. + +decode_message_message_thread({xmlel, _, _attrs, + _els}) -> + Cdata = decode_message_message_thread_els(_els, <<>>), + Cdata. + +decode_message_message_thread_els([{xmlcdata, _data} + | _els], + Cdata) -> + decode_message_message_thread_els(_els, + <<Cdata/binary, _data/binary>>); +decode_message_message_thread_els([_ | _els], Cdata) -> + decode_message_message_thread_els(_els, Cdata); +decode_message_message_thread_els([], Cdata) -> + decode_message_message_thread_cdata(Cdata). + +encode_message_message_thread(undefined, _acc) -> _acc; +encode_message_message_thread(Cdata, _acc) -> + _els = encode_message_message_thread_cdata(Cdata, []), + _attrs = [], + [{xmlel, <<"thread">>, _attrs, _els} | _acc]. + +decode_message_message_thread_cdata(<<>>) -> undefined; +decode_message_message_thread_cdata(_val) -> _val. + +encode_message_message_thread_cdata(undefined, _acc) -> + _acc; +encode_message_message_thread_cdata(_val, _acc) -> + [{xmlcdata, _val} | _acc]. + +decode_message_message_body({xmlel, _, _attrs, _els}) -> + Body_lang = decode_message_message_body_attrs(_attrs, + undefined), + Cdata = decode_message_message_body_els(_els, <<>>), + {Body_lang, Cdata}. + +decode_message_message_body_els([{xmlcdata, _data} + | _els], + Cdata) -> + decode_message_message_body_els(_els, + <<Cdata/binary, _data/binary>>); +decode_message_message_body_els([_ | _els], Cdata) -> + decode_message_message_body_els(_els, Cdata); +decode_message_message_body_els([], Cdata) -> + decode_message_message_body_cdata(Cdata). + +decode_message_message_body_attrs([{<<"xml:lang">>, + _val} + | _attrs], + _Body_lang) -> + decode_message_message_body_attrs(_attrs, _val); +decode_message_message_body_attrs([_ | _attrs], + Body_lang) -> + decode_message_message_body_attrs(_attrs, Body_lang); +decode_message_message_body_attrs([], Body_lang) -> + 'decode_message_message_body_xml:lang'(Body_lang). + +encode_message_message_body([], _acc) -> _acc; +encode_message_message_body([{Body_lang, Cdata} + | _tail], + _acc) -> + _els = encode_message_message_body_cdata(Cdata, []), + _attrs = + 'encode_message_message_body_xml:lang'(Body_lang, []), + encode_message_message_body(_tail, + [{xmlel, <<"body">>, _attrs, _els} | _acc]). + +'decode_message_message_body_xml:lang'(undefined) -> + undefined; +'decode_message_message_body_xml:lang'(_val) -> _val. + +'encode_message_message_body_xml:lang'(undefined, + _acc) -> + _acc; +'encode_message_message_body_xml:lang'(_val, _acc) -> + [{<<"xml:lang">>, _val} | _acc]. + +decode_message_message_body_cdata(<<>>) -> undefined; +decode_message_message_body_cdata(_val) -> _val. + +encode_message_message_body_cdata(undefined, _acc) -> + _acc; +encode_message_message_body_cdata(_val, _acc) -> + [{xmlcdata, _val} | _acc]. + +decode_message_message_subject({xmlel, _, _attrs, + _els}) -> + Subject_lang = + decode_message_message_subject_attrs(_attrs, undefined), + Cdata = decode_message_message_subject_els(_els, <<>>), + {Subject_lang, Cdata}. + +decode_message_message_subject_els([{xmlcdata, _data} + | _els], + Cdata) -> + decode_message_message_subject_els(_els, + <<Cdata/binary, _data/binary>>); +decode_message_message_subject_els([_ | _els], Cdata) -> + decode_message_message_subject_els(_els, Cdata); +decode_message_message_subject_els([], Cdata) -> + decode_message_message_subject_cdata(Cdata). + +decode_message_message_subject_attrs([{<<"xml:lang">>, + _val} + | _attrs], + _Subject_lang) -> + decode_message_message_subject_attrs(_attrs, _val); +decode_message_message_subject_attrs([_ | _attrs], + Subject_lang) -> + decode_message_message_subject_attrs(_attrs, + Subject_lang); +decode_message_message_subject_attrs([], + Subject_lang) -> + 'decode_message_message_subject_xml:lang'(Subject_lang). + +encode_message_message_subject([], _acc) -> _acc; +encode_message_message_subject([{Subject_lang, Cdata} + | _tail], + _acc) -> + _els = encode_message_message_subject_cdata(Cdata, []), + _attrs = + 'encode_message_message_subject_xml:lang'(Subject_lang, + []), + encode_message_message_subject(_tail, + [{xmlel, <<"subject">>, _attrs, _els} + | _acc]). + +'decode_message_message_subject_xml:lang'(undefined) -> + undefined; +'decode_message_message_subject_xml:lang'(_val) -> _val. + +'encode_message_message_subject_xml:lang'(undefined, + _acc) -> + _acc; +'encode_message_message_subject_xml:lang'(_val, _acc) -> + [{<<"xml:lang">>, _val} | _acc]. + +decode_message_message_subject_cdata(<<>>) -> undefined; +decode_message_message_subject_cdata(_val) -> _val. + +encode_message_message_subject_cdata(undefined, _acc) -> + _acc; +encode_message_message_subject_cdata(_val, _acc) -> + [{xmlcdata, _val} | _acc]. + +decode_presence_presence({xmlel, _, _attrs, _els}) -> + {To, From, Lang, Type, Id} = + decode_presence_presence_attrs(_attrs, undefined, + undefined, undefined, undefined, + undefined), + {__Els, Error, Priority, Status, Show} = + decode_presence_presence_els(_els, [], undefined, + undefined, [], undefined), + {presence, Id, Type, Lang, From, To, Show, Status, + Priority, Error, __Els}. + +decode_presence_presence_els([{xmlel, <<"error">>, + _attrs, _} = + _el + | _els], + __Els, Error, Priority, Status, Show) -> + case xml:get_attr_s(<<"xmlns">>, _attrs) of + <<>> -> + decode_presence_presence_els(_els, __Els, + decode_error_error(_el), Priority, + Status, Show); + _ -> + decode_presence_presence_els(_els, + [decode(_el) | __Els], Error, Priority, + Status, Show) + end; +decode_presence_presence_els([{xmlel, <<"priority">>, + _attrs, _} = + _el + | _els], + __Els, Error, Priority, Status, Show) -> + case xml:get_attr_s(<<"xmlns">>, _attrs) of + <<>> -> + decode_presence_presence_els(_els, __Els, Error, + decode_presence_presence_priority(_el), + Status, Show); + _ -> + decode_presence_presence_els(_els, + [decode(_el) | __Els], Error, Priority, + Status, Show) + end; +decode_presence_presence_els([{xmlel, <<"status">>, + _attrs, _} = + _el + | _els], + __Els, Error, Priority, Status, Show) -> + case xml:get_attr_s(<<"xmlns">>, _attrs) of + <<>> -> + decode_presence_presence_els(_els, __Els, Error, + Priority, + [decode_presence_presence_status(_el) + | Status], + Show); + _ -> + decode_presence_presence_els(_els, + [decode(_el) | __Els], Error, Priority, + Status, Show) + end; +decode_presence_presence_els([{xmlel, <<"show">>, + _attrs, _} = + _el + | _els], + __Els, Error, Priority, Status, Show) -> + case xml:get_attr_s(<<"xmlns">>, _attrs) of + <<>> -> + decode_presence_presence_els(_els, __Els, Error, + Priority, Status, + decode_presence_presence_show(_el)); + _ -> + decode_presence_presence_els(_els, + [decode(_el) | __Els], Error, Priority, + Status, Show) + end; +decode_presence_presence_els([{xmlel, _, _, _} = _el + | _els], + __Els, Error, Priority, Status, Show) -> + decode_presence_presence_els(_els, + [decode(_el) | __Els], Error, Priority, Status, + Show); +decode_presence_presence_els([_ | _els], __Els, Error, + Priority, Status, Show) -> + decode_presence_presence_els(_els, __Els, Error, + Priority, Status, Show); +decode_presence_presence_els([], __Els, Error, Priority, + Status, Show) -> + {lists:reverse(__Els), Error, Priority, + lists:reverse(Status), Show}. + +decode_presence_presence_attrs([{<<"to">>, _val} + | _attrs], + _To, From, Lang, Type, Id) -> + decode_presence_presence_attrs(_attrs, _val, From, Lang, + Type, Id); +decode_presence_presence_attrs([{<<"from">>, _val} + | _attrs], + To, _From, Lang, Type, Id) -> + decode_presence_presence_attrs(_attrs, To, _val, Lang, + Type, Id); +decode_presence_presence_attrs([{<<"xml:lang">>, _val} + | _attrs], + To, From, _Lang, Type, Id) -> + decode_presence_presence_attrs(_attrs, To, From, _val, + Type, Id); +decode_presence_presence_attrs([{<<"type">>, _val} + | _attrs], + To, From, Lang, _Type, Id) -> + decode_presence_presence_attrs(_attrs, To, From, Lang, + _val, Id); +decode_presence_presence_attrs([{<<"id">>, _val} + | _attrs], + To, From, Lang, Type, _Id) -> + decode_presence_presence_attrs(_attrs, To, From, Lang, + Type, _val); +decode_presence_presence_attrs([_ | _attrs], To, From, + Lang, Type, Id) -> + decode_presence_presence_attrs(_attrs, To, From, Lang, + Type, Id); +decode_presence_presence_attrs([], To, From, Lang, Type, + Id) -> + {decode_presence_presence_to(To), + decode_presence_presence_from(From), + 'decode_presence_presence_xml:lang'(Lang), + decode_presence_presence_type(Type), + decode_presence_presence_id(Id)}. + +encode_presence_presence(undefined, _acc) -> _acc; +encode_presence_presence({presence, Id, Type, Lang, + From, To, Show, Status, Priority, Error, __Els}, + _acc) -> + _els = encode_presence_presence_show(Show, + encode_presence_presence_status(Status, + encode_presence_presence_priority(Priority, + encode_error_error(Error, + [encode(_subel) + || _subel + <- __Els] + ++ + [])))), + _attrs = encode_presence_presence_id(Id, + encode_presence_presence_type(Type, + 'encode_presence_presence_xml:lang'(Lang, + encode_presence_presence_from(From, + encode_presence_presence_to(To, + []))))), + [{xmlel, <<"presence">>, _attrs, _els} | _acc]. + +decode_presence_presence_id(undefined) -> undefined; +decode_presence_presence_id(_val) -> _val. + +encode_presence_presence_id(undefined, _acc) -> _acc; +encode_presence_presence_id(_val, _acc) -> + [{<<"id">>, _val} | _acc]. + +decode_presence_presence_type(undefined) -> undefined; +decode_presence_presence_type(_val) -> + case catch xml_gen:dec_enum(_val, + [unavailable, subscribe, subscribed, + unsubscribe, unsubscribed, probe, error]) + of + {'EXIT', _} -> + erlang:error({bad_attr_value, <<"type">>, + <<"presence">>, <<>>}); + _res -> _res + end. + +encode_presence_presence_type(undefined, _acc) -> _acc; +encode_presence_presence_type(_val, _acc) -> + [{<<"type">>, xml_gen:enc_enum(_val)} | _acc]. + +decode_presence_presence_from(undefined) -> undefined; +decode_presence_presence_from(_val) -> + case catch dec_jid(_val) of + {'EXIT', _} -> + erlang:error({bad_attr_value, <<"from">>, + <<"presence">>, <<>>}); + _res -> _res + end. + +encode_presence_presence_from(undefined, _acc) -> _acc; +encode_presence_presence_from(_val, _acc) -> + [{<<"from">>, enc_jid(_val)} | _acc]. + +decode_presence_presence_to(undefined) -> undefined; +decode_presence_presence_to(_val) -> + case catch dec_jid(_val) of + {'EXIT', _} -> + erlang:error({bad_attr_value, <<"to">>, <<"presence">>, + <<>>}); + _res -> _res + end. + +encode_presence_presence_to(undefined, _acc) -> _acc; +encode_presence_presence_to(_val, _acc) -> + [{<<"to">>, enc_jid(_val)} | _acc]. + +'decode_presence_presence_xml:lang'(undefined) -> + undefined; +'decode_presence_presence_xml:lang'(_val) -> _val. + +'encode_presence_presence_xml:lang'(undefined, _acc) -> + _acc; +'encode_presence_presence_xml:lang'(_val, _acc) -> + [{<<"xml:lang">>, _val} | _acc]. + +decode_presence_presence_priority({xmlel, _, _attrs, + _els}) -> + Cdata = decode_presence_presence_priority_els(_els, + <<>>), + Cdata. + +decode_presence_presence_priority_els([{xmlcdata, _data} + | _els], + Cdata) -> + decode_presence_presence_priority_els(_els, + <<Cdata/binary, _data/binary>>); +decode_presence_presence_priority_els([_ | _els], + Cdata) -> + decode_presence_presence_priority_els(_els, Cdata); +decode_presence_presence_priority_els([], Cdata) -> + decode_presence_presence_priority_cdata(Cdata). + +encode_presence_presence_priority(undefined, _acc) -> + _acc; +encode_presence_presence_priority(Cdata, _acc) -> + _els = encode_presence_presence_priority_cdata(Cdata, + []), + _attrs = [], + [{xmlel, <<"priority">>, _attrs, _els} | _acc]. + +decode_presence_presence_priority_cdata(<<>>) -> + undefined; +decode_presence_presence_priority_cdata(_val) -> + case catch xml_gen:dec_int(_val, -128, 127) of + {'EXIT', _} -> + erlang:error({bad_cdata_value, <<>>, <<"priority">>, + <<>>}); + _res -> _res + end. + +encode_presence_presence_priority_cdata(undefined, + _acc) -> + _acc; +encode_presence_presence_priority_cdata(_val, _acc) -> + [{xmlcdata, xml_gen:enc_int(_val)} | _acc]. + +decode_presence_presence_status({xmlel, _, _attrs, + _els}) -> + Status_lang = + decode_presence_presence_status_attrs(_attrs, + undefined), + Cdata = decode_presence_presence_status_els(_els, <<>>), + {Status_lang, Cdata}. + +decode_presence_presence_status_els([{xmlcdata, _data} + | _els], + Cdata) -> + decode_presence_presence_status_els(_els, + <<Cdata/binary, _data/binary>>); +decode_presence_presence_status_els([_ | _els], + Cdata) -> + decode_presence_presence_status_els(_els, Cdata); +decode_presence_presence_status_els([], Cdata) -> + decode_presence_presence_status_cdata(Cdata). + +decode_presence_presence_status_attrs([{<<"xml:lang">>, + _val} + | _attrs], + _Status_lang) -> + decode_presence_presence_status_attrs(_attrs, _val); +decode_presence_presence_status_attrs([_ | _attrs], + Status_lang) -> + decode_presence_presence_status_attrs(_attrs, + Status_lang); +decode_presence_presence_status_attrs([], + Status_lang) -> + 'decode_presence_presence_status_xml:lang'(Status_lang). + +encode_presence_presence_status([], _acc) -> _acc; +encode_presence_presence_status([{Status_lang, Cdata} + | _tail], + _acc) -> + _els = encode_presence_presence_status_cdata(Cdata, []), + _attrs = + 'encode_presence_presence_status_xml:lang'(Status_lang, + []), + encode_presence_presence_status(_tail, + [{xmlel, <<"status">>, _attrs, _els} + | _acc]). + +'decode_presence_presence_status_xml:lang'(undefined) -> + undefined; +'decode_presence_presence_status_xml:lang'(_val) -> + _val. + +'encode_presence_presence_status_xml:lang'(undefined, + _acc) -> + _acc; +'encode_presence_presence_status_xml:lang'(_val, + _acc) -> + [{<<"xml:lang">>, _val} | _acc]. + +decode_presence_presence_status_cdata(<<>>) -> + undefined; +decode_presence_presence_status_cdata(_val) -> _val. + +encode_presence_presence_status_cdata(undefined, + _acc) -> + _acc; +encode_presence_presence_status_cdata(_val, _acc) -> + [{xmlcdata, _val} | _acc]. + +decode_presence_presence_show({xmlel, _, _attrs, + _els}) -> + Cdata = decode_presence_presence_show_els(_els, <<>>), + Cdata. + +decode_presence_presence_show_els([{xmlcdata, _data} + | _els], + Cdata) -> + decode_presence_presence_show_els(_els, + <<Cdata/binary, _data/binary>>); +decode_presence_presence_show_els([_ | _els], Cdata) -> + decode_presence_presence_show_els(_els, Cdata); +decode_presence_presence_show_els([], Cdata) -> + decode_presence_presence_show_cdata(Cdata). + +encode_presence_presence_show(undefined, _acc) -> _acc; +encode_presence_presence_show(Cdata, _acc) -> + _els = encode_presence_presence_show_cdata(Cdata, []), + _attrs = [], + [{xmlel, <<"show">>, _attrs, _els} | _acc]. + +decode_presence_presence_show_cdata(<<>>) -> undefined; +decode_presence_presence_show_cdata(_val) -> + case catch xml_gen:dec_enum(_val, [away, chat, dnd, xa]) + of + {'EXIT', _} -> + erlang:error({bad_cdata_value, <<>>, <<"show">>, <<>>}); + _res -> _res + end. + +encode_presence_presence_show_cdata(undefined, _acc) -> + _acc; +encode_presence_presence_show_cdata(_val, _acc) -> + [{xmlcdata, xml_gen:enc_enum(_val)} | _acc]. + +decode_error_error({xmlel, _, _attrs, _els}) -> + {By, Error_type} = decode_error_error_attrs(_attrs, + undefined, undefined), + {Text, Reason} = decode_error_error_els(_els, undefined, + undefined), + {error, Error_type, By, Reason, Text}. + +decode_error_error_els([{xmlel, <<"text">>, _attrs, _} = + _el + | _els], + Text, Reason) -> + case xml:get_attr_s(<<"xmlns">>, _attrs) of + <<"urn:ietf:params:xml:ns:xmpp-stanzas">> -> + decode_error_error_els(_els, + decode_error_error_text(_el), Reason); + _ -> decode_error_error_els(_els, Text, Reason) + end; +decode_error_error_els([{xmlel, + <<"unexpected-request">>, _attrs, _} = + _el + | _els], + Text, Reason) -> + case xml:get_attr_s(<<"xmlns">>, _attrs) of + <<"urn:ietf:params:xml:ns:xmpp-stanzas">> -> + decode_error_error_els(_els, Text, + 'decode_error_error_unexpected-request'(_el)); + _ -> decode_error_error_els(_els, Text, Reason) + end; +decode_error_error_els([{xmlel, + <<"undefined-condition">>, _attrs, _} = + _el + | _els], + Text, Reason) -> + case xml:get_attr_s(<<"xmlns">>, _attrs) of + <<"urn:ietf:params:xml:ns:xmpp-stanzas">> -> + decode_error_error_els(_els, Text, + 'decode_error_error_undefined-condition'(_el)); + _ -> decode_error_error_els(_els, Text, Reason) + end; +decode_error_error_els([{xmlel, + <<"subscription-required">>, _attrs, _} = + _el + | _els], + Text, Reason) -> + case xml:get_attr_s(<<"xmlns">>, _attrs) of + <<"urn:ietf:params:xml:ns:xmpp-stanzas">> -> + decode_error_error_els(_els, Text, + 'decode_error_error_subscription-required'(_el)); + _ -> decode_error_error_els(_els, Text, Reason) + end; +decode_error_error_els([{xmlel, + <<"service-unavailable">>, _attrs, _} = + _el + | _els], + Text, Reason) -> + case xml:get_attr_s(<<"xmlns">>, _attrs) of + <<"urn:ietf:params:xml:ns:xmpp-stanzas">> -> + decode_error_error_els(_els, Text, + 'decode_error_error_service-unavailable'(_el)); + _ -> decode_error_error_els(_els, Text, Reason) + end; +decode_error_error_els([{xmlel, + <<"resource-constraint">>, _attrs, _} = + _el + | _els], + Text, Reason) -> + case xml:get_attr_s(<<"xmlns">>, _attrs) of + <<"urn:ietf:params:xml:ns:xmpp-stanzas">> -> + decode_error_error_els(_els, Text, + 'decode_error_error_resource-constraint'(_el)); + _ -> decode_error_error_els(_els, Text, Reason) + end; +decode_error_error_els([{xmlel, + <<"remote-server-timeout">>, _attrs, _} = + _el + | _els], + Text, Reason) -> + case xml:get_attr_s(<<"xmlns">>, _attrs) of + <<"urn:ietf:params:xml:ns:xmpp-stanzas">> -> + decode_error_error_els(_els, Text, + 'decode_error_error_remote-server-timeout'(_el)); + _ -> decode_error_error_els(_els, Text, Reason) + end; +decode_error_error_els([{xmlel, + <<"remote-server-not-found">>, _attrs, _} = + _el + | _els], + Text, Reason) -> + case xml:get_attr_s(<<"xmlns">>, _attrs) of + <<"urn:ietf:params:xml:ns:xmpp-stanzas">> -> + decode_error_error_els(_els, Text, + 'decode_error_error_remote-server-not-found'(_el)); + _ -> decode_error_error_els(_els, Text, Reason) + end; +decode_error_error_els([{xmlel, + <<"registration-required">>, _attrs, _} = + _el + | _els], + Text, Reason) -> + case xml:get_attr_s(<<"xmlns">>, _attrs) of + <<"urn:ietf:params:xml:ns:xmpp-stanzas">> -> + decode_error_error_els(_els, Text, + 'decode_error_error_registration-required'(_el)); + _ -> decode_error_error_els(_els, Text, Reason) + end; +decode_error_error_els([{xmlel, <<"redirect">>, _attrs, + _} = + _el + | _els], + Text, Reason) -> + case xml:get_attr_s(<<"xmlns">>, _attrs) of + <<"urn:ietf:params:xml:ns:xmpp-stanzas">> -> + decode_error_error_els(_els, Text, + decode_error_error_redirect(_el)); + _ -> decode_error_error_els(_els, Text, Reason) + end; +decode_error_error_els([{xmlel, + <<"recipient-unavailable">>, _attrs, _} = + _el + | _els], + Text, Reason) -> + case xml:get_attr_s(<<"xmlns">>, _attrs) of + <<"urn:ietf:params:xml:ns:xmpp-stanzas">> -> + decode_error_error_els(_els, Text, + 'decode_error_error_recipient-unavailable'(_el)); + _ -> decode_error_error_els(_els, Text, Reason) + end; +decode_error_error_els([{xmlel, <<"policy-violation">>, + _attrs, _} = + _el + | _els], + Text, Reason) -> + case xml:get_attr_s(<<"xmlns">>, _attrs) of + <<"urn:ietf:params:xml:ns:xmpp-stanzas">> -> + decode_error_error_els(_els, Text, + 'decode_error_error_policy-violation'(_el)); + _ -> decode_error_error_els(_els, Text, Reason) + end; +decode_error_error_els([{xmlel, <<"not-authorized">>, + _attrs, _} = + _el + | _els], + Text, Reason) -> + case xml:get_attr_s(<<"xmlns">>, _attrs) of + <<"urn:ietf:params:xml:ns:xmpp-stanzas">> -> + decode_error_error_els(_els, Text, + 'decode_error_error_not-authorized'(_el)); + _ -> decode_error_error_els(_els, Text, Reason) + end; +decode_error_error_els([{xmlel, <<"not-allowed">>, + _attrs, _} = + _el + | _els], + Text, Reason) -> + case xml:get_attr_s(<<"xmlns">>, _attrs) of + <<"urn:ietf:params:xml:ns:xmpp-stanzas">> -> + decode_error_error_els(_els, Text, + 'decode_error_error_not-allowed'(_el)); + _ -> decode_error_error_els(_els, Text, Reason) + end; +decode_error_error_els([{xmlel, <<"not-acceptable">>, + _attrs, _} = + _el + | _els], + Text, Reason) -> + case xml:get_attr_s(<<"xmlns">>, _attrs) of + <<"urn:ietf:params:xml:ns:xmpp-stanzas">> -> + decode_error_error_els(_els, Text, + 'decode_error_error_not-acceptable'(_el)); + _ -> decode_error_error_els(_els, Text, Reason) + end; +decode_error_error_els([{xmlel, <<"jid-malformed">>, + _attrs, _} = + _el + | _els], + Text, Reason) -> + case xml:get_attr_s(<<"xmlns">>, _attrs) of + <<"urn:ietf:params:xml:ns:xmpp-stanzas">> -> + decode_error_error_els(_els, Text, + 'decode_error_error_jid-malformed'(_el)); + _ -> decode_error_error_els(_els, Text, Reason) + end; +decode_error_error_els([{xmlel, <<"item-not-found">>, + _attrs, _} = + _el + | _els], + Text, Reason) -> + case xml:get_attr_s(<<"xmlns">>, _attrs) of + <<"urn:ietf:params:xml:ns:xmpp-stanzas">> -> + decode_error_error_els(_els, Text, + 'decode_error_error_item-not-found'(_el)); + _ -> decode_error_error_els(_els, Text, Reason) + end; +decode_error_error_els([{xmlel, + <<"internal-server-error">>, _attrs, _} = + _el + | _els], + Text, Reason) -> + case xml:get_attr_s(<<"xmlns">>, _attrs) of + <<"urn:ietf:params:xml:ns:xmpp-stanzas">> -> + decode_error_error_els(_els, Text, + 'decode_error_error_internal-server-error'(_el)); + _ -> decode_error_error_els(_els, Text, Reason) + end; +decode_error_error_els([{xmlel, <<"gone">>, _attrs, _} = + _el + | _els], + Text, Reason) -> + case xml:get_attr_s(<<"xmlns">>, _attrs) of + <<"urn:ietf:params:xml:ns:xmpp-stanzas">> -> + decode_error_error_els(_els, Text, + decode_error_error_gone(_el)); + _ -> decode_error_error_els(_els, Text, Reason) + end; +decode_error_error_els([{xmlel, <<"forbidden">>, _attrs, + _} = + _el + | _els], + Text, Reason) -> + case xml:get_attr_s(<<"xmlns">>, _attrs) of + <<"urn:ietf:params:xml:ns:xmpp-stanzas">> -> + decode_error_error_els(_els, Text, + decode_error_error_forbidden(_el)); + _ -> decode_error_error_els(_els, Text, Reason) + end; +decode_error_error_els([{xmlel, + <<"feature-not-implemented">>, _attrs, _} = + _el + | _els], + Text, Reason) -> + case xml:get_attr_s(<<"xmlns">>, _attrs) of + <<"urn:ietf:params:xml:ns:xmpp-stanzas">> -> + decode_error_error_els(_els, Text, + 'decode_error_error_feature-not-implemented'(_el)); + _ -> decode_error_error_els(_els, Text, Reason) + end; +decode_error_error_els([{xmlel, <<"conflict">>, _attrs, + _} = + _el + | _els], + Text, Reason) -> + case xml:get_attr_s(<<"xmlns">>, _attrs) of + <<"urn:ietf:params:xml:ns:xmpp-stanzas">> -> + decode_error_error_els(_els, Text, + decode_error_error_conflict(_el)); + _ -> decode_error_error_els(_els, Text, Reason) + end; +decode_error_error_els([{xmlel, <<"bad-request">>, + _attrs, _} = + _el + | _els], + Text, Reason) -> + case xml:get_attr_s(<<"xmlns">>, _attrs) of + <<"urn:ietf:params:xml:ns:xmpp-stanzas">> -> + decode_error_error_els(_els, Text, + 'decode_error_error_bad-request'(_el)); + _ -> decode_error_error_els(_els, Text, Reason) + end; +decode_error_error_els([_ | _els], Text, Reason) -> + decode_error_error_els(_els, Text, Reason); +decode_error_error_els([], Text, Reason) -> + {Text, Reason}. + +decode_error_error_attrs([{<<"by">>, _val} | _attrs], + _By, Error_type) -> + decode_error_error_attrs(_attrs, _val, Error_type); +decode_error_error_attrs([{<<"type">>, _val} | _attrs], + By, _Error_type) -> + decode_error_error_attrs(_attrs, By, _val); +decode_error_error_attrs([_ | _attrs], By, + Error_type) -> + decode_error_error_attrs(_attrs, By, Error_type); +decode_error_error_attrs([], By, Error_type) -> + {decode_error_error_by(By), + decode_error_error_type(Error_type)}. + +'encode_error_error_$reason'(undefined, _acc) -> _acc; +'encode_error_error_$reason'('unexpected-request' = _r, + _acc) -> + 'encode_error_error_unexpected-request'(_r, _acc); +'encode_error_error_$reason'('undefined-condition' = _r, + _acc) -> + 'encode_error_error_undefined-condition'(_r, _acc); +'encode_error_error_$reason'('subscription-required' = + _r, + _acc) -> + 'encode_error_error_subscription-required'(_r, _acc); +'encode_error_error_$reason'('service-unavailable' = _r, + _acc) -> + 'encode_error_error_service-unavailable'(_r, _acc); +'encode_error_error_$reason'('resource-constraint' = _r, + _acc) -> + 'encode_error_error_resource-constraint'(_r, _acc); +'encode_error_error_$reason'('remote-server-timeout' = + _r, + _acc) -> + 'encode_error_error_remote-server-timeout'(_r, _acc); +'encode_error_error_$reason'('remote-server-not-found' = + _r, + _acc) -> + 'encode_error_error_remote-server-not-found'(_r, _acc); +'encode_error_error_$reason'('registration-required' = + _r, + _acc) -> + 'encode_error_error_registration-required'(_r, _acc); +'encode_error_error_$reason'({redirect, _} = _r, + _acc) -> + encode_error_error_redirect(_r, _acc); +'encode_error_error_$reason'('recipient-unavailable' = + _r, + _acc) -> + 'encode_error_error_recipient-unavailable'(_r, _acc); +'encode_error_error_$reason'('policy-violation' = _r, + _acc) -> + 'encode_error_error_policy-violation'(_r, _acc); +'encode_error_error_$reason'('not-authorized' = _r, + _acc) -> + 'encode_error_error_not-authorized'(_r, _acc); +'encode_error_error_$reason'('not-allowed' = _r, + _acc) -> + 'encode_error_error_not-allowed'(_r, _acc); +'encode_error_error_$reason'('not-acceptable' = _r, + _acc) -> + 'encode_error_error_not-acceptable'(_r, _acc); +'encode_error_error_$reason'('jid-malformed' = _r, + _acc) -> + 'encode_error_error_jid-malformed'(_r, _acc); +'encode_error_error_$reason'('item-not-found' = _r, + _acc) -> + 'encode_error_error_item-not-found'(_r, _acc); +'encode_error_error_$reason'('internal-server-error' = + _r, + _acc) -> + 'encode_error_error_internal-server-error'(_r, _acc); +'encode_error_error_$reason'({gone, _} = _r, _acc) -> + encode_error_error_gone(_r, _acc); +'encode_error_error_$reason'(forbidden = _r, _acc) -> + encode_error_error_forbidden(_r, _acc); +'encode_error_error_$reason'('feature-not-implemented' = + _r, + _acc) -> + 'encode_error_error_feature-not-implemented'(_r, _acc); +'encode_error_error_$reason'(conflict = _r, _acc) -> + encode_error_error_conflict(_r, _acc); +'encode_error_error_$reason'('bad-request' = _r, + _acc) -> + 'encode_error_error_bad-request'(_r, _acc). + +encode_error_error(undefined, _acc) -> _acc; +encode_error_error({error, Error_type, By, Reason, + Text}, + _acc) -> + _els = 'encode_error_error_$reason'(Reason, + encode_error_error_text(Text, [])), + _attrs = encode_error_error_type(Error_type, + encode_error_error_by(By, [])), + [{xmlel, <<"error">>, _attrs, _els} | _acc]. + +decode_error_error_type(undefined) -> + erlang:error({missing_attr, <<"type">>, <<"error">>, + <<>>}); +decode_error_error_type(_val) -> + case catch xml_gen:dec_enum(_val, + [auth, cancel, continue, modify, wait]) + of + {'EXIT', _} -> + erlang:error({bad_attr_value, <<"type">>, <<"error">>, + <<>>}); + _res -> _res + end. + +encode_error_error_type(_val, _acc) -> + [{<<"type">>, xml_gen:enc_enum(_val)} | _acc]. + +decode_error_error_by(undefined) -> undefined; +decode_error_error_by(_val) -> _val. + +encode_error_error_by(undefined, _acc) -> _acc; +encode_error_error_by(_val, _acc) -> + [{<<"by">>, _val} | _acc]. + +'decode_error_error_unexpected-request'({xmlel, _, + _attrs, _els}) -> + 'unexpected-request'. + +'encode_error_error_unexpected-request'(undefined, + _acc) -> + _acc; +'encode_error_error_unexpected-request'('unexpected-request', + _acc) -> + _els = [], + _attrs = [{<<"xmlns">>, + <<"urn:ietf:params:xml:ns:xmpp-stanzas">>}], + [{xmlel, <<"unexpected-request">>, _attrs, _els} + | _acc]. + +'decode_error_error_undefined-condition'({xmlel, _, + _attrs, _els}) -> + 'undefined-condition'. + +'encode_error_error_undefined-condition'(undefined, + _acc) -> + _acc; +'encode_error_error_undefined-condition'('undefined-condition', + _acc) -> + _els = [], + _attrs = [{<<"xmlns">>, + <<"urn:ietf:params:xml:ns:xmpp-stanzas">>}], + [{xmlel, <<"undefined-condition">>, _attrs, _els} + | _acc]. + +'decode_error_error_subscription-required'({xmlel, _, + _attrs, _els}) -> + 'subscription-required'. + +'encode_error_error_subscription-required'(undefined, + _acc) -> + _acc; +'encode_error_error_subscription-required'('subscription-required', + _acc) -> + _els = [], + _attrs = [{<<"xmlns">>, + <<"urn:ietf:params:xml:ns:xmpp-stanzas">>}], + [{xmlel, <<"subscription-required">>, _attrs, _els} + | _acc]. + +'decode_error_error_service-unavailable'({xmlel, _, + _attrs, _els}) -> + 'service-unavailable'. + +'encode_error_error_service-unavailable'(undefined, + _acc) -> + _acc; +'encode_error_error_service-unavailable'('service-unavailable', + _acc) -> + _els = [], + _attrs = [{<<"xmlns">>, + <<"urn:ietf:params:xml:ns:xmpp-stanzas">>}], + [{xmlel, <<"service-unavailable">>, _attrs, _els} + | _acc]. + +'decode_error_error_resource-constraint'({xmlel, _, + _attrs, _els}) -> + 'resource-constraint'. + +'encode_error_error_resource-constraint'(undefined, + _acc) -> + _acc; +'encode_error_error_resource-constraint'('resource-constraint', + _acc) -> + _els = [], + _attrs = [{<<"xmlns">>, + <<"urn:ietf:params:xml:ns:xmpp-stanzas">>}], + [{xmlel, <<"resource-constraint">>, _attrs, _els} + | _acc]. + +'decode_error_error_remote-server-timeout'({xmlel, _, + _attrs, _els}) -> + 'remote-server-timeout'. + +'encode_error_error_remote-server-timeout'(undefined, + _acc) -> + _acc; +'encode_error_error_remote-server-timeout'('remote-server-timeout', + _acc) -> + _els = [], + _attrs = [{<<"xmlns">>, + <<"urn:ietf:params:xml:ns:xmpp-stanzas">>}], + [{xmlel, <<"remote-server-timeout">>, _attrs, _els} + | _acc]. + +'decode_error_error_remote-server-not-found'({xmlel, _, + _attrs, _els}) -> + 'remote-server-not-found'. + +'encode_error_error_remote-server-not-found'(undefined, + _acc) -> + _acc; +'encode_error_error_remote-server-not-found'('remote-server-not-found', + _acc) -> + _els = [], + _attrs = [{<<"xmlns">>, + <<"urn:ietf:params:xml:ns:xmpp-stanzas">>}], + [{xmlel, <<"remote-server-not-found">>, _attrs, _els} + | _acc]. + +'decode_error_error_registration-required'({xmlel, _, + _attrs, _els}) -> + 'registration-required'. + +'encode_error_error_registration-required'(undefined, + _acc) -> + _acc; +'encode_error_error_registration-required'('registration-required', + _acc) -> + _els = [], + _attrs = [{<<"xmlns">>, + <<"urn:ietf:params:xml:ns:xmpp-stanzas">>}], + [{xmlel, <<"registration-required">>, _attrs, _els} + | _acc]. + +decode_error_error_redirect({xmlel, _, _attrs, _els}) -> + Cdata = decode_error_error_redirect_els(_els, <<>>), + {redirect, Cdata}. + +decode_error_error_redirect_els([{xmlcdata, _data} + | _els], + Cdata) -> + decode_error_error_redirect_els(_els, + <<Cdata/binary, _data/binary>>); +decode_error_error_redirect_els([_ | _els], Cdata) -> + decode_error_error_redirect_els(_els, Cdata); +decode_error_error_redirect_els([], Cdata) -> + decode_error_error_redirect_cdata(Cdata). + +encode_error_error_redirect(undefined, _acc) -> _acc; +encode_error_error_redirect({redirect, Cdata}, _acc) -> + _els = encode_error_error_redirect_cdata(Cdata, []), + _attrs = [{<<"xmlns">>, + <<"urn:ietf:params:xml:ns:xmpp-stanzas">>}], + [{xmlel, <<"redirect">>, _attrs, _els} | _acc]. + +decode_error_error_redirect_cdata(<<>>) -> undefined; +decode_error_error_redirect_cdata(_val) -> _val. + +encode_error_error_redirect_cdata(undefined, _acc) -> + _acc; +encode_error_error_redirect_cdata(_val, _acc) -> + [{xmlcdata, _val} | _acc]. + +'decode_error_error_recipient-unavailable'({xmlel, _, + _attrs, _els}) -> + 'recipient-unavailable'. + +'encode_error_error_recipient-unavailable'(undefined, + _acc) -> + _acc; +'encode_error_error_recipient-unavailable'('recipient-unavailable', + _acc) -> + _els = [], + _attrs = [{<<"xmlns">>, + <<"urn:ietf:params:xml:ns:xmpp-stanzas">>}], + [{xmlel, <<"recipient-unavailable">>, _attrs, _els} + | _acc]. + +'decode_error_error_policy-violation'({xmlel, _, _attrs, + _els}) -> + 'policy-violation'. + +'encode_error_error_policy-violation'(undefined, + _acc) -> + _acc; +'encode_error_error_policy-violation'('policy-violation', + _acc) -> + _els = [], + _attrs = [{<<"xmlns">>, + <<"urn:ietf:params:xml:ns:xmpp-stanzas">>}], + [{xmlel, <<"policy-violation">>, _attrs, _els} | _acc]. + +'decode_error_error_not-authorized'({xmlel, _, _attrs, + _els}) -> + 'not-authorized'. + +'encode_error_error_not-authorized'(undefined, _acc) -> + _acc; +'encode_error_error_not-authorized'('not-authorized', + _acc) -> + _els = [], + _attrs = [{<<"xmlns">>, + <<"urn:ietf:params:xml:ns:xmpp-stanzas">>}], + [{xmlel, <<"not-authorized">>, _attrs, _els} | _acc]. + +'decode_error_error_not-allowed'({xmlel, _, _attrs, + _els}) -> + 'not-allowed'. + +'encode_error_error_not-allowed'(undefined, _acc) -> + _acc; +'encode_error_error_not-allowed'('not-allowed', _acc) -> + _els = [], + _attrs = [{<<"xmlns">>, + <<"urn:ietf:params:xml:ns:xmpp-stanzas">>}], + [{xmlel, <<"not-allowed">>, _attrs, _els} | _acc]. + +'decode_error_error_not-acceptable'({xmlel, _, _attrs, + _els}) -> + 'not-acceptable'. + +'encode_error_error_not-acceptable'(undefined, _acc) -> + _acc; +'encode_error_error_not-acceptable'('not-acceptable', + _acc) -> + _els = [], + _attrs = [{<<"xmlns">>, + <<"urn:ietf:params:xml:ns:xmpp-stanzas">>}], + [{xmlel, <<"not-acceptable">>, _attrs, _els} | _acc]. + +'decode_error_error_jid-malformed'({xmlel, _, _attrs, + _els}) -> + 'jid-malformed'. + +'encode_error_error_jid-malformed'(undefined, _acc) -> + _acc; +'encode_error_error_jid-malformed'('jid-malformed', + _acc) -> + _els = [], + _attrs = [{<<"xmlns">>, + <<"urn:ietf:params:xml:ns:xmpp-stanzas">>}], + [{xmlel, <<"jid-malformed">>, _attrs, _els} | _acc]. + +'decode_error_error_item-not-found'({xmlel, _, _attrs, + _els}) -> + 'item-not-found'. + +'encode_error_error_item-not-found'(undefined, _acc) -> + _acc; +'encode_error_error_item-not-found'('item-not-found', + _acc) -> + _els = [], + _attrs = [{<<"xmlns">>, + <<"urn:ietf:params:xml:ns:xmpp-stanzas">>}], + [{xmlel, <<"item-not-found">>, _attrs, _els} | _acc]. + +'decode_error_error_internal-server-error'({xmlel, _, + _attrs, _els}) -> + 'internal-server-error'. + +'encode_error_error_internal-server-error'(undefined, + _acc) -> + _acc; +'encode_error_error_internal-server-error'('internal-server-error', + _acc) -> + _els = [], + _attrs = [{<<"xmlns">>, + <<"urn:ietf:params:xml:ns:xmpp-stanzas">>}], + [{xmlel, <<"internal-server-error">>, _attrs, _els} + | _acc]. + +decode_error_error_gone({xmlel, _, _attrs, _els}) -> + Cdata = decode_error_error_gone_els(_els, <<>>), + {gone, Cdata}. + +decode_error_error_gone_els([{xmlcdata, _data} | _els], + Cdata) -> + decode_error_error_gone_els(_els, + <<Cdata/binary, _data/binary>>); +decode_error_error_gone_els([_ | _els], Cdata) -> + decode_error_error_gone_els(_els, Cdata); +decode_error_error_gone_els([], Cdata) -> + decode_error_error_gone_cdata(Cdata). + +encode_error_error_gone(undefined, _acc) -> _acc; +encode_error_error_gone({gone, Cdata}, _acc) -> + _els = encode_error_error_gone_cdata(Cdata, []), + _attrs = [{<<"xmlns">>, + <<"urn:ietf:params:xml:ns:xmpp-stanzas">>}], + [{xmlel, <<"gone">>, _attrs, _els} | _acc]. + +decode_error_error_gone_cdata(<<>>) -> undefined; +decode_error_error_gone_cdata(_val) -> _val. + +encode_error_error_gone_cdata(undefined, _acc) -> _acc; +encode_error_error_gone_cdata(_val, _acc) -> + [{xmlcdata, _val} | _acc]. + +decode_error_error_forbidden({xmlel, _, _attrs, + _els}) -> + forbidden. + +encode_error_error_forbidden(undefined, _acc) -> _acc; +encode_error_error_forbidden(forbidden, _acc) -> + _els = [], + _attrs = [{<<"xmlns">>, + <<"urn:ietf:params:xml:ns:xmpp-stanzas">>}], + [{xmlel, <<"forbidden">>, _attrs, _els} | _acc]. + +'decode_error_error_feature-not-implemented'({xmlel, _, + _attrs, _els}) -> + 'feature-not-implemented'. + +'encode_error_error_feature-not-implemented'(undefined, + _acc) -> + _acc; +'encode_error_error_feature-not-implemented'('feature-not-implemented', + _acc) -> + _els = [], + _attrs = [{<<"xmlns">>, + <<"urn:ietf:params:xml:ns:xmpp-stanzas">>}], + [{xmlel, <<"feature-not-implemented">>, _attrs, _els} + | _acc]. + +decode_error_error_conflict({xmlel, _, _attrs, _els}) -> + conflict. + +encode_error_error_conflict(undefined, _acc) -> _acc; +encode_error_error_conflict(conflict, _acc) -> + _els = [], + _attrs = [{<<"xmlns">>, + <<"urn:ietf:params:xml:ns:xmpp-stanzas">>}], + [{xmlel, <<"conflict">>, _attrs, _els} | _acc]. + +'decode_error_error_bad-request'({xmlel, _, _attrs, + _els}) -> + 'bad-request'. + +'encode_error_error_bad-request'(undefined, _acc) -> + _acc; +'encode_error_error_bad-request'('bad-request', _acc) -> + _els = [], + _attrs = [{<<"xmlns">>, + <<"urn:ietf:params:xml:ns:xmpp-stanzas">>}], + [{xmlel, <<"bad-request">>, _attrs, _els} | _acc]. + +decode_error_error_text({xmlel, _, _attrs, _els}) -> + Text_lang = decode_error_error_text_attrs(_attrs, + undefined), + Cdata = decode_error_error_text_els(_els, <<>>), + {Text_lang, Cdata}. + +decode_error_error_text_els([{xmlcdata, _data} | _els], + Cdata) -> + decode_error_error_text_els(_els, + <<Cdata/binary, _data/binary>>); +decode_error_error_text_els([_ | _els], Cdata) -> + decode_error_error_text_els(_els, Cdata); +decode_error_error_text_els([], Cdata) -> + decode_error_error_text_cdata(Cdata). + +decode_error_error_text_attrs([{<<"xml:lang">>, _val} + | _attrs], + _Text_lang) -> + decode_error_error_text_attrs(_attrs, _val); +decode_error_error_text_attrs([_ | _attrs], + Text_lang) -> + decode_error_error_text_attrs(_attrs, Text_lang); +decode_error_error_text_attrs([], Text_lang) -> + 'decode_error_error_text_xml:lang'(Text_lang). + +encode_error_error_text(undefined, _acc) -> _acc; +encode_error_error_text({Text_lang, Cdata}, _acc) -> + _els = encode_error_error_text_cdata(Cdata, []), + _attrs = 'encode_error_error_text_xml:lang'(Text_lang, + [{<<"xmlns">>, + <<"urn:ietf:params:xml:ns:xmpp-stanzas">>}]), + [{xmlel, <<"text">>, _attrs, _els} | _acc]. + +'decode_error_error_text_xml:lang'(undefined) -> + undefined; +'decode_error_error_text_xml:lang'(_val) -> _val. + +'encode_error_error_text_xml:lang'(undefined, _acc) -> + _acc; +'encode_error_error_text_xml:lang'(_val, _acc) -> + [{<<"xml:lang">>, _val} | _acc]. + +decode_error_error_text_cdata(<<>>) -> undefined; +decode_error_error_text_cdata(_val) -> _val. + +encode_error_error_text_cdata(undefined, _acc) -> _acc; +encode_error_error_text_cdata(_val, _acc) -> + [{xmlcdata, _val} | _acc]. + +decode_bind_bind({xmlel, _, _attrs, _els}) -> + {Resource, Jid} = decode_bind_bind_els(_els, undefined, + undefined), + {bind, Jid, Resource}. + +decode_bind_bind_els([{xmlel, <<"resource">>, _attrs, + _} = + _el + | _els], + Resource, Jid) -> + case xml:get_attr_s(<<"xmlns">>, _attrs) of + <<>> -> + decode_bind_bind_els(_els, + decode_bind_bind_resource(_el), Jid); + _ -> decode_bind_bind_els(_els, Resource, Jid) + end; +decode_bind_bind_els([{xmlel, <<"jid">>, _attrs, _} = + _el + | _els], + Resource, Jid) -> + case xml:get_attr_s(<<"xmlns">>, _attrs) of + <<>> -> + decode_bind_bind_els(_els, Resource, + decode_bind_bind_jid(_el)); + _ -> decode_bind_bind_els(_els, Resource, Jid) + end; +decode_bind_bind_els([_ | _els], Resource, Jid) -> + decode_bind_bind_els(_els, Resource, Jid); +decode_bind_bind_els([], Resource, Jid) -> + {Resource, Jid}. + +encode_bind_bind(undefined, _acc) -> _acc; +encode_bind_bind({bind, Jid, Resource}, _acc) -> + _els = encode_bind_bind_jid(Jid, + encode_bind_bind_resource(Resource, [])), + _attrs = [{<<"xmlns">>, + <<"urn:ietf:params:xml:ns:xmpp-bind">>}], + [{xmlel, <<"bind">>, _attrs, _els} | _acc]. + +decode_bind_bind_resource({xmlel, _, _attrs, _els}) -> + Cdata = decode_bind_bind_resource_els(_els, <<>>), + Cdata. + +decode_bind_bind_resource_els([{xmlcdata, _data} + | _els], + Cdata) -> + decode_bind_bind_resource_els(_els, + <<Cdata/binary, _data/binary>>); +decode_bind_bind_resource_els([_ | _els], Cdata) -> + decode_bind_bind_resource_els(_els, Cdata); +decode_bind_bind_resource_els([], Cdata) -> + decode_bind_bind_resource_cdata(Cdata). + +encode_bind_bind_resource(undefined, _acc) -> _acc; +encode_bind_bind_resource(Cdata, _acc) -> + _els = encode_bind_bind_resource_cdata(Cdata, []), + _attrs = [], + [{xmlel, <<"resource">>, _attrs, _els} | _acc]. + +decode_bind_bind_resource_cdata(<<>>) -> undefined; +decode_bind_bind_resource_cdata(_val) -> + case catch resourceprep(_val) of + {'EXIT', _} -> + erlang:error({bad_cdata_value, <<>>, <<"resource">>, + <<>>}); + _res -> _res + end. + +encode_bind_bind_resource_cdata(undefined, _acc) -> + _acc; +encode_bind_bind_resource_cdata(_val, _acc) -> + [{xmlcdata, resourceprep(_val)} | _acc]. + +decode_bind_bind_jid({xmlel, _, _attrs, _els}) -> + Cdata = decode_bind_bind_jid_els(_els, <<>>), Cdata. + +decode_bind_bind_jid_els([{xmlcdata, _data} | _els], + Cdata) -> + decode_bind_bind_jid_els(_els, + <<Cdata/binary, _data/binary>>); +decode_bind_bind_jid_els([_ | _els], Cdata) -> + decode_bind_bind_jid_els(_els, Cdata); +decode_bind_bind_jid_els([], Cdata) -> + decode_bind_bind_jid_cdata(Cdata). + +encode_bind_bind_jid(undefined, _acc) -> _acc; +encode_bind_bind_jid(Cdata, _acc) -> + _els = encode_bind_bind_jid_cdata(Cdata, []), + _attrs = [], + [{xmlel, <<"jid">>, _attrs, _els} | _acc]. + +decode_bind_bind_jid_cdata(<<>>) -> undefined; +decode_bind_bind_jid_cdata(_val) -> + case catch dec_jid(_val) of + {'EXIT', _} -> + erlang:error({bad_cdata_value, <<>>, <<"jid">>, <<>>}); + _res -> _res + end. + +encode_bind_bind_jid_cdata(undefined, _acc) -> _acc; +encode_bind_bind_jid_cdata(_val, _acc) -> + [{xmlcdata, enc_jid(_val)} | _acc]. + +decode_sasl_auth_auth({xmlel, _, _attrs, _els}) -> + Mechanism = decode_sasl_auth_auth_attrs(_attrs, + undefined), + Cdata = decode_sasl_auth_auth_els(_els, <<>>), + {sasl_auth, Mechanism, Cdata}. + +decode_sasl_auth_auth_els([{xmlcdata, _data} | _els], + Cdata) -> + decode_sasl_auth_auth_els(_els, + <<Cdata/binary, _data/binary>>); +decode_sasl_auth_auth_els([_ | _els], Cdata) -> + decode_sasl_auth_auth_els(_els, Cdata); +decode_sasl_auth_auth_els([], Cdata) -> + decode_sasl_auth_auth_cdata(Cdata). + +decode_sasl_auth_auth_attrs([{<<"mechanism">>, _val} + | _attrs], + _Mechanism) -> + decode_sasl_auth_auth_attrs(_attrs, _val); +decode_sasl_auth_auth_attrs([_ | _attrs], Mechanism) -> + decode_sasl_auth_auth_attrs(_attrs, Mechanism); +decode_sasl_auth_auth_attrs([], Mechanism) -> + decode_sasl_auth_auth_mechanism(Mechanism). + +encode_sasl_auth_auth(undefined, _acc) -> _acc; +encode_sasl_auth_auth({sasl_auth, Mechanism, Cdata}, + _acc) -> + _els = encode_sasl_auth_auth_cdata(Cdata, []), + _attrs = encode_sasl_auth_auth_mechanism(Mechanism, + [{<<"xmlns">>, + <<"urn:ietf:params:xml:ns:xmpp-sasl">>}]), + [{xmlel, <<"auth">>, _attrs, _els} | _acc]. + +decode_sasl_auth_auth_mechanism(undefined) -> + erlang:error({missing_attr, <<"mechanism">>, <<"auth">>, + <<"urn:ietf:params:xml:ns:xmpp-sasl">>}); +decode_sasl_auth_auth_mechanism(_val) -> _val. + +encode_sasl_auth_auth_mechanism(_val, _acc) -> + [{<<"mechanism">>, _val} | _acc]. + +decode_sasl_auth_auth_cdata(<<>>) -> undefined; +decode_sasl_auth_auth_cdata(_val) -> + case catch base64:decode(_val) of + {'EXIT', _} -> + erlang:error({bad_cdata_value, <<>>, <<"auth">>, + <<"urn:ietf:params:xml:ns:xmpp-sasl">>}); + _res -> _res + end. + +encode_sasl_auth_auth_cdata(undefined, _acc) -> _acc; +encode_sasl_auth_auth_cdata(_val, _acc) -> + [{xmlcdata, base64:encode(_val)} | _acc]. + +decode_sasl_abort_abort({xmlel, _, _attrs, _els}) -> + {sasl_abort}. + +encode_sasl_abort_abort(undefined, _acc) -> _acc; +encode_sasl_abort_abort({sasl_abort}, _acc) -> + _els = [], + _attrs = [{<<"xmlns">>, + <<"urn:ietf:params:xml:ns:xmpp-sasl">>}], + [{xmlel, <<"abort">>, _attrs, _els} | _acc]. + +decode_sasl_challenge_challenge({xmlel, _, _attrs, + _els}) -> + Cdata = decode_sasl_challenge_challenge_els(_els, <<>>), + {sasl_challenge, Cdata}. + +decode_sasl_challenge_challenge_els([{xmlcdata, _data} + | _els], + Cdata) -> + decode_sasl_challenge_challenge_els(_els, + <<Cdata/binary, _data/binary>>); +decode_sasl_challenge_challenge_els([_ | _els], + Cdata) -> + decode_sasl_challenge_challenge_els(_els, Cdata); +decode_sasl_challenge_challenge_els([], Cdata) -> + decode_sasl_challenge_challenge_cdata(Cdata). + +encode_sasl_challenge_challenge(undefined, _acc) -> + _acc; +encode_sasl_challenge_challenge({sasl_challenge, Cdata}, + _acc) -> + _els = encode_sasl_challenge_challenge_cdata(Cdata, []), + _attrs = [{<<"xmlns">>, + <<"urn:ietf:params:xml:ns:xmpp-sasl">>}], + [{xmlel, <<"challenge">>, _attrs, _els} | _acc]. + +decode_sasl_challenge_challenge_cdata(<<>>) -> + undefined; +decode_sasl_challenge_challenge_cdata(_val) -> + case catch base64:decode(_val) of + {'EXIT', _} -> + erlang:error({bad_cdata_value, <<>>, <<"challenge">>, + <<"urn:ietf:params:xml:ns:xmpp-sasl">>}); + _res -> _res + end. + +encode_sasl_challenge_challenge_cdata(undefined, + _acc) -> + _acc; +encode_sasl_challenge_challenge_cdata(_val, _acc) -> + [{xmlcdata, base64:encode(_val)} | _acc]. + +decode_sasl_response_response({xmlel, _, _attrs, + _els}) -> + Cdata = decode_sasl_response_response_els(_els, <<>>), + {sasl_response, Cdata}. + +decode_sasl_response_response_els([{xmlcdata, _data} + | _els], + Cdata) -> + decode_sasl_response_response_els(_els, + <<Cdata/binary, _data/binary>>); +decode_sasl_response_response_els([_ | _els], Cdata) -> + decode_sasl_response_response_els(_els, Cdata); +decode_sasl_response_response_els([], Cdata) -> + decode_sasl_response_response_cdata(Cdata). + +encode_sasl_response_response(undefined, _acc) -> _acc; +encode_sasl_response_response({sasl_response, Cdata}, + _acc) -> + _els = encode_sasl_response_response_cdata(Cdata, []), + _attrs = [{<<"xmlns">>, + <<"urn:ietf:params:xml:ns:xmpp-sasl">>}], + [{xmlel, <<"response">>, _attrs, _els} | _acc]. + +decode_sasl_response_response_cdata(<<>>) -> undefined; +decode_sasl_response_response_cdata(_val) -> + case catch base64:decode(_val) of + {'EXIT', _} -> + erlang:error({bad_cdata_value, <<>>, <<"response">>, + <<"urn:ietf:params:xml:ns:xmpp-sasl">>}); + _res -> _res + end. + +encode_sasl_response_response_cdata(undefined, _acc) -> + _acc; +encode_sasl_response_response_cdata(_val, _acc) -> + [{xmlcdata, base64:encode(_val)} | _acc]. + +decode_sasl_success_success({xmlel, _, _attrs, _els}) -> + Cdata = decode_sasl_success_success_els(_els, <<>>), + {sasl_success, Cdata}. + +decode_sasl_success_success_els([{xmlcdata, _data} + | _els], + Cdata) -> + decode_sasl_success_success_els(_els, + <<Cdata/binary, _data/binary>>); +decode_sasl_success_success_els([_ | _els], Cdata) -> + decode_sasl_success_success_els(_els, Cdata); +decode_sasl_success_success_els([], Cdata) -> + decode_sasl_success_success_cdata(Cdata). + +encode_sasl_success_success(undefined, _acc) -> _acc; +encode_sasl_success_success({sasl_success, Cdata}, + _acc) -> + _els = encode_sasl_success_success_cdata(Cdata, []), + _attrs = [{<<"xmlns">>, + <<"urn:ietf:params:xml:ns:xmpp-sasl">>}], + [{xmlel, <<"success">>, _attrs, _els} | _acc]. + +decode_sasl_success_success_cdata(<<>>) -> undefined; +decode_sasl_success_success_cdata(_val) -> + case catch base64:decode(_val) of + {'EXIT', _} -> + erlang:error({bad_cdata_value, <<>>, <<"success">>, + <<"urn:ietf:params:xml:ns:xmpp-sasl">>}); + _res -> _res + end. + +encode_sasl_success_success_cdata(undefined, _acc) -> + _acc; +encode_sasl_success_success_cdata(_val, _acc) -> + [{xmlcdata, base64:encode(_val)} | _acc]. + +decode_sasl_failure_failure({xmlel, _, _attrs, _els}) -> + {Text, Reason} = decode_sasl_failure_failure_els(_els, + undefined, undefined), + {sasl_failure, Reason, Text}. + +decode_sasl_failure_failure_els([{xmlel, <<"text">>, + _attrs, _} = + _el + | _els], + Text, Reason) -> + case xml:get_attr_s(<<"xmlns">>, _attrs) of + <<>> -> + decode_sasl_failure_failure_els(_els, + decode_sasl_failure_failure_text(_el), + Reason); + _ -> decode_sasl_failure_failure_els(_els, Text, Reason) + end; +decode_sasl_failure_failure_els([{xmlel, + <<"temporary-auth-failure">>, _attrs, _} = + _el + | _els], + Text, Reason) -> + case xml:get_attr_s(<<"xmlns">>, _attrs) of + <<>> -> + decode_sasl_failure_failure_els(_els, Text, + 'decode_sasl_failure_failure_temporary-auth-failure'(_el)); + _ -> decode_sasl_failure_failure_els(_els, Text, Reason) + end; +decode_sasl_failure_failure_els([{xmlel, + <<"not-authorized">>, _attrs, _} = + _el + | _els], + Text, Reason) -> + case xml:get_attr_s(<<"xmlns">>, _attrs) of + <<>> -> + decode_sasl_failure_failure_els(_els, Text, + 'decode_sasl_failure_failure_not-authorized'(_el)); + _ -> decode_sasl_failure_failure_els(_els, Text, Reason) + end; +decode_sasl_failure_failure_els([{xmlel, + <<"mechanism-too-weak">>, _attrs, _} = + _el + | _els], + Text, Reason) -> + case xml:get_attr_s(<<"xmlns">>, _attrs) of + <<>> -> + decode_sasl_failure_failure_els(_els, Text, + 'decode_sasl_failure_failure_mechanism-too-weak'(_el)); + _ -> decode_sasl_failure_failure_els(_els, Text, Reason) + end; +decode_sasl_failure_failure_els([{xmlel, + <<"malformed-request">>, _attrs, _} = + _el + | _els], + Text, Reason) -> + case xml:get_attr_s(<<"xmlns">>, _attrs) of + <<>> -> + decode_sasl_failure_failure_els(_els, Text, + 'decode_sasl_failure_failure_malformed-request'(_el)); + _ -> decode_sasl_failure_failure_els(_els, Text, Reason) + end; +decode_sasl_failure_failure_els([{xmlel, + <<"invalid-mechanism">>, _attrs, _} = + _el + | _els], + Text, Reason) -> + case xml:get_attr_s(<<"xmlns">>, _attrs) of + <<>> -> + decode_sasl_failure_failure_els(_els, Text, + 'decode_sasl_failure_failure_invalid-mechanism'(_el)); + _ -> decode_sasl_failure_failure_els(_els, Text, Reason) + end; +decode_sasl_failure_failure_els([{xmlel, + <<"invalid-authzid">>, _attrs, _} = + _el + | _els], + Text, Reason) -> + case xml:get_attr_s(<<"xmlns">>, _attrs) of + <<>> -> + decode_sasl_failure_failure_els(_els, Text, + 'decode_sasl_failure_failure_invalid-authzid'(_el)); + _ -> decode_sasl_failure_failure_els(_els, Text, Reason) + end; +decode_sasl_failure_failure_els([{xmlel, + <<"incorrect-encoding">>, _attrs, _} = + _el + | _els], + Text, Reason) -> + case xml:get_attr_s(<<"xmlns">>, _attrs) of + <<>> -> + decode_sasl_failure_failure_els(_els, Text, + 'decode_sasl_failure_failure_incorrect-encoding'(_el)); + _ -> decode_sasl_failure_failure_els(_els, Text, Reason) + end; +decode_sasl_failure_failure_els([{xmlel, + <<"encryption-required">>, _attrs, _} = + _el + | _els], + Text, Reason) -> + case xml:get_attr_s(<<"xmlns">>, _attrs) of + <<>> -> + decode_sasl_failure_failure_els(_els, Text, + 'decode_sasl_failure_failure_encryption-required'(_el)); + _ -> decode_sasl_failure_failure_els(_els, Text, Reason) + end; +decode_sasl_failure_failure_els([{xmlel, + <<"credentials-expired">>, _attrs, _} = + _el + | _els], + Text, Reason) -> + case xml:get_attr_s(<<"xmlns">>, _attrs) of + <<>> -> + decode_sasl_failure_failure_els(_els, Text, + 'decode_sasl_failure_failure_credentials-expired'(_el)); + _ -> decode_sasl_failure_failure_els(_els, Text, Reason) + end; +decode_sasl_failure_failure_els([{xmlel, + <<"account-disabled">>, _attrs, _} = + _el + | _els], + Text, Reason) -> + case xml:get_attr_s(<<"xmlns">>, _attrs) of + <<>> -> + decode_sasl_failure_failure_els(_els, Text, + 'decode_sasl_failure_failure_account-disabled'(_el)); + _ -> decode_sasl_failure_failure_els(_els, Text, Reason) + end; +decode_sasl_failure_failure_els([{xmlel, <<"aborted">>, + _attrs, _} = + _el + | _els], + Text, Reason) -> + case xml:get_attr_s(<<"xmlns">>, _attrs) of + <<>> -> + decode_sasl_failure_failure_els(_els, Text, + decode_sasl_failure_failure_aborted(_el)); + _ -> decode_sasl_failure_failure_els(_els, Text, Reason) + end; +decode_sasl_failure_failure_els([_ | _els], Text, + Reason) -> + decode_sasl_failure_failure_els(_els, Text, Reason); +decode_sasl_failure_failure_els([], Text, Reason) -> + {Text, Reason}. + +'encode_sasl_failure_failure_$reason'(undefined, + _acc) -> + _acc; +'encode_sasl_failure_failure_$reason'('temporary-auth-failure' = + _r, + _acc) -> + 'encode_sasl_failure_failure_temporary-auth-failure'(_r, + _acc); +'encode_sasl_failure_failure_$reason'('not-authorized' = + _r, + _acc) -> + 'encode_sasl_failure_failure_not-authorized'(_r, _acc); +'encode_sasl_failure_failure_$reason'('mechanism-too-weak' = + _r, + _acc) -> + 'encode_sasl_failure_failure_mechanism-too-weak'(_r, + _acc); +'encode_sasl_failure_failure_$reason'('malformed-request' = + _r, + _acc) -> + 'encode_sasl_failure_failure_malformed-request'(_r, + _acc); +'encode_sasl_failure_failure_$reason'('invalid-mechanism' = + _r, + _acc) -> + 'encode_sasl_failure_failure_invalid-mechanism'(_r, + _acc); +'encode_sasl_failure_failure_$reason'('invalid-authzid' = + _r, + _acc) -> + 'encode_sasl_failure_failure_invalid-authzid'(_r, _acc); +'encode_sasl_failure_failure_$reason'('incorrect-encoding' = + _r, + _acc) -> + 'encode_sasl_failure_failure_incorrect-encoding'(_r, + _acc); +'encode_sasl_failure_failure_$reason'('encryption-required' = + _r, + _acc) -> + 'encode_sasl_failure_failure_encryption-required'(_r, + _acc); +'encode_sasl_failure_failure_$reason'('credentials-expired' = + _r, + _acc) -> + 'encode_sasl_failure_failure_credentials-expired'(_r, + _acc); +'encode_sasl_failure_failure_$reason'('account-disabled' = + _r, + _acc) -> + 'encode_sasl_failure_failure_account-disabled'(_r, + _acc); +'encode_sasl_failure_failure_$reason'(aborted = _r, + _acc) -> + encode_sasl_failure_failure_aborted(_r, _acc). + +encode_sasl_failure_failure(undefined, _acc) -> _acc; +encode_sasl_failure_failure({sasl_failure, Reason, + Text}, + _acc) -> + _els = 'encode_sasl_failure_failure_$reason'(Reason, + encode_sasl_failure_failure_text(Text, + [])), + _attrs = [{<<"xmlns">>, + <<"urn:ietf:params:xml:ns:xmpp-sasl">>}], + [{xmlel, <<"failure">>, _attrs, _els} | _acc]. + +'decode_sasl_failure_failure_temporary-auth-failure'({xmlel, + _, _attrs, _els}) -> + 'temporary-auth-failure'. + +'encode_sasl_failure_failure_temporary-auth-failure'(undefined, + _acc) -> + _acc; +'encode_sasl_failure_failure_temporary-auth-failure'('temporary-auth-failure', + _acc) -> + _els = [], + _attrs = [], + [{xmlel, <<"temporary-auth-failure">>, _attrs, _els} + | _acc]. + +'decode_sasl_failure_failure_not-authorized'({xmlel, _, + _attrs, _els}) -> + 'not-authorized'. + +'encode_sasl_failure_failure_not-authorized'(undefined, + _acc) -> + _acc; +'encode_sasl_failure_failure_not-authorized'('not-authorized', + _acc) -> + _els = [], + _attrs = [], + [{xmlel, <<"not-authorized">>, _attrs, _els} | _acc]. + +'decode_sasl_failure_failure_mechanism-too-weak'({xmlel, + _, _attrs, _els}) -> + 'mechanism-too-weak'. + +'encode_sasl_failure_failure_mechanism-too-weak'(undefined, + _acc) -> + _acc; +'encode_sasl_failure_failure_mechanism-too-weak'('mechanism-too-weak', + _acc) -> + _els = [], + _attrs = [], + [{xmlel, <<"mechanism-too-weak">>, _attrs, _els} + | _acc]. + +'decode_sasl_failure_failure_malformed-request'({xmlel, + _, _attrs, _els}) -> + 'malformed-request'. + +'encode_sasl_failure_failure_malformed-request'(undefined, + _acc) -> + _acc; +'encode_sasl_failure_failure_malformed-request'('malformed-request', + _acc) -> + _els = [], + _attrs = [], + [{xmlel, <<"malformed-request">>, _attrs, _els} | _acc]. + +'decode_sasl_failure_failure_invalid-mechanism'({xmlel, + _, _attrs, _els}) -> + 'invalid-mechanism'. + +'encode_sasl_failure_failure_invalid-mechanism'(undefined, + _acc) -> + _acc; +'encode_sasl_failure_failure_invalid-mechanism'('invalid-mechanism', + _acc) -> + _els = [], + _attrs = [], + [{xmlel, <<"invalid-mechanism">>, _attrs, _els} | _acc]. + +'decode_sasl_failure_failure_invalid-authzid'({xmlel, _, + _attrs, _els}) -> + 'invalid-authzid'. + +'encode_sasl_failure_failure_invalid-authzid'(undefined, + _acc) -> + _acc; +'encode_sasl_failure_failure_invalid-authzid'('invalid-authzid', + _acc) -> + _els = [], + _attrs = [], + [{xmlel, <<"invalid-authzid">>, _attrs, _els} | _acc]. + +'decode_sasl_failure_failure_incorrect-encoding'({xmlel, + _, _attrs, _els}) -> + 'incorrect-encoding'. + +'encode_sasl_failure_failure_incorrect-encoding'(undefined, + _acc) -> + _acc; +'encode_sasl_failure_failure_incorrect-encoding'('incorrect-encoding', + _acc) -> + _els = [], + _attrs = [], + [{xmlel, <<"incorrect-encoding">>, _attrs, _els} + | _acc]. + +'decode_sasl_failure_failure_encryption-required'({xmlel, + _, _attrs, _els}) -> + 'encryption-required'. + +'encode_sasl_failure_failure_encryption-required'(undefined, + _acc) -> + _acc; +'encode_sasl_failure_failure_encryption-required'('encryption-required', + _acc) -> + _els = [], + _attrs = [], + [{xmlel, <<"encryption-required">>, _attrs, _els} + | _acc]. + +'decode_sasl_failure_failure_credentials-expired'({xmlel, + _, _attrs, _els}) -> + 'credentials-expired'. + +'encode_sasl_failure_failure_credentials-expired'(undefined, + _acc) -> + _acc; +'encode_sasl_failure_failure_credentials-expired'('credentials-expired', + _acc) -> + _els = [], + _attrs = [], + [{xmlel, <<"credentials-expired">>, _attrs, _els} + | _acc]. + +'decode_sasl_failure_failure_account-disabled'({xmlel, + _, _attrs, _els}) -> + 'account-disabled'. + +'encode_sasl_failure_failure_account-disabled'(undefined, + _acc) -> + _acc; +'encode_sasl_failure_failure_account-disabled'('account-disabled', + _acc) -> + _els = [], + _attrs = [], + [{xmlel, <<"account-disabled">>, _attrs, _els} | _acc]. + +decode_sasl_failure_failure_aborted({xmlel, _, _attrs, + _els}) -> + aborted. + +encode_sasl_failure_failure_aborted(undefined, _acc) -> + _acc; +encode_sasl_failure_failure_aborted(aborted, _acc) -> + _els = [], + _attrs = [], + [{xmlel, <<"aborted">>, _attrs, _els} | _acc]. + +decode_sasl_failure_failure_text({xmlel, _, _attrs, + _els}) -> + Text_lang = + decode_sasl_failure_failure_text_attrs(_attrs, + undefined), + Cdata = decode_sasl_failure_failure_text_els(_els, + <<>>), + {Text_lang, Cdata}. + +decode_sasl_failure_failure_text_els([{xmlcdata, _data} + | _els], + Cdata) -> + decode_sasl_failure_failure_text_els(_els, + <<Cdata/binary, _data/binary>>); +decode_sasl_failure_failure_text_els([_ | _els], + Cdata) -> + decode_sasl_failure_failure_text_els(_els, Cdata); +decode_sasl_failure_failure_text_els([], Cdata) -> + decode_sasl_failure_failure_text_cdata(Cdata). + +decode_sasl_failure_failure_text_attrs([{<<"xml:lang">>, + _val} + | _attrs], + _Text_lang) -> + decode_sasl_failure_failure_text_attrs(_attrs, _val); +decode_sasl_failure_failure_text_attrs([_ | _attrs], + Text_lang) -> + decode_sasl_failure_failure_text_attrs(_attrs, + Text_lang); +decode_sasl_failure_failure_text_attrs([], Text_lang) -> + 'decode_sasl_failure_failure_text_xml:lang'(Text_lang). + +encode_sasl_failure_failure_text(undefined, _acc) -> + _acc; +encode_sasl_failure_failure_text({Text_lang, Cdata}, + _acc) -> + _els = encode_sasl_failure_failure_text_cdata(Cdata, + []), + _attrs = + 'encode_sasl_failure_failure_text_xml:lang'(Text_lang, + []), + [{xmlel, <<"text">>, _attrs, _els} | _acc]. + +'decode_sasl_failure_failure_text_xml:lang'(undefined) -> + undefined; +'decode_sasl_failure_failure_text_xml:lang'(_val) -> + _val. + +'encode_sasl_failure_failure_text_xml:lang'(undefined, + _acc) -> + _acc; +'encode_sasl_failure_failure_text_xml:lang'(_val, + _acc) -> + [{<<"xml:lang">>, _val} | _acc]. + +decode_sasl_failure_failure_text_cdata(<<>>) -> + undefined; +decode_sasl_failure_failure_text_cdata(_val) -> _val. + +encode_sasl_failure_failure_text_cdata(undefined, + _acc) -> + _acc; +encode_sasl_failure_failure_text_cdata(_val, _acc) -> + [{xmlcdata, _val} | _acc]. + +decode_sasl_mechanism_mechanism({xmlel, _, _attrs, + _els}) -> + Cdata = decode_sasl_mechanism_mechanism_els(_els, <<>>), + Cdata. + +decode_sasl_mechanism_mechanism_els([{xmlcdata, _data} + | _els], + Cdata) -> + decode_sasl_mechanism_mechanism_els(_els, + <<Cdata/binary, _data/binary>>); +decode_sasl_mechanism_mechanism_els([_ | _els], + Cdata) -> + decode_sasl_mechanism_mechanism_els(_els, Cdata); +decode_sasl_mechanism_mechanism_els([], Cdata) -> + decode_sasl_mechanism_mechanism_cdata(Cdata). + +encode_sasl_mechanism_mechanism([], _acc) -> _acc; +encode_sasl_mechanism_mechanism([Cdata | _tail], + _acc) -> + _els = encode_sasl_mechanism_mechanism_cdata(Cdata, []), + _attrs = [], + encode_sasl_mechanism_mechanism(_tail, + [{xmlel, <<"mechanism">>, _attrs, _els} + | _acc]). + +decode_sasl_mechanism_mechanism_cdata(<<>>) -> + undefined; +decode_sasl_mechanism_mechanism_cdata(_val) -> _val. + +encode_sasl_mechanism_mechanism_cdata(undefined, + _acc) -> + _acc; +encode_sasl_mechanism_mechanism_cdata(_val, _acc) -> + [{xmlcdata, _val} | _acc]. + +decode_sasl_mechanisms_mechanisms({xmlel, _, _attrs, + _els}) -> + Mechanism = decode_sasl_mechanisms_mechanisms_els(_els, + []), + {sasl_mechanisms, Mechanism}. + +decode_sasl_mechanisms_mechanisms_els([{xmlel, + <<"mechanism">>, _attrs, _} = + _el + | _els], + Mechanism) -> + case xml:get_attr_s(<<"xmlns">>, _attrs) of + <<>> -> + decode_sasl_mechanisms_mechanisms_els(_els, + [decode_sasl_mechanism_mechanism(_el) + | Mechanism]); + _ -> + decode_sasl_mechanisms_mechanisms_els(_els, Mechanism) + end; +decode_sasl_mechanisms_mechanisms_els([_ | _els], + Mechanism) -> + decode_sasl_mechanisms_mechanisms_els(_els, Mechanism); +decode_sasl_mechanisms_mechanisms_els([], Mechanism) -> + xml_gen:reverse(Mechanism, 1, infinity). + +encode_sasl_mechanisms_mechanisms(undefined, _acc) -> + _acc; +encode_sasl_mechanisms_mechanisms({sasl_mechanisms, + Mechanism}, + _acc) -> + _els = encode_sasl_mechanism_mechanism(Mechanism, []), + _attrs = [{<<"xmlns">>, + <<"urn:ietf:params:xml:ns:xmpp-sasl">>}], + [{xmlel, <<"mechanisms">>, _attrs, _els} | _acc]. + +decode_starttls_starttls({xmlel, _, _attrs, _els}) -> + Required = decode_starttls_starttls_els(_els, false), + {starttls, Required}. + +decode_starttls_starttls_els([{xmlel, <<"required">>, + _attrs, _} = + _el + | _els], + Required) -> + case xml:get_attr_s(<<"xmlns">>, _attrs) of + <<>> -> + decode_starttls_starttls_els(_els, + decode_starttls_starttls_required(_el)); + _ -> decode_starttls_starttls_els(_els, Required) + end; +decode_starttls_starttls_els([_ | _els], Required) -> + decode_starttls_starttls_els(_els, Required); +decode_starttls_starttls_els([], Required) -> Required. + +encode_starttls_starttls(undefined, _acc) -> _acc; +encode_starttls_starttls({starttls, Required}, _acc) -> + _els = encode_starttls_starttls_required(Required, []), + _attrs = [{<<"xmlns">>, + <<"urn:ietf:params:xml:ns:xmpp-tls">>}], + [{xmlel, <<"starttls">>, _attrs, _els} | _acc]. + +decode_starttls_starttls_required({xmlel, _, _attrs, + _els}) -> + true. + +encode_starttls_starttls_required(false, _acc) -> _acc; +encode_starttls_starttls_required(true, _acc) -> + _els = [], + _attrs = [], + [{xmlel, <<"required">>, _attrs, _els} | _acc]. + +decode_starttls_proceed_proceed({xmlel, _, _attrs, + _els}) -> + {starttls_proceed}. + +encode_starttls_proceed_proceed(undefined, _acc) -> + _acc; +encode_starttls_proceed_proceed({starttls_proceed}, + _acc) -> + _els = [], + _attrs = [{<<"xmlns">>, + <<"urn:ietf:params:xml:ns:xmpp-tls">>}], + [{xmlel, <<"proceed">>, _attrs, _els} | _acc]. + +decode_starttls_failure_failure({xmlel, _, _attrs, + _els}) -> + {starttls_failure}. + +encode_starttls_failure_failure(undefined, _acc) -> + _acc; +encode_starttls_failure_failure({starttls_failure}, + _acc) -> + _els = [], + _attrs = [{<<"xmlns">>, + <<"urn:ietf:params:xml:ns:xmpp-tls">>}], + [{xmlel, <<"failure">>, _attrs, _els} | _acc]. + +'decode_stream_features_stream:features'({xmlel, _, + _attrs, _els}) -> + __Els = + 'decode_stream_features_stream:features_els'(_els, []), + {stream_features, __Els}. + +'decode_stream_features_stream:features_els'([{xmlel, _, + _, _} = + _el + | _els], + __Els) -> + 'decode_stream_features_stream:features_els'(_els, + [decode(_el) | __Els]); +'decode_stream_features_stream:features_els'([_ | _els], + __Els) -> + 'decode_stream_features_stream:features_els'(_els, + __Els); +'decode_stream_features_stream:features_els'([], + __Els) -> + lists:reverse(__Els). + +'encode_stream_features_stream:features'(undefined, + _acc) -> + _acc; +'encode_stream_features_stream:features'({stream_features, + __Els}, + _acc) -> + _els = [encode(_subel) || _subel <- __Els] ++ [], + _attrs = [], + [{xmlel, <<"stream:features">>, _attrs, _els} | _acc]. + +decode_p1_push_push({xmlel, _, _attrs, _els}) -> + {p1_push}. + +encode_p1_push_push(undefined, _acc) -> _acc; +encode_p1_push_push({p1_push}, _acc) -> + _els = [], + _attrs = [{<<"xmlns">>, <<"p1:push">>}], + [{xmlel, <<"push">>, _attrs, _els} | _acc]. + +decode_p1_rebind_rebind({xmlel, _, _attrs, _els}) -> + {p1_rebind}. + +encode_p1_rebind_rebind(undefined, _acc) -> _acc; +encode_p1_rebind_rebind({p1_rebind}, _acc) -> + _els = [], + _attrs = [{<<"xmlns">>, <<"p1:rebind">>}], + [{xmlel, <<"rebind">>, _attrs, _els} | _acc]. + +decode_p1_ack_ack({xmlel, _, _attrs, _els}) -> {p1_ack}. + +encode_p1_ack_ack(undefined, _acc) -> _acc; +encode_p1_ack_ack({p1_ack}, _acc) -> + _els = [], + _attrs = [{<<"xmlns">>, <<"p1:ack">>}], + [{xmlel, <<"ack">>, _attrs, _els} | _acc]. + +decode_caps_c({xmlel, _, _attrs, _els}) -> + {Ver, Node, Hash} = decode_caps_c_attrs(_attrs, + undefined, undefined, undefined), + {caps, Hash, Node, Ver}. + +decode_caps_c_attrs([{<<"ver">>, _val} | _attrs], _Ver, + Node, Hash) -> + decode_caps_c_attrs(_attrs, _val, Node, Hash); +decode_caps_c_attrs([{<<"node">>, _val} | _attrs], Ver, + _Node, Hash) -> + decode_caps_c_attrs(_attrs, Ver, _val, Hash); +decode_caps_c_attrs([{<<"hash">>, _val} | _attrs], Ver, + Node, _Hash) -> + decode_caps_c_attrs(_attrs, Ver, Node, _val); +decode_caps_c_attrs([_ | _attrs], Ver, Node, Hash) -> + decode_caps_c_attrs(_attrs, Ver, Node, Hash); +decode_caps_c_attrs([], Ver, Node, Hash) -> + {decode_caps_c_ver(Ver), decode_caps_c_node(Node), + decode_caps_c_hash(Hash)}. + +encode_caps_c(undefined, _acc) -> _acc; +encode_caps_c({caps, Hash, Node, Ver}, _acc) -> + _els = [], + _attrs = encode_caps_c_hash(Hash, + encode_caps_c_node(Node, + encode_caps_c_ver(Ver, + [{<<"xmlns">>, + <<"http://jabber.org/protocol/caps">>}]))), + [{xmlel, <<"c">>, _attrs, _els} | _acc]. + +decode_caps_c_hash(undefined) -> undefined; +decode_caps_c_hash(_val) -> _val. + +encode_caps_c_hash(undefined, _acc) -> _acc; +encode_caps_c_hash(_val, _acc) -> + [{<<"hash">>, _val} | _acc]. + +decode_caps_c_node(undefined) -> undefined; +decode_caps_c_node(_val) -> _val. + +encode_caps_c_node(undefined, _acc) -> _acc; +encode_caps_c_node(_val, _acc) -> + [{<<"node">>, _val} | _acc]. + +decode_caps_c_ver(undefined) -> undefined; +decode_caps_c_ver(_val) -> + case catch base64:decode(_val) of + {'EXIT', _} -> + erlang:error({bad_attr_value, <<"ver">>, <<"c">>, + <<"http://jabber.org/protocol/caps">>}); + _res -> _res + end. + +encode_caps_c_ver(undefined, _acc) -> _acc; +encode_caps_c_ver(_val, _acc) -> + [{<<"ver">>, base64:encode(_val)} | _acc]. + +decode_register_register({xmlel, _, _attrs, _els}) -> + {register}. + +encode_register_register(undefined, _acc) -> _acc; +encode_register_register({register}, _acc) -> + _els = [], + _attrs = [{<<"xmlns">>, + <<"http://jabber.org/features/iq-register">>}], + [{xmlel, <<"register">>, _attrs, _els} | _acc]. + +decode_session_session({xmlel, _, _attrs, _els}) -> + {session}. + +encode_session_session(undefined, _acc) -> _acc; +encode_session_session({session}, _acc) -> + _els = [], + _attrs = [{<<"xmlns">>, + <<"urn:ietf:params:xml:ns:xmpp-session">>}], + [{xmlel, <<"session">>, _attrs, _els} | _acc]. + +decode_ping_ping({xmlel, _, _attrs, _els}) -> {ping}. + +encode_ping_ping(undefined, _acc) -> _acc; +encode_ping_ping({ping}, _acc) -> + _els = [], + _attrs = [{<<"xmlns">>, <<"urn:xmpp:ping">>}], + [{xmlel, <<"ping">>, _attrs, _els} | _acc]. + +decode_time_time({xmlel, _, _attrs, _els}) -> + {Utc, Tzo} = decode_time_time_els(_els, undefined, + undefined), + {time, Tzo, Utc}. + +decode_time_time_els([{xmlel, <<"utc">>, _attrs, _} = + _el + | _els], + Utc, Tzo) -> + case xml:get_attr_s(<<"xmlns">>, _attrs) of + <<>> -> + decode_time_time_els(_els, decode_time_time_utc(_el), + Tzo); + _ -> decode_time_time_els(_els, Utc, Tzo) + end; +decode_time_time_els([{xmlel, <<"tzo">>, _attrs, _} = + _el + | _els], + Utc, Tzo) -> + case xml:get_attr_s(<<"xmlns">>, _attrs) of + <<>> -> + decode_time_time_els(_els, Utc, + decode_time_time_tzo(_el)); + _ -> decode_time_time_els(_els, Utc, Tzo) + end; +decode_time_time_els([_ | _els], Utc, Tzo) -> + decode_time_time_els(_els, Utc, Tzo); +decode_time_time_els([], Utc, Tzo) -> {Utc, Tzo}. + +encode_time_time(undefined, _acc) -> _acc; +encode_time_time({time, Tzo, Utc}, _acc) -> + _els = encode_time_time_tzo(Tzo, + encode_time_time_utc(Utc, [])), + _attrs = [{<<"xmlns">>, <<"urn:xmpp:time">>}], + [{xmlel, <<"time">>, _attrs, _els} | _acc]. + +decode_time_time_utc({xmlel, _, _attrs, _els}) -> + Cdata = decode_time_time_utc_els(_els, <<>>), Cdata. + +decode_time_time_utc_els([{xmlcdata, _data} | _els], + Cdata) -> + decode_time_time_utc_els(_els, + <<Cdata/binary, _data/binary>>); +decode_time_time_utc_els([_ | _els], Cdata) -> + decode_time_time_utc_els(_els, Cdata); +decode_time_time_utc_els([], Cdata) -> + decode_time_time_utc_cdata(Cdata). + +encode_time_time_utc(undefined, _acc) -> _acc; +encode_time_time_utc(Cdata, _acc) -> + _els = encode_time_time_utc_cdata(Cdata, []), + _attrs = [], + [{xmlel, <<"utc">>, _attrs, _els} | _acc]. + +decode_time_time_utc_cdata(<<>>) -> undefined; +decode_time_time_utc_cdata(_val) -> + case catch dec_utc(_val) of + {'EXIT', _} -> + erlang:error({bad_cdata_value, <<>>, <<"utc">>, <<>>}); + _res -> _res + end. + +encode_time_time_utc_cdata(undefined, _acc) -> _acc; +encode_time_time_utc_cdata(_val, _acc) -> + [{xmlcdata, enc_utc(_val)} | _acc]. + +decode_time_time_tzo({xmlel, _, _attrs, _els}) -> + Cdata = decode_time_time_tzo_els(_els, <<>>), Cdata. + +decode_time_time_tzo_els([{xmlcdata, _data} | _els], + Cdata) -> + decode_time_time_tzo_els(_els, + <<Cdata/binary, _data/binary>>); +decode_time_time_tzo_els([_ | _els], Cdata) -> + decode_time_time_tzo_els(_els, Cdata); +decode_time_time_tzo_els([], Cdata) -> + decode_time_time_tzo_cdata(Cdata). + +encode_time_time_tzo(undefined, _acc) -> _acc; +encode_time_time_tzo(Cdata, _acc) -> + _els = encode_time_time_tzo_cdata(Cdata, []), + _attrs = [], + [{xmlel, <<"tzo">>, _attrs, _els} | _acc]. + +decode_time_time_tzo_cdata(<<>>) -> undefined; +decode_time_time_tzo_cdata(_val) -> + case catch dec_tzo(_val) of + {'EXIT', _} -> + erlang:error({bad_cdata_value, <<>>, <<"tzo">>, <<>>}); + _res -> _res + end. + +encode_time_time_tzo_cdata(undefined, _acc) -> _acc; +encode_time_time_tzo_cdata(_val, _acc) -> + [{xmlcdata, enc_tzo(_val)} | _acc]. + +'decode_stream_error_stream:error'({xmlel, _, _attrs, + _els}) -> + {Text, Reason} = + 'decode_stream_error_stream:error_els'(_els, undefined, + undefined), + {stream_error, Reason, Text}. + +'decode_stream_error_stream:error_els'([{xmlel, + <<"text">>, _attrs, _} = + _el + | _els], + Text, Reason) -> + case xml:get_attr_s(<<"xmlns">>, _attrs) of + <<"urn:ietf:params:xml:ns:xmpp-streams">> -> + 'decode_stream_error_stream:error_els'(_els, + 'decode_stream_error_stream:error_text'(_el), + Reason); + _ -> + 'decode_stream_error_stream:error_els'(_els, Text, + Reason) + end; +'decode_stream_error_stream:error_els'([{xmlel, + <<"unsupported-version">>, _attrs, _} = + _el + | _els], + Text, Reason) -> + case xml:get_attr_s(<<"xmlns">>, _attrs) of + <<"urn:ietf:params:xml:ns:xmpp-streams">> -> + 'decode_stream_error_stream:error_els'(_els, Text, + 'decode_stream_error_stream:error_unsupported-version'(_el)); + _ -> + 'decode_stream_error_stream:error_els'(_els, Text, + Reason) + end; +'decode_stream_error_stream:error_els'([{xmlel, + <<"unsupported-stanza-type">>, _attrs, + _} = + _el + | _els], + Text, Reason) -> + case xml:get_attr_s(<<"xmlns">>, _attrs) of + <<"urn:ietf:params:xml:ns:xmpp-streams">> -> + 'decode_stream_error_stream:error_els'(_els, Text, + 'decode_stream_error_stream:error_unsupported-stanza-type'(_el)); + _ -> + 'decode_stream_error_stream:error_els'(_els, Text, + Reason) + end; +'decode_stream_error_stream:error_els'([{xmlel, + <<"unsupported-encoding">>, _attrs, + _} = + _el + | _els], + Text, Reason) -> + case xml:get_attr_s(<<"xmlns">>, _attrs) of + <<"urn:ietf:params:xml:ns:xmpp-streams">> -> + 'decode_stream_error_stream:error_els'(_els, Text, + 'decode_stream_error_stream:error_unsupported-encoding'(_el)); + _ -> + 'decode_stream_error_stream:error_els'(_els, Text, + Reason) + end; +'decode_stream_error_stream:error_els'([{xmlel, + <<"undefined-condition">>, _attrs, _} = + _el + | _els], + Text, Reason) -> + case xml:get_attr_s(<<"xmlns">>, _attrs) of + <<"urn:ietf:params:xml:ns:xmpp-streams">> -> + 'decode_stream_error_stream:error_els'(_els, Text, + 'decode_stream_error_stream:error_undefined-condition'(_el)); + _ -> + 'decode_stream_error_stream:error_els'(_els, Text, + Reason) + end; +'decode_stream_error_stream:error_els'([{xmlel, + <<"system-shutdown">>, _attrs, _} = + _el + | _els], + Text, Reason) -> + case xml:get_attr_s(<<"xmlns">>, _attrs) of + <<"urn:ietf:params:xml:ns:xmpp-streams">> -> + 'decode_stream_error_stream:error_els'(_els, Text, + 'decode_stream_error_stream:error_system-shutdown'(_el)); + _ -> + 'decode_stream_error_stream:error_els'(_els, Text, + Reason) + end; +'decode_stream_error_stream:error_els'([{xmlel, + <<"see-other-host">>, _attrs, _} = + _el + | _els], + Text, Reason) -> + case xml:get_attr_s(<<"xmlns">>, _attrs) of + <<"urn:ietf:params:xml:ns:xmpp-streams">> -> + 'decode_stream_error_stream:error_els'(_els, Text, + 'decode_stream_error_stream:error_see-other-host'(_el)); + _ -> + 'decode_stream_error_stream:error_els'(_els, Text, + Reason) + end; +'decode_stream_error_stream:error_els'([{xmlel, + <<"restricted-xml">>, _attrs, _} = + _el + | _els], + Text, Reason) -> + case xml:get_attr_s(<<"xmlns">>, _attrs) of + <<"urn:ietf:params:xml:ns:xmpp-streams">> -> + 'decode_stream_error_stream:error_els'(_els, Text, + 'decode_stream_error_stream:error_restricted-xml'(_el)); + _ -> + 'decode_stream_error_stream:error_els'(_els, Text, + Reason) + end; +'decode_stream_error_stream:error_els'([{xmlel, + <<"resource-constraint">>, _attrs, _} = + _el + | _els], + Text, Reason) -> + case xml:get_attr_s(<<"xmlns">>, _attrs) of + <<"urn:ietf:params:xml:ns:xmpp-streams">> -> + 'decode_stream_error_stream:error_els'(_els, Text, + 'decode_stream_error_stream:error_resource-constraint'(_el)); + _ -> + 'decode_stream_error_stream:error_els'(_els, Text, + Reason) + end; +'decode_stream_error_stream:error_els'([{xmlel, + <<"reset">>, _attrs, _} = + _el + | _els], + Text, Reason) -> + case xml:get_attr_s(<<"xmlns">>, _attrs) of + <<"urn:ietf:params:xml:ns:xmpp-streams">> -> + 'decode_stream_error_stream:error_els'(_els, Text, + 'decode_stream_error_stream:error_reset'(_el)); + _ -> + 'decode_stream_error_stream:error_els'(_els, Text, + Reason) + end; +'decode_stream_error_stream:error_els'([{xmlel, + <<"remote-connection-failed">>, _attrs, + _} = + _el + | _els], + Text, Reason) -> + case xml:get_attr_s(<<"xmlns">>, _attrs) of + <<"urn:ietf:params:xml:ns:xmpp-streams">> -> + 'decode_stream_error_stream:error_els'(_els, Text, + 'decode_stream_error_stream:error_remote-connection-failed'(_el)); + _ -> + 'decode_stream_error_stream:error_els'(_els, Text, + Reason) + end; +'decode_stream_error_stream:error_els'([{xmlel, + <<"policy-violation">>, _attrs, _} = + _el + | _els], + Text, Reason) -> + case xml:get_attr_s(<<"xmlns">>, _attrs) of + <<"urn:ietf:params:xml:ns:xmpp-streams">> -> + 'decode_stream_error_stream:error_els'(_els, Text, + 'decode_stream_error_stream:error_policy-violation'(_el)); + _ -> + 'decode_stream_error_stream:error_els'(_els, Text, + Reason) + end; +'decode_stream_error_stream:error_els'([{xmlel, + <<"not-well-formed">>, _attrs, _} = + _el + | _els], + Text, Reason) -> + case xml:get_attr_s(<<"xmlns">>, _attrs) of + <<"urn:ietf:params:xml:ns:xmpp-streams">> -> + 'decode_stream_error_stream:error_els'(_els, Text, + 'decode_stream_error_stream:error_not-well-formed'(_el)); + _ -> + 'decode_stream_error_stream:error_els'(_els, Text, + Reason) + end; +'decode_stream_error_stream:error_els'([{xmlel, + <<"not-authorized">>, _attrs, _} = + _el + | _els], + Text, Reason) -> + case xml:get_attr_s(<<"xmlns">>, _attrs) of + <<"urn:ietf:params:xml:ns:xmpp-streams">> -> + 'decode_stream_error_stream:error_els'(_els, Text, + 'decode_stream_error_stream:error_not-authorized'(_el)); + _ -> + 'decode_stream_error_stream:error_els'(_els, Text, + Reason) + end; +'decode_stream_error_stream:error_els'([{xmlel, + <<"invalid-xml">>, _attrs, _} = + _el + | _els], + Text, Reason) -> + case xml:get_attr_s(<<"xmlns">>, _attrs) of + <<"urn:ietf:params:xml:ns:xmpp-streams">> -> + 'decode_stream_error_stream:error_els'(_els, Text, + 'decode_stream_error_stream:error_invalid-xml'(_el)); + _ -> + 'decode_stream_error_stream:error_els'(_els, Text, + Reason) + end; +'decode_stream_error_stream:error_els'([{xmlel, + <<"invalid-namespace">>, _attrs, _} = + _el + | _els], + Text, Reason) -> + case xml:get_attr_s(<<"xmlns">>, _attrs) of + <<"urn:ietf:params:xml:ns:xmpp-streams">> -> + 'decode_stream_error_stream:error_els'(_els, Text, + 'decode_stream_error_stream:error_invalid-namespace'(_el)); + _ -> + 'decode_stream_error_stream:error_els'(_els, Text, + Reason) + end; +'decode_stream_error_stream:error_els'([{xmlel, + <<"invalid-id">>, _attrs, _} = + _el + | _els], + Text, Reason) -> + case xml:get_attr_s(<<"xmlns">>, _attrs) of + <<"urn:ietf:params:xml:ns:xmpp-streams">> -> + 'decode_stream_error_stream:error_els'(_els, Text, + 'decode_stream_error_stream:error_invalid-id'(_el)); + _ -> + 'decode_stream_error_stream:error_els'(_els, Text, + Reason) + end; +'decode_stream_error_stream:error_els'([{xmlel, + <<"invalid-from">>, _attrs, _} = + _el + | _els], + Text, Reason) -> + case xml:get_attr_s(<<"xmlns">>, _attrs) of + <<"urn:ietf:params:xml:ns:xmpp-streams">> -> + 'decode_stream_error_stream:error_els'(_els, Text, + 'decode_stream_error_stream:error_invalid-from'(_el)); + _ -> + 'decode_stream_error_stream:error_els'(_els, Text, + Reason) + end; +'decode_stream_error_stream:error_els'([{xmlel, + <<"internal-server-error">>, _attrs, + _} = + _el + | _els], + Text, Reason) -> + case xml:get_attr_s(<<"xmlns">>, _attrs) of + <<"urn:ietf:params:xml:ns:xmpp-streams">> -> + 'decode_stream_error_stream:error_els'(_els, Text, + 'decode_stream_error_stream:error_internal-server-error'(_el)); + _ -> + 'decode_stream_error_stream:error_els'(_els, Text, + Reason) + end; +'decode_stream_error_stream:error_els'([{xmlel, + <<"improper-addressing">>, _attrs, _} = + _el + | _els], + Text, Reason) -> + case xml:get_attr_s(<<"xmlns">>, _attrs) of + <<"urn:ietf:params:xml:ns:xmpp-streams">> -> + 'decode_stream_error_stream:error_els'(_els, Text, + 'decode_stream_error_stream:error_improper-addressing'(_el)); + _ -> + 'decode_stream_error_stream:error_els'(_els, Text, + Reason) + end; +'decode_stream_error_stream:error_els'([{xmlel, + <<"host-unknown">>, _attrs, _} = + _el + | _els], + Text, Reason) -> + case xml:get_attr_s(<<"xmlns">>, _attrs) of + <<"urn:ietf:params:xml:ns:xmpp-streams">> -> + 'decode_stream_error_stream:error_els'(_els, Text, + 'decode_stream_error_stream:error_host-unknown'(_el)); + _ -> + 'decode_stream_error_stream:error_els'(_els, Text, + Reason) + end; +'decode_stream_error_stream:error_els'([{xmlel, + <<"host-gone">>, _attrs, _} = + _el + | _els], + Text, Reason) -> + case xml:get_attr_s(<<"xmlns">>, _attrs) of + <<"urn:ietf:params:xml:ns:xmpp-streams">> -> + 'decode_stream_error_stream:error_els'(_els, Text, + 'decode_stream_error_stream:error_host-gone'(_el)); + _ -> + 'decode_stream_error_stream:error_els'(_els, Text, + Reason) + end; +'decode_stream_error_stream:error_els'([{xmlel, + <<"connection-timeout">>, _attrs, _} = + _el + | _els], + Text, Reason) -> + case xml:get_attr_s(<<"xmlns">>, _attrs) of + <<"urn:ietf:params:xml:ns:xmpp-streams">> -> + 'decode_stream_error_stream:error_els'(_els, Text, + 'decode_stream_error_stream:error_connection-timeout'(_el)); + _ -> + 'decode_stream_error_stream:error_els'(_els, Text, + Reason) + end; +'decode_stream_error_stream:error_els'([{xmlel, + <<"conflict">>, _attrs, _} = + _el + | _els], + Text, Reason) -> + case xml:get_attr_s(<<"xmlns">>, _attrs) of + <<"urn:ietf:params:xml:ns:xmpp-streams">> -> + 'decode_stream_error_stream:error_els'(_els, Text, + 'decode_stream_error_stream:error_conflict'(_el)); + _ -> + 'decode_stream_error_stream:error_els'(_els, Text, + Reason) + end; +'decode_stream_error_stream:error_els'([{xmlel, + <<"bad-namespace-prefix">>, _attrs, + _} = + _el + | _els], + Text, Reason) -> + case xml:get_attr_s(<<"xmlns">>, _attrs) of + <<"urn:ietf:params:xml:ns:xmpp-streams">> -> + 'decode_stream_error_stream:error_els'(_els, Text, + 'decode_stream_error_stream:error_bad-namespace-prefix'(_el)); + _ -> + 'decode_stream_error_stream:error_els'(_els, Text, + Reason) + end; +'decode_stream_error_stream:error_els'([{xmlel, + <<"bad-format">>, _attrs, _} = + _el + | _els], + Text, Reason) -> + case xml:get_attr_s(<<"xmlns">>, _attrs) of + <<"urn:ietf:params:xml:ns:xmpp-streams">> -> + 'decode_stream_error_stream:error_els'(_els, Text, + 'decode_stream_error_stream:error_bad-format'(_el)); + _ -> + 'decode_stream_error_stream:error_els'(_els, Text, + Reason) + end; +'decode_stream_error_stream:error_els'([_ | _els], Text, + Reason) -> + 'decode_stream_error_stream:error_els'(_els, Text, + Reason); +'decode_stream_error_stream:error_els'([], Text, + Reason) -> + {Text, Reason}. + +'encode_stream_error_stream:error_$reason'(undefined, + _acc) -> + _acc; +'encode_stream_error_stream:error_$reason'('unsupported-version' = + _r, + _acc) -> + 'encode_stream_error_stream:error_unsupported-version'(_r, + _acc); +'encode_stream_error_stream:error_$reason'('unsupported-stanza-type' = + _r, + _acc) -> + 'encode_stream_error_stream:error_unsupported-stanza-type'(_r, + _acc); +'encode_stream_error_stream:error_$reason'('unsupported-encoding' = + _r, + _acc) -> + 'encode_stream_error_stream:error_unsupported-encoding'(_r, + _acc); +'encode_stream_error_stream:error_$reason'('undefined-condition' = + _r, + _acc) -> + 'encode_stream_error_stream:error_undefined-condition'(_r, + _acc); +'encode_stream_error_stream:error_$reason'('system-shutdown' = + _r, + _acc) -> + 'encode_stream_error_stream:error_system-shutdown'(_r, + _acc); +'encode_stream_error_stream:error_$reason'({'see-other-host', + _} = + _r, + _acc) -> + 'encode_stream_error_stream:error_see-other-host'(_r, + _acc); +'encode_stream_error_stream:error_$reason'('restricted-xml' = + _r, + _acc) -> + 'encode_stream_error_stream:error_restricted-xml'(_r, + _acc); +'encode_stream_error_stream:error_$reason'('resource-constraint' = + _r, + _acc) -> + 'encode_stream_error_stream:error_resource-constraint'(_r, + _acc); +'encode_stream_error_stream:error_$reason'(reset = _r, + _acc) -> + 'encode_stream_error_stream:error_reset'(_r, _acc); +'encode_stream_error_stream:error_$reason'('remote-connection-failed' = + _r, + _acc) -> + 'encode_stream_error_stream:error_remote-connection-failed'(_r, + _acc); +'encode_stream_error_stream:error_$reason'('policy-violation' = + _r, + _acc) -> + 'encode_stream_error_stream:error_policy-violation'(_r, + _acc); +'encode_stream_error_stream:error_$reason'('not-well-formed' = + _r, + _acc) -> + 'encode_stream_error_stream:error_not-well-formed'(_r, + _acc); +'encode_stream_error_stream:error_$reason'('not-authorized' = + _r, + _acc) -> + 'encode_stream_error_stream:error_not-authorized'(_r, + _acc); +'encode_stream_error_stream:error_$reason'('invalid-xml' = + _r, + _acc) -> + 'encode_stream_error_stream:error_invalid-xml'(_r, + _acc); +'encode_stream_error_stream:error_$reason'('invalid-namespace' = + _r, + _acc) -> + 'encode_stream_error_stream:error_invalid-namespace'(_r, + _acc); +'encode_stream_error_stream:error_$reason'('invalid-id' = + _r, + _acc) -> + 'encode_stream_error_stream:error_invalid-id'(_r, _acc); +'encode_stream_error_stream:error_$reason'('invalid-from' = + _r, + _acc) -> + 'encode_stream_error_stream:error_invalid-from'(_r, + _acc); +'encode_stream_error_stream:error_$reason'('internal-server-error' = + _r, + _acc) -> + 'encode_stream_error_stream:error_internal-server-error'(_r, + _acc); +'encode_stream_error_stream:error_$reason'('improper-addressing' = + _r, + _acc) -> + 'encode_stream_error_stream:error_improper-addressing'(_r, + _acc); +'encode_stream_error_stream:error_$reason'('host-unknown' = + _r, + _acc) -> + 'encode_stream_error_stream:error_host-unknown'(_r, + _acc); +'encode_stream_error_stream:error_$reason'('host-gone' = + _r, + _acc) -> + 'encode_stream_error_stream:error_host-gone'(_r, _acc); +'encode_stream_error_stream:error_$reason'('connection-timeout' = + _r, + _acc) -> + 'encode_stream_error_stream:error_connection-timeout'(_r, + _acc); +'encode_stream_error_stream:error_$reason'(conflict = + _r, + _acc) -> + 'encode_stream_error_stream:error_conflict'(_r, _acc); +'encode_stream_error_stream:error_$reason'('bad-namespace-prefix' = + _r, + _acc) -> + 'encode_stream_error_stream:error_bad-namespace-prefix'(_r, + _acc); +'encode_stream_error_stream:error_$reason'('bad-format' = + _r, + _acc) -> + 'encode_stream_error_stream:error_bad-format'(_r, _acc). + +'encode_stream_error_stream:error'(undefined, _acc) -> + _acc; +'encode_stream_error_stream:error'({stream_error, + Reason, Text}, + _acc) -> + _els = + 'encode_stream_error_stream:error_$reason'(Reason, + 'encode_stream_error_stream:error_text'(Text, + [])), + _attrs = [], + [{xmlel, <<"stream:error">>, _attrs, _els} | _acc]. + +'decode_stream_error_stream:error_unsupported-version'({xmlel, + _, _attrs, _els}) -> + 'unsupported-version'. + +'encode_stream_error_stream:error_unsupported-version'(undefined, + _acc) -> + _acc; +'encode_stream_error_stream:error_unsupported-version'('unsupported-version', + _acc) -> + _els = [], + _attrs = [{<<"xmlns">>, + <<"urn:ietf:params:xml:ns:xmpp-streams">>}], + [{xmlel, <<"unsupported-version">>, _attrs, _els} + | _acc]. + +'decode_stream_error_stream:error_unsupported-stanza-type'({xmlel, + _, _attrs, _els}) -> + 'unsupported-stanza-type'. + +'encode_stream_error_stream:error_unsupported-stanza-type'(undefined, + _acc) -> + _acc; +'encode_stream_error_stream:error_unsupported-stanza-type'('unsupported-stanza-type', + _acc) -> + _els = [], + _attrs = [{<<"xmlns">>, + <<"urn:ietf:params:xml:ns:xmpp-streams">>}], + [{xmlel, <<"unsupported-stanza-type">>, _attrs, _els} + | _acc]. + +'decode_stream_error_stream:error_unsupported-encoding'({xmlel, + _, _attrs, _els}) -> + 'unsupported-encoding'. + +'encode_stream_error_stream:error_unsupported-encoding'(undefined, + _acc) -> + _acc; +'encode_stream_error_stream:error_unsupported-encoding'('unsupported-encoding', + _acc) -> + _els = [], + _attrs = [{<<"xmlns">>, + <<"urn:ietf:params:xml:ns:xmpp-streams">>}], + [{xmlel, <<"unsupported-encoding">>, _attrs, _els} + | _acc]. + +'decode_stream_error_stream:error_undefined-condition'({xmlel, + _, _attrs, _els}) -> + 'undefined-condition'. + +'encode_stream_error_stream:error_undefined-condition'(undefined, + _acc) -> + _acc; +'encode_stream_error_stream:error_undefined-condition'('undefined-condition', + _acc) -> + _els = [], + _attrs = [{<<"xmlns">>, + <<"urn:ietf:params:xml:ns:xmpp-streams">>}], + [{xmlel, <<"undefined-condition">>, _attrs, _els} + | _acc]. + +'decode_stream_error_stream:error_system-shutdown'({xmlel, + _, _attrs, _els}) -> + 'system-shutdown'. + +'encode_stream_error_stream:error_system-shutdown'(undefined, + _acc) -> + _acc; +'encode_stream_error_stream:error_system-shutdown'('system-shutdown', + _acc) -> + _els = [], + _attrs = [{<<"xmlns">>, + <<"urn:ietf:params:xml:ns:xmpp-streams">>}], + [{xmlel, <<"system-shutdown">>, _attrs, _els} | _acc]. + +'decode_stream_error_stream:error_see-other-host'({xmlel, + _, _attrs, _els}) -> + Cdata = + 'decode_stream_error_stream:error_see-other-host_els'(_els, + <<>>), + {'see-other-host', Cdata}. + +'decode_stream_error_stream:error_see-other-host_els'([{xmlcdata, + _data} + | _els], + Cdata) -> + 'decode_stream_error_stream:error_see-other-host_els'(_els, + <<Cdata/binary, + _data/binary>>); +'decode_stream_error_stream:error_see-other-host_els'([_ + | _els], + Cdata) -> + 'decode_stream_error_stream:error_see-other-host_els'(_els, + Cdata); +'decode_stream_error_stream:error_see-other-host_els'([], + Cdata) -> + 'decode_stream_error_stream:error_see-other-host_cdata'(Cdata). + +'encode_stream_error_stream:error_see-other-host'(undefined, + _acc) -> + _acc; +'encode_stream_error_stream:error_see-other-host'({'see-other-host', + Cdata}, + _acc) -> + _els = + 'encode_stream_error_stream:error_see-other-host_cdata'(Cdata, + []), + _attrs = [{<<"xmlns">>, + <<"urn:ietf:params:xml:ns:xmpp-streams">>}], + [{xmlel, <<"see-other-host">>, _attrs, _els} | _acc]. + +'decode_stream_error_stream:error_see-other-host_cdata'(<<>>) -> + undefined; +'decode_stream_error_stream:error_see-other-host_cdata'(_val) -> + _val. + +'encode_stream_error_stream:error_see-other-host_cdata'(undefined, + _acc) -> + _acc; +'encode_stream_error_stream:error_see-other-host_cdata'(_val, + _acc) -> + [{xmlcdata, _val} | _acc]. + +'decode_stream_error_stream:error_restricted-xml'({xmlel, + _, _attrs, _els}) -> + 'restricted-xml'. + +'encode_stream_error_stream:error_restricted-xml'(undefined, + _acc) -> + _acc; +'encode_stream_error_stream:error_restricted-xml'('restricted-xml', + _acc) -> + _els = [], + _attrs = [{<<"xmlns">>, + <<"urn:ietf:params:xml:ns:xmpp-streams">>}], + [{xmlel, <<"restricted-xml">>, _attrs, _els} | _acc]. + +'decode_stream_error_stream:error_resource-constraint'({xmlel, + _, _attrs, _els}) -> + 'resource-constraint'. + +'encode_stream_error_stream:error_resource-constraint'(undefined, + _acc) -> + _acc; +'encode_stream_error_stream:error_resource-constraint'('resource-constraint', + _acc) -> + _els = [], + _attrs = [{<<"xmlns">>, + <<"urn:ietf:params:xml:ns:xmpp-streams">>}], + [{xmlel, <<"resource-constraint">>, _attrs, _els} + | _acc]. + +'decode_stream_error_stream:error_reset'({xmlel, _, + _attrs, _els}) -> + reset. + +'encode_stream_error_stream:error_reset'(undefined, + _acc) -> + _acc; +'encode_stream_error_stream:error_reset'(reset, _acc) -> + _els = [], + _attrs = [{<<"xmlns">>, + <<"urn:ietf:params:xml:ns:xmpp-streams">>}], + [{xmlel, <<"reset">>, _attrs, _els} | _acc]. + +'decode_stream_error_stream:error_remote-connection-failed'({xmlel, + _, _attrs, + _els}) -> + 'remote-connection-failed'. + +'encode_stream_error_stream:error_remote-connection-failed'(undefined, + _acc) -> + _acc; +'encode_stream_error_stream:error_remote-connection-failed'('remote-connection-failed', + _acc) -> + _els = [], + _attrs = [{<<"xmlns">>, + <<"urn:ietf:params:xml:ns:xmpp-streams">>}], + [{xmlel, <<"remote-connection-failed">>, _attrs, _els} + | _acc]. + +'decode_stream_error_stream:error_policy-violation'({xmlel, + _, _attrs, _els}) -> + 'policy-violation'. + +'encode_stream_error_stream:error_policy-violation'(undefined, + _acc) -> + _acc; +'encode_stream_error_stream:error_policy-violation'('policy-violation', + _acc) -> + _els = [], + _attrs = [{<<"xmlns">>, + <<"urn:ietf:params:xml:ns:xmpp-streams">>}], + [{xmlel, <<"policy-violation">>, _attrs, _els} | _acc]. + +'decode_stream_error_stream:error_not-well-formed'({xmlel, + _, _attrs, _els}) -> + 'not-well-formed'. + +'encode_stream_error_stream:error_not-well-formed'(undefined, + _acc) -> + _acc; +'encode_stream_error_stream:error_not-well-formed'('not-well-formed', + _acc) -> + _els = [], + _attrs = [{<<"xmlns">>, + <<"urn:ietf:params:xml:ns:xmpp-streams">>}], + [{xmlel, <<"not-well-formed">>, _attrs, _els} | _acc]. + +'decode_stream_error_stream:error_not-authorized'({xmlel, + _, _attrs, _els}) -> + 'not-authorized'. + +'encode_stream_error_stream:error_not-authorized'(undefined, + _acc) -> + _acc; +'encode_stream_error_stream:error_not-authorized'('not-authorized', + _acc) -> + _els = [], + _attrs = [{<<"xmlns">>, + <<"urn:ietf:params:xml:ns:xmpp-streams">>}], + [{xmlel, <<"not-authorized">>, _attrs, _els} | _acc]. + +'decode_stream_error_stream:error_invalid-xml'({xmlel, + _, _attrs, _els}) -> + 'invalid-xml'. + +'encode_stream_error_stream:error_invalid-xml'(undefined, + _acc) -> + _acc; +'encode_stream_error_stream:error_invalid-xml'('invalid-xml', + _acc) -> + _els = [], + _attrs = [{<<"xmlns">>, + <<"urn:ietf:params:xml:ns:xmpp-streams">>}], + [{xmlel, <<"invalid-xml">>, _attrs, _els} | _acc]. + +'decode_stream_error_stream:error_invalid-namespace'({xmlel, + _, _attrs, _els}) -> + 'invalid-namespace'. + +'encode_stream_error_stream:error_invalid-namespace'(undefined, + _acc) -> + _acc; +'encode_stream_error_stream:error_invalid-namespace'('invalid-namespace', + _acc) -> + _els = [], + _attrs = [{<<"xmlns">>, + <<"urn:ietf:params:xml:ns:xmpp-streams">>}], + [{xmlel, <<"invalid-namespace">>, _attrs, _els} | _acc]. + +'decode_stream_error_stream:error_invalid-id'({xmlel, _, + _attrs, _els}) -> + 'invalid-id'. + +'encode_stream_error_stream:error_invalid-id'(undefined, + _acc) -> + _acc; +'encode_stream_error_stream:error_invalid-id'('invalid-id', + _acc) -> + _els = [], + _attrs = [{<<"xmlns">>, + <<"urn:ietf:params:xml:ns:xmpp-streams">>}], + [{xmlel, <<"invalid-id">>, _attrs, _els} | _acc]. + +'decode_stream_error_stream:error_invalid-from'({xmlel, + _, _attrs, _els}) -> + 'invalid-from'. + +'encode_stream_error_stream:error_invalid-from'(undefined, + _acc) -> + _acc; +'encode_stream_error_stream:error_invalid-from'('invalid-from', + _acc) -> + _els = [], + _attrs = [{<<"xmlns">>, + <<"urn:ietf:params:xml:ns:xmpp-streams">>}], + [{xmlel, <<"invalid-from">>, _attrs, _els} | _acc]. + +'decode_stream_error_stream:error_internal-server-error'({xmlel, + _, _attrs, _els}) -> + 'internal-server-error'. + +'encode_stream_error_stream:error_internal-server-error'(undefined, + _acc) -> + _acc; +'encode_stream_error_stream:error_internal-server-error'('internal-server-error', + _acc) -> + _els = [], + _attrs = [{<<"xmlns">>, + <<"urn:ietf:params:xml:ns:xmpp-streams">>}], + [{xmlel, <<"internal-server-error">>, _attrs, _els} + | _acc]. + +'decode_stream_error_stream:error_improper-addressing'({xmlel, + _, _attrs, _els}) -> + 'improper-addressing'. + +'encode_stream_error_stream:error_improper-addressing'(undefined, + _acc) -> + _acc; +'encode_stream_error_stream:error_improper-addressing'('improper-addressing', + _acc) -> + _els = [], + _attrs = [{<<"xmlns">>, + <<"urn:ietf:params:xml:ns:xmpp-streams">>}], + [{xmlel, <<"improper-addressing">>, _attrs, _els} + | _acc]. + +'decode_stream_error_stream:error_host-unknown'({xmlel, + _, _attrs, _els}) -> + 'host-unknown'. + +'encode_stream_error_stream:error_host-unknown'(undefined, + _acc) -> + _acc; +'encode_stream_error_stream:error_host-unknown'('host-unknown', + _acc) -> + _els = [], + _attrs = [{<<"xmlns">>, + <<"urn:ietf:params:xml:ns:xmpp-streams">>}], + [{xmlel, <<"host-unknown">>, _attrs, _els} | _acc]. + +'decode_stream_error_stream:error_host-gone'({xmlel, _, + _attrs, _els}) -> + 'host-gone'. + +'encode_stream_error_stream:error_host-gone'(undefined, + _acc) -> + _acc; +'encode_stream_error_stream:error_host-gone'('host-gone', + _acc) -> + _els = [], + _attrs = [{<<"xmlns">>, + <<"urn:ietf:params:xml:ns:xmpp-streams">>}], + [{xmlel, <<"host-gone">>, _attrs, _els} | _acc]. + +'decode_stream_error_stream:error_connection-timeout'({xmlel, + _, _attrs, _els}) -> + 'connection-timeout'. + +'encode_stream_error_stream:error_connection-timeout'(undefined, + _acc) -> + _acc; +'encode_stream_error_stream:error_connection-timeout'('connection-timeout', + _acc) -> + _els = [], + _attrs = [{<<"xmlns">>, + <<"urn:ietf:params:xml:ns:xmpp-streams">>}], + [{xmlel, <<"connection-timeout">>, _attrs, _els} + | _acc]. + +'decode_stream_error_stream:error_conflict'({xmlel, _, + _attrs, _els}) -> + conflict. + +'encode_stream_error_stream:error_conflict'(undefined, + _acc) -> + _acc; +'encode_stream_error_stream:error_conflict'(conflict, + _acc) -> + _els = [], + _attrs = [{<<"xmlns">>, + <<"urn:ietf:params:xml:ns:xmpp-streams">>}], + [{xmlel, <<"conflict">>, _attrs, _els} | _acc]. + +'decode_stream_error_stream:error_bad-namespace-prefix'({xmlel, + _, _attrs, _els}) -> + 'bad-namespace-prefix'. + +'encode_stream_error_stream:error_bad-namespace-prefix'(undefined, + _acc) -> + _acc; +'encode_stream_error_stream:error_bad-namespace-prefix'('bad-namespace-prefix', + _acc) -> + _els = [], + _attrs = [{<<"xmlns">>, + <<"urn:ietf:params:xml:ns:xmpp-streams">>}], + [{xmlel, <<"bad-namespace-prefix">>, _attrs, _els} + | _acc]. + +'decode_stream_error_stream:error_bad-format'({xmlel, _, + _attrs, _els}) -> + 'bad-format'. + +'encode_stream_error_stream:error_bad-format'(undefined, + _acc) -> + _acc; +'encode_stream_error_stream:error_bad-format'('bad-format', + _acc) -> + _els = [], + _attrs = [{<<"xmlns">>, + <<"urn:ietf:params:xml:ns:xmpp-streams">>}], + [{xmlel, <<"bad-format">>, _attrs, _els} | _acc]. + +'decode_stream_error_stream:error_text'({xmlel, _, + _attrs, _els}) -> + Text_lang = + 'decode_stream_error_stream:error_text_attrs'(_attrs, + undefined), + Cdata = + 'decode_stream_error_stream:error_text_els'(_els, <<>>), + {Text_lang, Cdata}. + +'decode_stream_error_stream:error_text_els'([{xmlcdata, + _data} + | _els], + Cdata) -> + 'decode_stream_error_stream:error_text_els'(_els, + <<Cdata/binary, _data/binary>>); +'decode_stream_error_stream:error_text_els'([_ | _els], + Cdata) -> + 'decode_stream_error_stream:error_text_els'(_els, + Cdata); +'decode_stream_error_stream:error_text_els'([], + Cdata) -> + 'decode_stream_error_stream:error_text_cdata'(Cdata). + +'decode_stream_error_stream:error_text_attrs'([{<<"xml:lang">>, + _val} + | _attrs], + _Text_lang) -> + 'decode_stream_error_stream:error_text_attrs'(_attrs, + _val); +'decode_stream_error_stream:error_text_attrs'([_ + | _attrs], + Text_lang) -> + 'decode_stream_error_stream:error_text_attrs'(_attrs, + Text_lang); +'decode_stream_error_stream:error_text_attrs'([], + Text_lang) -> + 'decode_stream_error_stream:error_text_xml:lang'(Text_lang). + +'encode_stream_error_stream:error_text'(undefined, + _acc) -> + _acc; +'encode_stream_error_stream:error_text'({Text_lang, + Cdata}, + _acc) -> + _els = + 'encode_stream_error_stream:error_text_cdata'(Cdata, + []), + _attrs = + 'encode_stream_error_stream:error_text_xml:lang'(Text_lang, + [{<<"xmlns">>, + <<"urn:ietf:params:xml:ns:xmpp-streams">>}]), + [{xmlel, <<"text">>, _attrs, _els} | _acc]. + +'decode_stream_error_stream:error_text_xml:lang'(undefined) -> + undefined; +'decode_stream_error_stream:error_text_xml:lang'(_val) -> + _val. + +'encode_stream_error_stream:error_text_xml:lang'(undefined, + _acc) -> + _acc; +'encode_stream_error_stream:error_text_xml:lang'(_val, + _acc) -> + [{<<"xml:lang">>, _val} | _acc]. + +'decode_stream_error_stream:error_text_cdata'(<<>>) -> + undefined; +'decode_stream_error_stream:error_text_cdata'(_val) -> + _val. + +'encode_stream_error_stream:error_text_cdata'(undefined, + _acc) -> + _acc; +'encode_stream_error_stream:error_text_cdata'(_val, + _acc) -> + [{xmlcdata, _val} | _acc]. + +decode_vcard_name_N({xmlel, _, _attrs, _els}) -> + {Suffix, Prefix, Middle, Given, Family} = + decode_vcard_name_N_els(_els, undefined, undefined, + undefined, undefined, undefined), + {vcard_name, Family, Given, Middle, Prefix, Suffix}. + +decode_vcard_name_N_els([{xmlel, <<"SUFFIX">>, _attrs, + _} = + _el + | _els], + Suffix, Prefix, Middle, Given, Family) -> + case xml:get_attr_s(<<"xmlns">>, _attrs) of + <<>> -> + decode_vcard_name_N_els(_els, + decode_vcard_name_N_SUFFIX(_el), Prefix, + Middle, Given, Family); + _ -> + decode_vcard_name_N_els(_els, Suffix, Prefix, Middle, + Given, Family) + end; +decode_vcard_name_N_els([{xmlel, <<"PREFIX">>, _attrs, + _} = + _el + | _els], + Suffix, Prefix, Middle, Given, Family) -> + case xml:get_attr_s(<<"xmlns">>, _attrs) of + <<>> -> + decode_vcard_name_N_els(_els, Suffix, + decode_vcard_name_N_PREFIX(_el), Middle, + Given, Family); + _ -> + decode_vcard_name_N_els(_els, Suffix, Prefix, Middle, + Given, Family) + end; +decode_vcard_name_N_els([{xmlel, <<"MIDDLE">>, _attrs, + _} = + _el + | _els], + Suffix, Prefix, Middle, Given, Family) -> + case xml:get_attr_s(<<"xmlns">>, _attrs) of + <<>> -> + decode_vcard_name_N_els(_els, Suffix, Prefix, + decode_vcard_name_N_MIDDLE(_el), Given, + Family); + _ -> + decode_vcard_name_N_els(_els, Suffix, Prefix, Middle, + Given, Family) + end; +decode_vcard_name_N_els([{xmlel, <<"GIVEN">>, _attrs, + _} = + _el + | _els], + Suffix, Prefix, Middle, Given, Family) -> + case xml:get_attr_s(<<"xmlns">>, _attrs) of + <<>> -> + decode_vcard_name_N_els(_els, Suffix, Prefix, Middle, + decode_vcard_name_N_GIVEN(_el), Family); + _ -> + decode_vcard_name_N_els(_els, Suffix, Prefix, Middle, + Given, Family) + end; +decode_vcard_name_N_els([{xmlel, <<"FAMILY">>, _attrs, + _} = + _el + | _els], + Suffix, Prefix, Middle, Given, Family) -> + case xml:get_attr_s(<<"xmlns">>, _attrs) of + <<>> -> + decode_vcard_name_N_els(_els, Suffix, Prefix, Middle, + Given, decode_vcard_name_N_FAMILY(_el)); + _ -> + decode_vcard_name_N_els(_els, Suffix, Prefix, Middle, + Given, Family) + end; +decode_vcard_name_N_els([_ | _els], Suffix, Prefix, + Middle, Given, Family) -> + decode_vcard_name_N_els(_els, Suffix, Prefix, Middle, + Given, Family); +decode_vcard_name_N_els([], Suffix, Prefix, Middle, + Given, Family) -> + {Suffix, Prefix, Middle, Given, Family}. + +encode_vcard_name_N(undefined, _acc) -> _acc; +encode_vcard_name_N({vcard_name, Family, Given, Middle, + Prefix, Suffix}, + _acc) -> + _els = encode_vcard_name_N_FAMILY(Family, + encode_vcard_name_N_GIVEN(Given, + encode_vcard_name_N_MIDDLE(Middle, + encode_vcard_name_N_PREFIX(Prefix, + encode_vcard_name_N_SUFFIX(Suffix, + []))))), + _attrs = [], + [{xmlel, <<"N">>, _attrs, _els} | _acc]. + +decode_vcard_name_N_SUFFIX({xmlel, _, _attrs, _els}) -> + Cdata = decode_vcard_name_N_SUFFIX_els(_els, <<>>), + Cdata. + +decode_vcard_name_N_SUFFIX_els([{xmlcdata, _data} + | _els], + Cdata) -> + decode_vcard_name_N_SUFFIX_els(_els, + <<Cdata/binary, _data/binary>>); +decode_vcard_name_N_SUFFIX_els([_ | _els], Cdata) -> + decode_vcard_name_N_SUFFIX_els(_els, Cdata); +decode_vcard_name_N_SUFFIX_els([], Cdata) -> + decode_vcard_name_N_SUFFIX_cdata(Cdata). + +encode_vcard_name_N_SUFFIX(undefined, _acc) -> _acc; +encode_vcard_name_N_SUFFIX(Cdata, _acc) -> + _els = encode_vcard_name_N_SUFFIX_cdata(Cdata, []), + _attrs = [], + [{xmlel, <<"SUFFIX">>, _attrs, _els} | _acc]. + +decode_vcard_name_N_SUFFIX_cdata(<<>>) -> undefined; +decode_vcard_name_N_SUFFIX_cdata(_val) -> _val. + +encode_vcard_name_N_SUFFIX_cdata(undefined, _acc) -> + _acc; +encode_vcard_name_N_SUFFIX_cdata(_val, _acc) -> + [{xmlcdata, _val} | _acc]. + +decode_vcard_name_N_PREFIX({xmlel, _, _attrs, _els}) -> + Cdata = decode_vcard_name_N_PREFIX_els(_els, <<>>), + Cdata. + +decode_vcard_name_N_PREFIX_els([{xmlcdata, _data} + | _els], + Cdata) -> + decode_vcard_name_N_PREFIX_els(_els, + <<Cdata/binary, _data/binary>>); +decode_vcard_name_N_PREFIX_els([_ | _els], Cdata) -> + decode_vcard_name_N_PREFIX_els(_els, Cdata); +decode_vcard_name_N_PREFIX_els([], Cdata) -> + decode_vcard_name_N_PREFIX_cdata(Cdata). + +encode_vcard_name_N_PREFIX(undefined, _acc) -> _acc; +encode_vcard_name_N_PREFIX(Cdata, _acc) -> + _els = encode_vcard_name_N_PREFIX_cdata(Cdata, []), + _attrs = [], + [{xmlel, <<"PREFIX">>, _attrs, _els} | _acc]. + +decode_vcard_name_N_PREFIX_cdata(<<>>) -> undefined; +decode_vcard_name_N_PREFIX_cdata(_val) -> _val. + +encode_vcard_name_N_PREFIX_cdata(undefined, _acc) -> + _acc; +encode_vcard_name_N_PREFIX_cdata(_val, _acc) -> + [{xmlcdata, _val} | _acc]. + +decode_vcard_name_N_MIDDLE({xmlel, _, _attrs, _els}) -> + Cdata = decode_vcard_name_N_MIDDLE_els(_els, <<>>), + Cdata. + +decode_vcard_name_N_MIDDLE_els([{xmlcdata, _data} + | _els], + Cdata) -> + decode_vcard_name_N_MIDDLE_els(_els, + <<Cdata/binary, _data/binary>>); +decode_vcard_name_N_MIDDLE_els([_ | _els], Cdata) -> + decode_vcard_name_N_MIDDLE_els(_els, Cdata); +decode_vcard_name_N_MIDDLE_els([], Cdata) -> + decode_vcard_name_N_MIDDLE_cdata(Cdata). + +encode_vcard_name_N_MIDDLE(undefined, _acc) -> _acc; +encode_vcard_name_N_MIDDLE(Cdata, _acc) -> + _els = encode_vcard_name_N_MIDDLE_cdata(Cdata, []), + _attrs = [], + [{xmlel, <<"MIDDLE">>, _attrs, _els} | _acc]. + +decode_vcard_name_N_MIDDLE_cdata(<<>>) -> undefined; +decode_vcard_name_N_MIDDLE_cdata(_val) -> _val. + +encode_vcard_name_N_MIDDLE_cdata(undefined, _acc) -> + _acc; +encode_vcard_name_N_MIDDLE_cdata(_val, _acc) -> + [{xmlcdata, _val} | _acc]. + +decode_vcard_name_N_GIVEN({xmlel, _, _attrs, _els}) -> + Cdata = decode_vcard_name_N_GIVEN_els(_els, <<>>), + Cdata. + +decode_vcard_name_N_GIVEN_els([{xmlcdata, _data} + | _els], + Cdata) -> + decode_vcard_name_N_GIVEN_els(_els, + <<Cdata/binary, _data/binary>>); +decode_vcard_name_N_GIVEN_els([_ | _els], Cdata) -> + decode_vcard_name_N_GIVEN_els(_els, Cdata); +decode_vcard_name_N_GIVEN_els([], Cdata) -> + decode_vcard_name_N_GIVEN_cdata(Cdata). + +encode_vcard_name_N_GIVEN(undefined, _acc) -> _acc; +encode_vcard_name_N_GIVEN(Cdata, _acc) -> + _els = encode_vcard_name_N_GIVEN_cdata(Cdata, []), + _attrs = [], + [{xmlel, <<"GIVEN">>, _attrs, _els} | _acc]. + +decode_vcard_name_N_GIVEN_cdata(<<>>) -> undefined; +decode_vcard_name_N_GIVEN_cdata(_val) -> _val. + +encode_vcard_name_N_GIVEN_cdata(undefined, _acc) -> + _acc; +encode_vcard_name_N_GIVEN_cdata(_val, _acc) -> + [{xmlcdata, _val} | _acc]. + +decode_vcard_name_N_FAMILY({xmlel, _, _attrs, _els}) -> + Cdata = decode_vcard_name_N_FAMILY_els(_els, <<>>), + Cdata. + +decode_vcard_name_N_FAMILY_els([{xmlcdata, _data} + | _els], + Cdata) -> + decode_vcard_name_N_FAMILY_els(_els, + <<Cdata/binary, _data/binary>>); +decode_vcard_name_N_FAMILY_els([_ | _els], Cdata) -> + decode_vcard_name_N_FAMILY_els(_els, Cdata); +decode_vcard_name_N_FAMILY_els([], Cdata) -> + decode_vcard_name_N_FAMILY_cdata(Cdata). + +encode_vcard_name_N_FAMILY(undefined, _acc) -> _acc; +encode_vcard_name_N_FAMILY(Cdata, _acc) -> + _els = encode_vcard_name_N_FAMILY_cdata(Cdata, []), + _attrs = [], + [{xmlel, <<"FAMILY">>, _attrs, _els} | _acc]. + +decode_vcard_name_N_FAMILY_cdata(<<>>) -> undefined; +decode_vcard_name_N_FAMILY_cdata(_val) -> _val. + +encode_vcard_name_N_FAMILY_cdata(undefined, _acc) -> + _acc; +encode_vcard_name_N_FAMILY_cdata(_val, _acc) -> + [{xmlcdata, _val} | _acc]. + +decode_vcard_adr_ADR({xmlel, _, _attrs, _els}) -> + {Ctry, Pcode, Region, Locality, Street, Extadd, Pobox, + Pref, Intl, Dom, Parcel, Postal, Work, Home} = + decode_vcard_adr_ADR_els(_els, undefined, undefined, + undefined, undefined, undefined, undefined, + undefined, false, false, false, false, false, + false, false), + {vcard_adr, Home, Work, Postal, Parcel, Dom, Intl, Pref, + Pobox, Extadd, Street, Locality, Region, Pcode, Ctry}. + +decode_vcard_adr_ADR_els([{xmlel, <<"CTRY">>, _attrs, + _} = + _el + | _els], + Ctry, Pcode, Region, Locality, Street, Extadd, Pobox, + Pref, Intl, Dom, Parcel, Postal, Work, Home) -> + case xml:get_attr_s(<<"xmlns">>, _attrs) of + <<>> -> + decode_vcard_adr_ADR_els(_els, + decode_vcard_adr_ADR_CTRY(_el), Pcode, + Region, Locality, Street, Extadd, Pobox, + Pref, Intl, Dom, Parcel, Postal, Work, Home); + _ -> + decode_vcard_adr_ADR_els(_els, Ctry, Pcode, Region, + Locality, Street, Extadd, Pobox, Pref, Intl, + Dom, Parcel, Postal, Work, Home) + end; +decode_vcard_adr_ADR_els([{xmlel, <<"PCODE">>, _attrs, + _} = + _el + | _els], + Ctry, Pcode, Region, Locality, Street, Extadd, Pobox, + Pref, Intl, Dom, Parcel, Postal, Work, Home) -> + case xml:get_attr_s(<<"xmlns">>, _attrs) of + <<>> -> + decode_vcard_adr_ADR_els(_els, Ctry, + decode_vcard_adr_ADR_PCODE(_el), Region, + Locality, Street, Extadd, Pobox, Pref, Intl, + Dom, Parcel, Postal, Work, Home); + _ -> + decode_vcard_adr_ADR_els(_els, Ctry, Pcode, Region, + Locality, Street, Extadd, Pobox, Pref, Intl, + Dom, Parcel, Postal, Work, Home) + end; +decode_vcard_adr_ADR_els([{xmlel, <<"REGION">>, _attrs, + _} = + _el + | _els], + Ctry, Pcode, Region, Locality, Street, Extadd, Pobox, + Pref, Intl, Dom, Parcel, Postal, Work, Home) -> + case xml:get_attr_s(<<"xmlns">>, _attrs) of + <<>> -> + decode_vcard_adr_ADR_els(_els, Ctry, Pcode, + decode_vcard_adr_ADR_REGION(_el), Locality, + Street, Extadd, Pobox, Pref, Intl, Dom, + Parcel, Postal, Work, Home); + _ -> + decode_vcard_adr_ADR_els(_els, Ctry, Pcode, Region, + Locality, Street, Extadd, Pobox, Pref, Intl, + Dom, Parcel, Postal, Work, Home) + end; +decode_vcard_adr_ADR_els([{xmlel, <<"LOCALITY">>, + _attrs, _} = + _el + | _els], + Ctry, Pcode, Region, Locality, Street, Extadd, Pobox, + Pref, Intl, Dom, Parcel, Postal, Work, Home) -> + case xml:get_attr_s(<<"xmlns">>, _attrs) of + <<>> -> + decode_vcard_adr_ADR_els(_els, Ctry, Pcode, Region, + decode_vcard_adr_ADR_LOCALITY(_el), Street, + Extadd, Pobox, Pref, Intl, Dom, Parcel, + Postal, Work, Home); + _ -> + decode_vcard_adr_ADR_els(_els, Ctry, Pcode, Region, + Locality, Street, Extadd, Pobox, Pref, Intl, + Dom, Parcel, Postal, Work, Home) + end; +decode_vcard_adr_ADR_els([{xmlel, <<"STREET">>, _attrs, + _} = + _el + | _els], + Ctry, Pcode, Region, Locality, Street, Extadd, Pobox, + Pref, Intl, Dom, Parcel, Postal, Work, Home) -> + case xml:get_attr_s(<<"xmlns">>, _attrs) of + <<>> -> + decode_vcard_adr_ADR_els(_els, Ctry, Pcode, Region, + Locality, decode_vcard_adr_ADR_STREET(_el), + Extadd, Pobox, Pref, Intl, Dom, Parcel, + Postal, Work, Home); + _ -> + decode_vcard_adr_ADR_els(_els, Ctry, Pcode, Region, + Locality, Street, Extadd, Pobox, Pref, Intl, + Dom, Parcel, Postal, Work, Home) + end; +decode_vcard_adr_ADR_els([{xmlel, <<"EXTADD">>, _attrs, + _} = + _el + | _els], + Ctry, Pcode, Region, Locality, Street, Extadd, Pobox, + Pref, Intl, Dom, Parcel, Postal, Work, Home) -> + case xml:get_attr_s(<<"xmlns">>, _attrs) of + <<>> -> + decode_vcard_adr_ADR_els(_els, Ctry, Pcode, Region, + Locality, Street, + decode_vcard_adr_ADR_EXTADD(_el), Pobox, + Pref, Intl, Dom, Parcel, Postal, Work, Home); + _ -> + decode_vcard_adr_ADR_els(_els, Ctry, Pcode, Region, + Locality, Street, Extadd, Pobox, Pref, Intl, + Dom, Parcel, Postal, Work, Home) + end; +decode_vcard_adr_ADR_els([{xmlel, <<"POBOX">>, _attrs, + _} = + _el + | _els], + Ctry, Pcode, Region, Locality, Street, Extadd, Pobox, + Pref, Intl, Dom, Parcel, Postal, Work, Home) -> + case xml:get_attr_s(<<"xmlns">>, _attrs) of + <<>> -> + decode_vcard_adr_ADR_els(_els, Ctry, Pcode, Region, + Locality, Street, Extadd, + decode_vcard_adr_ADR_POBOX(_el), Pref, Intl, + Dom, Parcel, Postal, Work, Home); + _ -> + decode_vcard_adr_ADR_els(_els, Ctry, Pcode, Region, + Locality, Street, Extadd, Pobox, Pref, Intl, + Dom, Parcel, Postal, Work, Home) + end; +decode_vcard_adr_ADR_els([{xmlel, <<"PREF">>, _attrs, + _} = + _el + | _els], + Ctry, Pcode, Region, Locality, Street, Extadd, Pobox, + Pref, Intl, Dom, Parcel, Postal, Work, Home) -> + case xml:get_attr_s(<<"xmlns">>, _attrs) of + <<>> -> + decode_vcard_adr_ADR_els(_els, Ctry, Pcode, Region, + Locality, Street, Extadd, Pobox, + decode_vcard_adr_ADR_PREF(_el), Intl, Dom, + Parcel, Postal, Work, Home); + _ -> + decode_vcard_adr_ADR_els(_els, Ctry, Pcode, Region, + Locality, Street, Extadd, Pobox, Pref, Intl, + Dom, Parcel, Postal, Work, Home) + end; +decode_vcard_adr_ADR_els([{xmlel, <<"INTL">>, _attrs, + _} = + _el + | _els], + Ctry, Pcode, Region, Locality, Street, Extadd, Pobox, + Pref, Intl, Dom, Parcel, Postal, Work, Home) -> + case xml:get_attr_s(<<"xmlns">>, _attrs) of + <<>> -> + decode_vcard_adr_ADR_els(_els, Ctry, Pcode, Region, + Locality, Street, Extadd, Pobox, Pref, + decode_vcard_adr_ADR_INTL(_el), Dom, Parcel, + Postal, Work, Home); + _ -> + decode_vcard_adr_ADR_els(_els, Ctry, Pcode, Region, + Locality, Street, Extadd, Pobox, Pref, Intl, + Dom, Parcel, Postal, Work, Home) + end; +decode_vcard_adr_ADR_els([{xmlel, <<"DOM">>, _attrs, + _} = + _el + | _els], + Ctry, Pcode, Region, Locality, Street, Extadd, Pobox, + Pref, Intl, Dom, Parcel, Postal, Work, Home) -> + case xml:get_attr_s(<<"xmlns">>, _attrs) of + <<>> -> + decode_vcard_adr_ADR_els(_els, Ctry, Pcode, Region, + Locality, Street, Extadd, Pobox, Pref, Intl, + decode_vcard_adr_ADR_DOM(_el), Parcel, + Postal, Work, Home); + _ -> + decode_vcard_adr_ADR_els(_els, Ctry, Pcode, Region, + Locality, Street, Extadd, Pobox, Pref, Intl, + Dom, Parcel, Postal, Work, Home) + end; +decode_vcard_adr_ADR_els([{xmlel, <<"PARCEL">>, _attrs, + _} = + _el + | _els], + Ctry, Pcode, Region, Locality, Street, Extadd, Pobox, + Pref, Intl, Dom, Parcel, Postal, Work, Home) -> + case xml:get_attr_s(<<"xmlns">>, _attrs) of + <<>> -> + decode_vcard_adr_ADR_els(_els, Ctry, Pcode, Region, + Locality, Street, Extadd, Pobox, Pref, Intl, + Dom, decode_vcard_adr_ADR_PARCEL(_el), + Postal, Work, Home); + _ -> + decode_vcard_adr_ADR_els(_els, Ctry, Pcode, Region, + Locality, Street, Extadd, Pobox, Pref, Intl, + Dom, Parcel, Postal, Work, Home) + end; +decode_vcard_adr_ADR_els([{xmlel, <<"POSTAL">>, _attrs, + _} = + _el + | _els], + Ctry, Pcode, Region, Locality, Street, Extadd, Pobox, + Pref, Intl, Dom, Parcel, Postal, Work, Home) -> + case xml:get_attr_s(<<"xmlns">>, _attrs) of + <<>> -> + decode_vcard_adr_ADR_els(_els, Ctry, Pcode, Region, + Locality, Street, Extadd, Pobox, Pref, Intl, + Dom, Parcel, + decode_vcard_adr_ADR_POSTAL(_el), Work, + Home); + _ -> + decode_vcard_adr_ADR_els(_els, Ctry, Pcode, Region, + Locality, Street, Extadd, Pobox, Pref, Intl, + Dom, Parcel, Postal, Work, Home) + end; +decode_vcard_adr_ADR_els([{xmlel, <<"WORK">>, _attrs, + _} = + _el + | _els], + Ctry, Pcode, Region, Locality, Street, Extadd, Pobox, + Pref, Intl, Dom, Parcel, Postal, Work, Home) -> + case xml:get_attr_s(<<"xmlns">>, _attrs) of + <<>> -> + decode_vcard_adr_ADR_els(_els, Ctry, Pcode, Region, + Locality, Street, Extadd, Pobox, Pref, Intl, + Dom, Parcel, Postal, + decode_vcard_adr_ADR_WORK(_el), Home); + _ -> + decode_vcard_adr_ADR_els(_els, Ctry, Pcode, Region, + Locality, Street, Extadd, Pobox, Pref, Intl, + Dom, Parcel, Postal, Work, Home) + end; +decode_vcard_adr_ADR_els([{xmlel, <<"HOME">>, _attrs, + _} = + _el + | _els], + Ctry, Pcode, Region, Locality, Street, Extadd, Pobox, + Pref, Intl, Dom, Parcel, Postal, Work, Home) -> + case xml:get_attr_s(<<"xmlns">>, _attrs) of + <<>> -> + decode_vcard_adr_ADR_els(_els, Ctry, Pcode, Region, + Locality, Street, Extadd, Pobox, Pref, Intl, + Dom, Parcel, Postal, Work, + decode_vcard_adr_ADR_HOME(_el)); + _ -> + decode_vcard_adr_ADR_els(_els, Ctry, Pcode, Region, + Locality, Street, Extadd, Pobox, Pref, Intl, + Dom, Parcel, Postal, Work, Home) + end; +decode_vcard_adr_ADR_els([_ | _els], Ctry, Pcode, + Region, Locality, Street, Extadd, Pobox, Pref, Intl, + Dom, Parcel, Postal, Work, Home) -> + decode_vcard_adr_ADR_els(_els, Ctry, Pcode, Region, + Locality, Street, Extadd, Pobox, Pref, Intl, Dom, + Parcel, Postal, Work, Home); +decode_vcard_adr_ADR_els([], Ctry, Pcode, Region, + Locality, Street, Extadd, Pobox, Pref, Intl, Dom, + Parcel, Postal, Work, Home) -> + {Ctry, Pcode, Region, Locality, Street, Extadd, Pobox, + Pref, Intl, Dom, Parcel, Postal, Work, Home}. + +encode_vcard_adr_ADR([], _acc) -> _acc; +encode_vcard_adr_ADR([{vcard_adr, Home, Work, Postal, + Parcel, Dom, Intl, Pref, Pobox, Extadd, Street, + Locality, Region, Pcode, Ctry} + | _tail], + _acc) -> + _els = encode_vcard_adr_ADR_HOME(Home, + encode_vcard_adr_ADR_WORK(Work, + encode_vcard_adr_ADR_POSTAL(Postal, + encode_vcard_adr_ADR_PARCEL(Parcel, + encode_vcard_adr_ADR_DOM(Dom, + encode_vcard_adr_ADR_INTL(Intl, + encode_vcard_adr_ADR_PREF(Pref, + encode_vcard_adr_ADR_POBOX(Pobox, + encode_vcard_adr_ADR_EXTADD(Extadd, + encode_vcard_adr_ADR_STREET(Street, + encode_vcard_adr_ADR_LOCALITY(Locality, + encode_vcard_adr_ADR_REGION(Region, + encode_vcard_adr_ADR_PCODE(Pcode, + encode_vcard_adr_ADR_CTRY(Ctry, + [])))))))))))))), + _attrs = [], + encode_vcard_adr_ADR(_tail, + [{xmlel, <<"ADR">>, _attrs, _els} | _acc]). + +decode_vcard_adr_ADR_CTRY({xmlel, _, _attrs, _els}) -> + Cdata = decode_vcard_adr_ADR_CTRY_els(_els, <<>>), + Cdata. + +decode_vcard_adr_ADR_CTRY_els([{xmlcdata, _data} + | _els], + Cdata) -> + decode_vcard_adr_ADR_CTRY_els(_els, + <<Cdata/binary, _data/binary>>); +decode_vcard_adr_ADR_CTRY_els([_ | _els], Cdata) -> + decode_vcard_adr_ADR_CTRY_els(_els, Cdata); +decode_vcard_adr_ADR_CTRY_els([], Cdata) -> + decode_vcard_adr_ADR_CTRY_cdata(Cdata). + +encode_vcard_adr_ADR_CTRY(undefined, _acc) -> _acc; +encode_vcard_adr_ADR_CTRY(Cdata, _acc) -> + _els = encode_vcard_adr_ADR_CTRY_cdata(Cdata, []), + _attrs = [], + [{xmlel, <<"CTRY">>, _attrs, _els} | _acc]. + +decode_vcard_adr_ADR_CTRY_cdata(<<>>) -> undefined; +decode_vcard_adr_ADR_CTRY_cdata(_val) -> _val. + +encode_vcard_adr_ADR_CTRY_cdata(undefined, _acc) -> + _acc; +encode_vcard_adr_ADR_CTRY_cdata(_val, _acc) -> + [{xmlcdata, _val} | _acc]. + +decode_vcard_adr_ADR_PCODE({xmlel, _, _attrs, _els}) -> + Cdata = decode_vcard_adr_ADR_PCODE_els(_els, <<>>), + Cdata. + +decode_vcard_adr_ADR_PCODE_els([{xmlcdata, _data} + | _els], + Cdata) -> + decode_vcard_adr_ADR_PCODE_els(_els, + <<Cdata/binary, _data/binary>>); +decode_vcard_adr_ADR_PCODE_els([_ | _els], Cdata) -> + decode_vcard_adr_ADR_PCODE_els(_els, Cdata); +decode_vcard_adr_ADR_PCODE_els([], Cdata) -> + decode_vcard_adr_ADR_PCODE_cdata(Cdata). + +encode_vcard_adr_ADR_PCODE(undefined, _acc) -> _acc; +encode_vcard_adr_ADR_PCODE(Cdata, _acc) -> + _els = encode_vcard_adr_ADR_PCODE_cdata(Cdata, []), + _attrs = [], + [{xmlel, <<"PCODE">>, _attrs, _els} | _acc]. + +decode_vcard_adr_ADR_PCODE_cdata(<<>>) -> undefined; +decode_vcard_adr_ADR_PCODE_cdata(_val) -> _val. + +encode_vcard_adr_ADR_PCODE_cdata(undefined, _acc) -> + _acc; +encode_vcard_adr_ADR_PCODE_cdata(_val, _acc) -> + [{xmlcdata, _val} | _acc]. + +decode_vcard_adr_ADR_REGION({xmlel, _, _attrs, _els}) -> + Cdata = decode_vcard_adr_ADR_REGION_els(_els, <<>>), + Cdata. + +decode_vcard_adr_ADR_REGION_els([{xmlcdata, _data} + | _els], + Cdata) -> + decode_vcard_adr_ADR_REGION_els(_els, + <<Cdata/binary, _data/binary>>); +decode_vcard_adr_ADR_REGION_els([_ | _els], Cdata) -> + decode_vcard_adr_ADR_REGION_els(_els, Cdata); +decode_vcard_adr_ADR_REGION_els([], Cdata) -> + decode_vcard_adr_ADR_REGION_cdata(Cdata). + +encode_vcard_adr_ADR_REGION(undefined, _acc) -> _acc; +encode_vcard_adr_ADR_REGION(Cdata, _acc) -> + _els = encode_vcard_adr_ADR_REGION_cdata(Cdata, []), + _attrs = [], + [{xmlel, <<"REGION">>, _attrs, _els} | _acc]. + +decode_vcard_adr_ADR_REGION_cdata(<<>>) -> undefined; +decode_vcard_adr_ADR_REGION_cdata(_val) -> _val. + +encode_vcard_adr_ADR_REGION_cdata(undefined, _acc) -> + _acc; +encode_vcard_adr_ADR_REGION_cdata(_val, _acc) -> + [{xmlcdata, _val} | _acc]. + +decode_vcard_adr_ADR_LOCALITY({xmlel, _, _attrs, + _els}) -> + Cdata = decode_vcard_adr_ADR_LOCALITY_els(_els, <<>>), + Cdata. + +decode_vcard_adr_ADR_LOCALITY_els([{xmlcdata, _data} + | _els], + Cdata) -> + decode_vcard_adr_ADR_LOCALITY_els(_els, + <<Cdata/binary, _data/binary>>); +decode_vcard_adr_ADR_LOCALITY_els([_ | _els], Cdata) -> + decode_vcard_adr_ADR_LOCALITY_els(_els, Cdata); +decode_vcard_adr_ADR_LOCALITY_els([], Cdata) -> + decode_vcard_adr_ADR_LOCALITY_cdata(Cdata). + +encode_vcard_adr_ADR_LOCALITY(undefined, _acc) -> _acc; +encode_vcard_adr_ADR_LOCALITY(Cdata, _acc) -> + _els = encode_vcard_adr_ADR_LOCALITY_cdata(Cdata, []), + _attrs = [], + [{xmlel, <<"LOCALITY">>, _attrs, _els} | _acc]. + +decode_vcard_adr_ADR_LOCALITY_cdata(<<>>) -> undefined; +decode_vcard_adr_ADR_LOCALITY_cdata(_val) -> _val. + +encode_vcard_adr_ADR_LOCALITY_cdata(undefined, _acc) -> + _acc; +encode_vcard_adr_ADR_LOCALITY_cdata(_val, _acc) -> + [{xmlcdata, _val} | _acc]. + +decode_vcard_adr_ADR_STREET({xmlel, _, _attrs, _els}) -> + Cdata = decode_vcard_adr_ADR_STREET_els(_els, <<>>), + Cdata. + +decode_vcard_adr_ADR_STREET_els([{xmlcdata, _data} + | _els], + Cdata) -> + decode_vcard_adr_ADR_STREET_els(_els, + <<Cdata/binary, _data/binary>>); +decode_vcard_adr_ADR_STREET_els([_ | _els], Cdata) -> + decode_vcard_adr_ADR_STREET_els(_els, Cdata); +decode_vcard_adr_ADR_STREET_els([], Cdata) -> + decode_vcard_adr_ADR_STREET_cdata(Cdata). + +encode_vcard_adr_ADR_STREET(undefined, _acc) -> _acc; +encode_vcard_adr_ADR_STREET(Cdata, _acc) -> + _els = encode_vcard_adr_ADR_STREET_cdata(Cdata, []), + _attrs = [], + [{xmlel, <<"STREET">>, _attrs, _els} | _acc]. + +decode_vcard_adr_ADR_STREET_cdata(<<>>) -> undefined; +decode_vcard_adr_ADR_STREET_cdata(_val) -> _val. + +encode_vcard_adr_ADR_STREET_cdata(undefined, _acc) -> + _acc; +encode_vcard_adr_ADR_STREET_cdata(_val, _acc) -> + [{xmlcdata, _val} | _acc]. + +decode_vcard_adr_ADR_EXTADD({xmlel, _, _attrs, _els}) -> + Cdata = decode_vcard_adr_ADR_EXTADD_els(_els, <<>>), + Cdata. + +decode_vcard_adr_ADR_EXTADD_els([{xmlcdata, _data} + | _els], + Cdata) -> + decode_vcard_adr_ADR_EXTADD_els(_els, + <<Cdata/binary, _data/binary>>); +decode_vcard_adr_ADR_EXTADD_els([_ | _els], Cdata) -> + decode_vcard_adr_ADR_EXTADD_els(_els, Cdata); +decode_vcard_adr_ADR_EXTADD_els([], Cdata) -> + decode_vcard_adr_ADR_EXTADD_cdata(Cdata). + +encode_vcard_adr_ADR_EXTADD(undefined, _acc) -> _acc; +encode_vcard_adr_ADR_EXTADD(Cdata, _acc) -> + _els = encode_vcard_adr_ADR_EXTADD_cdata(Cdata, []), + _attrs = [], + [{xmlel, <<"EXTADD">>, _attrs, _els} | _acc]. + +decode_vcard_adr_ADR_EXTADD_cdata(<<>>) -> undefined; +decode_vcard_adr_ADR_EXTADD_cdata(_val) -> _val. + +encode_vcard_adr_ADR_EXTADD_cdata(undefined, _acc) -> + _acc; +encode_vcard_adr_ADR_EXTADD_cdata(_val, _acc) -> + [{xmlcdata, _val} | _acc]. + +decode_vcard_adr_ADR_POBOX({xmlel, _, _attrs, _els}) -> + Cdata = decode_vcard_adr_ADR_POBOX_els(_els, <<>>), + Cdata. + +decode_vcard_adr_ADR_POBOX_els([{xmlcdata, _data} + | _els], + Cdata) -> + decode_vcard_adr_ADR_POBOX_els(_els, + <<Cdata/binary, _data/binary>>); +decode_vcard_adr_ADR_POBOX_els([_ | _els], Cdata) -> + decode_vcard_adr_ADR_POBOX_els(_els, Cdata); +decode_vcard_adr_ADR_POBOX_els([], Cdata) -> + decode_vcard_adr_ADR_POBOX_cdata(Cdata). + +encode_vcard_adr_ADR_POBOX(undefined, _acc) -> _acc; +encode_vcard_adr_ADR_POBOX(Cdata, _acc) -> + _els = encode_vcard_adr_ADR_POBOX_cdata(Cdata, []), + _attrs = [], + [{xmlel, <<"POBOX">>, _attrs, _els} | _acc]. + +decode_vcard_adr_ADR_POBOX_cdata(<<>>) -> undefined; +decode_vcard_adr_ADR_POBOX_cdata(_val) -> _val. + +encode_vcard_adr_ADR_POBOX_cdata(undefined, _acc) -> + _acc; +encode_vcard_adr_ADR_POBOX_cdata(_val, _acc) -> + [{xmlcdata, _val} | _acc]. + +decode_vcard_adr_ADR_PREF({xmlel, _, _attrs, _els}) -> + true. + +encode_vcard_adr_ADR_PREF(false, _acc) -> _acc; +encode_vcard_adr_ADR_PREF(true, _acc) -> + _els = [], + _attrs = [], + [{xmlel, <<"PREF">>, _attrs, _els} | _acc]. + +decode_vcard_adr_ADR_INTL({xmlel, _, _attrs, _els}) -> + true. + +encode_vcard_adr_ADR_INTL(false, _acc) -> _acc; +encode_vcard_adr_ADR_INTL(true, _acc) -> + _els = [], + _attrs = [], + [{xmlel, <<"INTL">>, _attrs, _els} | _acc]. + +decode_vcard_adr_ADR_DOM({xmlel, _, _attrs, _els}) -> + true. + +encode_vcard_adr_ADR_DOM(false, _acc) -> _acc; +encode_vcard_adr_ADR_DOM(true, _acc) -> + _els = [], + _attrs = [], + [{xmlel, <<"DOM">>, _attrs, _els} | _acc]. + +decode_vcard_adr_ADR_PARCEL({xmlel, _, _attrs, _els}) -> + true. + +encode_vcard_adr_ADR_PARCEL(false, _acc) -> _acc; +encode_vcard_adr_ADR_PARCEL(true, _acc) -> + _els = [], + _attrs = [], + [{xmlel, <<"PARCEL">>, _attrs, _els} | _acc]. + +decode_vcard_adr_ADR_POSTAL({xmlel, _, _attrs, _els}) -> + true. + +encode_vcard_adr_ADR_POSTAL(false, _acc) -> _acc; +encode_vcard_adr_ADR_POSTAL(true, _acc) -> + _els = [], + _attrs = [], + [{xmlel, <<"POSTAL">>, _attrs, _els} | _acc]. + +decode_vcard_adr_ADR_WORK({xmlel, _, _attrs, _els}) -> + true. + +encode_vcard_adr_ADR_WORK(false, _acc) -> _acc; +encode_vcard_adr_ADR_WORK(true, _acc) -> + _els = [], + _attrs = [], + [{xmlel, <<"WORK">>, _attrs, _els} | _acc]. + +decode_vcard_adr_ADR_HOME({xmlel, _, _attrs, _els}) -> + true. + +encode_vcard_adr_ADR_HOME(false, _acc) -> _acc; +encode_vcard_adr_ADR_HOME(true, _acc) -> + _els = [], + _attrs = [], + [{xmlel, <<"HOME">>, _attrs, _els} | _acc]. + +decode_vcard_label_LABEL({xmlel, _, _attrs, _els}) -> + {Line, Pref, Intl, Dom, Parcel, Postal, Work, Home} = + decode_vcard_label_LABEL_els(_els, [], false, false, + false, false, false, false, false), + {vcard_label, Home, Work, Postal, Parcel, Dom, Intl, + Pref, Line}. + +decode_vcard_label_LABEL_els([{xmlel, <<"LINE">>, + _attrs, _} = + _el + | _els], + Line, Pref, Intl, Dom, Parcel, Postal, Work, + Home) -> + case xml:get_attr_s(<<"xmlns">>, _attrs) of + <<>> -> + decode_vcard_label_LABEL_els(_els, + [decode_vcard_label_LABEL_LINE(_el) + | Line], + Pref, Intl, Dom, Parcel, Postal, Work, + Home); + _ -> + decode_vcard_label_LABEL_els(_els, Line, Pref, Intl, + Dom, Parcel, Postal, Work, Home) + end; +decode_vcard_label_LABEL_els([{xmlel, <<"PREF">>, + _attrs, _} = + _el + | _els], + Line, Pref, Intl, Dom, Parcel, Postal, Work, + Home) -> + case xml:get_attr_s(<<"xmlns">>, _attrs) of + <<>> -> + decode_vcard_label_LABEL_els(_els, Line, + decode_vcard_label_LABEL_PREF(_el), Intl, + Dom, Parcel, Postal, Work, Home); + _ -> + decode_vcard_label_LABEL_els(_els, Line, Pref, Intl, + Dom, Parcel, Postal, Work, Home) + end; +decode_vcard_label_LABEL_els([{xmlel, <<"INTL">>, + _attrs, _} = + _el + | _els], + Line, Pref, Intl, Dom, Parcel, Postal, Work, + Home) -> + case xml:get_attr_s(<<"xmlns">>, _attrs) of + <<>> -> + decode_vcard_label_LABEL_els(_els, Line, Pref, + decode_vcard_label_LABEL_INTL(_el), Dom, + Parcel, Postal, Work, Home); + _ -> + decode_vcard_label_LABEL_els(_els, Line, Pref, Intl, + Dom, Parcel, Postal, Work, Home) + end; +decode_vcard_label_LABEL_els([{xmlel, <<"DOM">>, _attrs, + _} = + _el + | _els], + Line, Pref, Intl, Dom, Parcel, Postal, Work, + Home) -> + case xml:get_attr_s(<<"xmlns">>, _attrs) of + <<>> -> + decode_vcard_label_LABEL_els(_els, Line, Pref, Intl, + decode_vcard_label_LABEL_DOM(_el), + Parcel, Postal, Work, Home); + _ -> + decode_vcard_label_LABEL_els(_els, Line, Pref, Intl, + Dom, Parcel, Postal, Work, Home) + end; +decode_vcard_label_LABEL_els([{xmlel, <<"PARCEL">>, + _attrs, _} = + _el + | _els], + Line, Pref, Intl, Dom, Parcel, Postal, Work, + Home) -> + case xml:get_attr_s(<<"xmlns">>, _attrs) of + <<>> -> + decode_vcard_label_LABEL_els(_els, Line, Pref, Intl, + Dom, + decode_vcard_label_LABEL_PARCEL(_el), + Postal, Work, Home); + _ -> + decode_vcard_label_LABEL_els(_els, Line, Pref, Intl, + Dom, Parcel, Postal, Work, Home) + end; +decode_vcard_label_LABEL_els([{xmlel, <<"POSTAL">>, + _attrs, _} = + _el + | _els], + Line, Pref, Intl, Dom, Parcel, Postal, Work, + Home) -> + case xml:get_attr_s(<<"xmlns">>, _attrs) of + <<>> -> + decode_vcard_label_LABEL_els(_els, Line, Pref, Intl, + Dom, Parcel, + decode_vcard_label_LABEL_POSTAL(_el), + Work, Home); + _ -> + decode_vcard_label_LABEL_els(_els, Line, Pref, Intl, + Dom, Parcel, Postal, Work, Home) + end; +decode_vcard_label_LABEL_els([{xmlel, <<"WORK">>, + _attrs, _} = + _el + | _els], + Line, Pref, Intl, Dom, Parcel, Postal, Work, + Home) -> + case xml:get_attr_s(<<"xmlns">>, _attrs) of + <<>> -> + decode_vcard_label_LABEL_els(_els, Line, Pref, Intl, + Dom, Parcel, Postal, + decode_vcard_label_LABEL_WORK(_el), + Home); + _ -> + decode_vcard_label_LABEL_els(_els, Line, Pref, Intl, + Dom, Parcel, Postal, Work, Home) + end; +decode_vcard_label_LABEL_els([{xmlel, <<"HOME">>, + _attrs, _} = + _el + | _els], + Line, Pref, Intl, Dom, Parcel, Postal, Work, + Home) -> + case xml:get_attr_s(<<"xmlns">>, _attrs) of + <<>> -> + decode_vcard_label_LABEL_els(_els, Line, Pref, Intl, + Dom, Parcel, Postal, Work, + decode_vcard_label_LABEL_HOME(_el)); + _ -> + decode_vcard_label_LABEL_els(_els, Line, Pref, Intl, + Dom, Parcel, Postal, Work, Home) + end; +decode_vcard_label_LABEL_els([_ | _els], Line, Pref, + Intl, Dom, Parcel, Postal, Work, Home) -> + decode_vcard_label_LABEL_els(_els, Line, Pref, Intl, + Dom, Parcel, Postal, Work, Home); +decode_vcard_label_LABEL_els([], Line, Pref, Intl, Dom, + Parcel, Postal, Work, Home) -> + {lists:reverse(Line), Pref, Intl, Dom, Parcel, Postal, + Work, Home}. + +encode_vcard_label_LABEL([], _acc) -> _acc; +encode_vcard_label_LABEL([{vcard_label, Home, Work, + Postal, Parcel, Dom, Intl, Pref, Line} + | _tail], + _acc) -> + _els = encode_vcard_label_LABEL_HOME(Home, + encode_vcard_label_LABEL_WORK(Work, + encode_vcard_label_LABEL_POSTAL(Postal, + encode_vcard_label_LABEL_PARCEL(Parcel, + encode_vcard_label_LABEL_DOM(Dom, + encode_vcard_label_LABEL_INTL(Intl, + encode_vcard_label_LABEL_PREF(Pref, + encode_vcard_label_LABEL_LINE(Line, + [])))))))), + _attrs = [], + encode_vcard_label_LABEL(_tail, + [{xmlel, <<"LABEL">>, _attrs, _els} | _acc]). + +decode_vcard_label_LABEL_LINE({xmlel, _, _attrs, + _els}) -> + Cdata = decode_vcard_label_LABEL_LINE_els(_els, <<>>), + Cdata. + +decode_vcard_label_LABEL_LINE_els([{xmlcdata, _data} + | _els], + Cdata) -> + decode_vcard_label_LABEL_LINE_els(_els, + <<Cdata/binary, _data/binary>>); +decode_vcard_label_LABEL_LINE_els([_ | _els], Cdata) -> + decode_vcard_label_LABEL_LINE_els(_els, Cdata); +decode_vcard_label_LABEL_LINE_els([], Cdata) -> + decode_vcard_label_LABEL_LINE_cdata(Cdata). + +encode_vcard_label_LABEL_LINE([], _acc) -> _acc; +encode_vcard_label_LABEL_LINE([Cdata | _tail], _acc) -> + _els = encode_vcard_label_LABEL_LINE_cdata(Cdata, []), + _attrs = [], + encode_vcard_label_LABEL_LINE(_tail, + [{xmlel, <<"LINE">>, _attrs, _els} | _acc]). + +decode_vcard_label_LABEL_LINE_cdata(<<>>) -> undefined; +decode_vcard_label_LABEL_LINE_cdata(_val) -> _val. + +encode_vcard_label_LABEL_LINE_cdata(undefined, _acc) -> + _acc; +encode_vcard_label_LABEL_LINE_cdata(_val, _acc) -> + [{xmlcdata, _val} | _acc]. + +decode_vcard_label_LABEL_PREF({xmlel, _, _attrs, + _els}) -> + true. + +encode_vcard_label_LABEL_PREF(false, _acc) -> _acc; +encode_vcard_label_LABEL_PREF(true, _acc) -> + _els = [], + _attrs = [], + [{xmlel, <<"PREF">>, _attrs, _els} | _acc]. + +decode_vcard_label_LABEL_INTL({xmlel, _, _attrs, + _els}) -> + true. + +encode_vcard_label_LABEL_INTL(false, _acc) -> _acc; +encode_vcard_label_LABEL_INTL(true, _acc) -> + _els = [], + _attrs = [], + [{xmlel, <<"INTL">>, _attrs, _els} | _acc]. + +decode_vcard_label_LABEL_DOM({xmlel, _, _attrs, + _els}) -> + true. + +encode_vcard_label_LABEL_DOM(false, _acc) -> _acc; +encode_vcard_label_LABEL_DOM(true, _acc) -> + _els = [], + _attrs = [], + [{xmlel, <<"DOM">>, _attrs, _els} | _acc]. + +decode_vcard_label_LABEL_PARCEL({xmlel, _, _attrs, + _els}) -> + true. + +encode_vcard_label_LABEL_PARCEL(false, _acc) -> _acc; +encode_vcard_label_LABEL_PARCEL(true, _acc) -> + _els = [], + _attrs = [], + [{xmlel, <<"PARCEL">>, _attrs, _els} | _acc]. + +decode_vcard_label_LABEL_POSTAL({xmlel, _, _attrs, + _els}) -> + true. + +encode_vcard_label_LABEL_POSTAL(false, _acc) -> _acc; +encode_vcard_label_LABEL_POSTAL(true, _acc) -> + _els = [], + _attrs = [], + [{xmlel, <<"POSTAL">>, _attrs, _els} | _acc]. + +decode_vcard_label_LABEL_WORK({xmlel, _, _attrs, + _els}) -> + true. + +encode_vcard_label_LABEL_WORK(false, _acc) -> _acc; +encode_vcard_label_LABEL_WORK(true, _acc) -> + _els = [], + _attrs = [], + [{xmlel, <<"WORK">>, _attrs, _els} | _acc]. + +decode_vcard_label_LABEL_HOME({xmlel, _, _attrs, + _els}) -> + true. + +encode_vcard_label_LABEL_HOME(false, _acc) -> _acc; +encode_vcard_label_LABEL_HOME(true, _acc) -> + _els = [], + _attrs = [], + [{xmlel, <<"HOME">>, _attrs, _els} | _acc]. + +decode_vcard_tel_TEL({xmlel, _, _attrs, _els}) -> + {Number, Pref, Pcs, Isdn, Modem, Bbs, Video, Cell, Msg, + Pager, Fax, Voice, Work, Home} = + decode_vcard_tel_TEL_els(_els, [], false, false, false, + false, false, false, false, false, false, + false, false, false, false), + {vcard_tel, Home, Work, Voice, Fax, Pager, Msg, Cell, + Video, Bbs, Modem, Isdn, Pcs, Pref, Number}. + +decode_vcard_tel_TEL_els([{xmlel, <<"NUMBER">>, _attrs, + _} = + _el + | _els], + Number, Pref, Pcs, Isdn, Modem, Bbs, Video, Cell, Msg, + Pager, Fax, Voice, Work, Home) -> + case xml:get_attr_s(<<"xmlns">>, _attrs) of + <<>> -> + decode_vcard_tel_TEL_els(_els, + [decode_vcard_tel_TEL_NUMBER(_el) | Number], + Pref, Pcs, Isdn, Modem, Bbs, Video, Cell, + Msg, Pager, Fax, Voice, Work, Home); + _ -> + decode_vcard_tel_TEL_els(_els, Number, Pref, Pcs, Isdn, + Modem, Bbs, Video, Cell, Msg, Pager, Fax, + Voice, Work, Home) + end; +decode_vcard_tel_TEL_els([{xmlel, <<"PREF">>, _attrs, + _} = + _el + | _els], + Number, Pref, Pcs, Isdn, Modem, Bbs, Video, Cell, Msg, + Pager, Fax, Voice, Work, Home) -> + case xml:get_attr_s(<<"xmlns">>, _attrs) of + <<>> -> + decode_vcard_tel_TEL_els(_els, Number, + decode_vcard_tel_TEL_PREF(_el), Pcs, Isdn, + Modem, Bbs, Video, Cell, Msg, Pager, Fax, + Voice, Work, Home); + _ -> + decode_vcard_tel_TEL_els(_els, Number, Pref, Pcs, Isdn, + Modem, Bbs, Video, Cell, Msg, Pager, Fax, + Voice, Work, Home) + end; +decode_vcard_tel_TEL_els([{xmlel, <<"PCS">>, _attrs, + _} = + _el + | _els], + Number, Pref, Pcs, Isdn, Modem, Bbs, Video, Cell, Msg, + Pager, Fax, Voice, Work, Home) -> + case xml:get_attr_s(<<"xmlns">>, _attrs) of + <<>> -> + decode_vcard_tel_TEL_els(_els, Number, Pref, + decode_vcard_tel_TEL_PCS(_el), Isdn, Modem, + Bbs, Video, Cell, Msg, Pager, Fax, Voice, + Work, Home); + _ -> + decode_vcard_tel_TEL_els(_els, Number, Pref, Pcs, Isdn, + Modem, Bbs, Video, Cell, Msg, Pager, Fax, + Voice, Work, Home) + end; +decode_vcard_tel_TEL_els([{xmlel, <<"ISDN">>, _attrs, + _} = + _el + | _els], + Number, Pref, Pcs, Isdn, Modem, Bbs, Video, Cell, Msg, + Pager, Fax, Voice, Work, Home) -> + case xml:get_attr_s(<<"xmlns">>, _attrs) of + <<>> -> + decode_vcard_tel_TEL_els(_els, Number, Pref, Pcs, + decode_vcard_tel_TEL_ISDN(_el), Modem, Bbs, + Video, Cell, Msg, Pager, Fax, Voice, Work, + Home); + _ -> + decode_vcard_tel_TEL_els(_els, Number, Pref, Pcs, Isdn, + Modem, Bbs, Video, Cell, Msg, Pager, Fax, + Voice, Work, Home) + end; +decode_vcard_tel_TEL_els([{xmlel, <<"MODEM">>, _attrs, + _} = + _el + | _els], + Number, Pref, Pcs, Isdn, Modem, Bbs, Video, Cell, Msg, + Pager, Fax, Voice, Work, Home) -> + case xml:get_attr_s(<<"xmlns">>, _attrs) of + <<>> -> + decode_vcard_tel_TEL_els(_els, Number, Pref, Pcs, Isdn, + decode_vcard_tel_TEL_MODEM(_el), Bbs, Video, + Cell, Msg, Pager, Fax, Voice, Work, Home); + _ -> + decode_vcard_tel_TEL_els(_els, Number, Pref, Pcs, Isdn, + Modem, Bbs, Video, Cell, Msg, Pager, Fax, + Voice, Work, Home) + end; +decode_vcard_tel_TEL_els([{xmlel, <<"BBS">>, _attrs, + _} = + _el + | _els], + Number, Pref, Pcs, Isdn, Modem, Bbs, Video, Cell, Msg, + Pager, Fax, Voice, Work, Home) -> + case xml:get_attr_s(<<"xmlns">>, _attrs) of + <<>> -> + decode_vcard_tel_TEL_els(_els, Number, Pref, Pcs, Isdn, + Modem, decode_vcard_tel_TEL_BBS(_el), Video, + Cell, Msg, Pager, Fax, Voice, Work, Home); + _ -> + decode_vcard_tel_TEL_els(_els, Number, Pref, Pcs, Isdn, + Modem, Bbs, Video, Cell, Msg, Pager, Fax, + Voice, Work, Home) + end; +decode_vcard_tel_TEL_els([{xmlel, <<"VIDEO">>, _attrs, + _} = + _el + | _els], + Number, Pref, Pcs, Isdn, Modem, Bbs, Video, Cell, Msg, + Pager, Fax, Voice, Work, Home) -> + case xml:get_attr_s(<<"xmlns">>, _attrs) of + <<>> -> + decode_vcard_tel_TEL_els(_els, Number, Pref, Pcs, Isdn, + Modem, Bbs, decode_vcard_tel_TEL_VIDEO(_el), + Cell, Msg, Pager, Fax, Voice, Work, Home); + _ -> + decode_vcard_tel_TEL_els(_els, Number, Pref, Pcs, Isdn, + Modem, Bbs, Video, Cell, Msg, Pager, Fax, + Voice, Work, Home) + end; +decode_vcard_tel_TEL_els([{xmlel, <<"CELL">>, _attrs, + _} = + _el + | _els], + Number, Pref, Pcs, Isdn, Modem, Bbs, Video, Cell, Msg, + Pager, Fax, Voice, Work, Home) -> + case xml:get_attr_s(<<"xmlns">>, _attrs) of + <<>> -> + decode_vcard_tel_TEL_els(_els, Number, Pref, Pcs, Isdn, + Modem, Bbs, Video, + decode_vcard_tel_TEL_CELL(_el), Msg, Pager, + Fax, Voice, Work, Home); + _ -> + decode_vcard_tel_TEL_els(_els, Number, Pref, Pcs, Isdn, + Modem, Bbs, Video, Cell, Msg, Pager, Fax, + Voice, Work, Home) + end; +decode_vcard_tel_TEL_els([{xmlel, <<"MSG">>, _attrs, + _} = + _el + | _els], + Number, Pref, Pcs, Isdn, Modem, Bbs, Video, Cell, Msg, + Pager, Fax, Voice, Work, Home) -> + case xml:get_attr_s(<<"xmlns">>, _attrs) of + <<>> -> + decode_vcard_tel_TEL_els(_els, Number, Pref, Pcs, Isdn, + Modem, Bbs, Video, Cell, + decode_vcard_tel_TEL_MSG(_el), Pager, Fax, + Voice, Work, Home); + _ -> + decode_vcard_tel_TEL_els(_els, Number, Pref, Pcs, Isdn, + Modem, Bbs, Video, Cell, Msg, Pager, Fax, + Voice, Work, Home) + end; +decode_vcard_tel_TEL_els([{xmlel, <<"PAGER">>, _attrs, + _} = + _el + | _els], + Number, Pref, Pcs, Isdn, Modem, Bbs, Video, Cell, Msg, + Pager, Fax, Voice, Work, Home) -> + case xml:get_attr_s(<<"xmlns">>, _attrs) of + <<>> -> + decode_vcard_tel_TEL_els(_els, Number, Pref, Pcs, Isdn, + Modem, Bbs, Video, Cell, Msg, + decode_vcard_tel_TEL_PAGER(_el), Fax, Voice, + Work, Home); + _ -> + decode_vcard_tel_TEL_els(_els, Number, Pref, Pcs, Isdn, + Modem, Bbs, Video, Cell, Msg, Pager, Fax, + Voice, Work, Home) + end; +decode_vcard_tel_TEL_els([{xmlel, <<"FAX">>, _attrs, + _} = + _el + | _els], + Number, Pref, Pcs, Isdn, Modem, Bbs, Video, Cell, Msg, + Pager, Fax, Voice, Work, Home) -> + case xml:get_attr_s(<<"xmlns">>, _attrs) of + <<>> -> + decode_vcard_tel_TEL_els(_els, Number, Pref, Pcs, Isdn, + Modem, Bbs, Video, Cell, Msg, Pager, + decode_vcard_tel_TEL_FAX(_el), Voice, Work, + Home); + _ -> + decode_vcard_tel_TEL_els(_els, Number, Pref, Pcs, Isdn, + Modem, Bbs, Video, Cell, Msg, Pager, Fax, + Voice, Work, Home) + end; +decode_vcard_tel_TEL_els([{xmlel, <<"VOICE">>, _attrs, + _} = + _el + | _els], + Number, Pref, Pcs, Isdn, Modem, Bbs, Video, Cell, Msg, + Pager, Fax, Voice, Work, Home) -> + case xml:get_attr_s(<<"xmlns">>, _attrs) of + <<>> -> + decode_vcard_tel_TEL_els(_els, Number, Pref, Pcs, Isdn, + Modem, Bbs, Video, Cell, Msg, Pager, Fax, + decode_vcard_tel_TEL_VOICE(_el), Work, Home); + _ -> + decode_vcard_tel_TEL_els(_els, Number, Pref, Pcs, Isdn, + Modem, Bbs, Video, Cell, Msg, Pager, Fax, + Voice, Work, Home) + end; +decode_vcard_tel_TEL_els([{xmlel, <<"WORK">>, _attrs, + _} = + _el + | _els], + Number, Pref, Pcs, Isdn, Modem, Bbs, Video, Cell, Msg, + Pager, Fax, Voice, Work, Home) -> + case xml:get_attr_s(<<"xmlns">>, _attrs) of + <<>> -> + decode_vcard_tel_TEL_els(_els, Number, Pref, Pcs, Isdn, + Modem, Bbs, Video, Cell, Msg, Pager, Fax, + Voice, decode_vcard_tel_TEL_WORK(_el), Home); + _ -> + decode_vcard_tel_TEL_els(_els, Number, Pref, Pcs, Isdn, + Modem, Bbs, Video, Cell, Msg, Pager, Fax, + Voice, Work, Home) + end; +decode_vcard_tel_TEL_els([{xmlel, <<"HOME">>, _attrs, + _} = + _el + | _els], + Number, Pref, Pcs, Isdn, Modem, Bbs, Video, Cell, Msg, + Pager, Fax, Voice, Work, Home) -> + case xml:get_attr_s(<<"xmlns">>, _attrs) of + <<>> -> + decode_vcard_tel_TEL_els(_els, Number, Pref, Pcs, Isdn, + Modem, Bbs, Video, Cell, Msg, Pager, Fax, + Voice, Work, decode_vcard_tel_TEL_HOME(_el)); + _ -> + decode_vcard_tel_TEL_els(_els, Number, Pref, Pcs, Isdn, + Modem, Bbs, Video, Cell, Msg, Pager, Fax, + Voice, Work, Home) + end; +decode_vcard_tel_TEL_els([_ | _els], Number, Pref, Pcs, + Isdn, Modem, Bbs, Video, Cell, Msg, Pager, Fax, Voice, + Work, Home) -> + decode_vcard_tel_TEL_els(_els, Number, Pref, Pcs, Isdn, + Modem, Bbs, Video, Cell, Msg, Pager, Fax, Voice, + Work, Home); +decode_vcard_tel_TEL_els([], [Number], Pref, Pcs, Isdn, + Modem, Bbs, Video, Cell, Msg, Pager, Fax, Voice, Work, + Home) -> + {Number, Pref, Pcs, Isdn, Modem, Bbs, Video, Cell, Msg, + Pager, Fax, Voice, Work, Home}. + +encode_vcard_tel_TEL([], _acc) -> _acc; +encode_vcard_tel_TEL([{vcard_tel, Home, Work, Voice, + Fax, Pager, Msg, Cell, Video, Bbs, Modem, Isdn, Pcs, + Pref, Number} + | _tail], + _acc) -> + _els = encode_vcard_tel_TEL_HOME(Home, + encode_vcard_tel_TEL_WORK(Work, + encode_vcard_tel_TEL_VOICE(Voice, + encode_vcard_tel_TEL_FAX(Fax, + encode_vcard_tel_TEL_PAGER(Pager, + encode_vcard_tel_TEL_MSG(Msg, + encode_vcard_tel_TEL_CELL(Cell, + encode_vcard_tel_TEL_VIDEO(Video, + encode_vcard_tel_TEL_BBS(Bbs, + encode_vcard_tel_TEL_MODEM(Modem, + encode_vcard_tel_TEL_ISDN(Isdn, + encode_vcard_tel_TEL_PCS(Pcs, + encode_vcard_tel_TEL_PREF(Pref, + encode_vcard_tel_TEL_NUMBER(Number, + [])))))))))))))), + _attrs = [], + encode_vcard_tel_TEL(_tail, + [{xmlel, <<"TEL">>, _attrs, _els} | _acc]). + +decode_vcard_tel_TEL_NUMBER({xmlel, _, _attrs, _els}) -> + Cdata = decode_vcard_tel_TEL_NUMBER_els(_els, <<>>), + Cdata. + +decode_vcard_tel_TEL_NUMBER_els([{xmlcdata, _data} + | _els], + Cdata) -> + decode_vcard_tel_TEL_NUMBER_els(_els, + <<Cdata/binary, _data/binary>>); +decode_vcard_tel_TEL_NUMBER_els([_ | _els], Cdata) -> + decode_vcard_tel_TEL_NUMBER_els(_els, Cdata); +decode_vcard_tel_TEL_NUMBER_els([], Cdata) -> + decode_vcard_tel_TEL_NUMBER_cdata(Cdata). + +encode_vcard_tel_TEL_NUMBER(Cdata, _acc) -> + _els = encode_vcard_tel_TEL_NUMBER_cdata(Cdata, []), + _attrs = [], + [{xmlel, <<"NUMBER">>, _attrs, _els} | _acc]. + +decode_vcard_tel_TEL_NUMBER_cdata(<<>>) -> undefined; +decode_vcard_tel_TEL_NUMBER_cdata(_val) -> _val. + +encode_vcard_tel_TEL_NUMBER_cdata(undefined, _acc) -> + _acc; +encode_vcard_tel_TEL_NUMBER_cdata(_val, _acc) -> + [{xmlcdata, _val} | _acc]. + +decode_vcard_tel_TEL_PREF({xmlel, _, _attrs, _els}) -> + true. + +encode_vcard_tel_TEL_PREF(false, _acc) -> _acc; +encode_vcard_tel_TEL_PREF(true, _acc) -> + _els = [], + _attrs = [], + [{xmlel, <<"PREF">>, _attrs, _els} | _acc]. + +decode_vcard_tel_TEL_PCS({xmlel, _, _attrs, _els}) -> + true. + +encode_vcard_tel_TEL_PCS(false, _acc) -> _acc; +encode_vcard_tel_TEL_PCS(true, _acc) -> + _els = [], + _attrs = [], + [{xmlel, <<"PCS">>, _attrs, _els} | _acc]. + +decode_vcard_tel_TEL_ISDN({xmlel, _, _attrs, _els}) -> + true. + +encode_vcard_tel_TEL_ISDN(false, _acc) -> _acc; +encode_vcard_tel_TEL_ISDN(true, _acc) -> + _els = [], + _attrs = [], + [{xmlel, <<"ISDN">>, _attrs, _els} | _acc]. + +decode_vcard_tel_TEL_MODEM({xmlel, _, _attrs, _els}) -> + true. + +encode_vcard_tel_TEL_MODEM(false, _acc) -> _acc; +encode_vcard_tel_TEL_MODEM(true, _acc) -> + _els = [], + _attrs = [], + [{xmlel, <<"MODEM">>, _attrs, _els} | _acc]. + +decode_vcard_tel_TEL_BBS({xmlel, _, _attrs, _els}) -> + true. + +encode_vcard_tel_TEL_BBS(false, _acc) -> _acc; +encode_vcard_tel_TEL_BBS(true, _acc) -> + _els = [], + _attrs = [], + [{xmlel, <<"BBS">>, _attrs, _els} | _acc]. + +decode_vcard_tel_TEL_VIDEO({xmlel, _, _attrs, _els}) -> + true. + +encode_vcard_tel_TEL_VIDEO(false, _acc) -> _acc; +encode_vcard_tel_TEL_VIDEO(true, _acc) -> + _els = [], + _attrs = [], + [{xmlel, <<"VIDEO">>, _attrs, _els} | _acc]. + +decode_vcard_tel_TEL_CELL({xmlel, _, _attrs, _els}) -> + true. + +encode_vcard_tel_TEL_CELL(false, _acc) -> _acc; +encode_vcard_tel_TEL_CELL(true, _acc) -> + _els = [], + _attrs = [], + [{xmlel, <<"CELL">>, _attrs, _els} | _acc]. + +decode_vcard_tel_TEL_MSG({xmlel, _, _attrs, _els}) -> + true. + +encode_vcard_tel_TEL_MSG(false, _acc) -> _acc; +encode_vcard_tel_TEL_MSG(true, _acc) -> + _els = [], + _attrs = [], + [{xmlel, <<"MSG">>, _attrs, _els} | _acc]. + +decode_vcard_tel_TEL_PAGER({xmlel, _, _attrs, _els}) -> + true. + +encode_vcard_tel_TEL_PAGER(false, _acc) -> _acc; +encode_vcard_tel_TEL_PAGER(true, _acc) -> + _els = [], + _attrs = [], + [{xmlel, <<"PAGER">>, _attrs, _els} | _acc]. + +decode_vcard_tel_TEL_FAX({xmlel, _, _attrs, _els}) -> + true. + +encode_vcard_tel_TEL_FAX(false, _acc) -> _acc; +encode_vcard_tel_TEL_FAX(true, _acc) -> + _els = [], + _attrs = [], + [{xmlel, <<"FAX">>, _attrs, _els} | _acc]. + +decode_vcard_tel_TEL_VOICE({xmlel, _, _attrs, _els}) -> + true. + +encode_vcard_tel_TEL_VOICE(false, _acc) -> _acc; +encode_vcard_tel_TEL_VOICE(true, _acc) -> + _els = [], + _attrs = [], + [{xmlel, <<"VOICE">>, _attrs, _els} | _acc]. + +decode_vcard_tel_TEL_WORK({xmlel, _, _attrs, _els}) -> + true. + +encode_vcard_tel_TEL_WORK(false, _acc) -> _acc; +encode_vcard_tel_TEL_WORK(true, _acc) -> + _els = [], + _attrs = [], + [{xmlel, <<"WORK">>, _attrs, _els} | _acc]. + +decode_vcard_tel_TEL_HOME({xmlel, _, _attrs, _els}) -> + true. + +encode_vcard_tel_TEL_HOME(false, _acc) -> _acc; +encode_vcard_tel_TEL_HOME(true, _acc) -> + _els = [], + _attrs = [], + [{xmlel, <<"HOME">>, _attrs, _els} | _acc]. + +decode_vcard_email_EMAIL({xmlel, _, _attrs, _els}) -> + {Userid, X400, Pref, Internet, Work, Home} = + decode_vcard_email_EMAIL_els(_els, [], false, false, + false, false, false), + {vcard_email, Home, Work, Internet, Pref, X400, Userid}. + +decode_vcard_email_EMAIL_els([{xmlel, <<"USERID">>, + _attrs, _} = + _el + | _els], + Userid, X400, Pref, Internet, Work, Home) -> + case xml:get_attr_s(<<"xmlns">>, _attrs) of + <<>> -> + decode_vcard_email_EMAIL_els(_els, + [decode_vcard_email_EMAIL_USERID(_el) + | Userid], + X400, Pref, Internet, Work, Home); + _ -> + decode_vcard_email_EMAIL_els(_els, Userid, X400, Pref, + Internet, Work, Home) + end; +decode_vcard_email_EMAIL_els([{xmlel, <<"X400">>, + _attrs, _} = + _el + | _els], + Userid, X400, Pref, Internet, Work, Home) -> + case xml:get_attr_s(<<"xmlns">>, _attrs) of + <<>> -> + decode_vcard_email_EMAIL_els(_els, Userid, + decode_vcard_email_EMAIL_X400(_el), Pref, + Internet, Work, Home); + _ -> + decode_vcard_email_EMAIL_els(_els, Userid, X400, Pref, + Internet, Work, Home) + end; +decode_vcard_email_EMAIL_els([{xmlel, <<"PREF">>, + _attrs, _} = + _el + | _els], + Userid, X400, Pref, Internet, Work, Home) -> + case xml:get_attr_s(<<"xmlns">>, _attrs) of + <<>> -> + decode_vcard_email_EMAIL_els(_els, Userid, X400, + decode_vcard_email_EMAIL_PREF(_el), + Internet, Work, Home); + _ -> + decode_vcard_email_EMAIL_els(_els, Userid, X400, Pref, + Internet, Work, Home) + end; +decode_vcard_email_EMAIL_els([{xmlel, <<"INTERNET">>, + _attrs, _} = + _el + | _els], + Userid, X400, Pref, Internet, Work, Home) -> + case xml:get_attr_s(<<"xmlns">>, _attrs) of + <<>> -> + decode_vcard_email_EMAIL_els(_els, Userid, X400, Pref, + decode_vcard_email_EMAIL_INTERNET(_el), + Work, Home); + _ -> + decode_vcard_email_EMAIL_els(_els, Userid, X400, Pref, + Internet, Work, Home) + end; +decode_vcard_email_EMAIL_els([{xmlel, <<"WORK">>, + _attrs, _} = + _el + | _els], + Userid, X400, Pref, Internet, Work, Home) -> + case xml:get_attr_s(<<"xmlns">>, _attrs) of + <<>> -> + decode_vcard_email_EMAIL_els(_els, Userid, X400, Pref, + Internet, + decode_vcard_email_EMAIL_WORK(_el), + Home); + _ -> + decode_vcard_email_EMAIL_els(_els, Userid, X400, Pref, + Internet, Work, Home) + end; +decode_vcard_email_EMAIL_els([{xmlel, <<"HOME">>, + _attrs, _} = + _el + | _els], + Userid, X400, Pref, Internet, Work, Home) -> + case xml:get_attr_s(<<"xmlns">>, _attrs) of + <<>> -> + decode_vcard_email_EMAIL_els(_els, Userid, X400, Pref, + Internet, Work, + decode_vcard_email_EMAIL_HOME(_el)); + _ -> + decode_vcard_email_EMAIL_els(_els, Userid, X400, Pref, + Internet, Work, Home) + end; +decode_vcard_email_EMAIL_els([_ | _els], Userid, X400, + Pref, Internet, Work, Home) -> + decode_vcard_email_EMAIL_els(_els, Userid, X400, Pref, + Internet, Work, Home); +decode_vcard_email_EMAIL_els([], [Userid], X400, Pref, + Internet, Work, Home) -> + {Userid, X400, Pref, Internet, Work, Home}. + +encode_vcard_email_EMAIL([], _acc) -> _acc; +encode_vcard_email_EMAIL([{vcard_email, Home, Work, + Internet, Pref, X400, Userid} + | _tail], + _acc) -> + _els = encode_vcard_email_EMAIL_HOME(Home, + encode_vcard_email_EMAIL_WORK(Work, + encode_vcard_email_EMAIL_INTERNET(Internet, + encode_vcard_email_EMAIL_PREF(Pref, + encode_vcard_email_EMAIL_X400(X400, + encode_vcard_email_EMAIL_USERID(Userid, + [])))))), + _attrs = [], + encode_vcard_email_EMAIL(_tail, + [{xmlel, <<"EMAIL">>, _attrs, _els} | _acc]). + +decode_vcard_email_EMAIL_USERID({xmlel, _, _attrs, + _els}) -> + Cdata = decode_vcard_email_EMAIL_USERID_els(_els, <<>>), + Cdata. + +decode_vcard_email_EMAIL_USERID_els([{xmlcdata, _data} + | _els], + Cdata) -> + decode_vcard_email_EMAIL_USERID_els(_els, + <<Cdata/binary, _data/binary>>); +decode_vcard_email_EMAIL_USERID_els([_ | _els], + Cdata) -> + decode_vcard_email_EMAIL_USERID_els(_els, Cdata); +decode_vcard_email_EMAIL_USERID_els([], Cdata) -> + decode_vcard_email_EMAIL_USERID_cdata(Cdata). + +encode_vcard_email_EMAIL_USERID(Cdata, _acc) -> + _els = encode_vcard_email_EMAIL_USERID_cdata(Cdata, []), + _attrs = [], + [{xmlel, <<"USERID">>, _attrs, _els} | _acc]. + +decode_vcard_email_EMAIL_USERID_cdata(<<>>) -> + undefined; +decode_vcard_email_EMAIL_USERID_cdata(_val) -> _val. + +encode_vcard_email_EMAIL_USERID_cdata(undefined, + _acc) -> + _acc; +encode_vcard_email_EMAIL_USERID_cdata(_val, _acc) -> + [{xmlcdata, _val} | _acc]. + +decode_vcard_email_EMAIL_X400({xmlel, _, _attrs, + _els}) -> + true. + +encode_vcard_email_EMAIL_X400(false, _acc) -> _acc; +encode_vcard_email_EMAIL_X400(true, _acc) -> + _els = [], + _attrs = [], + [{xmlel, <<"X400">>, _attrs, _els} | _acc]. + +decode_vcard_email_EMAIL_PREF({xmlel, _, _attrs, + _els}) -> + true. + +encode_vcard_email_EMAIL_PREF(false, _acc) -> _acc; +encode_vcard_email_EMAIL_PREF(true, _acc) -> + _els = [], + _attrs = [], + [{xmlel, <<"PREF">>, _attrs, _els} | _acc]. + +decode_vcard_email_EMAIL_INTERNET({xmlel, _, _attrs, + _els}) -> + true. + +encode_vcard_email_EMAIL_INTERNET(false, _acc) -> _acc; +encode_vcard_email_EMAIL_INTERNET(true, _acc) -> + _els = [], + _attrs = [], + [{xmlel, <<"INTERNET">>, _attrs, _els} | _acc]. + +decode_vcard_email_EMAIL_WORK({xmlel, _, _attrs, + _els}) -> + true. + +encode_vcard_email_EMAIL_WORK(false, _acc) -> _acc; +encode_vcard_email_EMAIL_WORK(true, _acc) -> + _els = [], + _attrs = [], + [{xmlel, <<"WORK">>, _attrs, _els} | _acc]. + +decode_vcard_email_EMAIL_HOME({xmlel, _, _attrs, + _els}) -> + true. + +encode_vcard_email_EMAIL_HOME(false, _acc) -> _acc; +encode_vcard_email_EMAIL_HOME(true, _acc) -> + _els = [], + _attrs = [], + [{xmlel, <<"HOME">>, _attrs, _els} | _acc]. + +decode_vcard_geo_GEO({xmlel, _, _attrs, _els}) -> + {Lon, Lat} = decode_vcard_geo_GEO_els(_els, [], []), + {vcard_geo, Lat, Lon}. + +decode_vcard_geo_GEO_els([{xmlel, <<"LON">>, _attrs, + _} = + _el + | _els], + Lon, Lat) -> + case xml:get_attr_s(<<"xmlns">>, _attrs) of + <<>> -> + decode_vcard_geo_GEO_els(_els, + [decode_vcard_geo_GEO_LON(_el) | Lon], Lat); + _ -> decode_vcard_geo_GEO_els(_els, Lon, Lat) + end; +decode_vcard_geo_GEO_els([{xmlel, <<"LAT">>, _attrs, + _} = + _el + | _els], + Lon, Lat) -> + case xml:get_attr_s(<<"xmlns">>, _attrs) of + <<>> -> + decode_vcard_geo_GEO_els(_els, Lon, + [decode_vcard_geo_GEO_LAT(_el) | Lat]); + _ -> decode_vcard_geo_GEO_els(_els, Lon, Lat) + end; +decode_vcard_geo_GEO_els([_ | _els], Lon, Lat) -> + decode_vcard_geo_GEO_els(_els, Lon, Lat); +decode_vcard_geo_GEO_els([], [Lon], [Lat]) -> + {Lon, Lat}. + +encode_vcard_geo_GEO(undefined, _acc) -> _acc; +encode_vcard_geo_GEO({vcard_geo, Lat, Lon}, _acc) -> + _els = encode_vcard_geo_GEO_LAT(Lat, + encode_vcard_geo_GEO_LON(Lon, [])), + _attrs = [], + [{xmlel, <<"GEO">>, _attrs, _els} | _acc]. + +decode_vcard_geo_GEO_LON({xmlel, _, _attrs, _els}) -> + Cdata = decode_vcard_geo_GEO_LON_els(_els, <<>>), Cdata. + +decode_vcard_geo_GEO_LON_els([{xmlcdata, _data} | _els], + Cdata) -> + decode_vcard_geo_GEO_LON_els(_els, + <<Cdata/binary, _data/binary>>); +decode_vcard_geo_GEO_LON_els([_ | _els], Cdata) -> + decode_vcard_geo_GEO_LON_els(_els, Cdata); +decode_vcard_geo_GEO_LON_els([], Cdata) -> + decode_vcard_geo_GEO_LON_cdata(Cdata). + +encode_vcard_geo_GEO_LON(Cdata, _acc) -> + _els = encode_vcard_geo_GEO_LON_cdata(Cdata, []), + _attrs = [], + [{xmlel, <<"LON">>, _attrs, _els} | _acc]. + +decode_vcard_geo_GEO_LON_cdata(<<>>) -> undefined; +decode_vcard_geo_GEO_LON_cdata(_val) -> _val. + +encode_vcard_geo_GEO_LON_cdata(undefined, _acc) -> _acc; +encode_vcard_geo_GEO_LON_cdata(_val, _acc) -> + [{xmlcdata, _val} | _acc]. + +decode_vcard_geo_GEO_LAT({xmlel, _, _attrs, _els}) -> + Cdata = decode_vcard_geo_GEO_LAT_els(_els, <<>>), Cdata. + +decode_vcard_geo_GEO_LAT_els([{xmlcdata, _data} | _els], + Cdata) -> + decode_vcard_geo_GEO_LAT_els(_els, + <<Cdata/binary, _data/binary>>); +decode_vcard_geo_GEO_LAT_els([_ | _els], Cdata) -> + decode_vcard_geo_GEO_LAT_els(_els, Cdata); +decode_vcard_geo_GEO_LAT_els([], Cdata) -> + decode_vcard_geo_GEO_LAT_cdata(Cdata). + +encode_vcard_geo_GEO_LAT(Cdata, _acc) -> + _els = encode_vcard_geo_GEO_LAT_cdata(Cdata, []), + _attrs = [], + [{xmlel, <<"LAT">>, _attrs, _els} | _acc]. + +decode_vcard_geo_GEO_LAT_cdata(<<>>) -> undefined; +decode_vcard_geo_GEO_LAT_cdata(_val) -> _val. + +encode_vcard_geo_GEO_LAT_cdata(undefined, _acc) -> _acc; +encode_vcard_geo_GEO_LAT_cdata(_val, _acc) -> + [{xmlcdata, _val} | _acc]. + +decode_vcard_type_TYPE({xmlel, _, _attrs, _els}) -> + Cdata = decode_vcard_type_TYPE_els(_els, <<>>), Cdata. + +decode_vcard_type_TYPE_els([{xmlcdata, _data} | _els], + Cdata) -> + decode_vcard_type_TYPE_els(_els, + <<Cdata/binary, _data/binary>>); +decode_vcard_type_TYPE_els([_ | _els], Cdata) -> + decode_vcard_type_TYPE_els(_els, Cdata); +decode_vcard_type_TYPE_els([], Cdata) -> + decode_vcard_type_TYPE_cdata(Cdata). + +encode_vcard_type_TYPE(undefined, _acc) -> _acc; +encode_vcard_type_TYPE(Cdata, _acc) -> + _els = encode_vcard_type_TYPE_cdata(Cdata, []), + _attrs = [], + [{xmlel, <<"TYPE">>, _attrs, _els} | _acc]. + +decode_vcard_type_TYPE_cdata(<<>>) -> undefined; +decode_vcard_type_TYPE_cdata(_val) -> _val. + +encode_vcard_type_TYPE_cdata(undefined, _acc) -> _acc; +encode_vcard_type_TYPE_cdata(_val, _acc) -> + [{xmlcdata, _val} | _acc]. + +decode_vcard_binval_BINVAL({xmlel, _, _attrs, _els}) -> + Cdata = decode_vcard_binval_BINVAL_els(_els, <<>>), + Cdata. + +decode_vcard_binval_BINVAL_els([{xmlcdata, _data} + | _els], + Cdata) -> + decode_vcard_binval_BINVAL_els(_els, + <<Cdata/binary, _data/binary>>); +decode_vcard_binval_BINVAL_els([_ | _els], Cdata) -> + decode_vcard_binval_BINVAL_els(_els, Cdata); +decode_vcard_binval_BINVAL_els([], Cdata) -> + decode_vcard_binval_BINVAL_cdata(Cdata). + +encode_vcard_binval_BINVAL(undefined, _acc) -> _acc; +encode_vcard_binval_BINVAL(Cdata, _acc) -> + _els = encode_vcard_binval_BINVAL_cdata(Cdata, []), + _attrs = [], + [{xmlel, <<"BINVAL">>, _attrs, _els} | _acc]. + +decode_vcard_binval_BINVAL_cdata(<<>>) -> undefined; +decode_vcard_binval_BINVAL_cdata(_val) -> + case catch base64:decode(_val) of + {'EXIT', _} -> + erlang:error({bad_cdata_value, <<>>, <<"BINVAL">>, + <<>>}); + _res -> _res + end. + +encode_vcard_binval_BINVAL_cdata(undefined, _acc) -> + _acc; +encode_vcard_binval_BINVAL_cdata(_val, _acc) -> + [{xmlcdata, base64:encode(_val)} | _acc]. + +decode_vcard_extval_EXTVAL({xmlel, _, _attrs, _els}) -> + Cdata = decode_vcard_extval_EXTVAL_els(_els, <<>>), + Cdata. + +decode_vcard_extval_EXTVAL_els([{xmlcdata, _data} + | _els], + Cdata) -> + decode_vcard_extval_EXTVAL_els(_els, + <<Cdata/binary, _data/binary>>); +decode_vcard_extval_EXTVAL_els([_ | _els], Cdata) -> + decode_vcard_extval_EXTVAL_els(_els, Cdata); +decode_vcard_extval_EXTVAL_els([], Cdata) -> + decode_vcard_extval_EXTVAL_cdata(Cdata). + +encode_vcard_extval_EXTVAL(undefined, _acc) -> _acc; +encode_vcard_extval_EXTVAL(Cdata, _acc) -> + _els = encode_vcard_extval_EXTVAL_cdata(Cdata, []), + _attrs = [], + [{xmlel, <<"EXTVAL">>, _attrs, _els} | _acc]. + +decode_vcard_extval_EXTVAL_cdata(<<>>) -> undefined; +decode_vcard_extval_EXTVAL_cdata(_val) -> _val. + +encode_vcard_extval_EXTVAL_cdata(undefined, _acc) -> + _acc; +encode_vcard_extval_EXTVAL_cdata(_val, _acc) -> + [{xmlcdata, _val} | _acc]. + +decode_vcard_logo_LOGO({xmlel, _, _attrs, _els}) -> + {Extval, Binval, Type} = + decode_vcard_logo_LOGO_els(_els, undefined, undefined, + undefined), + {vcard_logo, Type, Binval, Extval}. + +decode_vcard_logo_LOGO_els([{xmlel, <<"EXTVAL">>, + _attrs, _} = + _el + | _els], + Extval, Binval, Type) -> + case xml:get_attr_s(<<"xmlns">>, _attrs) of + <<>> -> + decode_vcard_logo_LOGO_els(_els, + decode_vcard_extval_EXTVAL(_el), Binval, + Type); + _ -> + decode_vcard_logo_LOGO_els(_els, Extval, Binval, Type) + end; +decode_vcard_logo_LOGO_els([{xmlel, <<"BINVAL">>, + _attrs, _} = + _el + | _els], + Extval, Binval, Type) -> + case xml:get_attr_s(<<"xmlns">>, _attrs) of + <<>> -> + decode_vcard_logo_LOGO_els(_els, Extval, + decode_vcard_binval_BINVAL(_el), Type); + _ -> + decode_vcard_logo_LOGO_els(_els, Extval, Binval, Type) + end; +decode_vcard_logo_LOGO_els([{xmlel, <<"TYPE">>, _attrs, + _} = + _el + | _els], + Extval, Binval, Type) -> + case xml:get_attr_s(<<"xmlns">>, _attrs) of + <<>> -> + decode_vcard_logo_LOGO_els(_els, Extval, Binval, + decode_vcard_type_TYPE(_el)); + _ -> + decode_vcard_logo_LOGO_els(_els, Extval, Binval, Type) + end; +decode_vcard_logo_LOGO_els([_ | _els], Extval, Binval, + Type) -> + decode_vcard_logo_LOGO_els(_els, Extval, Binval, Type); +decode_vcard_logo_LOGO_els([], Extval, Binval, Type) -> + {Extval, Binval, Type}. + +encode_vcard_logo_LOGO(undefined, _acc) -> _acc; +encode_vcard_logo_LOGO({vcard_logo, Type, Binval, + Extval}, + _acc) -> + _els = encode_vcard_type_TYPE(Type, + encode_vcard_binval_BINVAL(Binval, + encode_vcard_extval_EXTVAL(Extval, + []))), + _attrs = [], + [{xmlel, <<"LOGO">>, _attrs, _els} | _acc]. + +decode_vcard_photo_PHOTO({xmlel, _, _attrs, _els}) -> + {Extval, Binval, Type} = + decode_vcard_photo_PHOTO_els(_els, undefined, undefined, + undefined), + {vcard_photo, Type, Binval, Extval}. + +decode_vcard_photo_PHOTO_els([{xmlel, <<"EXTVAL">>, + _attrs, _} = + _el + | _els], + Extval, Binval, Type) -> + case xml:get_attr_s(<<"xmlns">>, _attrs) of + <<>> -> + decode_vcard_photo_PHOTO_els(_els, + decode_vcard_extval_EXTVAL(_el), Binval, + Type); + _ -> + decode_vcard_photo_PHOTO_els(_els, Extval, Binval, Type) + end; +decode_vcard_photo_PHOTO_els([{xmlel, <<"BINVAL">>, + _attrs, _} = + _el + | _els], + Extval, Binval, Type) -> + case xml:get_attr_s(<<"xmlns">>, _attrs) of + <<>> -> + decode_vcard_photo_PHOTO_els(_els, Extval, + decode_vcard_binval_BINVAL(_el), Type); + _ -> + decode_vcard_photo_PHOTO_els(_els, Extval, Binval, Type) + end; +decode_vcard_photo_PHOTO_els([{xmlel, <<"TYPE">>, + _attrs, _} = + _el + | _els], + Extval, Binval, Type) -> + case xml:get_attr_s(<<"xmlns">>, _attrs) of + <<>> -> + decode_vcard_photo_PHOTO_els(_els, Extval, Binval, + decode_vcard_type_TYPE(_el)); + _ -> + decode_vcard_photo_PHOTO_els(_els, Extval, Binval, Type) + end; +decode_vcard_photo_PHOTO_els([_ | _els], Extval, Binval, + Type) -> + decode_vcard_photo_PHOTO_els(_els, Extval, Binval, + Type); +decode_vcard_photo_PHOTO_els([], Extval, Binval, + Type) -> + {Extval, Binval, Type}. + +encode_vcard_photo_PHOTO(undefined, _acc) -> _acc; +encode_vcard_photo_PHOTO({vcard_photo, Type, Binval, + Extval}, + _acc) -> + _els = encode_vcard_type_TYPE(Type, + encode_vcard_binval_BINVAL(Binval, + encode_vcard_extval_EXTVAL(Extval, + []))), + _attrs = [], + [{xmlel, <<"PHOTO">>, _attrs, _els} | _acc]. + +decode_vcard_org_ORG({xmlel, _, _attrs, _els}) -> + {Units, Name} = decode_vcard_org_ORG_els(_els, [], []), + {vcard_org, Name, Units}. + +decode_vcard_org_ORG_els([{xmlel, <<"ORGUNIT">>, _attrs, + _} = + _el + | _els], + Units, Name) -> + case xml:get_attr_s(<<"xmlns">>, _attrs) of + <<>> -> + decode_vcard_org_ORG_els(_els, + [decode_vcard_org_ORG_ORGUNIT(_el) | Units], + Name); + _ -> decode_vcard_org_ORG_els(_els, Units, Name) + end; +decode_vcard_org_ORG_els([{xmlel, <<"ORGNAME">>, _attrs, + _} = + _el + | _els], + Units, Name) -> + case xml:get_attr_s(<<"xmlns">>, _attrs) of + <<>> -> + decode_vcard_org_ORG_els(_els, Units, + [decode_vcard_org_ORG_ORGNAME(_el) | Name]); + _ -> decode_vcard_org_ORG_els(_els, Units, Name) + end; +decode_vcard_org_ORG_els([_ | _els], Units, Name) -> + decode_vcard_org_ORG_els(_els, Units, Name); +decode_vcard_org_ORG_els([], Units, [Name]) -> + {lists:reverse(Units), Name}. + +encode_vcard_org_ORG(undefined, _acc) -> _acc; +encode_vcard_org_ORG({vcard_org, Name, Units}, _acc) -> + _els = encode_vcard_org_ORG_ORGNAME(Name, + encode_vcard_org_ORG_ORGUNIT(Units, + [])), + _attrs = [], + [{xmlel, <<"ORG">>, _attrs, _els} | _acc]. + +decode_vcard_org_ORG_ORGUNIT({xmlel, _, _attrs, + _els}) -> + Cdata = decode_vcard_org_ORG_ORGUNIT_els(_els, <<>>), + Cdata. + +decode_vcard_org_ORG_ORGUNIT_els([{xmlcdata, _data} + | _els], + Cdata) -> + decode_vcard_org_ORG_ORGUNIT_els(_els, + <<Cdata/binary, _data/binary>>); +decode_vcard_org_ORG_ORGUNIT_els([_ | _els], Cdata) -> + decode_vcard_org_ORG_ORGUNIT_els(_els, Cdata); +decode_vcard_org_ORG_ORGUNIT_els([], Cdata) -> + decode_vcard_org_ORG_ORGUNIT_cdata(Cdata). + +encode_vcard_org_ORG_ORGUNIT([], _acc) -> _acc; +encode_vcard_org_ORG_ORGUNIT([Cdata | _tail], _acc) -> + _els = encode_vcard_org_ORG_ORGUNIT_cdata(Cdata, []), + _attrs = [], + encode_vcard_org_ORG_ORGUNIT(_tail, + [{xmlel, <<"ORGUNIT">>, _attrs, _els} | _acc]). + +decode_vcard_org_ORG_ORGUNIT_cdata(<<>>) -> undefined; +decode_vcard_org_ORG_ORGUNIT_cdata(_val) -> _val. + +encode_vcard_org_ORG_ORGUNIT_cdata(undefined, _acc) -> + _acc; +encode_vcard_org_ORG_ORGUNIT_cdata(_val, _acc) -> + [{xmlcdata, _val} | _acc]. + +decode_vcard_org_ORG_ORGNAME({xmlel, _, _attrs, + _els}) -> + Cdata = decode_vcard_org_ORG_ORGNAME_els(_els, <<>>), + Cdata. + +decode_vcard_org_ORG_ORGNAME_els([{xmlcdata, _data} + | _els], + Cdata) -> + decode_vcard_org_ORG_ORGNAME_els(_els, + <<Cdata/binary, _data/binary>>); +decode_vcard_org_ORG_ORGNAME_els([_ | _els], Cdata) -> + decode_vcard_org_ORG_ORGNAME_els(_els, Cdata); +decode_vcard_org_ORG_ORGNAME_els([], Cdata) -> + decode_vcard_org_ORG_ORGNAME_cdata(Cdata). + +encode_vcard_org_ORG_ORGNAME(Cdata, _acc) -> + _els = encode_vcard_org_ORG_ORGNAME_cdata(Cdata, []), + _attrs = [], + [{xmlel, <<"ORGNAME">>, _attrs, _els} | _acc]. + +decode_vcard_org_ORG_ORGNAME_cdata(<<>>) -> undefined; +decode_vcard_org_ORG_ORGNAME_cdata(_val) -> _val. + +encode_vcard_org_ORG_ORGNAME_cdata(undefined, _acc) -> + _acc; +encode_vcard_org_ORG_ORGNAME_cdata(_val, _acc) -> + [{xmlcdata, _val} | _acc]. + +decode_vcard_sound_SOUND({xmlel, _, _attrs, _els}) -> + {Extval, Binval, Phonetic} = + decode_vcard_sound_SOUND_els(_els, undefined, undefined, + undefined), + {vcard_sound, Phonetic, Binval, Extval}. + +decode_vcard_sound_SOUND_els([{xmlel, <<"EXTVAL">>, + _attrs, _} = + _el + | _els], + Extval, Binval, Phonetic) -> + case xml:get_attr_s(<<"xmlns">>, _attrs) of + <<>> -> + decode_vcard_sound_SOUND_els(_els, + decode_vcard_extval_EXTVAL(_el), Binval, + Phonetic); + _ -> + decode_vcard_sound_SOUND_els(_els, Extval, Binval, + Phonetic) + end; +decode_vcard_sound_SOUND_els([{xmlel, <<"BINVAL">>, + _attrs, _} = + _el + | _els], + Extval, Binval, Phonetic) -> + case xml:get_attr_s(<<"xmlns">>, _attrs) of + <<>> -> + decode_vcard_sound_SOUND_els(_els, Extval, + decode_vcard_binval_BINVAL(_el), + Phonetic); + _ -> + decode_vcard_sound_SOUND_els(_els, Extval, Binval, + Phonetic) + end; +decode_vcard_sound_SOUND_els([{xmlel, <<"PHONETIC">>, + _attrs, _} = + _el + | _els], + Extval, Binval, Phonetic) -> + case xml:get_attr_s(<<"xmlns">>, _attrs) of + <<>> -> + decode_vcard_sound_SOUND_els(_els, Extval, Binval, + decode_vcard_sound_SOUND_PHONETIC(_el)); + _ -> + decode_vcard_sound_SOUND_els(_els, Extval, Binval, + Phonetic) + end; +decode_vcard_sound_SOUND_els([_ | _els], Extval, Binval, + Phonetic) -> + decode_vcard_sound_SOUND_els(_els, Extval, Binval, + Phonetic); +decode_vcard_sound_SOUND_els([], Extval, Binval, + Phonetic) -> + {Extval, Binval, Phonetic}. + +encode_vcard_sound_SOUND(undefined, _acc) -> _acc; +encode_vcard_sound_SOUND({vcard_sound, Phonetic, Binval, + Extval}, + _acc) -> + _els = encode_vcard_sound_SOUND_PHONETIC(Phonetic, + encode_vcard_binval_BINVAL(Binval, + encode_vcard_extval_EXTVAL(Extval, + []))), + _attrs = [], + [{xmlel, <<"SOUND">>, _attrs, _els} | _acc]. + +decode_vcard_sound_SOUND_PHONETIC({xmlel, _, _attrs, + _els}) -> + Cdata = decode_vcard_sound_SOUND_PHONETIC_els(_els, + <<>>), + Cdata. + +decode_vcard_sound_SOUND_PHONETIC_els([{xmlcdata, _data} + | _els], + Cdata) -> + decode_vcard_sound_SOUND_PHONETIC_els(_els, + <<Cdata/binary, _data/binary>>); +decode_vcard_sound_SOUND_PHONETIC_els([_ | _els], + Cdata) -> + decode_vcard_sound_SOUND_PHONETIC_els(_els, Cdata); +decode_vcard_sound_SOUND_PHONETIC_els([], Cdata) -> + decode_vcard_sound_SOUND_PHONETIC_cdata(Cdata). + +encode_vcard_sound_SOUND_PHONETIC(undefined, _acc) -> + _acc; +encode_vcard_sound_SOUND_PHONETIC(Cdata, _acc) -> + _els = encode_vcard_sound_SOUND_PHONETIC_cdata(Cdata, + []), + _attrs = [], + [{xmlel, <<"PHONETIC">>, _attrs, _els} | _acc]. + +decode_vcard_sound_SOUND_PHONETIC_cdata(<<>>) -> + undefined; +decode_vcard_sound_SOUND_PHONETIC_cdata(_val) -> _val. + +encode_vcard_sound_SOUND_PHONETIC_cdata(undefined, + _acc) -> + _acc; +encode_vcard_sound_SOUND_PHONETIC_cdata(_val, _acc) -> + [{xmlcdata, _val} | _acc]. + +decode_vcard_key_KEY({xmlel, _, _attrs, _els}) -> + {Cred, Type} = decode_vcard_key_KEY_els(_els, [], + undefined), + {vcard_key, Type, Cred}. + +decode_vcard_key_KEY_els([{xmlel, <<"CRED">>, _attrs, + _} = + _el + | _els], + Cred, Type) -> + case xml:get_attr_s(<<"xmlns">>, _attrs) of + <<>> -> + decode_vcard_key_KEY_els(_els, + [decode_vcard_key_KEY_CRED(_el) | Cred], + Type); + _ -> decode_vcard_key_KEY_els(_els, Cred, Type) + end; +decode_vcard_key_KEY_els([{xmlel, <<"TYPE">>, _attrs, + _} = + _el + | _els], + Cred, Type) -> + case xml:get_attr_s(<<"xmlns">>, _attrs) of + <<>> -> + decode_vcard_key_KEY_els(_els, Cred, + decode_vcard_type_TYPE(_el)); + _ -> decode_vcard_key_KEY_els(_els, Cred, Type) + end; +decode_vcard_key_KEY_els([_ | _els], Cred, Type) -> + decode_vcard_key_KEY_els(_els, Cred, Type); +decode_vcard_key_KEY_els([], [Cred], Type) -> + {Cred, Type}. + +encode_vcard_key_KEY(undefined, _acc) -> _acc; +encode_vcard_key_KEY({vcard_key, Type, Cred}, _acc) -> + _els = encode_vcard_type_TYPE(Type, + encode_vcard_key_KEY_CRED(Cred, [])), + _attrs = [], + [{xmlel, <<"KEY">>, _attrs, _els} | _acc]. + +decode_vcard_key_KEY_CRED({xmlel, _, _attrs, _els}) -> + Cdata = decode_vcard_key_KEY_CRED_els(_els, <<>>), + Cdata. + +decode_vcard_key_KEY_CRED_els([{xmlcdata, _data} + | _els], + Cdata) -> + decode_vcard_key_KEY_CRED_els(_els, + <<Cdata/binary, _data/binary>>); +decode_vcard_key_KEY_CRED_els([_ | _els], Cdata) -> + decode_vcard_key_KEY_CRED_els(_els, Cdata); +decode_vcard_key_KEY_CRED_els([], Cdata) -> + decode_vcard_key_KEY_CRED_cdata(Cdata). + +encode_vcard_key_KEY_CRED(Cdata, _acc) -> + _els = encode_vcard_key_KEY_CRED_cdata(Cdata, []), + _attrs = [], + [{xmlel, <<"CRED">>, _attrs, _els} | _acc]. + +decode_vcard_key_KEY_CRED_cdata(<<>>) -> undefined; +decode_vcard_key_KEY_CRED_cdata(_val) -> _val. + +encode_vcard_key_KEY_CRED_cdata(undefined, _acc) -> + _acc; +encode_vcard_key_KEY_CRED_cdata(_val, _acc) -> + [{xmlcdata, _val} | _acc]. + +decode_vcard_vCard({xmlel, _, _attrs, _els}) -> + {Desc, Key, Class, Url, Uid, Sound, Sort_string, Rev, + Prodid, Note, Categories, Org, Logo, Role, Title, Geo, + Tz, Mailer, Jabberid, Email, Tel, Label, Adr, Bday, + Photo, Nickname, N, Fn, Version} = + decode_vcard_vCard_els(_els, undefined, undefined, + undefined, undefined, undefined, undefined, + undefined, undefined, undefined, undefined, [], + undefined, undefined, undefined, undefined, + undefined, undefined, undefined, undefined, [], + [], [], [], undefined, undefined, undefined, + undefined, undefined, undefined), + {vcard, Version, Fn, N, Nickname, Photo, Bday, Adr, + Label, Tel, Email, Jabberid, Mailer, Tz, Geo, Title, + Role, Logo, Org, Categories, Note, Prodid, Rev, + Sort_string, Sound, Uid, Url, Class, Key, Desc}. + +decode_vcard_vCard_els([{xmlel, <<"DESC">>, _attrs, _} = + _el + | _els], + Desc, Key, Class, Url, Uid, Sound, Sort_string, Rev, + Prodid, Note, Categories, Org, Logo, Role, Title, Geo, + Tz, Mailer, Jabberid, Email, Tel, Label, Adr, Bday, + Photo, Nickname, N, Fn, Version) -> + case xml:get_attr_s(<<"xmlns">>, _attrs) of + <<>> -> + decode_vcard_vCard_els(_els, + decode_vcard_vCard_DESC(_el), Key, Class, Url, + Uid, Sound, Sort_string, Rev, Prodid, Note, + Categories, Org, Logo, Role, Title, Geo, Tz, + Mailer, Jabberid, Email, Tel, Label, Adr, Bday, + Photo, Nickname, N, Fn, Version); + _ -> + decode_vcard_vCard_els(_els, Desc, Key, Class, Url, Uid, + Sound, Sort_string, Rev, Prodid, Note, + Categories, Org, Logo, Role, Title, Geo, Tz, + Mailer, Jabberid, Email, Tel, Label, Adr, Bday, + Photo, Nickname, N, Fn, Version) + end; +decode_vcard_vCard_els([{xmlel, <<"KEY">>, _attrs, _} = + _el + | _els], + Desc, Key, Class, Url, Uid, Sound, Sort_string, Rev, + Prodid, Note, Categories, Org, Logo, Role, Title, Geo, + Tz, Mailer, Jabberid, Email, Tel, Label, Adr, Bday, + Photo, Nickname, N, Fn, Version) -> + case xml:get_attr_s(<<"xmlns">>, _attrs) of + <<>> -> + decode_vcard_vCard_els(_els, Desc, + decode_vcard_key_KEY(_el), Class, Url, Uid, + Sound, Sort_string, Rev, Prodid, Note, + Categories, Org, Logo, Role, Title, Geo, Tz, + Mailer, Jabberid, Email, Tel, Label, Adr, Bday, + Photo, Nickname, N, Fn, Version); + _ -> + decode_vcard_vCard_els(_els, Desc, Key, Class, Url, Uid, + Sound, Sort_string, Rev, Prodid, Note, + Categories, Org, Logo, Role, Title, Geo, Tz, + Mailer, Jabberid, Email, Tel, Label, Adr, Bday, + Photo, Nickname, N, Fn, Version) + end; +decode_vcard_vCard_els([{xmlel, <<"CLASS">>, _attrs, + _} = + _el + | _els], + Desc, Key, Class, Url, Uid, Sound, Sort_string, Rev, + Prodid, Note, Categories, Org, Logo, Role, Title, Geo, + Tz, Mailer, Jabberid, Email, Tel, Label, Adr, Bday, + Photo, Nickname, N, Fn, Version) -> + case xml:get_attr_s(<<"xmlns">>, _attrs) of + <<>> -> + decode_vcard_vCard_els(_els, Desc, Key, + decode_vcard_vCard_CLASS(_el), Url, Uid, Sound, + Sort_string, Rev, Prodid, Note, Categories, + Org, Logo, Role, Title, Geo, Tz, Mailer, + Jabberid, Email, Tel, Label, Adr, Bday, Photo, + Nickname, N, Fn, Version); + _ -> + decode_vcard_vCard_els(_els, Desc, Key, Class, Url, Uid, + Sound, Sort_string, Rev, Prodid, Note, + Categories, Org, Logo, Role, Title, Geo, Tz, + Mailer, Jabberid, Email, Tel, Label, Adr, Bday, + Photo, Nickname, N, Fn, Version) + end; +decode_vcard_vCard_els([{xmlel, <<"URL">>, _attrs, _} = + _el + | _els], + Desc, Key, Class, Url, Uid, Sound, Sort_string, Rev, + Prodid, Note, Categories, Org, Logo, Role, Title, Geo, + Tz, Mailer, Jabberid, Email, Tel, Label, Adr, Bday, + Photo, Nickname, N, Fn, Version) -> + case xml:get_attr_s(<<"xmlns">>, _attrs) of + <<>> -> + decode_vcard_vCard_els(_els, Desc, Key, Class, + decode_vcard_vCard_URL(_el), Uid, Sound, + Sort_string, Rev, Prodid, Note, Categories, + Org, Logo, Role, Title, Geo, Tz, Mailer, + Jabberid, Email, Tel, Label, Adr, Bday, Photo, + Nickname, N, Fn, Version); + _ -> + decode_vcard_vCard_els(_els, Desc, Key, Class, Url, Uid, + Sound, Sort_string, Rev, Prodid, Note, + Categories, Org, Logo, Role, Title, Geo, Tz, + Mailer, Jabberid, Email, Tel, Label, Adr, Bday, + Photo, Nickname, N, Fn, Version) + end; +decode_vcard_vCard_els([{xmlel, <<"UID">>, _attrs, _} = + _el + | _els], + Desc, Key, Class, Url, Uid, Sound, Sort_string, Rev, + Prodid, Note, Categories, Org, Logo, Role, Title, Geo, + Tz, Mailer, Jabberid, Email, Tel, Label, Adr, Bday, + Photo, Nickname, N, Fn, Version) -> + case xml:get_attr_s(<<"xmlns">>, _attrs) of + <<>> -> + decode_vcard_vCard_els(_els, Desc, Key, Class, Url, + decode_vcard_vCard_UID(_el), Sound, + Sort_string, Rev, Prodid, Note, Categories, + Org, Logo, Role, Title, Geo, Tz, Mailer, + Jabberid, Email, Tel, Label, Adr, Bday, Photo, + Nickname, N, Fn, Version); + _ -> + decode_vcard_vCard_els(_els, Desc, Key, Class, Url, Uid, + Sound, Sort_string, Rev, Prodid, Note, + Categories, Org, Logo, Role, Title, Geo, Tz, + Mailer, Jabberid, Email, Tel, Label, Adr, Bday, + Photo, Nickname, N, Fn, Version) + end; +decode_vcard_vCard_els([{xmlel, <<"SOUND">>, _attrs, + _} = + _el + | _els], + Desc, Key, Class, Url, Uid, Sound, Sort_string, Rev, + Prodid, Note, Categories, Org, Logo, Role, Title, Geo, + Tz, Mailer, Jabberid, Email, Tel, Label, Adr, Bday, + Photo, Nickname, N, Fn, Version) -> + case xml:get_attr_s(<<"xmlns">>, _attrs) of + <<>> -> + decode_vcard_vCard_els(_els, Desc, Key, Class, Url, Uid, + decode_vcard_sound_SOUND(_el), Sort_string, + Rev, Prodid, Note, Categories, Org, Logo, Role, + Title, Geo, Tz, Mailer, Jabberid, Email, Tel, + Label, Adr, Bday, Photo, Nickname, N, Fn, + Version); + _ -> + decode_vcard_vCard_els(_els, Desc, Key, Class, Url, Uid, + Sound, Sort_string, Rev, Prodid, Note, + Categories, Org, Logo, Role, Title, Geo, Tz, + Mailer, Jabberid, Email, Tel, Label, Adr, Bday, + Photo, Nickname, N, Fn, Version) + end; +decode_vcard_vCard_els([{xmlel, <<"SORT-STRING">>, + _attrs, _} = + _el + | _els], + Desc, Key, Class, Url, Uid, Sound, Sort_string, Rev, + Prodid, Note, Categories, Org, Logo, Role, Title, Geo, + Tz, Mailer, Jabberid, Email, Tel, Label, Adr, Bday, + Photo, Nickname, N, Fn, Version) -> + case xml:get_attr_s(<<"xmlns">>, _attrs) of + <<>> -> + decode_vcard_vCard_els(_els, Desc, Key, Class, Url, Uid, + Sound, 'decode_vcard_vCard_SORT-STRING'(_el), + Rev, Prodid, Note, Categories, Org, Logo, Role, + Title, Geo, Tz, Mailer, Jabberid, Email, Tel, + Label, Adr, Bday, Photo, Nickname, N, Fn, + Version); + _ -> + decode_vcard_vCard_els(_els, Desc, Key, Class, Url, Uid, + Sound, Sort_string, Rev, Prodid, Note, + Categories, Org, Logo, Role, Title, Geo, Tz, + Mailer, Jabberid, Email, Tel, Label, Adr, Bday, + Photo, Nickname, N, Fn, Version) + end; +decode_vcard_vCard_els([{xmlel, <<"REV">>, _attrs, _} = + _el + | _els], + Desc, Key, Class, Url, Uid, Sound, Sort_string, Rev, + Prodid, Note, Categories, Org, Logo, Role, Title, Geo, + Tz, Mailer, Jabberid, Email, Tel, Label, Adr, Bday, + Photo, Nickname, N, Fn, Version) -> + case xml:get_attr_s(<<"xmlns">>, _attrs) of + <<>> -> + decode_vcard_vCard_els(_els, Desc, Key, Class, Url, Uid, + Sound, Sort_string, + decode_vcard_vCard_REV(_el), Prodid, Note, + Categories, Org, Logo, Role, Title, Geo, Tz, + Mailer, Jabberid, Email, Tel, Label, Adr, Bday, + Photo, Nickname, N, Fn, Version); + _ -> + decode_vcard_vCard_els(_els, Desc, Key, Class, Url, Uid, + Sound, Sort_string, Rev, Prodid, Note, + Categories, Org, Logo, Role, Title, Geo, Tz, + Mailer, Jabberid, Email, Tel, Label, Adr, Bday, + Photo, Nickname, N, Fn, Version) + end; +decode_vcard_vCard_els([{xmlel, <<"PRODID">>, _attrs, + _} = + _el + | _els], + Desc, Key, Class, Url, Uid, Sound, Sort_string, Rev, + Prodid, Note, Categories, Org, Logo, Role, Title, Geo, + Tz, Mailer, Jabberid, Email, Tel, Label, Adr, Bday, + Photo, Nickname, N, Fn, Version) -> + case xml:get_attr_s(<<"xmlns">>, _attrs) of + <<>> -> + decode_vcard_vCard_els(_els, Desc, Key, Class, Url, Uid, + Sound, Sort_string, Rev, + decode_vcard_vCard_PRODID(_el), Note, + Categories, Org, Logo, Role, Title, Geo, Tz, + Mailer, Jabberid, Email, Tel, Label, Adr, Bday, + Photo, Nickname, N, Fn, Version); + _ -> + decode_vcard_vCard_els(_els, Desc, Key, Class, Url, Uid, + Sound, Sort_string, Rev, Prodid, Note, + Categories, Org, Logo, Role, Title, Geo, Tz, + Mailer, Jabberid, Email, Tel, Label, Adr, Bday, + Photo, Nickname, N, Fn, Version) + end; +decode_vcard_vCard_els([{xmlel, <<"NOTE">>, _attrs, _} = + _el + | _els], + Desc, Key, Class, Url, Uid, Sound, Sort_string, Rev, + Prodid, Note, Categories, Org, Logo, Role, Title, Geo, + Tz, Mailer, Jabberid, Email, Tel, Label, Adr, Bday, + Photo, Nickname, N, Fn, Version) -> + case xml:get_attr_s(<<"xmlns">>, _attrs) of + <<>> -> + decode_vcard_vCard_els(_els, Desc, Key, Class, Url, Uid, + Sound, Sort_string, Rev, Prodid, + decode_vcard_vCard_NOTE(_el), Categories, Org, + Logo, Role, Title, Geo, Tz, Mailer, Jabberid, + Email, Tel, Label, Adr, Bday, Photo, Nickname, + N, Fn, Version); + _ -> + decode_vcard_vCard_els(_els, Desc, Key, Class, Url, Uid, + Sound, Sort_string, Rev, Prodid, Note, + Categories, Org, Logo, Role, Title, Geo, Tz, + Mailer, Jabberid, Email, Tel, Label, Adr, Bday, + Photo, Nickname, N, Fn, Version) + end; +decode_vcard_vCard_els([{xmlel, <<"CATEGORIES">>, + _attrs, _} = + _el + | _els], + Desc, Key, Class, Url, Uid, Sound, Sort_string, Rev, + Prodid, Note, Categories, Org, Logo, Role, Title, Geo, + Tz, Mailer, Jabberid, Email, Tel, Label, Adr, Bday, + Photo, Nickname, N, Fn, Version) -> + case xml:get_attr_s(<<"xmlns">>, _attrs) of + <<>> -> + decode_vcard_vCard_els(_els, Desc, Key, Class, Url, Uid, + Sound, Sort_string, Rev, Prodid, Note, + decode_vcard_vCard_CATEGORIES(_el), Org, Logo, + Role, Title, Geo, Tz, Mailer, Jabberid, Email, + Tel, Label, Adr, Bday, Photo, Nickname, N, Fn, + Version); + _ -> + decode_vcard_vCard_els(_els, Desc, Key, Class, Url, Uid, + Sound, Sort_string, Rev, Prodid, Note, + Categories, Org, Logo, Role, Title, Geo, Tz, + Mailer, Jabberid, Email, Tel, Label, Adr, Bday, + Photo, Nickname, N, Fn, Version) + end; +decode_vcard_vCard_els([{xmlel, <<"ORG">>, _attrs, _} = + _el + | _els], + Desc, Key, Class, Url, Uid, Sound, Sort_string, Rev, + Prodid, Note, Categories, Org, Logo, Role, Title, Geo, + Tz, Mailer, Jabberid, Email, Tel, Label, Adr, Bday, + Photo, Nickname, N, Fn, Version) -> + case xml:get_attr_s(<<"xmlns">>, _attrs) of + <<>> -> + decode_vcard_vCard_els(_els, Desc, Key, Class, Url, Uid, + Sound, Sort_string, Rev, Prodid, Note, + Categories, decode_vcard_org_ORG(_el), Logo, + Role, Title, Geo, Tz, Mailer, Jabberid, Email, + Tel, Label, Adr, Bday, Photo, Nickname, N, Fn, + Version); + _ -> + decode_vcard_vCard_els(_els, Desc, Key, Class, Url, Uid, + Sound, Sort_string, Rev, Prodid, Note, + Categories, Org, Logo, Role, Title, Geo, Tz, + Mailer, Jabberid, Email, Tel, Label, Adr, Bday, + Photo, Nickname, N, Fn, Version) + end; +decode_vcard_vCard_els([{xmlel, <<"LOGO">>, _attrs, _} = + _el + | _els], + Desc, Key, Class, Url, Uid, Sound, Sort_string, Rev, + Prodid, Note, Categories, Org, Logo, Role, Title, Geo, + Tz, Mailer, Jabberid, Email, Tel, Label, Adr, Bday, + Photo, Nickname, N, Fn, Version) -> + case xml:get_attr_s(<<"xmlns">>, _attrs) of + <<>> -> + decode_vcard_vCard_els(_els, Desc, Key, Class, Url, Uid, + Sound, Sort_string, Rev, Prodid, Note, + Categories, Org, decode_vcard_logo_LOGO(_el), + Role, Title, Geo, Tz, Mailer, Jabberid, Email, + Tel, Label, Adr, Bday, Photo, Nickname, N, Fn, + Version); + _ -> + decode_vcard_vCard_els(_els, Desc, Key, Class, Url, Uid, + Sound, Sort_string, Rev, Prodid, Note, + Categories, Org, Logo, Role, Title, Geo, Tz, + Mailer, Jabberid, Email, Tel, Label, Adr, Bday, + Photo, Nickname, N, Fn, Version) + end; +decode_vcard_vCard_els([{xmlel, <<"ROLE">>, _attrs, _} = + _el + | _els], + Desc, Key, Class, Url, Uid, Sound, Sort_string, Rev, + Prodid, Note, Categories, Org, Logo, Role, Title, Geo, + Tz, Mailer, Jabberid, Email, Tel, Label, Adr, Bday, + Photo, Nickname, N, Fn, Version) -> + case xml:get_attr_s(<<"xmlns">>, _attrs) of + <<>> -> + decode_vcard_vCard_els(_els, Desc, Key, Class, Url, Uid, + Sound, Sort_string, Rev, Prodid, Note, + Categories, Org, Logo, + decode_vcard_vCard_ROLE(_el), Title, Geo, Tz, + Mailer, Jabberid, Email, Tel, Label, Adr, Bday, + Photo, Nickname, N, Fn, Version); + _ -> + decode_vcard_vCard_els(_els, Desc, Key, Class, Url, Uid, + Sound, Sort_string, Rev, Prodid, Note, + Categories, Org, Logo, Role, Title, Geo, Tz, + Mailer, Jabberid, Email, Tel, Label, Adr, Bday, + Photo, Nickname, N, Fn, Version) + end; +decode_vcard_vCard_els([{xmlel, <<"TITLE">>, _attrs, + _} = + _el + | _els], + Desc, Key, Class, Url, Uid, Sound, Sort_string, Rev, + Prodid, Note, Categories, Org, Logo, Role, Title, Geo, + Tz, Mailer, Jabberid, Email, Tel, Label, Adr, Bday, + Photo, Nickname, N, Fn, Version) -> + case xml:get_attr_s(<<"xmlns">>, _attrs) of + <<>> -> + decode_vcard_vCard_els(_els, Desc, Key, Class, Url, Uid, + Sound, Sort_string, Rev, Prodid, Note, + Categories, Org, Logo, Role, + decode_vcard_vCard_TITLE(_el), Geo, Tz, Mailer, + Jabberid, Email, Tel, Label, Adr, Bday, Photo, + Nickname, N, Fn, Version); + _ -> + decode_vcard_vCard_els(_els, Desc, Key, Class, Url, Uid, + Sound, Sort_string, Rev, Prodid, Note, + Categories, Org, Logo, Role, Title, Geo, Tz, + Mailer, Jabberid, Email, Tel, Label, Adr, Bday, + Photo, Nickname, N, Fn, Version) + end; +decode_vcard_vCard_els([{xmlel, <<"GEO">>, _attrs, _} = + _el + | _els], + Desc, Key, Class, Url, Uid, Sound, Sort_string, Rev, + Prodid, Note, Categories, Org, Logo, Role, Title, Geo, + Tz, Mailer, Jabberid, Email, Tel, Label, Adr, Bday, + Photo, Nickname, N, Fn, Version) -> + case xml:get_attr_s(<<"xmlns">>, _attrs) of + <<>> -> + decode_vcard_vCard_els(_els, Desc, Key, Class, Url, Uid, + Sound, Sort_string, Rev, Prodid, Note, + Categories, Org, Logo, Role, Title, + decode_vcard_geo_GEO(_el), Tz, Mailer, + Jabberid, Email, Tel, Label, Adr, Bday, Photo, + Nickname, N, Fn, Version); + _ -> + decode_vcard_vCard_els(_els, Desc, Key, Class, Url, Uid, + Sound, Sort_string, Rev, Prodid, Note, + Categories, Org, Logo, Role, Title, Geo, Tz, + Mailer, Jabberid, Email, Tel, Label, Adr, Bday, + Photo, Nickname, N, Fn, Version) + end; +decode_vcard_vCard_els([{xmlel, <<"TZ">>, _attrs, _} = + _el + | _els], + Desc, Key, Class, Url, Uid, Sound, Sort_string, Rev, + Prodid, Note, Categories, Org, Logo, Role, Title, Geo, + Tz, Mailer, Jabberid, Email, Tel, Label, Adr, Bday, + Photo, Nickname, N, Fn, Version) -> + case xml:get_attr_s(<<"xmlns">>, _attrs) of + <<>> -> + decode_vcard_vCard_els(_els, Desc, Key, Class, Url, Uid, + Sound, Sort_string, Rev, Prodid, Note, + Categories, Org, Logo, Role, Title, Geo, + decode_vcard_vCard_TZ(_el), Mailer, Jabberid, + Email, Tel, Label, Adr, Bday, Photo, Nickname, + N, Fn, Version); + _ -> + decode_vcard_vCard_els(_els, Desc, Key, Class, Url, Uid, + Sound, Sort_string, Rev, Prodid, Note, + Categories, Org, Logo, Role, Title, Geo, Tz, + Mailer, Jabberid, Email, Tel, Label, Adr, Bday, + Photo, Nickname, N, Fn, Version) + end; +decode_vcard_vCard_els([{xmlel, <<"MAILER">>, _attrs, + _} = + _el + | _els], + Desc, Key, Class, Url, Uid, Sound, Sort_string, Rev, + Prodid, Note, Categories, Org, Logo, Role, Title, Geo, + Tz, Mailer, Jabberid, Email, Tel, Label, Adr, Bday, + Photo, Nickname, N, Fn, Version) -> + case xml:get_attr_s(<<"xmlns">>, _attrs) of + <<>> -> + decode_vcard_vCard_els(_els, Desc, Key, Class, Url, Uid, + Sound, Sort_string, Rev, Prodid, Note, + Categories, Org, Logo, Role, Title, Geo, Tz, + decode_vcard_vCard_MAILER(_el), Jabberid, + Email, Tel, Label, Adr, Bday, Photo, Nickname, + N, Fn, Version); + _ -> + decode_vcard_vCard_els(_els, Desc, Key, Class, Url, Uid, + Sound, Sort_string, Rev, Prodid, Note, + Categories, Org, Logo, Role, Title, Geo, Tz, + Mailer, Jabberid, Email, Tel, Label, Adr, Bday, + Photo, Nickname, N, Fn, Version) + end; +decode_vcard_vCard_els([{xmlel, <<"JABBERID">>, _attrs, + _} = + _el + | _els], + Desc, Key, Class, Url, Uid, Sound, Sort_string, Rev, + Prodid, Note, Categories, Org, Logo, Role, Title, Geo, + Tz, Mailer, Jabberid, Email, Tel, Label, Adr, Bday, + Photo, Nickname, N, Fn, Version) -> + case xml:get_attr_s(<<"xmlns">>, _attrs) of + <<>> -> + decode_vcard_vCard_els(_els, Desc, Key, Class, Url, Uid, + Sound, Sort_string, Rev, Prodid, Note, + Categories, Org, Logo, Role, Title, Geo, Tz, + Mailer, decode_vcard_vCard_JABBERID(_el), + Email, Tel, Label, Adr, Bday, Photo, Nickname, + N, Fn, Version); + _ -> + decode_vcard_vCard_els(_els, Desc, Key, Class, Url, Uid, + Sound, Sort_string, Rev, Prodid, Note, + Categories, Org, Logo, Role, Title, Geo, Tz, + Mailer, Jabberid, Email, Tel, Label, Adr, Bday, + Photo, Nickname, N, Fn, Version) + end; +decode_vcard_vCard_els([{xmlel, <<"EMAIL">>, _attrs, + _} = + _el + | _els], + Desc, Key, Class, Url, Uid, Sound, Sort_string, Rev, + Prodid, Note, Categories, Org, Logo, Role, Title, Geo, + Tz, Mailer, Jabberid, Email, Tel, Label, Adr, Bday, + Photo, Nickname, N, Fn, Version) -> + case xml:get_attr_s(<<"xmlns">>, _attrs) of + <<>> -> + decode_vcard_vCard_els(_els, Desc, Key, Class, Url, Uid, + Sound, Sort_string, Rev, Prodid, Note, + Categories, Org, Logo, Role, Title, Geo, Tz, + Mailer, Jabberid, + [decode_vcard_email_EMAIL(_el) | Email], Tel, + Label, Adr, Bday, Photo, Nickname, N, Fn, + Version); + _ -> + decode_vcard_vCard_els(_els, Desc, Key, Class, Url, Uid, + Sound, Sort_string, Rev, Prodid, Note, + Categories, Org, Logo, Role, Title, Geo, Tz, + Mailer, Jabberid, Email, Tel, Label, Adr, Bday, + Photo, Nickname, N, Fn, Version) + end; +decode_vcard_vCard_els([{xmlel, <<"TEL">>, _attrs, _} = + _el + | _els], + Desc, Key, Class, Url, Uid, Sound, Sort_string, Rev, + Prodid, Note, Categories, Org, Logo, Role, Title, Geo, + Tz, Mailer, Jabberid, Email, Tel, Label, Adr, Bday, + Photo, Nickname, N, Fn, Version) -> + case xml:get_attr_s(<<"xmlns">>, _attrs) of + <<>> -> + decode_vcard_vCard_els(_els, Desc, Key, Class, Url, Uid, + Sound, Sort_string, Rev, Prodid, Note, + Categories, Org, Logo, Role, Title, Geo, Tz, + Mailer, Jabberid, Email, + [decode_vcard_tel_TEL(_el) | Tel], Label, Adr, + Bday, Photo, Nickname, N, Fn, Version); + _ -> + decode_vcard_vCard_els(_els, Desc, Key, Class, Url, Uid, + Sound, Sort_string, Rev, Prodid, Note, + Categories, Org, Logo, Role, Title, Geo, Tz, + Mailer, Jabberid, Email, Tel, Label, Adr, Bday, + Photo, Nickname, N, Fn, Version) + end; +decode_vcard_vCard_els([{xmlel, <<"LABEL">>, _attrs, + _} = + _el + | _els], + Desc, Key, Class, Url, Uid, Sound, Sort_string, Rev, + Prodid, Note, Categories, Org, Logo, Role, Title, Geo, + Tz, Mailer, Jabberid, Email, Tel, Label, Adr, Bday, + Photo, Nickname, N, Fn, Version) -> + case xml:get_attr_s(<<"xmlns">>, _attrs) of + <<>> -> + decode_vcard_vCard_els(_els, Desc, Key, Class, Url, Uid, + Sound, Sort_string, Rev, Prodid, Note, + Categories, Org, Logo, Role, Title, Geo, Tz, + Mailer, Jabberid, Email, Tel, + [decode_vcard_label_LABEL(_el) | Label], Adr, + Bday, Photo, Nickname, N, Fn, Version); + _ -> + decode_vcard_vCard_els(_els, Desc, Key, Class, Url, Uid, + Sound, Sort_string, Rev, Prodid, Note, + Categories, Org, Logo, Role, Title, Geo, Tz, + Mailer, Jabberid, Email, Tel, Label, Adr, Bday, + Photo, Nickname, N, Fn, Version) + end; +decode_vcard_vCard_els([{xmlel, <<"ADR">>, _attrs, _} = + _el + | _els], + Desc, Key, Class, Url, Uid, Sound, Sort_string, Rev, + Prodid, Note, Categories, Org, Logo, Role, Title, Geo, + Tz, Mailer, Jabberid, Email, Tel, Label, Adr, Bday, + Photo, Nickname, N, Fn, Version) -> + case xml:get_attr_s(<<"xmlns">>, _attrs) of + <<>> -> + decode_vcard_vCard_els(_els, Desc, Key, Class, Url, Uid, + Sound, Sort_string, Rev, Prodid, Note, + Categories, Org, Logo, Role, Title, Geo, Tz, + Mailer, Jabberid, Email, Tel, Label, + [decode_vcard_adr_ADR(_el) | Adr], Bday, Photo, + Nickname, N, Fn, Version); + _ -> + decode_vcard_vCard_els(_els, Desc, Key, Class, Url, Uid, + Sound, Sort_string, Rev, Prodid, Note, + Categories, Org, Logo, Role, Title, Geo, Tz, + Mailer, Jabberid, Email, Tel, Label, Adr, Bday, + Photo, Nickname, N, Fn, Version) + end; +decode_vcard_vCard_els([{xmlel, <<"BDAY">>, _attrs, _} = + _el + | _els], + Desc, Key, Class, Url, Uid, Sound, Sort_string, Rev, + Prodid, Note, Categories, Org, Logo, Role, Title, Geo, + Tz, Mailer, Jabberid, Email, Tel, Label, Adr, Bday, + Photo, Nickname, N, Fn, Version) -> + case xml:get_attr_s(<<"xmlns">>, _attrs) of + <<>> -> + decode_vcard_vCard_els(_els, Desc, Key, Class, Url, Uid, + Sound, Sort_string, Rev, Prodid, Note, + Categories, Org, Logo, Role, Title, Geo, Tz, + Mailer, Jabberid, Email, Tel, Label, Adr, + decode_vcard_vCard_BDAY(_el), Photo, Nickname, + N, Fn, Version); + _ -> + decode_vcard_vCard_els(_els, Desc, Key, Class, Url, Uid, + Sound, Sort_string, Rev, Prodid, Note, + Categories, Org, Logo, Role, Title, Geo, Tz, + Mailer, Jabberid, Email, Tel, Label, Adr, Bday, + Photo, Nickname, N, Fn, Version) + end; +decode_vcard_vCard_els([{xmlel, <<"PHOTO">>, _attrs, + _} = + _el + | _els], + Desc, Key, Class, Url, Uid, Sound, Sort_string, Rev, + Prodid, Note, Categories, Org, Logo, Role, Title, Geo, + Tz, Mailer, Jabberid, Email, Tel, Label, Adr, Bday, + Photo, Nickname, N, Fn, Version) -> + case xml:get_attr_s(<<"xmlns">>, _attrs) of + <<>> -> + decode_vcard_vCard_els(_els, Desc, Key, Class, Url, Uid, + Sound, Sort_string, Rev, Prodid, Note, + Categories, Org, Logo, Role, Title, Geo, Tz, + Mailer, Jabberid, Email, Tel, Label, Adr, Bday, + decode_vcard_photo_PHOTO(_el), Nickname, N, Fn, + Version); + _ -> + decode_vcard_vCard_els(_els, Desc, Key, Class, Url, Uid, + Sound, Sort_string, Rev, Prodid, Note, + Categories, Org, Logo, Role, Title, Geo, Tz, + Mailer, Jabberid, Email, Tel, Label, Adr, Bday, + Photo, Nickname, N, Fn, Version) + end; +decode_vcard_vCard_els([{xmlel, <<"NICKNAME">>, _attrs, + _} = + _el + | _els], + Desc, Key, Class, Url, Uid, Sound, Sort_string, Rev, + Prodid, Note, Categories, Org, Logo, Role, Title, Geo, + Tz, Mailer, Jabberid, Email, Tel, Label, Adr, Bday, + Photo, Nickname, N, Fn, Version) -> + case xml:get_attr_s(<<"xmlns">>, _attrs) of + <<>> -> + decode_vcard_vCard_els(_els, Desc, Key, Class, Url, Uid, + Sound, Sort_string, Rev, Prodid, Note, + Categories, Org, Logo, Role, Title, Geo, Tz, + Mailer, Jabberid, Email, Tel, Label, Adr, Bday, + Photo, decode_vcard_vCard_NICKNAME(_el), N, Fn, + Version); + _ -> + decode_vcard_vCard_els(_els, Desc, Key, Class, Url, Uid, + Sound, Sort_string, Rev, Prodid, Note, + Categories, Org, Logo, Role, Title, Geo, Tz, + Mailer, Jabberid, Email, Tel, Label, Adr, Bday, + Photo, Nickname, N, Fn, Version) + end; +decode_vcard_vCard_els([{xmlel, <<"N">>, _attrs, _} = + _el + | _els], + Desc, Key, Class, Url, Uid, Sound, Sort_string, Rev, + Prodid, Note, Categories, Org, Logo, Role, Title, Geo, + Tz, Mailer, Jabberid, Email, Tel, Label, Adr, Bday, + Photo, Nickname, N, Fn, Version) -> + case xml:get_attr_s(<<"xmlns">>, _attrs) of + <<>> -> + decode_vcard_vCard_els(_els, Desc, Key, Class, Url, Uid, + Sound, Sort_string, Rev, Prodid, Note, + Categories, Org, Logo, Role, Title, Geo, Tz, + Mailer, Jabberid, Email, Tel, Label, Adr, Bday, + Photo, Nickname, decode_vcard_name_N(_el), Fn, + Version); + _ -> + decode_vcard_vCard_els(_els, Desc, Key, Class, Url, Uid, + Sound, Sort_string, Rev, Prodid, Note, + Categories, Org, Logo, Role, Title, Geo, Tz, + Mailer, Jabberid, Email, Tel, Label, Adr, Bday, + Photo, Nickname, N, Fn, Version) + end; +decode_vcard_vCard_els([{xmlel, <<"FN">>, _attrs, _} = + _el + | _els], + Desc, Key, Class, Url, Uid, Sound, Sort_string, Rev, + Prodid, Note, Categories, Org, Logo, Role, Title, Geo, + Tz, Mailer, Jabberid, Email, Tel, Label, Adr, Bday, + Photo, Nickname, N, Fn, Version) -> + case xml:get_attr_s(<<"xmlns">>, _attrs) of + <<>> -> + decode_vcard_vCard_els(_els, Desc, Key, Class, Url, Uid, + Sound, Sort_string, Rev, Prodid, Note, + Categories, Org, Logo, Role, Title, Geo, Tz, + Mailer, Jabberid, Email, Tel, Label, Adr, Bday, + Photo, Nickname, N, decode_vcard_vCard_FN(_el), + Version); + _ -> + decode_vcard_vCard_els(_els, Desc, Key, Class, Url, Uid, + Sound, Sort_string, Rev, Prodid, Note, + Categories, Org, Logo, Role, Title, Geo, Tz, + Mailer, Jabberid, Email, Tel, Label, Adr, Bday, + Photo, Nickname, N, Fn, Version) + end; +decode_vcard_vCard_els([{xmlel, <<"VERSION">>, _attrs, + _} = + _el + | _els], + Desc, Key, Class, Url, Uid, Sound, Sort_string, Rev, + Prodid, Note, Categories, Org, Logo, Role, Title, Geo, + Tz, Mailer, Jabberid, Email, Tel, Label, Adr, Bday, + Photo, Nickname, N, Fn, Version) -> + case xml:get_attr_s(<<"xmlns">>, _attrs) of + <<>> -> + decode_vcard_vCard_els(_els, Desc, Key, Class, Url, Uid, + Sound, Sort_string, Rev, Prodid, Note, + Categories, Org, Logo, Role, Title, Geo, Tz, + Mailer, Jabberid, Email, Tel, Label, Adr, Bday, + Photo, Nickname, N, Fn, + decode_vcard_vCard_VERSION(_el)); + _ -> + decode_vcard_vCard_els(_els, Desc, Key, Class, Url, Uid, + Sound, Sort_string, Rev, Prodid, Note, + Categories, Org, Logo, Role, Title, Geo, Tz, + Mailer, Jabberid, Email, Tel, Label, Adr, Bday, + Photo, Nickname, N, Fn, Version) + end; +decode_vcard_vCard_els([_ | _els], Desc, Key, Class, + Url, Uid, Sound, Sort_string, Rev, Prodid, Note, + Categories, Org, Logo, Role, Title, Geo, Tz, Mailer, + Jabberid, Email, Tel, Label, Adr, Bday, Photo, Nickname, + N, Fn, Version) -> + decode_vcard_vCard_els(_els, Desc, Key, Class, Url, Uid, + Sound, Sort_string, Rev, Prodid, Note, Categories, + Org, Logo, Role, Title, Geo, Tz, Mailer, Jabberid, + Email, Tel, Label, Adr, Bday, Photo, Nickname, N, Fn, + Version); +decode_vcard_vCard_els([], Desc, Key, Class, Url, Uid, + Sound, Sort_string, Rev, Prodid, Note, Categories, Org, + Logo, Role, Title, Geo, Tz, Mailer, Jabberid, Email, + Tel, Label, Adr, Bday, Photo, Nickname, N, Fn, + Version) -> + {Desc, Key, Class, Url, Uid, Sound, Sort_string, Rev, + Prodid, Note, Categories, Org, Logo, Role, Title, Geo, + Tz, Mailer, Jabberid, lists:reverse(Email), + lists:reverse(Tel), lists:reverse(Label), + lists:reverse(Adr), Bday, Photo, Nickname, N, Fn, + Version}. + +encode_vcard_vCard(undefined, _acc) -> _acc; +encode_vcard_vCard({vcard, Version, Fn, N, Nickname, + Photo, Bday, Adr, Label, Tel, Email, Jabberid, Mailer, + Tz, Geo, Title, Role, Logo, Org, Categories, Note, + Prodid, Rev, Sort_string, Sound, Uid, Url, Class, Key, + Desc}, + _acc) -> + _els = encode_vcard_vCard_VERSION(Version, + encode_vcard_vCard_FN(Fn, + encode_vcard_name_N(N, + encode_vcard_vCard_NICKNAME(Nickname, + encode_vcard_photo_PHOTO(Photo, + encode_vcard_vCard_BDAY(Bday, + encode_vcard_adr_ADR(Adr, + encode_vcard_label_LABEL(Label, + encode_vcard_tel_TEL(Tel, + encode_vcard_email_EMAIL(Email, + encode_vcard_vCard_JABBERID(Jabberid, + encode_vcard_vCard_MAILER(Mailer, + encode_vcard_vCard_TZ(Tz, + encode_vcard_geo_GEO(Geo, + encode_vcard_vCard_TITLE(Title, + encode_vcard_vCard_ROLE(Role, + encode_vcard_logo_LOGO(Logo, + encode_vcard_org_ORG(Org, + encode_vcard_vCard_CATEGORIES(Categories, + encode_vcard_vCard_NOTE(Note, + encode_vcard_vCard_PRODID(Prodid, + encode_vcard_vCard_REV(Rev, + 'encode_vcard_vCard_SORT-STRING'(Sort_string, + encode_vcard_sound_SOUND(Sound, + encode_vcard_vCard_UID(Uid, + encode_vcard_vCard_URL(Url, + encode_vcard_vCard_CLASS(Class, + encode_vcard_key_KEY(Key, + encode_vcard_vCard_DESC(Desc, + []))))))))))))))))))))))))))))), + _attrs = [{<<"xmlns">>, <<"vcard-temp">>}], + [{xmlel, <<"vCard">>, _attrs, _els} | _acc]. + +decode_vcard_vCard_DESC({xmlel, _, _attrs, _els}) -> + Cdata = decode_vcard_vCard_DESC_els(_els, <<>>), Cdata. + +decode_vcard_vCard_DESC_els([{xmlcdata, _data} | _els], + Cdata) -> + decode_vcard_vCard_DESC_els(_els, + <<Cdata/binary, _data/binary>>); +decode_vcard_vCard_DESC_els([_ | _els], Cdata) -> + decode_vcard_vCard_DESC_els(_els, Cdata); +decode_vcard_vCard_DESC_els([], Cdata) -> + decode_vcard_vCard_DESC_cdata(Cdata). + +encode_vcard_vCard_DESC(undefined, _acc) -> _acc; +encode_vcard_vCard_DESC(Cdata, _acc) -> + _els = encode_vcard_vCard_DESC_cdata(Cdata, []), + _attrs = [], + [{xmlel, <<"DESC">>, _attrs, _els} | _acc]. + +decode_vcard_vCard_DESC_cdata(<<>>) -> undefined; +decode_vcard_vCard_DESC_cdata(_val) -> _val. + +encode_vcard_vCard_DESC_cdata(undefined, _acc) -> _acc; +encode_vcard_vCard_DESC_cdata(_val, _acc) -> + [{xmlcdata, _val} | _acc]. + +decode_vcard_vCard_CLASS({xmlel, _, _attrs, _els}) -> + Value = decode_vcard_vCard_CLASS_els(_els, undefined), + Value. + +decode_vcard_vCard_CLASS_els([{xmlel, + <<"CONFIDENTIAL">>, _attrs, _} = + _el + | _els], + Value) -> + case xml:get_attr_s(<<"xmlns">>, _attrs) of + <<>> -> + decode_vcard_vCard_CLASS_els(_els, + decode_vcard_vCard_CLASS_CONFIDENTIAL(_el)); + _ -> decode_vcard_vCard_CLASS_els(_els, Value) + end; +decode_vcard_vCard_CLASS_els([{xmlel, <<"PRIVATE">>, + _attrs, _} = + _el + | _els], + Value) -> + case xml:get_attr_s(<<"xmlns">>, _attrs) of + <<>> -> + decode_vcard_vCard_CLASS_els(_els, + decode_vcard_vCard_CLASS_PRIVATE(_el)); + _ -> decode_vcard_vCard_CLASS_els(_els, Value) + end; +decode_vcard_vCard_CLASS_els([{xmlel, <<"PUBLIC">>, + _attrs, _} = + _el + | _els], + Value) -> + case xml:get_attr_s(<<"xmlns">>, _attrs) of + <<>> -> + decode_vcard_vCard_CLASS_els(_els, + decode_vcard_vCard_CLASS_PUBLIC(_el)); + _ -> decode_vcard_vCard_CLASS_els(_els, Value) + end; +decode_vcard_vCard_CLASS_els([_ | _els], Value) -> + decode_vcard_vCard_CLASS_els(_els, Value); +decode_vcard_vCard_CLASS_els([], Value) -> Value. + +'encode_vcard_vCard_CLASS_$value'(undefined, _acc) -> + _acc; +'encode_vcard_vCard_CLASS_$value'(confidential = _r, + _acc) -> + encode_vcard_vCard_CLASS_CONFIDENTIAL(_r, _acc); +'encode_vcard_vCard_CLASS_$value'(private = _r, _acc) -> + encode_vcard_vCard_CLASS_PRIVATE(_r, _acc); +'encode_vcard_vCard_CLASS_$value'(public = _r, _acc) -> + encode_vcard_vCard_CLASS_PUBLIC(_r, _acc). + +encode_vcard_vCard_CLASS(undefined, _acc) -> _acc; +encode_vcard_vCard_CLASS(Value, _acc) -> + _els = 'encode_vcard_vCard_CLASS_$value'(Value, []), + _attrs = [], + [{xmlel, <<"CLASS">>, _attrs, _els} | _acc]. + +decode_vcard_vCard_CLASS_CONFIDENTIAL({xmlel, _, _attrs, + _els}) -> + confidential. + +encode_vcard_vCard_CLASS_CONFIDENTIAL(undefined, + _acc) -> + _acc; +encode_vcard_vCard_CLASS_CONFIDENTIAL(confidential, + _acc) -> + _els = [], + _attrs = [], + [{xmlel, <<"CONFIDENTIAL">>, _attrs, _els} | _acc]. + +decode_vcard_vCard_CLASS_PRIVATE({xmlel, _, _attrs, + _els}) -> + private. + +encode_vcard_vCard_CLASS_PRIVATE(undefined, _acc) -> + _acc; +encode_vcard_vCard_CLASS_PRIVATE(private, _acc) -> + _els = [], + _attrs = [], + [{xmlel, <<"PRIVATE">>, _attrs, _els} | _acc]. + +decode_vcard_vCard_CLASS_PUBLIC({xmlel, _, _attrs, + _els}) -> + public. + +encode_vcard_vCard_CLASS_PUBLIC(undefined, _acc) -> + _acc; +encode_vcard_vCard_CLASS_PUBLIC(public, _acc) -> + _els = [], + _attrs = [], + [{xmlel, <<"PUBLIC">>, _attrs, _els} | _acc]. + +decode_vcard_vCard_URL({xmlel, _, _attrs, _els}) -> + Cdata = decode_vcard_vCard_URL_els(_els, <<>>), Cdata. + +decode_vcard_vCard_URL_els([{xmlcdata, _data} | _els], + Cdata) -> + decode_vcard_vCard_URL_els(_els, + <<Cdata/binary, _data/binary>>); +decode_vcard_vCard_URL_els([_ | _els], Cdata) -> + decode_vcard_vCard_URL_els(_els, Cdata); +decode_vcard_vCard_URL_els([], Cdata) -> + decode_vcard_vCard_URL_cdata(Cdata). + +encode_vcard_vCard_URL(undefined, _acc) -> _acc; +encode_vcard_vCard_URL(Cdata, _acc) -> + _els = encode_vcard_vCard_URL_cdata(Cdata, []), + _attrs = [], + [{xmlel, <<"URL">>, _attrs, _els} | _acc]. + +decode_vcard_vCard_URL_cdata(<<>>) -> undefined; +decode_vcard_vCard_URL_cdata(_val) -> _val. + +encode_vcard_vCard_URL_cdata(undefined, _acc) -> _acc; +encode_vcard_vCard_URL_cdata(_val, _acc) -> + [{xmlcdata, _val} | _acc]. + +decode_vcard_vCard_UID({xmlel, _, _attrs, _els}) -> + Cdata = decode_vcard_vCard_UID_els(_els, <<>>), Cdata. + +decode_vcard_vCard_UID_els([{xmlcdata, _data} | _els], + Cdata) -> + decode_vcard_vCard_UID_els(_els, + <<Cdata/binary, _data/binary>>); +decode_vcard_vCard_UID_els([_ | _els], Cdata) -> + decode_vcard_vCard_UID_els(_els, Cdata); +decode_vcard_vCard_UID_els([], Cdata) -> + decode_vcard_vCard_UID_cdata(Cdata). + +encode_vcard_vCard_UID(undefined, _acc) -> _acc; +encode_vcard_vCard_UID(Cdata, _acc) -> + _els = encode_vcard_vCard_UID_cdata(Cdata, []), + _attrs = [], + [{xmlel, <<"UID">>, _attrs, _els} | _acc]. + +decode_vcard_vCard_UID_cdata(<<>>) -> undefined; +decode_vcard_vCard_UID_cdata(_val) -> _val. + +encode_vcard_vCard_UID_cdata(undefined, _acc) -> _acc; +encode_vcard_vCard_UID_cdata(_val, _acc) -> + [{xmlcdata, _val} | _acc]. + +'decode_vcard_vCard_SORT-STRING'({xmlel, _, _attrs, + _els}) -> + Cdata = 'decode_vcard_vCard_SORT-STRING_els'(_els, + <<>>), + Cdata. + +'decode_vcard_vCard_SORT-STRING_els'([{xmlcdata, _data} + | _els], + Cdata) -> + 'decode_vcard_vCard_SORT-STRING_els'(_els, + <<Cdata/binary, _data/binary>>); +'decode_vcard_vCard_SORT-STRING_els'([_ | _els], + Cdata) -> + 'decode_vcard_vCard_SORT-STRING_els'(_els, Cdata); +'decode_vcard_vCard_SORT-STRING_els'([], Cdata) -> + 'decode_vcard_vCard_SORT-STRING_cdata'(Cdata). + +'encode_vcard_vCard_SORT-STRING'(undefined, _acc) -> + _acc; +'encode_vcard_vCard_SORT-STRING'(Cdata, _acc) -> + _els = 'encode_vcard_vCard_SORT-STRING_cdata'(Cdata, + []), + _attrs = [], + [{xmlel, <<"SORT-STRING">>, _attrs, _els} | _acc]. + +'decode_vcard_vCard_SORT-STRING_cdata'(<<>>) -> + undefined; +'decode_vcard_vCard_SORT-STRING_cdata'(_val) -> _val. + +'encode_vcard_vCard_SORT-STRING_cdata'(undefined, + _acc) -> + _acc; +'encode_vcard_vCard_SORT-STRING_cdata'(_val, _acc) -> + [{xmlcdata, _val} | _acc]. + +decode_vcard_vCard_REV({xmlel, _, _attrs, _els}) -> + Cdata = decode_vcard_vCard_REV_els(_els, <<>>), Cdata. + +decode_vcard_vCard_REV_els([{xmlcdata, _data} | _els], + Cdata) -> + decode_vcard_vCard_REV_els(_els, + <<Cdata/binary, _data/binary>>); +decode_vcard_vCard_REV_els([_ | _els], Cdata) -> + decode_vcard_vCard_REV_els(_els, Cdata); +decode_vcard_vCard_REV_els([], Cdata) -> + decode_vcard_vCard_REV_cdata(Cdata). + +encode_vcard_vCard_REV(undefined, _acc) -> _acc; +encode_vcard_vCard_REV(Cdata, _acc) -> + _els = encode_vcard_vCard_REV_cdata(Cdata, []), + _attrs = [], + [{xmlel, <<"REV">>, _attrs, _els} | _acc]. + +decode_vcard_vCard_REV_cdata(<<>>) -> undefined; +decode_vcard_vCard_REV_cdata(_val) -> _val. + +encode_vcard_vCard_REV_cdata(undefined, _acc) -> _acc; +encode_vcard_vCard_REV_cdata(_val, _acc) -> + [{xmlcdata, _val} | _acc]. + +decode_vcard_vCard_PRODID({xmlel, _, _attrs, _els}) -> + Cdata = decode_vcard_vCard_PRODID_els(_els, <<>>), + Cdata. + +decode_vcard_vCard_PRODID_els([{xmlcdata, _data} + | _els], + Cdata) -> + decode_vcard_vCard_PRODID_els(_els, + <<Cdata/binary, _data/binary>>); +decode_vcard_vCard_PRODID_els([_ | _els], Cdata) -> + decode_vcard_vCard_PRODID_els(_els, Cdata); +decode_vcard_vCard_PRODID_els([], Cdata) -> + decode_vcard_vCard_PRODID_cdata(Cdata). + +encode_vcard_vCard_PRODID(undefined, _acc) -> _acc; +encode_vcard_vCard_PRODID(Cdata, _acc) -> + _els = encode_vcard_vCard_PRODID_cdata(Cdata, []), + _attrs = [], + [{xmlel, <<"PRODID">>, _attrs, _els} | _acc]. + +decode_vcard_vCard_PRODID_cdata(<<>>) -> undefined; +decode_vcard_vCard_PRODID_cdata(_val) -> _val. + +encode_vcard_vCard_PRODID_cdata(undefined, _acc) -> + _acc; +encode_vcard_vCard_PRODID_cdata(_val, _acc) -> + [{xmlcdata, _val} | _acc]. + +decode_vcard_vCard_NOTE({xmlel, _, _attrs, _els}) -> + Cdata = decode_vcard_vCard_NOTE_els(_els, <<>>), Cdata. + +decode_vcard_vCard_NOTE_els([{xmlcdata, _data} | _els], + Cdata) -> + decode_vcard_vCard_NOTE_els(_els, + <<Cdata/binary, _data/binary>>); +decode_vcard_vCard_NOTE_els([_ | _els], Cdata) -> + decode_vcard_vCard_NOTE_els(_els, Cdata); +decode_vcard_vCard_NOTE_els([], Cdata) -> + decode_vcard_vCard_NOTE_cdata(Cdata). + +encode_vcard_vCard_NOTE(undefined, _acc) -> _acc; +encode_vcard_vCard_NOTE(Cdata, _acc) -> + _els = encode_vcard_vCard_NOTE_cdata(Cdata, []), + _attrs = [], + [{xmlel, <<"NOTE">>, _attrs, _els} | _acc]. + +decode_vcard_vCard_NOTE_cdata(<<>>) -> undefined; +decode_vcard_vCard_NOTE_cdata(_val) -> _val. + +encode_vcard_vCard_NOTE_cdata(undefined, _acc) -> _acc; +encode_vcard_vCard_NOTE_cdata(_val, _acc) -> + [{xmlcdata, _val} | _acc]. + +decode_vcard_vCard_CATEGORIES({xmlel, _, _attrs, + _els}) -> + Keywords = decode_vcard_vCard_CATEGORIES_els(_els, []), + Keywords. + +decode_vcard_vCard_CATEGORIES_els([{xmlel, + <<"KEYWORD">>, _attrs, _} = + _el + | _els], + Keywords) -> + case xml:get_attr_s(<<"xmlns">>, _attrs) of + <<>> -> + decode_vcard_vCard_CATEGORIES_els(_els, + [decode_vcard_vCard_CATEGORIES_KEYWORD(_el) + | Keywords]); + _ -> decode_vcard_vCard_CATEGORIES_els(_els, Keywords) + end; +decode_vcard_vCard_CATEGORIES_els([_ | _els], + Keywords) -> + decode_vcard_vCard_CATEGORIES_els(_els, Keywords); +decode_vcard_vCard_CATEGORIES_els([], Keywords) -> + lists:reverse(Keywords). + +encode_vcard_vCard_CATEGORIES([], _acc) -> _acc; +encode_vcard_vCard_CATEGORIES(Keywords, _acc) -> + _els = encode_vcard_vCard_CATEGORIES_KEYWORD(Keywords, + []), + _attrs = [], + [{xmlel, <<"CATEGORIES">>, _attrs, _els} | _acc]. + +decode_vcard_vCard_CATEGORIES_KEYWORD({xmlel, _, _attrs, + _els}) -> + Cdata = decode_vcard_vCard_CATEGORIES_KEYWORD_els(_els, + <<>>), + Cdata. + +decode_vcard_vCard_CATEGORIES_KEYWORD_els([{xmlcdata, + _data} + | _els], + Cdata) -> + decode_vcard_vCard_CATEGORIES_KEYWORD_els(_els, + <<Cdata/binary, _data/binary>>); +decode_vcard_vCard_CATEGORIES_KEYWORD_els([_ | _els], + Cdata) -> + decode_vcard_vCard_CATEGORIES_KEYWORD_els(_els, Cdata); +decode_vcard_vCard_CATEGORIES_KEYWORD_els([], Cdata) -> + decode_vcard_vCard_CATEGORIES_KEYWORD_cdata(Cdata). + +encode_vcard_vCard_CATEGORIES_KEYWORD([], _acc) -> _acc; +encode_vcard_vCard_CATEGORIES_KEYWORD([Cdata | _tail], + _acc) -> + _els = + encode_vcard_vCard_CATEGORIES_KEYWORD_cdata(Cdata, []), + _attrs = [], + encode_vcard_vCard_CATEGORIES_KEYWORD(_tail, + [{xmlel, <<"KEYWORD">>, _attrs, _els} + | _acc]). + +decode_vcard_vCard_CATEGORIES_KEYWORD_cdata(<<>>) -> + undefined; +decode_vcard_vCard_CATEGORIES_KEYWORD_cdata(_val) -> + _val. + +encode_vcard_vCard_CATEGORIES_KEYWORD_cdata(undefined, + _acc) -> + _acc; +encode_vcard_vCard_CATEGORIES_KEYWORD_cdata(_val, + _acc) -> + [{xmlcdata, _val} | _acc]. + +decode_vcard_vCard_ROLE({xmlel, _, _attrs, _els}) -> + Cdata = decode_vcard_vCard_ROLE_els(_els, <<>>), Cdata. + +decode_vcard_vCard_ROLE_els([{xmlcdata, _data} | _els], + Cdata) -> + decode_vcard_vCard_ROLE_els(_els, + <<Cdata/binary, _data/binary>>); +decode_vcard_vCard_ROLE_els([_ | _els], Cdata) -> + decode_vcard_vCard_ROLE_els(_els, Cdata); +decode_vcard_vCard_ROLE_els([], Cdata) -> + decode_vcard_vCard_ROLE_cdata(Cdata). + +encode_vcard_vCard_ROLE(undefined, _acc) -> _acc; +encode_vcard_vCard_ROLE(Cdata, _acc) -> + _els = encode_vcard_vCard_ROLE_cdata(Cdata, []), + _attrs = [], + [{xmlel, <<"ROLE">>, _attrs, _els} | _acc]. + +decode_vcard_vCard_ROLE_cdata(<<>>) -> undefined; +decode_vcard_vCard_ROLE_cdata(_val) -> _val. + +encode_vcard_vCard_ROLE_cdata(undefined, _acc) -> _acc; +encode_vcard_vCard_ROLE_cdata(_val, _acc) -> + [{xmlcdata, _val} | _acc]. + +decode_vcard_vCard_TITLE({xmlel, _, _attrs, _els}) -> + Cdata = decode_vcard_vCard_TITLE_els(_els, <<>>), Cdata. + +decode_vcard_vCard_TITLE_els([{xmlcdata, _data} | _els], + Cdata) -> + decode_vcard_vCard_TITLE_els(_els, + <<Cdata/binary, _data/binary>>); +decode_vcard_vCard_TITLE_els([_ | _els], Cdata) -> + decode_vcard_vCard_TITLE_els(_els, Cdata); +decode_vcard_vCard_TITLE_els([], Cdata) -> + decode_vcard_vCard_TITLE_cdata(Cdata). + +encode_vcard_vCard_TITLE(undefined, _acc) -> _acc; +encode_vcard_vCard_TITLE(Cdata, _acc) -> + _els = encode_vcard_vCard_TITLE_cdata(Cdata, []), + _attrs = [], + [{xmlel, <<"TITLE">>, _attrs, _els} | _acc]. + +decode_vcard_vCard_TITLE_cdata(<<>>) -> undefined; +decode_vcard_vCard_TITLE_cdata(_val) -> _val. + +encode_vcard_vCard_TITLE_cdata(undefined, _acc) -> _acc; +encode_vcard_vCard_TITLE_cdata(_val, _acc) -> + [{xmlcdata, _val} | _acc]. + +decode_vcard_vCard_TZ({xmlel, _, _attrs, _els}) -> + Cdata = decode_vcard_vCard_TZ_els(_els, <<>>), Cdata. + +decode_vcard_vCard_TZ_els([{xmlcdata, _data} | _els], + Cdata) -> + decode_vcard_vCard_TZ_els(_els, + <<Cdata/binary, _data/binary>>); +decode_vcard_vCard_TZ_els([_ | _els], Cdata) -> + decode_vcard_vCard_TZ_els(_els, Cdata); +decode_vcard_vCard_TZ_els([], Cdata) -> + decode_vcard_vCard_TZ_cdata(Cdata). + +encode_vcard_vCard_TZ(undefined, _acc) -> _acc; +encode_vcard_vCard_TZ(Cdata, _acc) -> + _els = encode_vcard_vCard_TZ_cdata(Cdata, []), + _attrs = [], + [{xmlel, <<"TZ">>, _attrs, _els} | _acc]. + +decode_vcard_vCard_TZ_cdata(<<>>) -> undefined; +decode_vcard_vCard_TZ_cdata(_val) -> _val. + +encode_vcard_vCard_TZ_cdata(undefined, _acc) -> _acc; +encode_vcard_vCard_TZ_cdata(_val, _acc) -> + [{xmlcdata, _val} | _acc]. + +decode_vcard_vCard_MAILER({xmlel, _, _attrs, _els}) -> + Cdata = decode_vcard_vCard_MAILER_els(_els, <<>>), + Cdata. + +decode_vcard_vCard_MAILER_els([{xmlcdata, _data} + | _els], + Cdata) -> + decode_vcard_vCard_MAILER_els(_els, + <<Cdata/binary, _data/binary>>); +decode_vcard_vCard_MAILER_els([_ | _els], Cdata) -> + decode_vcard_vCard_MAILER_els(_els, Cdata); +decode_vcard_vCard_MAILER_els([], Cdata) -> + decode_vcard_vCard_MAILER_cdata(Cdata). + +encode_vcard_vCard_MAILER(undefined, _acc) -> _acc; +encode_vcard_vCard_MAILER(Cdata, _acc) -> + _els = encode_vcard_vCard_MAILER_cdata(Cdata, []), + _attrs = [], + [{xmlel, <<"MAILER">>, _attrs, _els} | _acc]. + +decode_vcard_vCard_MAILER_cdata(<<>>) -> undefined; +decode_vcard_vCard_MAILER_cdata(_val) -> _val. + +encode_vcard_vCard_MAILER_cdata(undefined, _acc) -> + _acc; +encode_vcard_vCard_MAILER_cdata(_val, _acc) -> + [{xmlcdata, _val} | _acc]. + +decode_vcard_vCard_JABBERID({xmlel, _, _attrs, _els}) -> + Cdata = decode_vcard_vCard_JABBERID_els(_els, <<>>), + Cdata. + +decode_vcard_vCard_JABBERID_els([{xmlcdata, _data} + | _els], + Cdata) -> + decode_vcard_vCard_JABBERID_els(_els, + <<Cdata/binary, _data/binary>>); +decode_vcard_vCard_JABBERID_els([_ | _els], Cdata) -> + decode_vcard_vCard_JABBERID_els(_els, Cdata); +decode_vcard_vCard_JABBERID_els([], Cdata) -> + decode_vcard_vCard_JABBERID_cdata(Cdata). + +encode_vcard_vCard_JABBERID(undefined, _acc) -> _acc; +encode_vcard_vCard_JABBERID(Cdata, _acc) -> + _els = encode_vcard_vCard_JABBERID_cdata(Cdata, []), + _attrs = [], + [{xmlel, <<"JABBERID">>, _attrs, _els} | _acc]. + +decode_vcard_vCard_JABBERID_cdata(<<>>) -> undefined; +decode_vcard_vCard_JABBERID_cdata(_val) -> _val. + +encode_vcard_vCard_JABBERID_cdata(undefined, _acc) -> + _acc; +encode_vcard_vCard_JABBERID_cdata(_val, _acc) -> + [{xmlcdata, _val} | _acc]. + +decode_vcard_vCard_BDAY({xmlel, _, _attrs, _els}) -> + Cdata = decode_vcard_vCard_BDAY_els(_els, <<>>), Cdata. + +decode_vcard_vCard_BDAY_els([{xmlcdata, _data} | _els], + Cdata) -> + decode_vcard_vCard_BDAY_els(_els, + <<Cdata/binary, _data/binary>>); +decode_vcard_vCard_BDAY_els([_ | _els], Cdata) -> + decode_vcard_vCard_BDAY_els(_els, Cdata); +decode_vcard_vCard_BDAY_els([], Cdata) -> + decode_vcard_vCard_BDAY_cdata(Cdata). + +encode_vcard_vCard_BDAY(undefined, _acc) -> _acc; +encode_vcard_vCard_BDAY(Cdata, _acc) -> + _els = encode_vcard_vCard_BDAY_cdata(Cdata, []), + _attrs = [], + [{xmlel, <<"BDAY">>, _attrs, _els} | _acc]. + +decode_vcard_vCard_BDAY_cdata(<<>>) -> undefined; +decode_vcard_vCard_BDAY_cdata(_val) -> _val. + +encode_vcard_vCard_BDAY_cdata(undefined, _acc) -> _acc; +encode_vcard_vCard_BDAY_cdata(_val, _acc) -> + [{xmlcdata, _val} | _acc]. + +decode_vcard_vCard_NICKNAME({xmlel, _, _attrs, _els}) -> + Cdata = decode_vcard_vCard_NICKNAME_els(_els, <<>>), + Cdata. + +decode_vcard_vCard_NICKNAME_els([{xmlcdata, _data} + | _els], + Cdata) -> + decode_vcard_vCard_NICKNAME_els(_els, + <<Cdata/binary, _data/binary>>); +decode_vcard_vCard_NICKNAME_els([_ | _els], Cdata) -> + decode_vcard_vCard_NICKNAME_els(_els, Cdata); +decode_vcard_vCard_NICKNAME_els([], Cdata) -> + decode_vcard_vCard_NICKNAME_cdata(Cdata). + +encode_vcard_vCard_NICKNAME(undefined, _acc) -> _acc; +encode_vcard_vCard_NICKNAME(Cdata, _acc) -> + _els = encode_vcard_vCard_NICKNAME_cdata(Cdata, []), + _attrs = [], + [{xmlel, <<"NICKNAME">>, _attrs, _els} | _acc]. + +decode_vcard_vCard_NICKNAME_cdata(<<>>) -> undefined; +decode_vcard_vCard_NICKNAME_cdata(_val) -> _val. + +encode_vcard_vCard_NICKNAME_cdata(undefined, _acc) -> + _acc; +encode_vcard_vCard_NICKNAME_cdata(_val, _acc) -> + [{xmlcdata, _val} | _acc]. + +decode_vcard_vCard_FN({xmlel, _, _attrs, _els}) -> + Cdata = decode_vcard_vCard_FN_els(_els, <<>>), Cdata. + +decode_vcard_vCard_FN_els([{xmlcdata, _data} | _els], + Cdata) -> + decode_vcard_vCard_FN_els(_els, + <<Cdata/binary, _data/binary>>); +decode_vcard_vCard_FN_els([_ | _els], Cdata) -> + decode_vcard_vCard_FN_els(_els, Cdata); +decode_vcard_vCard_FN_els([], Cdata) -> + decode_vcard_vCard_FN_cdata(Cdata). + +encode_vcard_vCard_FN(undefined, _acc) -> _acc; +encode_vcard_vCard_FN(Cdata, _acc) -> + _els = encode_vcard_vCard_FN_cdata(Cdata, []), + _attrs = [], + [{xmlel, <<"FN">>, _attrs, _els} | _acc]. + +decode_vcard_vCard_FN_cdata(<<>>) -> undefined; +decode_vcard_vCard_FN_cdata(_val) -> _val. + +encode_vcard_vCard_FN_cdata(undefined, _acc) -> _acc; +encode_vcard_vCard_FN_cdata(_val, _acc) -> + [{xmlcdata, _val} | _acc]. + +decode_vcard_vCard_VERSION({xmlel, _, _attrs, _els}) -> + Cdata = decode_vcard_vCard_VERSION_els(_els, <<>>), + Cdata. + +decode_vcard_vCard_VERSION_els([{xmlcdata, _data} + | _els], + Cdata) -> + decode_vcard_vCard_VERSION_els(_els, + <<Cdata/binary, _data/binary>>); +decode_vcard_vCard_VERSION_els([_ | _els], Cdata) -> + decode_vcard_vCard_VERSION_els(_els, Cdata); +decode_vcard_vCard_VERSION_els([], Cdata) -> + decode_vcard_vCard_VERSION_cdata(Cdata). + +encode_vcard_vCard_VERSION(undefined, _acc) -> _acc; +encode_vcard_vCard_VERSION(Cdata, _acc) -> + _els = encode_vcard_vCard_VERSION_cdata(Cdata, []), + _attrs = [], + [{xmlel, <<"VERSION">>, _attrs, _els} | _acc]. + +decode_vcard_vCard_VERSION_cdata(<<>>) -> undefined; +decode_vcard_vCard_VERSION_cdata(_val) -> _val. + +encode_vcard_vCard_VERSION_cdata(undefined, _acc) -> + _acc; +encode_vcard_vCard_VERSION_cdata(_val, _acc) -> + [{xmlcdata, _val} | _acc]. + +decode_xfield_field({xmlel, _, _attrs, _els}) -> + {Var, Type, Label} = decode_xfield_field_attrs(_attrs, + undefined, undefined, + undefined), + {Options, Values, Desc, Required} = + decode_xfield_field_els(_els, [], [], undefined, false), + {xfield, Label, Type, Var, Required, Desc, Values, + Options}. + +decode_xfield_field_els([{xmlel, <<"option">>, _attrs, + _} = + _el + | _els], + Options, Values, Desc, Required) -> + case xml:get_attr_s(<<"xmlns">>, _attrs) of + <<>> -> + decode_xfield_field_els(_els, + [decode_xfield_field_option(_el) | Options], + Values, Desc, Required); + _ -> + decode_xfield_field_els(_els, Options, Values, Desc, + Required) + end; +decode_xfield_field_els([{xmlel, <<"value">>, _attrs, + _} = + _el + | _els], + Options, Values, Desc, Required) -> + case xml:get_attr_s(<<"xmlns">>, _attrs) of + <<>> -> + decode_xfield_field_els(_els, Options, + [decode_xfield_field_value(_el) | Values], + Desc, Required); + _ -> + decode_xfield_field_els(_els, Options, Values, Desc, + Required) + end; +decode_xfield_field_els([{xmlel, <<"desc">>, _attrs, + _} = + _el + | _els], + Options, Values, Desc, Required) -> + case xml:get_attr_s(<<"xmlns">>, _attrs) of + <<>> -> + decode_xfield_field_els(_els, Options, Values, + decode_xfield_field_desc(_el), Required); + _ -> + decode_xfield_field_els(_els, Options, Values, Desc, + Required) + end; +decode_xfield_field_els([{xmlel, <<"required">>, _attrs, + _} = + _el + | _els], + Options, Values, Desc, Required) -> + case xml:get_attr_s(<<"xmlns">>, _attrs) of + <<>> -> + decode_xfield_field_els(_els, Options, Values, Desc, + decode_xfield_field_required(_el)); + _ -> + decode_xfield_field_els(_els, Options, Values, Desc, + Required) + end; +decode_xfield_field_els([_ | _els], Options, Values, + Desc, Required) -> + decode_xfield_field_els(_els, Options, Values, Desc, + Required); +decode_xfield_field_els([], Options, Values, Desc, + Required) -> + {lists:reverse(Options), lists:reverse(Values), Desc, + Required}. + +decode_xfield_field_attrs([{<<"var">>, _val} | _attrs], + _Var, Type, Label) -> + decode_xfield_field_attrs(_attrs, _val, Type, Label); +decode_xfield_field_attrs([{<<"type">>, _val} | _attrs], + Var, _Type, Label) -> + decode_xfield_field_attrs(_attrs, Var, _val, Label); +decode_xfield_field_attrs([{<<"label">>, _val} + | _attrs], + Var, Type, _Label) -> + decode_xfield_field_attrs(_attrs, Var, Type, _val); +decode_xfield_field_attrs([_ | _attrs], Var, Type, + Label) -> + decode_xfield_field_attrs(_attrs, Var, Type, Label); +decode_xfield_field_attrs([], Var, Type, Label) -> + {decode_xfield_field_var(Var), + decode_xfield_field_type(Type), + decode_xfield_field_label(Label)}. + +encode_xfield_field([], _acc) -> _acc; +encode_xfield_field([{xfield, Label, Type, Var, + Required, Desc, Values, Options} + | _tail], + _acc) -> + _els = encode_xfield_field_required(Required, + encode_xfield_field_desc(Desc, + encode_xfield_field_value(Values, + encode_xfield_field_option(Options, + [])))), + _attrs = encode_xfield_field_label(Label, + encode_xfield_field_type(Type, + encode_xfield_field_var(Var, + []))), + encode_xfield_field(_tail, + [{xmlel, <<"field">>, _attrs, _els} | _acc]). + +decode_xfield_field_label(undefined) -> undefined; +decode_xfield_field_label(_val) -> _val. + +encode_xfield_field_label(undefined, _acc) -> _acc; +encode_xfield_field_label(_val, _acc) -> + [{<<"label">>, _val} | _acc]. + +decode_xfield_field_type(undefined) -> undefined; +decode_xfield_field_type(_val) -> + case catch xml_gen:dec_enum(_val, + [boolean, fixed, hidden, 'jid-multi', + 'jid-single', 'list-multi', 'list-single', + 'text-multi', 'text-private', 'text-single']) + of + {'EXIT', _} -> + erlang:error({bad_attr_value, <<"type">>, <<"field">>, + <<>>}); + _res -> _res + end. + +encode_xfield_field_type(undefined, _acc) -> _acc; +encode_xfield_field_type(_val, _acc) -> + [{<<"type">>, xml_gen:enc_enum(_val)} | _acc]. + +decode_xfield_field_var(undefined) -> undefined; +decode_xfield_field_var(_val) -> _val. + +encode_xfield_field_var(undefined, _acc) -> _acc; +encode_xfield_field_var(_val, _acc) -> + [{<<"var">>, _val} | _acc]. + +decode_xfield_field_option({xmlel, _, _attrs, _els}) -> + Value = decode_xfield_field_option_els(_els, []), Value. + +decode_xfield_field_option_els([{xmlel, <<"value">>, + _attrs, _} = + _el + | _els], + Value) -> + case xml:get_attr_s(<<"xmlns">>, _attrs) of + <<>> -> + decode_xfield_field_option_els(_els, + [decode_xfield_field_option_value(_el) + | Value]); + _ -> decode_xfield_field_option_els(_els, Value) + end; +decode_xfield_field_option_els([_ | _els], Value) -> + decode_xfield_field_option_els(_els, Value); +decode_xfield_field_option_els([], [Value]) -> Value. + +encode_xfield_field_option([], _acc) -> _acc; +encode_xfield_field_option([Value | _tail], _acc) -> + _els = encode_xfield_field_option_value(Value, []), + _attrs = [], + encode_xfield_field_option(_tail, + [{xmlel, <<"option">>, _attrs, _els} | _acc]). + +decode_xfield_field_option_value({xmlel, _, _attrs, + _els}) -> + Cdata = decode_xfield_field_option_value_els(_els, + <<>>), + Cdata. + +decode_xfield_field_option_value_els([{xmlcdata, _data} + | _els], + Cdata) -> + decode_xfield_field_option_value_els(_els, + <<Cdata/binary, _data/binary>>); +decode_xfield_field_option_value_els([_ | _els], + Cdata) -> + decode_xfield_field_option_value_els(_els, Cdata); +decode_xfield_field_option_value_els([], Cdata) -> + decode_xfield_field_option_value_cdata(Cdata). + +encode_xfield_field_option_value(Cdata, _acc) -> + _els = encode_xfield_field_option_value_cdata(Cdata, + []), + _attrs = [], + [{xmlel, <<"value">>, _attrs, _els} | _acc]. + +decode_xfield_field_option_value_cdata(<<>>) -> + undefined; +decode_xfield_field_option_value_cdata(_val) -> _val. + +encode_xfield_field_option_value_cdata(undefined, + _acc) -> + _acc; +encode_xfield_field_option_value_cdata(_val, _acc) -> + [{xmlcdata, _val} | _acc]. + +decode_xfield_field_value({xmlel, _, _attrs, _els}) -> + Cdata = decode_xfield_field_value_els(_els, <<>>), + Cdata. + +decode_xfield_field_value_els([{xmlcdata, _data} + | _els], + Cdata) -> + decode_xfield_field_value_els(_els, + <<Cdata/binary, _data/binary>>); +decode_xfield_field_value_els([_ | _els], Cdata) -> + decode_xfield_field_value_els(_els, Cdata); +decode_xfield_field_value_els([], Cdata) -> + decode_xfield_field_value_cdata(Cdata). + +encode_xfield_field_value([], _acc) -> _acc; +encode_xfield_field_value([Cdata | _tail], _acc) -> + _els = encode_xfield_field_value_cdata(Cdata, []), + _attrs = [], + encode_xfield_field_value(_tail, + [{xmlel, <<"value">>, _attrs, _els} | _acc]). + +decode_xfield_field_value_cdata(<<>>) -> undefined; +decode_xfield_field_value_cdata(_val) -> _val. + +encode_xfield_field_value_cdata(undefined, _acc) -> + _acc; +encode_xfield_field_value_cdata(_val, _acc) -> + [{xmlcdata, _val} | _acc]. + +decode_xfield_field_desc({xmlel, _, _attrs, _els}) -> + Cdata = decode_xfield_field_desc_els(_els, <<>>), Cdata. + +decode_xfield_field_desc_els([{xmlcdata, _data} | _els], + Cdata) -> + decode_xfield_field_desc_els(_els, + <<Cdata/binary, _data/binary>>); +decode_xfield_field_desc_els([_ | _els], Cdata) -> + decode_xfield_field_desc_els(_els, Cdata); +decode_xfield_field_desc_els([], Cdata) -> + decode_xfield_field_desc_cdata(Cdata). + +encode_xfield_field_desc(undefined, _acc) -> _acc; +encode_xfield_field_desc(Cdata, _acc) -> + _els = encode_xfield_field_desc_cdata(Cdata, []), + _attrs = [], + [{xmlel, <<"desc">>, _attrs, _els} | _acc]. + +decode_xfield_field_desc_cdata(<<>>) -> undefined; +decode_xfield_field_desc_cdata(_val) -> _val. + +encode_xfield_field_desc_cdata(undefined, _acc) -> _acc; +encode_xfield_field_desc_cdata(_val, _acc) -> + [{xmlcdata, _val} | _acc]. + +decode_xfield_field_required({xmlel, _, _attrs, + _els}) -> + true. + +encode_xfield_field_required(false, _acc) -> _acc; +encode_xfield_field_required(true, _acc) -> + _els = [], + _attrs = [], + [{xmlel, <<"required">>, _attrs, _els} | _acc]. + +decode_xdata_x({xmlel, _, _attrs, _els}) -> + Type = decode_xdata_x_attrs(_attrs, undefined), + {Fields, Items, Reported, Title, Instructions} = + decode_xdata_x_els(_els, [], [], undefined, undefined, + []), + {xdata, Type, Instructions, Title, Reported, Items, + Fields}. + +decode_xdata_x_els([{xmlel, <<"field">>, _attrs, _} = + _el + | _els], + Fields, Items, Reported, Title, Instructions) -> + case xml:get_attr_s(<<"xmlns">>, _attrs) of + <<>> -> + decode_xdata_x_els(_els, + [decode_xfield_field(_el) | Fields], Items, + Reported, Title, Instructions); + _ -> + decode_xdata_x_els(_els, Fields, Items, Reported, Title, + Instructions) + end; +decode_xdata_x_els([{xmlel, <<"item">>, _attrs, _} = _el + | _els], + Fields, Items, Reported, Title, Instructions) -> + case xml:get_attr_s(<<"xmlns">>, _attrs) of + <<>> -> + decode_xdata_x_els(_els, Fields, + [decode_xdata_x_item(_el) | Items], Reported, + Title, Instructions); + _ -> + decode_xdata_x_els(_els, Fields, Items, Reported, Title, + Instructions) + end; +decode_xdata_x_els([{xmlel, <<"reported">>, _attrs, _} = + _el + | _els], + Fields, Items, Reported, Title, Instructions) -> + case xml:get_attr_s(<<"xmlns">>, _attrs) of + <<>> -> + decode_xdata_x_els(_els, Fields, Items, + decode_xdata_x_reported(_el), Title, Instructions); + _ -> + decode_xdata_x_els(_els, Fields, Items, Reported, Title, + Instructions) + end; +decode_xdata_x_els([{xmlel, <<"title">>, _attrs, _} = + _el + | _els], + Fields, Items, Reported, Title, Instructions) -> + case xml:get_attr_s(<<"xmlns">>, _attrs) of + <<>> -> + decode_xdata_x_els(_els, Fields, Items, Reported, + decode_xdata_x_title(_el), Instructions); + _ -> + decode_xdata_x_els(_els, Fields, Items, Reported, Title, + Instructions) + end; +decode_xdata_x_els([{xmlel, <<"instructions">>, _attrs, + _} = + _el + | _els], + Fields, Items, Reported, Title, Instructions) -> + case xml:get_attr_s(<<"xmlns">>, _attrs) of + <<>> -> + decode_xdata_x_els(_els, Fields, Items, Reported, Title, + [decode_xdata_x_instructions(_el) | Instructions]); + _ -> + decode_xdata_x_els(_els, Fields, Items, Reported, Title, + Instructions) + end; +decode_xdata_x_els([_ | _els], Fields, Items, Reported, + Title, Instructions) -> + decode_xdata_x_els(_els, Fields, Items, Reported, Title, + Instructions); +decode_xdata_x_els([], Fields, Items, Reported, Title, + Instructions) -> + {lists:reverse(Fields), lists:reverse(Items), Reported, + Title, lists:reverse(Instructions)}. + +decode_xdata_x_attrs([{<<"type">>, _val} | _attrs], + _Type) -> + decode_xdata_x_attrs(_attrs, _val); +decode_xdata_x_attrs([_ | _attrs], Type) -> + decode_xdata_x_attrs(_attrs, Type); +decode_xdata_x_attrs([], Type) -> + decode_xdata_x_type(Type). + +encode_xdata_x([], _acc) -> _acc; +encode_xdata_x([{xdata, Type, Instructions, Title, + Reported, Items, Fields} + | _tail], + _acc) -> + _els = encode_xdata_x_instructions(Instructions, + encode_xdata_x_title(Title, + encode_xdata_x_reported(Reported, + encode_xdata_x_item(Items, + encode_xfield_field(Fields, + []))))), + _attrs = encode_xdata_x_type(Type, + [{<<"xmlns">>, <<"jabber:x:data">>}]), + encode_xdata_x(_tail, + [{xmlel, <<"x">>, _attrs, _els} | _acc]). + +decode_xdata_x_type(undefined) -> + erlang:error({missing_attr, <<"type">>, <<"x">>, + <<"jabber:x:data">>}); +decode_xdata_x_type(_val) -> + case catch xml_gen:dec_enum(_val, + [cancel, form, result, submit]) + of + {'EXIT', _} -> + erlang:error({bad_attr_value, <<"type">>, <<"x">>, + <<"jabber:x:data">>}); + _res -> _res + end. + +encode_xdata_x_type(_val, _acc) -> + [{<<"type">>, xml_gen:enc_enum(_val)} | _acc]. + +decode_xdata_x_item({xmlel, _, _attrs, _els}) -> + Fields = decode_xdata_x_item_els(_els, []), Fields. + +decode_xdata_x_item_els([{xmlel, <<"field">>, _attrs, + _} = + _el + | _els], + Fields) -> + case xml:get_attr_s(<<"xmlns">>, _attrs) of + <<>> -> + decode_xdata_x_item_els(_els, + [decode_xfield_field(_el) | Fields]); + _ -> decode_xdata_x_item_els(_els, Fields) + end; +decode_xdata_x_item_els([_ | _els], Fields) -> + decode_xdata_x_item_els(_els, Fields); +decode_xdata_x_item_els([], Fields) -> + lists:reverse(Fields). + +encode_xdata_x_item([], _acc) -> _acc; +encode_xdata_x_item([Fields | _tail], _acc) -> + _els = encode_xfield_field(Fields, []), + _attrs = [], + encode_xdata_x_item(_tail, + [{xmlel, <<"item">>, _attrs, _els} | _acc]). + +decode_xdata_x_reported({xmlel, _, _attrs, _els}) -> + Fields = decode_xdata_x_reported_els(_els, []), Fields. + +decode_xdata_x_reported_els([{xmlel, <<"field">>, + _attrs, _} = + _el + | _els], + Fields) -> + case xml:get_attr_s(<<"xmlns">>, _attrs) of + <<>> -> + decode_xdata_x_reported_els(_els, + [decode_xfield_field(_el) | Fields]); + _ -> decode_xdata_x_reported_els(_els, Fields) + end; +decode_xdata_x_reported_els([_ | _els], Fields) -> + decode_xdata_x_reported_els(_els, Fields); +decode_xdata_x_reported_els([], Fields) -> + lists:reverse(Fields). + +encode_xdata_x_reported(undefined, _acc) -> _acc; +encode_xdata_x_reported(Fields, _acc) -> + _els = encode_xfield_field(Fields, []), + _attrs = [], + [{xmlel, <<"reported">>, _attrs, _els} | _acc]. + +decode_xdata_x_title({xmlel, _, _attrs, _els}) -> + Cdata = decode_xdata_x_title_els(_els, <<>>), Cdata. + +decode_xdata_x_title_els([{xmlcdata, _data} | _els], + Cdata) -> + decode_xdata_x_title_els(_els, + <<Cdata/binary, _data/binary>>); +decode_xdata_x_title_els([_ | _els], Cdata) -> + decode_xdata_x_title_els(_els, Cdata); +decode_xdata_x_title_els([], Cdata) -> + decode_xdata_x_title_cdata(Cdata). + +encode_xdata_x_title(undefined, _acc) -> _acc; +encode_xdata_x_title(Cdata, _acc) -> + _els = encode_xdata_x_title_cdata(Cdata, []), + _attrs = [], + [{xmlel, <<"title">>, _attrs, _els} | _acc]. + +decode_xdata_x_title_cdata(<<>>) -> undefined; +decode_xdata_x_title_cdata(_val) -> _val. + +encode_xdata_x_title_cdata(undefined, _acc) -> _acc; +encode_xdata_x_title_cdata(_val, _acc) -> + [{xmlcdata, _val} | _acc]. + +decode_xdata_x_instructions({xmlel, _, _attrs, _els}) -> + Cdata = decode_xdata_x_instructions_els(_els, <<>>), + Cdata. + +decode_xdata_x_instructions_els([{xmlcdata, _data} + | _els], + Cdata) -> + decode_xdata_x_instructions_els(_els, + <<Cdata/binary, _data/binary>>); +decode_xdata_x_instructions_els([_ | _els], Cdata) -> + decode_xdata_x_instructions_els(_els, Cdata); +decode_xdata_x_instructions_els([], Cdata) -> + decode_xdata_x_instructions_cdata(Cdata). + +encode_xdata_x_instructions([], _acc) -> _acc; +encode_xdata_x_instructions([Cdata | _tail], _acc) -> + _els = encode_xdata_x_instructions_cdata(Cdata, []), + _attrs = [], + encode_xdata_x_instructions(_tail, + [{xmlel, <<"instructions">>, _attrs, _els} + | _acc]). + +decode_xdata_x_instructions_cdata(<<>>) -> undefined; +decode_xdata_x_instructions_cdata(_val) -> _val. + +encode_xdata_x_instructions_cdata(undefined, _acc) -> + _acc; +encode_xdata_x_instructions_cdata(_val, _acc) -> + [{xmlcdata, _val} | _acc]. + +decode_pubsub_subscription_subscription({xmlel, _, + _attrs, _els}) -> + {Type, Subid, Node, Jid} = + decode_pubsub_subscription_subscription_attrs(_attrs, + undefined, undefined, + undefined, undefined), + {pubsub_subscription, Jid, Node, Subid, Type}. + +decode_pubsub_subscription_subscription_attrs([{<<"subscription">>, + _val} + | _attrs], + _Type, Subid, Node, Jid) -> + decode_pubsub_subscription_subscription_attrs(_attrs, + _val, Subid, Node, Jid); +decode_pubsub_subscription_subscription_attrs([{<<"subid">>, + _val} + | _attrs], + Type, _Subid, Node, Jid) -> + decode_pubsub_subscription_subscription_attrs(_attrs, + Type, _val, Node, Jid); +decode_pubsub_subscription_subscription_attrs([{<<"node">>, + _val} + | _attrs], + Type, Subid, _Node, Jid) -> + decode_pubsub_subscription_subscription_attrs(_attrs, + Type, Subid, _val, Jid); +decode_pubsub_subscription_subscription_attrs([{<<"jid">>, + _val} + | _attrs], + Type, Subid, Node, _Jid) -> + decode_pubsub_subscription_subscription_attrs(_attrs, + Type, Subid, Node, _val); +decode_pubsub_subscription_subscription_attrs([_ + | _attrs], + Type, Subid, Node, Jid) -> + decode_pubsub_subscription_subscription_attrs(_attrs, + Type, Subid, Node, Jid); +decode_pubsub_subscription_subscription_attrs([], Type, + Subid, Node, Jid) -> + {decode_pubsub_subscription_subscription_subscription(Type), + decode_pubsub_subscription_subscription_subid(Subid), + decode_pubsub_subscription_subscription_node(Node), + decode_pubsub_subscription_subscription_jid(Jid)}. + +encode_pubsub_subscription_subscription([], _acc) -> + _acc; +encode_pubsub_subscription_subscription([{pubsub_subscription, + Jid, Node, Subid, Type} + | _tail], + _acc) -> + _els = [], + _attrs = + encode_pubsub_subscription_subscription_jid(Jid, + encode_pubsub_subscription_subscription_node(Node, + encode_pubsub_subscription_subscription_subid(Subid, + encode_pubsub_subscription_subscription_subscription(Type, + [])))), + encode_pubsub_subscription_subscription(_tail, + [{xmlel, <<"subscription">>, _attrs, + _els} + | _acc]). + +decode_pubsub_subscription_subscription_jid(undefined) -> + erlang:error({missing_attr, <<"jid">>, + <<"subscription">>, <<>>}); +decode_pubsub_subscription_subscription_jid(_val) -> + case catch dec_jid(_val) of + {'EXIT', _} -> + erlang:error({bad_attr_value, <<"jid">>, + <<"subscription">>, <<>>}); + _res -> _res + end. + +encode_pubsub_subscription_subscription_jid(_val, + _acc) -> + [{<<"jid">>, enc_jid(_val)} | _acc]. + +decode_pubsub_subscription_subscription_node(undefined) -> + undefined; +decode_pubsub_subscription_subscription_node(_val) -> + _val. + +encode_pubsub_subscription_subscription_node(undefined, + _acc) -> + _acc; +encode_pubsub_subscription_subscription_node(_val, + _acc) -> + [{<<"node">>, _val} | _acc]. + +decode_pubsub_subscription_subscription_subid(undefined) -> + undefined; +decode_pubsub_subscription_subscription_subid(_val) -> + _val. + +encode_pubsub_subscription_subscription_subid(undefined, + _acc) -> + _acc; +encode_pubsub_subscription_subscription_subid(_val, + _acc) -> + [{<<"subid">>, _val} | _acc]. + +decode_pubsub_subscription_subscription_subscription(undefined) -> + undefined; +decode_pubsub_subscription_subscription_subscription(_val) -> + case catch xml_gen:dec_enum(_val, + [none, pending, subscribed, unconfigured]) + of + {'EXIT', _} -> + erlang:error({bad_attr_value, <<"subscription">>, + <<"subscription">>, <<>>}); + _res -> _res + end. + +encode_pubsub_subscription_subscription_subscription(undefined, + _acc) -> + _acc; +encode_pubsub_subscription_subscription_subscription(_val, + _acc) -> + [{<<"subscription">>, xml_gen:enc_enum(_val)} | _acc]. + +decode_pubsub_affiliation_affiliation({xmlel, _, _attrs, + _els}) -> + {Type, Node} = + decode_pubsub_affiliation_affiliation_attrs(_attrs, + undefined, undefined), + {pubsub_affiliation, Node, Type}. + +decode_pubsub_affiliation_affiliation_attrs([{<<"affiliation">>, + _val} + | _attrs], + _Type, Node) -> + decode_pubsub_affiliation_affiliation_attrs(_attrs, + _val, Node); +decode_pubsub_affiliation_affiliation_attrs([{<<"node">>, + _val} + | _attrs], + Type, _Node) -> + decode_pubsub_affiliation_affiliation_attrs(_attrs, + Type, _val); +decode_pubsub_affiliation_affiliation_attrs([_ + | _attrs], + Type, Node) -> + decode_pubsub_affiliation_affiliation_attrs(_attrs, + Type, Node); +decode_pubsub_affiliation_affiliation_attrs([], Type, + Node) -> + {decode_pubsub_affiliation_affiliation_affiliation(Type), + decode_pubsub_affiliation_affiliation_node(Node)}. + +encode_pubsub_affiliation_affiliation([], _acc) -> _acc; +encode_pubsub_affiliation_affiliation([{pubsub_affiliation, + Node, Type} + | _tail], + _acc) -> + _els = [], + _attrs = + encode_pubsub_affiliation_affiliation_node(Node, + encode_pubsub_affiliation_affiliation_affiliation(Type, + [])), + encode_pubsub_affiliation_affiliation(_tail, + [{xmlel, <<"affiliation">>, _attrs, + _els} + | _acc]). + +decode_pubsub_affiliation_affiliation_node(undefined) -> + erlang:error({missing_attr, <<"node">>, + <<"affiliation">>, <<>>}); +decode_pubsub_affiliation_affiliation_node(_val) -> + _val. + +encode_pubsub_affiliation_affiliation_node(_val, + _acc) -> + [{<<"node">>, _val} | _acc]. + +decode_pubsub_affiliation_affiliation_affiliation(undefined) -> + erlang:error({missing_attr, <<"affiliation">>, + <<"affiliation">>, <<>>}); +decode_pubsub_affiliation_affiliation_affiliation(_val) -> + case catch xml_gen:dec_enum(_val, + [member, none, outcast, owner, publisher, + 'publish-only']) + of + {'EXIT', _} -> + erlang:error({bad_attr_value, <<"affiliation">>, + <<"affiliation">>, <<>>}); + _res -> _res + end. + +encode_pubsub_affiliation_affiliation_affiliation(_val, + _acc) -> + [{<<"affiliation">>, xml_gen:enc_enum(_val)} | _acc]. + +decode_pubsub_item_item({xmlel, _, _attrs, _els}) -> + Id = decode_pubsub_item_item_attrs(_attrs, undefined), + __Els = decode_pubsub_item_item_els(_els, []), + {pubsub_item, Id, __Els}. + +decode_pubsub_item_item_els([{xmlel, _, _, _} = _el + | _els], + __Els) -> + decode_pubsub_item_item_els(_els, + [decode(_el) | __Els]); +decode_pubsub_item_item_els([_ | _els], __Els) -> + decode_pubsub_item_item_els(_els, __Els); +decode_pubsub_item_item_els([], __Els) -> + lists:reverse(__Els). + +decode_pubsub_item_item_attrs([{<<"id">>, _val} + | _attrs], + _Id) -> + decode_pubsub_item_item_attrs(_attrs, _val); +decode_pubsub_item_item_attrs([_ | _attrs], Id) -> + decode_pubsub_item_item_attrs(_attrs, Id); +decode_pubsub_item_item_attrs([], Id) -> + decode_pubsub_item_item_id(Id). + +encode_pubsub_item_item([], _acc) -> _acc; +encode_pubsub_item_item([{pubsub_item, Id, __Els} + | _tail], + _acc) -> + _els = [encode(_subel) || _subel <- __Els] ++ [], + _attrs = encode_pubsub_item_item_id(Id, []), + encode_pubsub_item_item(_tail, + [{xmlel, <<"item">>, _attrs, _els} | _acc]). + +decode_pubsub_item_item_id(undefined) -> undefined; +decode_pubsub_item_item_id(_val) -> _val. + +encode_pubsub_item_item_id(undefined, _acc) -> _acc; +encode_pubsub_item_item_id(_val, _acc) -> + [{<<"id">>, _val} | _acc]. + +decode_pubsub_items_items({xmlel, _, _attrs, _els}) -> + {Subid, Max_items, Node} = + decode_pubsub_items_items_attrs(_attrs, undefined, + undefined, undefined), + Item = decode_pubsub_items_items_els(_els, []), + {pubsub_items, Node, Max_items, Subid, Item}. + +decode_pubsub_items_items_els([{xmlel, <<"item">>, + _attrs, _} = + _el + | _els], + Item) -> + case xml:get_attr_s(<<"xmlns">>, _attrs) of + <<>> -> + decode_pubsub_items_items_els(_els, + [decode_pubsub_item_item(_el) | Item]); + _ -> decode_pubsub_items_items_els(_els, Item) + end; +decode_pubsub_items_items_els([_ | _els], Item) -> + decode_pubsub_items_items_els(_els, Item); +decode_pubsub_items_items_els([], Item) -> + lists:reverse(Item). + +decode_pubsub_items_items_attrs([{<<"subid">>, _val} + | _attrs], + _Subid, Max_items, Node) -> + decode_pubsub_items_items_attrs(_attrs, _val, Max_items, + Node); +decode_pubsub_items_items_attrs([{<<"max_items">>, _val} + | _attrs], + Subid, _Max_items, Node) -> + decode_pubsub_items_items_attrs(_attrs, Subid, _val, + Node); +decode_pubsub_items_items_attrs([{<<"node">>, _val} + | _attrs], + Subid, Max_items, _Node) -> + decode_pubsub_items_items_attrs(_attrs, Subid, + Max_items, _val); +decode_pubsub_items_items_attrs([_ | _attrs], Subid, + Max_items, Node) -> + decode_pubsub_items_items_attrs(_attrs, Subid, + Max_items, Node); +decode_pubsub_items_items_attrs([], Subid, Max_items, + Node) -> + {decode_pubsub_items_items_subid(Subid), + decode_pubsub_items_items_max_items(Max_items), + decode_pubsub_items_items_node(Node)}. + +encode_pubsub_items_items([], _acc) -> _acc; +encode_pubsub_items_items([{pubsub_items, Node, + Max_items, Subid, Item} + | _tail], + _acc) -> + _els = encode_pubsub_item_item(Item, []), + _attrs = encode_pubsub_items_items_node(Node, + encode_pubsub_items_items_max_items(Max_items, + encode_pubsub_items_items_subid(Subid, + []))), + encode_pubsub_items_items(_tail, + [{xmlel, <<"items">>, _attrs, _els} | _acc]). + +decode_pubsub_items_items_max_items(undefined) -> + undefined; +decode_pubsub_items_items_max_items(_val) -> + case catch xml_gen:dec_int(_val, 0, infinity) of + {'EXIT', _} -> + erlang:error({bad_attr_value, <<"max_items">>, + <<"items">>, <<>>}); + _res -> _res + end. + +encode_pubsub_items_items_max_items(undefined, _acc) -> + _acc; +encode_pubsub_items_items_max_items(_val, _acc) -> + [{<<"max_items">>, xml_gen:enc_int(_val)} | _acc]. + +decode_pubsub_items_items_node(undefined) -> + erlang:error({missing_attr, <<"node">>, <<"items">>, + <<>>}); +decode_pubsub_items_items_node(_val) -> _val. + +encode_pubsub_items_items_node(_val, _acc) -> + [{<<"node">>, _val} | _acc]. + +decode_pubsub_items_items_subid(undefined) -> undefined; +decode_pubsub_items_items_subid(_val) -> _val. + +encode_pubsub_items_items_subid(undefined, _acc) -> + _acc; +encode_pubsub_items_items_subid(_val, _acc) -> + [{<<"subid">>, _val} | _acc]. + +decode_pubsub_event_event({xmlel, _, _attrs, _els}) -> + Items = decode_pubsub_event_event_els(_els, []), + {pubsub_event, Items}. + +decode_pubsub_event_event_els([{xmlel, <<"items">>, + _attrs, _} = + _el + | _els], + Items) -> + case xml:get_attr_s(<<"xmlns">>, _attrs) of + <<>> -> + decode_pubsub_event_event_els(_els, + [decode_pubsub_items_items(_el) + | Items]); + _ -> decode_pubsub_event_event_els(_els, Items) + end; +decode_pubsub_event_event_els([_ | _els], Items) -> + decode_pubsub_event_event_els(_els, Items); +decode_pubsub_event_event_els([], Items) -> + lists:reverse(Items). + +encode_pubsub_event_event(undefined, _acc) -> _acc; +encode_pubsub_event_event({pubsub_event, Items}, + _acc) -> + _els = encode_pubsub_items_items(Items, []), + _attrs = [{<<"xmlns">>, + <<"http://jabber.org/protocol/pubsub#event">>}], + [{xmlel, <<"event">>, _attrs, _els} | _acc]. + +decode_pubsub_pubsub({xmlel, _, _attrs, _els}) -> + {Subscribe, Publish, Affiliations, Subscriptions} = + decode_pubsub_pubsub_els(_els, undefined, undefined, + undefined, undefined), + {pubsub, Subscriptions, Affiliations, Publish, + Subscribe}. + +decode_pubsub_pubsub_els([{xmlel, <<"subscribe">>, + _attrs, _} = + _el + | _els], + Subscribe, Publish, Affiliations, Subscriptions) -> + case xml:get_attr_s(<<"xmlns">>, _attrs) of + <<>> -> + decode_pubsub_pubsub_els(_els, + decode_pubsub_pubsub_subscribe(_el), Publish, + Affiliations, Subscriptions); + _ -> + decode_pubsub_pubsub_els(_els, Subscribe, Publish, + Affiliations, Subscriptions) + end; +decode_pubsub_pubsub_els([{xmlel, <<"publish">>, _attrs, + _} = + _el + | _els], + Subscribe, Publish, Affiliations, Subscriptions) -> + case xml:get_attr_s(<<"xmlns">>, _attrs) of + <<>> -> + decode_pubsub_pubsub_els(_els, Subscribe, + decode_pubsub_pubsub_publish(_el), + Affiliations, Subscriptions); + _ -> + decode_pubsub_pubsub_els(_els, Subscribe, Publish, + Affiliations, Subscriptions) + end; +decode_pubsub_pubsub_els([{xmlel, <<"affiliations">>, + _attrs, _} = + _el + | _els], + Subscribe, Publish, Affiliations, Subscriptions) -> + case xml:get_attr_s(<<"xmlns">>, _attrs) of + <<>> -> + decode_pubsub_pubsub_els(_els, Subscribe, Publish, + decode_pubsub_pubsub_affiliations(_el), + Subscriptions); + _ -> + decode_pubsub_pubsub_els(_els, Subscribe, Publish, + Affiliations, Subscriptions) + end; +decode_pubsub_pubsub_els([{xmlel, <<"subscriptions">>, + _attrs, _} = + _el + | _els], + Subscribe, Publish, Affiliations, Subscriptions) -> + case xml:get_attr_s(<<"xmlns">>, _attrs) of + <<>> -> + decode_pubsub_pubsub_els(_els, Subscribe, Publish, + Affiliations, + decode_pubsub_pubsub_subscriptions(_el)); + _ -> + decode_pubsub_pubsub_els(_els, Subscribe, Publish, + Affiliations, Subscriptions) + end; +decode_pubsub_pubsub_els([_ | _els], Subscribe, Publish, + Affiliations, Subscriptions) -> + decode_pubsub_pubsub_els(_els, Subscribe, Publish, + Affiliations, Subscriptions); +decode_pubsub_pubsub_els([], Subscribe, Publish, + Affiliations, Subscriptions) -> + {Subscribe, Publish, Affiliations, Subscriptions}. + +encode_pubsub_pubsub(undefined, _acc) -> _acc; +encode_pubsub_pubsub({pubsub, Subscriptions, + Affiliations, Publish, Subscribe}, + _acc) -> + _els = encode_pubsub_pubsub_subscriptions(Subscriptions, + encode_pubsub_pubsub_affiliations(Affiliations, + encode_pubsub_pubsub_publish(Publish, + encode_pubsub_pubsub_subscribe(Subscribe, + [])))), + _attrs = [{<<"xmlns">>, + <<"http://jabber.org/protocol/pubsub">>}], + [{xmlel, <<"pubsub">>, _attrs, _els} | _acc]. + +decode_pubsub_pubsub_publish({xmlel, _, _attrs, + _els}) -> + Node = decode_pubsub_pubsub_publish_attrs(_attrs, + undefined), + Item = decode_pubsub_pubsub_publish_els(_els, []), + {Node, Item}. + +decode_pubsub_pubsub_publish_els([{xmlel, <<"item">>, + _attrs, _} = + _el + | _els], + Item) -> + case xml:get_attr_s(<<"xmlns">>, _attrs) of + <<>> -> + decode_pubsub_pubsub_publish_els(_els, + [decode_pubsub_item_item(_el) + | Item]); + _ -> decode_pubsub_pubsub_publish_els(_els, Item) + end; +decode_pubsub_pubsub_publish_els([_ | _els], Item) -> + decode_pubsub_pubsub_publish_els(_els, Item); +decode_pubsub_pubsub_publish_els([], Item) -> + lists:reverse(Item). + +decode_pubsub_pubsub_publish_attrs([{<<"node">>, _val} + | _attrs], + _Node) -> + decode_pubsub_pubsub_publish_attrs(_attrs, _val); +decode_pubsub_pubsub_publish_attrs([_ | _attrs], + Node) -> + decode_pubsub_pubsub_publish_attrs(_attrs, Node); +decode_pubsub_pubsub_publish_attrs([], Node) -> + decode_pubsub_pubsub_publish_node(Node). + +encode_pubsub_pubsub_publish(undefined, _acc) -> _acc; +encode_pubsub_pubsub_publish({Node, Item}, _acc) -> + _els = encode_pubsub_item_item(Item, []), + _attrs = encode_pubsub_pubsub_publish_node(Node, []), + [{xmlel, <<"publish">>, _attrs, _els} | _acc]. + +decode_pubsub_pubsub_publish_node(undefined) -> + erlang:error({missing_attr, <<"node">>, <<"publish">>, + <<>>}); +decode_pubsub_pubsub_publish_node(_val) -> _val. + +encode_pubsub_pubsub_publish_node(_val, _acc) -> + [{<<"node">>, _val} | _acc]. + +decode_pubsub_pubsub_subscribe({xmlel, _, _attrs, + _els}) -> + {Jid, Node} = + decode_pubsub_pubsub_subscribe_attrs(_attrs, undefined, + undefined), + {Node, Jid}. + +decode_pubsub_pubsub_subscribe_attrs([{<<"jid">>, _val} + | _attrs], + _Jid, Node) -> + decode_pubsub_pubsub_subscribe_attrs(_attrs, _val, + Node); +decode_pubsub_pubsub_subscribe_attrs([{<<"node">>, _val} + | _attrs], + Jid, _Node) -> + decode_pubsub_pubsub_subscribe_attrs(_attrs, Jid, _val); +decode_pubsub_pubsub_subscribe_attrs([_ | _attrs], Jid, + Node) -> + decode_pubsub_pubsub_subscribe_attrs(_attrs, Jid, Node); +decode_pubsub_pubsub_subscribe_attrs([], Jid, Node) -> + {decode_pubsub_pubsub_subscribe_jid(Jid), + decode_pubsub_pubsub_subscribe_node(Node)}. + +encode_pubsub_pubsub_subscribe(undefined, _acc) -> _acc; +encode_pubsub_pubsub_subscribe({Node, Jid}, _acc) -> + _els = [], + _attrs = encode_pubsub_pubsub_subscribe_node(Node, + encode_pubsub_pubsub_subscribe_jid(Jid, + [])), + [{xmlel, <<"subscribe">>, _attrs, _els} | _acc]. + +decode_pubsub_pubsub_subscribe_node(undefined) -> + undefined; +decode_pubsub_pubsub_subscribe_node(_val) -> _val. + +encode_pubsub_pubsub_subscribe_node(undefined, _acc) -> + _acc; +encode_pubsub_pubsub_subscribe_node(_val, _acc) -> + [{<<"node">>, _val} | _acc]. + +decode_pubsub_pubsub_subscribe_jid(undefined) -> + erlang:error({missing_attr, <<"jid">>, <<"subscribe">>, + <<>>}); +decode_pubsub_pubsub_subscribe_jid(_val) -> + case catch dec_jid(_val) of + {'EXIT', _} -> + erlang:error({bad_attr_value, <<"jid">>, + <<"subscribe">>, <<>>}); + _res -> _res + end. + +encode_pubsub_pubsub_subscribe_jid(_val, _acc) -> + [{<<"jid">>, enc_jid(_val)} | _acc]. + +decode_pubsub_pubsub_affiliations({xmlel, _, _attrs, + _els}) -> + Pubsub_affiliations = + decode_pubsub_pubsub_affiliations_els(_els, []), + Pubsub_affiliations. + +decode_pubsub_pubsub_affiliations_els([{xmlel, + <<"affiliation">>, _attrs, _} = + _el + | _els], + Pubsub_affiliations) -> + case xml:get_attr_s(<<"xmlns">>, _attrs) of + <<>> -> + decode_pubsub_pubsub_affiliations_els(_els, + [decode_pubsub_affiliation_affiliation(_el) + | Pubsub_affiliations]); + _ -> + decode_pubsub_pubsub_affiliations_els(_els, + Pubsub_affiliations) + end; +decode_pubsub_pubsub_affiliations_els([_ | _els], + Pubsub_affiliations) -> + decode_pubsub_pubsub_affiliations_els(_els, + Pubsub_affiliations); +decode_pubsub_pubsub_affiliations_els([], + Pubsub_affiliations) -> + lists:reverse(Pubsub_affiliations). + +encode_pubsub_pubsub_affiliations(undefined, _acc) -> + _acc; +encode_pubsub_pubsub_affiliations(Pubsub_affiliations, + _acc) -> + _els = + encode_pubsub_affiliation_affiliation(Pubsub_affiliations, + []), + _attrs = [], + [{xmlel, <<"affiliations">>, _attrs, _els} | _acc]. + +decode_pubsub_pubsub_subscriptions({xmlel, _, _attrs, + _els}) -> + Node = decode_pubsub_pubsub_subscriptions_attrs(_attrs, + undefined), + Pubsub_subscriptions = + decode_pubsub_pubsub_subscriptions_els(_els, []), + {Node, Pubsub_subscriptions}. + +decode_pubsub_pubsub_subscriptions_els([{xmlel, + <<"subscription">>, _attrs, _} = + _el + | _els], + Pubsub_subscriptions) -> + case xml:get_attr_s(<<"xmlns">>, _attrs) of + <<>> -> + decode_pubsub_pubsub_subscriptions_els(_els, + [decode_pubsub_subscription_subscription(_el) + | Pubsub_subscriptions]); + _ -> + decode_pubsub_pubsub_subscriptions_els(_els, + Pubsub_subscriptions) + end; +decode_pubsub_pubsub_subscriptions_els([_ | _els], + Pubsub_subscriptions) -> + decode_pubsub_pubsub_subscriptions_els(_els, + Pubsub_subscriptions); +decode_pubsub_pubsub_subscriptions_els([], + Pubsub_subscriptions) -> + lists:reverse(Pubsub_subscriptions). + +decode_pubsub_pubsub_subscriptions_attrs([{<<"node">>, + _val} + | _attrs], + _Node) -> + decode_pubsub_pubsub_subscriptions_attrs(_attrs, _val); +decode_pubsub_pubsub_subscriptions_attrs([_ | _attrs], + Node) -> + decode_pubsub_pubsub_subscriptions_attrs(_attrs, Node); +decode_pubsub_pubsub_subscriptions_attrs([], Node) -> + decode_pubsub_pubsub_subscriptions_node(Node). + +encode_pubsub_pubsub_subscriptions(undefined, _acc) -> + _acc; +encode_pubsub_pubsub_subscriptions({Node, + Pubsub_subscriptions}, + _acc) -> + _els = + encode_pubsub_subscription_subscription(Pubsub_subscriptions, + []), + _attrs = encode_pubsub_pubsub_subscriptions_node(Node, + []), + [{xmlel, <<"subscriptions">>, _attrs, _els} | _acc]. + +decode_pubsub_pubsub_subscriptions_node(undefined) -> + none; +decode_pubsub_pubsub_subscriptions_node(_val) -> _val. + +encode_pubsub_pubsub_subscriptions_node(none, _acc) -> + _acc; +encode_pubsub_pubsub_subscriptions_node(_val, _acc) -> + [{<<"node">>, _val} | _acc]. + +decode_delay_delay({xmlel, _, _attrs, _els}) -> + {From, Stamp} = decode_delay_delay_attrs(_attrs, + undefined, undefined), + {delay, Stamp, From}. + +decode_delay_delay_attrs([{<<"from">>, _val} | _attrs], + _From, Stamp) -> + decode_delay_delay_attrs(_attrs, _val, Stamp); +decode_delay_delay_attrs([{<<"stamp">>, _val} | _attrs], + From, _Stamp) -> + decode_delay_delay_attrs(_attrs, From, _val); +decode_delay_delay_attrs([_ | _attrs], From, Stamp) -> + decode_delay_delay_attrs(_attrs, From, Stamp); +decode_delay_delay_attrs([], From, Stamp) -> + {decode_delay_delay_from(From), + decode_delay_delay_stamp(Stamp)}. + +encode_delay_delay(undefined, _acc) -> _acc; +encode_delay_delay({delay, Stamp, From}, _acc) -> + _els = [], + _attrs = encode_delay_delay_stamp(Stamp, + encode_delay_delay_from(From, + [{<<"xmlns">>, + <<"urn:xmpp:delay">>}])), + [{xmlel, <<"delay">>, _attrs, _els} | _acc]. + +decode_delay_delay_stamp(undefined) -> + erlang:error({missing_attr, <<"stamp">>, <<"delay">>, + <<"urn:xmpp:delay">>}); +decode_delay_delay_stamp(_val) -> + case catch dec_utc(_val) of + {'EXIT', _} -> + erlang:error({bad_attr_value, <<"stamp">>, <<"delay">>, + <<"urn:xmpp:delay">>}); + _res -> _res + end. + +encode_delay_delay_stamp(_val, _acc) -> + [{<<"stamp">>, enc_utc(_val)} | _acc]. + +decode_delay_delay_from(undefined) -> undefined; +decode_delay_delay_from(_val) -> + case catch dec_jid(_val) of + {'EXIT', _} -> + erlang:error({bad_attr_value, <<"from">>, <<"delay">>, + <<"urn:xmpp:delay">>}); + _res -> _res + end. + +encode_delay_delay_from(undefined, _acc) -> _acc; +encode_delay_delay_from(_val, _acc) -> + [{<<"from">>, enc_jid(_val)} | _acc]. |