summaryrefslogtreecommitdiffstats
path: root/src/stkutil.c
diff options
context:
space:
mode:
authorDenis Kenzior <denkenz@gmail.com>2010-03-01 16:18:17 -0600
committerDenis Kenzior <denkenz@gmail.com>2010-03-01 16:18:17 -0600
commitc8c318d8b90a7cd3699583471407da86670c46a0 (patch)
tree766c1efecd63bc6b53d8ba116e85e6561e80b93b /src/stkutil.c
parent93e24f22b8e3714591b0dadc7f35d2c42ef728d6 (diff)
downloadofono-c8c318d8b90a7cd3699583471407da86670c46a0.tar.bz2
Add parser for text attribute objects
Diffstat (limited to 'src/stkutil.c')
-rw-r--r--src/stkutil.c29
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)