summaryrefslogtreecommitdiffstats
path: root/src/stkutil.c
diff options
context:
space:
mode:
authorYang Gu <yang.gu@intel.com>2010-05-19 18:24:41 +0800
committerDenis Kenzior <denkenz@gmail.com>2010-05-25 17:19:38 -0500
commitf21e69c7a816381c9379fe42e3505c6eeda49f16 (patch)
tree97f5718c5d77c2b7eb63613f2d6a96e125d5b26b /src/stkutil.c
parent3af46003686b7092d8b43df8f2f417cda25d3378 (diff)
downloadofono-f21e69c7a816381c9379fe42e3505c6eeda49f16.tar.bz2
stk: Add parser for run at command commands
Diffstat (limited to 'src/stkutil.c')
-rw-r--r--src/stkutil.c42
1 files changed, 42 insertions, 0 deletions
diff --git a/src/stkutil.c b/src/stkutil.c
index ca51887f..47b18de4 100644
--- a/src/stkutil.c
+++ b/src/stkutil.c
@@ -2757,6 +2757,45 @@ static gboolean parse_setup_idle_mode_text(struct stk_command *command,
return TRUE;
}
+static void destroy_run_at_command(struct stk_command *command)
+{
+ g_free(command->run_at_command.alpha_id);
+ g_free(command->run_at_command.at_command);
+}
+
+static gboolean parse_run_at_command(struct stk_command *command,
+ struct comprehension_tlv_iter *iter)
+{
+ struct stk_command_run_at_command *obj = &command->run_at_command;
+ gboolean ret;
+
+ if (command->src != STK_DEVICE_IDENTITY_TYPE_UICC)
+ return FALSE;
+
+ if (command->dst != STK_DEVICE_IDENTITY_TYPE_TERMINAL)
+ return FALSE;
+
+ ret = parse_dataobj(iter, STK_DATA_OBJECT_TYPE_ALPHA_ID, 0,
+ &obj->alpha_id,
+ STK_DATA_OBJECT_TYPE_AT_COMMAND,
+ DATAOBJ_FLAG_MANDATORY | DATAOBJ_FLAG_MINIMUM,
+ &obj->at_command,
+ STK_DATA_OBJECT_TYPE_ICON_ID, 0,
+ &obj->icon_id,
+ STK_DATA_OBJECT_TYPE_TEXT_ATTRIBUTE, 0,
+ &obj->text_attr,
+ STK_DATA_OBJECT_TYPE_FRAME_ID, 0,
+ &obj->frame_id,
+ STK_DATA_OBJECT_TYPE_INVALID);
+
+ if (ret == FALSE)
+ return FALSE;
+
+ command->destructor = destroy_run_at_command;
+
+ return TRUE;
+}
+
struct stk_command *stk_command_new_from_pdu(const unsigned char *pdu,
unsigned int len)
{
@@ -2875,6 +2914,9 @@ struct stk_command *stk_command_new_from_pdu(const unsigned char *pdu,
case STK_COMMAND_TYPE_SETUP_IDLE_MODE_TEXT:
ok = parse_setup_idle_mode_text(command, &iter);
break;
+ case STK_COMMAND_TYPE_RUN_AT_COMMAND:
+ ok = parse_run_at_command(command, &iter);
+ break;
default:
ok = FALSE;
break;