summaryrefslogtreecommitdiffstats
path: root/src/stkutil.c
diff options
context:
space:
mode:
authorDenis Kenzior <denkenz@gmail.com>2010-03-01 16:02:33 -0600
committerDenis Kenzior <denkenz@gmail.com>2010-03-01 16:02:33 -0600
commite0501c493090508e6596ed3919e05430183791c9 (patch)
tree04b71b6651800aa0954bbe34651b5e061c78b55a /src/stkutil.c
parent36c9201246946c2473574591dcaeaae64360b0b4 (diff)
downloadofono-e0501c493090508e6596ed3919e05430183791c9.tar.bz2
Add parser for Duration objects
Diffstat (limited to 'src/stkutil.c')
-rw-r--r--src/stkutil.c31
1 files changed, 31 insertions, 0 deletions
diff --git a/src/stkutil.c b/src/stkutil.c
index 231f4522..20c314c1 100644
--- a/src/stkutil.c
+++ b/src/stkutil.c
@@ -41,6 +41,33 @@ enum stk_data_object_flag {
typedef gboolean (*dataobj_handler)(struct comprehension_tlv_iter *, void *);
+static gboolean parse_dataobj_duration(struct comprehension_tlv_iter *iter,
+ void *user)
+{
+ struct stk_duration *duration = user;
+ const unsigned char *data;
+
+ if (comprehension_tlv_iter_get_tag(iter) !=
+ STK_DATA_OBJECT_TYPE_DURATION)
+ return FALSE;
+
+ if (comprehension_tlv_iter_get_length(iter) != 2)
+ return FALSE;
+
+ data = comprehension_tlv_iter_get_data(iter);
+
+ if (data[0] > 0x02)
+ return FALSE;
+
+ if (data[1] == 0)
+ return FALSE;
+
+ duration->unit = data[0];
+ duration->interval = data[1];
+
+ return TRUE;
+}
+
/* Defined in TS 102.223 Section 8.15 */
static gboolean parse_dataobj_text(struct comprehension_tlv_iter *iter,
void *user)
@@ -159,6 +186,8 @@ static dataobj_handler handler_for_type(enum stk_data_object_type type)
return parse_dataobj_icon_id;
case STK_DATA_OBJECT_TYPE_IMMEDIATE_RESPONSE:
return parse_dataobj_imm_resp;
+ case STK_DATA_OBJECT_TYPE_DURATION:
+ return parse_dataobj_duration;
default:
return NULL;
};
@@ -238,6 +267,8 @@ static gboolean parse_display_text(struct stk_command *command,
&command->display_text.icon_id,
STK_DATA_OBJECT_TYPE_IMMEDIATE_RESPONSE, 0,
&command->display_text.immediate_response,
+ STK_DATA_OBJECT_TYPE_DURATION, 0,
+ &command->display_text.duration,
STK_DATA_OBJECT_TYPE_INVALID);
if (ret == FALSE)