diff options
author | Denis Kenzior <denkenz@gmail.com> | 2010-03-01 16:18:17 -0600 |
---|---|---|
committer | Denis Kenzior <denkenz@gmail.com> | 2010-03-01 16:18:17 -0600 |
commit | c8c318d8b90a7cd3699583471407da86670c46a0 (patch) | |
tree | 766c1efecd63bc6b53d8ba116e85e6561e80b93b /src/stkutil.c | |
parent | 93e24f22b8e3714591b0dadc7f35d2c42ef728d6 (diff) | |
download | ofono-c8c318d8b90a7cd3699583471407da86670c46a0.tar.bz2 |
Add parser for text attribute objects
Diffstat (limited to 'src/stkutil.c')
-rw-r--r-- | src/stkutil.c | 29 |
1 files changed, 29 insertions, 0 deletions
diff --git a/src/stkutil.c b/src/stkutil.c index 20c314c1..5322f083 100644 --- a/src/stkutil.c +++ b/src/stkutil.c @@ -177,6 +177,31 @@ static gboolean parse_dataobj_imm_resp(struct comprehension_tlv_iter *iter, return TRUE; } +/* Defined in TS 102.223 Section 8.72 */ +static gboolean parse_dataobj_text_attr(struct comprehension_tlv_iter *iter, + void *user) +{ + struct stk_text_attribute *attr = user; + const unsigned char *data; + unsigned int len; + + if (comprehension_tlv_iter_get_tag(iter) != + STK_DATA_OBJECT_TYPE_IMMEDIATE_RESPONSE) + return FALSE; + + len = comprehension_tlv_iter_get_length(iter); + + if (len > 127) + return FALSE; + + data = comprehension_tlv_iter_get_data(iter); + + memcpy(attr->attributes, data, len); + attr->len = len; + + return TRUE; +} + static dataobj_handler handler_for_type(enum stk_data_object_type type) { switch (type) { @@ -188,6 +213,8 @@ static dataobj_handler handler_for_type(enum stk_data_object_type type) return parse_dataobj_imm_resp; case STK_DATA_OBJECT_TYPE_DURATION: return parse_dataobj_duration; + case STK_DATA_OBJECT_TYPE_TEXT_ATTRIBUTE: + return parse_dataobj_text_attr; default: return NULL; }; @@ -269,6 +296,8 @@ static gboolean parse_display_text(struct stk_command *command, &command->display_text.immediate_response, STK_DATA_OBJECT_TYPE_DURATION, 0, &command->display_text.duration, + STK_DATA_OBJECT_TYPE_TEXT_ATTRIBUTE, 0, + &command->display_text.text_attribute, STK_DATA_OBJECT_TYPE_INVALID); if (ret == FALSE) |