GHashTable *event_info_table;
package_manager_event_cb event_cb;
void *user_data;
+ GMutex mutex;
};
struct package_manager_request_s {
}
package_manager->handle_id = package_manager_new_id();
+ g_mutex_init(&package_manager->mutex);
*manager = package_manager;
NULL);
}
+ g_mutex_clear(&manager->mutex);
pkgmgr_client_free(manager->pc);
g_hash_table_destroy(manager->event_info_table);
free(manager);
return PACKAGE_MANAGER_ERROR_NONE;
if (manager && manager->event_info_table) {
+ g_mutex_lock(&manager->mutex);
info = g_hash_table_lookup(manager->event_info_table, pkg_name);
} else {
_LOGE("invalid handle");
if (!info) {
if (strcasecmp(key, "start") != 0) {
_LOGD("unexpected signal or no info(removed)");
+ g_mutex_unlock(&manager->mutex);
return PACKAGE_MANAGER_ERROR_NONE;
}
}
if (strcasecmp(key, "start") == 0) {
ret = package_manager_get_event_type(val, &event_type);
- if (ret != PACKAGE_MANAGER_ERROR_NONE)
+ if (ret != PACKAGE_MANAGER_ERROR_NONE) {
+ g_mutex_unlock(&manager->mutex);
return PACKAGE_MANAGER_ERROR_INVALID_PARAMETER;
+ }
if (!info) {
__insert_event_info(manager, pkg_name, event_type,
g_hash_table_remove(manager->event_info_table, info->pkg_name);
}
+ g_mutex_unlock(&manager->mutex);
+
return PACKAGE_MANAGER_ERROR_NONE;
}
manager->event_cb = NULL;
manager->user_data = NULL;
+ g_mutex_lock(&manager->mutex);
g_hash_table_remove_all(manager->event_info_table);
+ g_mutex_unlock(&manager->mutex);
retval = pkgmgr_client_remove_listen_status(manager->pc);
if (retval == PKGMGR_R_EINVAL)