}
unsigned int uid = tts_client_get_uid(client);
- SLOG(LOG_INFO, TAG_TTSC, "[INFO] tts_h(%p), tts_client(%p), uid(%u)", tts_client_get_handle(client), client, uid);
+ tts_mode_e mode = tts_client_get_mode(client);
+ SLOG(LOG_INFO, TAG_TTSC, "[INFO] tts_h(%p), tts_client(%p), uid(%u), mode(%d)", tts_client_get_handle(client), client, uid, (int)mode);
/* check service engine status */
bool is_launched = __is_engine_launched();
}
}
- if (0 != tts_ipc_request_hello(uid)) {
+ if (0 != tts_ipc_request_hello(uid, mode)) {
SLOG(LOG_ERROR, TAG_TTSC, "[ERROR] Fail to request hello !!"); //LCOV_EXCL_LINE
} else {
SLOG(LOG_INFO, TAG_TTSC, "@@@ Send Hello");
// TODO: make function duplicated block
/* do request initialize */
bool credential_needed = false;
- int ret = tts_ipc_request_initialize(uid, &credential_needed);
+ tts_mode_e mode = tts_client_get_mode(client);
+ int ret = tts_ipc_request_initialize(uid, mode, &credential_needed);
if (TTS_ERROR_ENGINE_NOT_FOUND == ret || TTS_ERROR_PERMISSION_DENIED == ret) {
SLOG(LOG_ERROR, TAG_TTSC, "[ERROR] Fail to initialize. ret(%d/%s)", ret, get_error_message(ret));
tts_core_notify_error_async(client, ret, -1, NULL);
return msg;
}
-int tts_dbus_request_hello(unsigned int uid)
+int tts_dbus_request_hello(unsigned int uid, tts_mode_e mode)
{
DBusError err;
dbus_error_init(&err);
}
int pid = getpid();
- if (true != dbus_message_append_args(msg, DBUS_TYPE_INT32, &pid, DBUS_TYPE_UINT32, &uid, DBUS_TYPE_INVALID)) {
+ if (true != dbus_message_append_args(msg, DBUS_TYPE_INT32, &pid, DBUS_TYPE_UINT32, &uid, DBUS_TYPE_INT32, &mode, DBUS_TYPE_INVALID)) {
dbus_message_unref(msg);
SLOG(LOG_ERROR, TAG_TTSC, "[ERROR] Fail to append args");
return result;
}
-int tts_dbus_request_initialize(unsigned int uid, bool* credential_needed)
+int tts_dbus_request_initialize(unsigned int uid, tts_mode_e mode, bool* credential_needed)
{
DBusMessage* msg;
DBusError err;
}
int pid = getpid();
- if (true != dbus_message_append_args(msg, DBUS_TYPE_INT32, &pid, DBUS_TYPE_UINT32, &uid, DBUS_TYPE_INVALID)) {
+ if (true != dbus_message_append_args(msg, DBUS_TYPE_INT32, &pid, DBUS_TYPE_UINT32, &uid, DBUS_TYPE_INT32, &mode, DBUS_TYPE_INVALID)) {
dbus_message_unref(msg);
SLOG(LOG_ERROR, TAG_TTSC, "[ERROR] Fail to append args");
int tts_dbus_stop_listening(unsigned int uid);
-int tts_dbus_request_hello(unsigned int uid);
+int tts_dbus_request_hello(unsigned int uid, tts_mode_e mode);
int tts_dbus_request_hello_sync(unsigned int uid);
-int tts_dbus_request_initialize(unsigned int uid, bool* credential_needed);
+int tts_dbus_request_initialize(unsigned int uid, tts_mode_e mode, bool* credential_needed);
int tts_dbus_request_finalize(unsigned int uid);
return g_vtable[STOP_LISTENING](uid);
}
-int tts_ipc_request_hello(unsigned int uid)
+int tts_ipc_request_hello(unsigned int uid, tts_mode_e mode)
{
SLOG(LOG_INFO, TAG_TTSC, "[IPC] tts_ipc_request_hello");
RETVM_IF(false == tts_client_is_valid_uid(uid), TTS_ERROR_INVALID_PARAMETER, "Fail to get tts_client with uid(%u)", uid);
RETVM_IF(NULL == g_vtable, TTS_ERROR_OPERATION_FAILED, "[ERROR] IPC method is not set");
- return g_vtable[REQUEST_HELLO](uid);
+ return g_vtable[REQUEST_HELLO](uid, mode);
}
int tts_ipc_request_hello_sync(unsigned int uid)
return g_vtable[REQUEST_HELLO_SYNC](uid);
}
-int tts_ipc_request_initialize(unsigned int uid, bool* credential_needed)
+int tts_ipc_request_initialize(unsigned int uid, tts_mode_e mode, bool* credential_needed)
{
SLOG(LOG_INFO, TAG_TTSC, "[IPC] tts_ipc_request_initialize");
RETVM_IF(false == tts_client_is_valid_uid(uid), TTS_ERROR_INVALID_PARAMETER, "Fail to get tts_client with uid(%u)", uid);
RETVM_IF(NULL == g_vtable, TTS_ERROR_OPERATION_FAILED, "[ERROR] IPC method is not set");
- return g_vtable[REQUEST_INITIALIZE](uid, credential_needed);
+ return g_vtable[REQUEST_INITIALIZE](uid, mode, credential_needed);
}
int tts_ipc_request_finalize(unsigned int uid)
int tts_ipc_stop_listening(unsigned int uid);
-int tts_ipc_request_hello(unsigned int uid);
+int tts_ipc_request_hello(unsigned int uid, tts_mode_e mode);
int tts_ipc_request_hello_sync(unsigned int uid);
-int tts_ipc_request_initialize(unsigned int uid, bool* credential_needed);
+int tts_ipc_request_initialize(unsigned int uid, tts_mode_e mode, bool* credential_needed);
int tts_ipc_request_finalize(unsigned int uid);
return TTS_ERROR_NONE;
}
-static int __invoke_register_callback(int pid, tts_tidl_info_s* info)
+static int __invoke_register_callback(int pid, tts_mode_e mode, tts_tidl_info_s* info)
{
if (info->register_callback_invoked) {
SLOG(LOG_ERROR, TAG_TTSC, "[INFO] Already register callback is invoked");
return ret;
}
- rpc_port_proxy_tts_invoke_register_cb(info->rpc_h, pid, info->uid, info->notify_cb_h);
+ rpc_port_proxy_tts_invoke_register_cb(info->rpc_h, pid, info->uid, (int)mode, info->notify_cb_h);
info->register_callback_invoked = true;
return TTS_ERROR_NONE;
}
-int tts_tidl_request_hello(unsigned int uid)
+int tts_tidl_request_hello(unsigned int uid, tts_mode_e mode)
{
SLOG(LOG_DEBUG, TAG_TTSC, "[TIDL] tts_tidl_request_hello");
}
SLOG(LOG_DEBUG, TAG_TTSC, ">>>>> TTS Hello");
- if (TTS_ERROR_NONE != __invoke_register_callback(client->pid, info)) {
+ if (TTS_ERROR_NONE != __invoke_register_callback(client->pid, mode, info)) {
SLOG(LOG_ERROR, TAG_TTSC, "[ERROR] Fail to invoke register callback");
return TTS_ERROR_OPERATION_FAILED;
}
return TTS_ERROR_NONE;
}
-int tts_tidl_request_initialize(unsigned int uid, bool* credential_needed)
+int tts_tidl_request_initialize(unsigned int uid, tts_mode_e mode, bool* credential_needed)
{
SLOG(LOG_DEBUG, TAG_TTSC, "[TIDL] tts_tidl_request_initialize");
RETVM_IF(!info->connected, TTS_ERROR_OPERATION_FAILED, "[ERROR] Not Connected");
bool temp;
- int ret = rpc_port_proxy_tts_invoke_initialize(info->rpc_h, client->pid, uid, &temp);
+ int ret = rpc_port_proxy_tts_invoke_initialize(info->rpc_h, client->pid, uid, (int)mode, &temp);
int exception = get_last_result();
if (RPC_PORT_ERROR_NONE != exception) {
ret = __convert_unhandled_error(exception);
int tts_tidl_stop_listening(unsigned int uid);
-int tts_tidl_request_hello(unsigned int uid);
+int tts_tidl_request_hello(unsigned int uid, tts_mode_e mode);
int tts_tidl_request_hello_sync(unsigned int uid);
-int tts_tidl_request_initialize(unsigned int uid, bool* credential_needed);
+int tts_tidl_request_initialize(unsigned int uid, tts_mode_e mode, bool* credential_needed);
int tts_tidl_request_finalize(unsigned int uid);
int pid;
unsigned int uid;
- dbus_message_get_args(msg, &err, DBUS_TYPE_INT32, &pid, DBUS_TYPE_UINT32, &uid, DBUS_TYPE_INVALID);
+ int mode = 0;
+ dbus_message_get_args(msg, &err, DBUS_TYPE_INT32, &pid, DBUS_TYPE_UINT32, &uid, DBUS_TYPE_INT32, &mode, DBUS_TYPE_INVALID);
if (dbus_error_is_set(&err)) {
SLOG(LOG_ERROR, tts_tag(), "[IN ERROR] ttsd Hello : get arguments error (%s)", err.message);
dbus_error_free(&err);
} else {
- SLOG(LOG_INFO, tts_tag(), "[IN] ttsd hello : pid(%d), uid(%u)", pid, uid);
+ SLOG(LOG_INFO, tts_tag(), "[IN] ttsd hello : pid(%d), uid(%u), mode(%d)", pid, uid, mode);
bool is_initialized = false;
bool is_credential_needed = false;
int credential_needed = 0;
DBusError err;
dbus_error_init(&err);
- int pid, uid;
+ int pid;
+ unsigned int uid;
bool credential_needed = 0;
+ int mode = 0;
int ret = 0;
dbus_message_get_args(msg, &err,
DBUS_TYPE_INT32, &pid,
DBUS_TYPE_UINT32, &uid,
+ DBUS_TYPE_INT32, &mode,
DBUS_TYPE_INVALID);
SLOG(LOG_DEBUG, tts_tag(), ">>>>> TTS INITIALIZE");
ret = TTSD_ERROR_OPERATION_FAILED;
} else {
- SECURE_SLOG(LOG_DEBUG, tts_tag(), "[IN] tts initialize : pid(%d), uid(%u)", pid , uid);
+ SECURE_SLOG(LOG_DEBUG, tts_tag(), "[IN] tts initialize : pid(%d), uid(%u), mode(%d)", pid, uid, mode);
ret = ttsd_server_initialize(pid, uid, TTS_IPC_METHOD_DBUS, &credential_needed);
}
free(sender);
}
-static void __register_cb(rpc_port_stub_tts_context_h context, int pid, int uid, rpc_port_stub_tts_notify_cb_h callback, void* user_data)
+static void __register_cb(rpc_port_stub_tts_context_h context, int pid, int uid, int mode, rpc_port_stub_tts_notify_cb_h callback, void *user_data)
{
unsigned int u_uid = (unsigned int)uid;
- SLOG(LOG_ERROR, tts_tag(), ">>>>> TTS REGISTER CALLBACK uid(%u)", u_uid);
+ SLOG(LOG_ERROR, tts_tag(), ">>>>> TTS REGISTER CALLBACK uid(%u), mode(%d)", u_uid, mode);
bool is_initialized = false;
ttsd_server_is_already_initialized(pid, u_uid, &is_initialized);
return TTSD_ERROR_NONE;
}
-static int __initialize_cb(rpc_port_stub_tts_context_h context, int pid, int uid, bool *credential_needed, void *user_data)
+static int __initialize_cb(rpc_port_stub_tts_context_h context, int pid, int uid, int mode, bool *credential_needed, void *user_data)
{
unsigned int u_uid = (unsigned int)uid;
- SECURE_SLOG(LOG_ERROR, tts_tag(), "[IN] tts initialize : pid(%d), uid(%u)", pid, u_uid);
+ SECURE_SLOG(LOG_ERROR, tts_tag(), "[IN] tts initialize : pid(%d), uid(%u), mode(%d)", pid, u_uid, mode);
if (0 != ttsd_server_initialize(pid, u_uid, TTS_IPC_METHOD_TIDL, credential_needed)) {
return TTSD_ERROR_OPERATION_FAILED;
interface tts {
void notify_cb(int pid, int uid, bundle msg) delegate;
- void register_cb(int pid, int uid, notify_cb callback) async;
+ void register_cb(int pid, int uid, int mode, notify_cb callback) async;
int register_cb_sync(int pid, int uid, notify_cb callback);
int set_mode(in int uid, in int mode);
- int initialize(in int pid, in int uid, out bool credential_needed);
+ int initialize(in int pid, in int uid, in int mode, out bool credential_needed);
int finalize(in int uid);
int add_text(int uid, string text, string lang, int vctype, int speed, int uttid, string credential);
int stop(in int uid);