diff options
author | Denis Kenzior <denkenz@gmail.com> | 2015-11-05 22:39:59 -0600 |
---|---|---|
committer | Denis Kenzior <denkenz@gmail.com> | 2015-11-05 22:39:59 -0600 |
commit | 07be422cfa8e330976b61d3e84ccf5206a98c39f (patch) | |
tree | 3a0832335c0db6fd8f14612d79968f8a5c23b5e8 | |
parent | 1ee339bb77217633ad1aabfd97f84e9fbe68890d (diff) | |
download | ofono-07be422cfa8e330976b61d3e84ccf5206a98c39f.tar.bz2 |
rilmodem: Implement ril_csca_query_cb inline
-rw-r--r-- | drivers/rilmodem/sms.c | 52 |
1 files changed, 38 insertions, 14 deletions
diff --git a/drivers/rilmodem/sms.c b/drivers/rilmodem/sms.c index f368b250..49a40cd6 100644 --- a/drivers/rilmodem/sms.c +++ b/drivers/rilmodem/sms.c @@ -95,23 +95,47 @@ static void ril_csca_query_cb(struct ril_msg *message, gpointer user_data) struct cb_data *cbd = user_data; ofono_sms_sca_query_cb_t cb = cbd->cb; struct sms_data *sd = cbd->user; - struct ofono_phone_number *sca; + struct ofono_phone_number sca; + struct parcel rilp; + char *temp_buf; + char *number; - if (message->error != RIL_E_SUCCESS) { - ofono_error("%s RILD reply failure: %s", - g_ril_request_id_to_string(sd->ril, message->req), - ril_error_to_string(message->error)); - CALLBACK_WITH_FAILURE(cb, NULL, cbd->data); - return; - } + if (message->error != RIL_E_SUCCESS) + goto error; - sca = g_ril_reply_parse_get_smsc_address(sd->ril, message); - if (sca == NULL) { - CALLBACK_WITH_FAILURE(cb, NULL, cbd->data); - } else { - CALLBACK_WITH_SUCCESS(cb, sca, cbd->data); - g_free(sca); + g_ril_init_parcel(message, &rilp); + + temp_buf = parcel_r_string(&rilp); + if (temp_buf == NULL) + goto error; + + /* RIL gives address in quotes */ + number = strtok(temp_buf, "\""); + if (number == NULL || *number == '\0') { + g_free(temp_buf); + goto error; } + + if (number[0] == '+') { + number = number + 1; + sca.type = OFONO_NUMBER_TYPE_INTERNATIONAL; + } else + sca.type = OFONO_NUMBER_TYPE_UNKNOWN; + + strncpy(sca.number, number, OFONO_MAX_PHONE_NUMBER_LENGTH); + sca.number[OFONO_MAX_PHONE_NUMBER_LENGTH] = '\0'; + + g_ril_append_print_buf(sd->ril, "{type=%d,number=%s}", + sca.type, sca.number); + g_ril_print_response(sd->ril, message); + + g_free(temp_buf); + + CALLBACK_WITH_SUCCESS(cb, &sca, cbd->data); + return; + +error: + CALLBACK_WITH_FAILURE(cb, NULL, cbd->data); } static void ril_csca_query(struct ofono_sms *sms, ofono_sms_sca_query_cb_t cb, |