Because strtok() modifies the original data,
the second query for global db is affected.
this causes unexpected result of multiple categroy filtering.
Change-Id: I72595fe9d254c36bbb433ff035aa07d10fd34177
Signed-off-by: jongmyeongko <jongmyeong.ko@samsung.com>
(cherry picked from commit
56992a61025d8c50ec59e57b550d6f3215857164)
pkgmgrinfo_node_x *node = (pkgmgrinfo_node_x *)data;
char buf[MAX_QUERY_LEN] = {'\0'};
int flag = 0;
pkgmgrinfo_node_x *node = (pkgmgrinfo_node_x *)data;
char buf[MAX_QUERY_LEN] = {'\0'};
int flag = 0;
char *ptr = NULL;
char *saveptr = NULL;
size_t len = 0;
char *ptr = NULL;
char *saveptr = NULL;
size_t len = 0;
break;
case E_PMINFO_APPINFO_PROP_APP_CATEGORY:
snprintf(buf, sizeof(buf), "package_app_app_category.category IN (");
break;
case E_PMINFO_APPINFO_PROP_APP_CATEGORY:
snprintf(buf, sizeof(buf), "package_app_app_category.category IN (");
- ptr = strtok_r(node->value, ",", &saveptr);
- if (ptr == NULL)
+ value = strdup(node->value);
+ if (value == NULL) {
+ _LOGE("out of memeory");
+ }
+ ptr = strtok_r(value, ",", &saveptr);
+ if (ptr == NULL) {
+ free(value);
+ return 0;
+ }
strncat(buf, "?", MAX_QUERY_LEN - len - 1);
len += strlen("?");
*params = g_list_append(*params, strdup(ptr));
strncat(buf, "?", MAX_QUERY_LEN - len - 1);
len += strlen("?");
*params = g_list_append(*params, strdup(ptr));
len += strlen("?");
*condition = strdup(buf);
flag = E_PMINFO_APPINFO_JOIN_CATEGORY;
len += strlen("?");
*condition = strdup(buf);
flag = E_PMINFO_APPINFO_JOIN_CATEGORY;
return flag;
case E_PMINFO_APPINFO_PROP_APP_NODISPLAY:
return flag;
case E_PMINFO_APPINFO_PROP_APP_NODISPLAY: