|
@@ -17,16 +17,14 @@ static int envlist_parse(envlist_t *envlist,
|
|
const char *env, int (*)(envlist_t *, const char *));
|
|
const char *env, int (*)(envlist_t *, const char *));
|
|
|
|
|
|
/*
|
|
/*
|
|
- * Allocates new envlist and returns pointer to that or
|
|
|
|
- * NULL in case of error.
|
|
|
|
|
|
+ * Allocates new envlist and returns pointer to it.
|
|
*/
|
|
*/
|
|
envlist_t *
|
|
envlist_t *
|
|
envlist_create(void)
|
|
envlist_create(void)
|
|
{
|
|
{
|
|
envlist_t *envlist;
|
|
envlist_t *envlist;
|
|
|
|
|
|
- if ((envlist = malloc(sizeof (*envlist))) == NULL)
|
|
|
|
- return (NULL);
|
|
|
|
|
|
+ envlist = g_malloc(sizeof(*envlist));
|
|
|
|
|
|
QLIST_INIT(&envlist->el_entries);
|
|
QLIST_INIT(&envlist->el_entries);
|
|
envlist->el_count = 0;
|
|
envlist->el_count = 0;
|
|
@@ -48,10 +46,10 @@ envlist_free(envlist_t *envlist)
|
|
entry = envlist->el_entries.lh_first;
|
|
entry = envlist->el_entries.lh_first;
|
|
QLIST_REMOVE(entry, ev_link);
|
|
QLIST_REMOVE(entry, ev_link);
|
|
|
|
|
|
- free((char *)entry->ev_var);
|
|
|
|
- free(entry);
|
|
|
|
|
|
+ g_free((char *)entry->ev_var);
|
|
|
|
+ g_free(entry);
|
|
}
|
|
}
|
|
- free(envlist);
|
|
|
|
|
|
+ g_free(envlist);
|
|
}
|
|
}
|
|
|
|
|
|
/*
|
|
/*
|
|
@@ -101,8 +99,7 @@ envlist_parse(envlist_t *envlist, const char *env,
|
|
if ((envlist == NULL) || (env == NULL))
|
|
if ((envlist == NULL) || (env == NULL))
|
|
return (EINVAL);
|
|
return (EINVAL);
|
|
|
|
|
|
- if ((tmpenv = strdup(env)) == NULL)
|
|
|
|
- return (errno);
|
|
|
|
|
|
+ tmpenv = g_strdup(env);
|
|
envsave = tmpenv;
|
|
envsave = tmpenv;
|
|
|
|
|
|
do {
|
|
do {
|
|
@@ -117,7 +114,7 @@ envlist_parse(envlist_t *envlist, const char *env,
|
|
tmpenv = envvar + 1;
|
|
tmpenv = envvar + 1;
|
|
} while (envvar != NULL);
|
|
} while (envvar != NULL);
|
|
|
|
|
|
- free(envsave);
|
|
|
|
|
|
+ g_free(envsave);
|
|
return ret;
|
|
return ret;
|
|
}
|
|
}
|
|
|
|
|
|
@@ -155,18 +152,14 @@ envlist_setenv(envlist_t *envlist, const char *env)
|
|
|
|
|
|
if (entry != NULL) {
|
|
if (entry != NULL) {
|
|
QLIST_REMOVE(entry, ev_link);
|
|
QLIST_REMOVE(entry, ev_link);
|
|
- free((char *)entry->ev_var);
|
|
|
|
- free(entry);
|
|
|
|
|
|
+ g_free((char *)entry->ev_var);
|
|
|
|
+ g_free(entry);
|
|
} else {
|
|
} else {
|
|
envlist->el_count++;
|
|
envlist->el_count++;
|
|
}
|
|
}
|
|
|
|
|
|
- if ((entry = malloc(sizeof (*entry))) == NULL)
|
|
|
|
- return (errno);
|
|
|
|
- if ((entry->ev_var = strdup(env)) == NULL) {
|
|
|
|
- free(entry);
|
|
|
|
- return (errno);
|
|
|
|
- }
|
|
|
|
|
|
+ entry = g_malloc(sizeof(*entry));
|
|
|
|
+ entry->ev_var = g_strdup(env);
|
|
QLIST_INSERT_HEAD(&envlist->el_entries, entry, ev_link);
|
|
QLIST_INSERT_HEAD(&envlist->el_entries, entry, ev_link);
|
|
|
|
|
|
return (0);
|
|
return (0);
|
|
@@ -201,8 +194,8 @@ envlist_unsetenv(envlist_t *envlist, const char *env)
|
|
}
|
|
}
|
|
if (entry != NULL) {
|
|
if (entry != NULL) {
|
|
QLIST_REMOVE(entry, ev_link);
|
|
QLIST_REMOVE(entry, ev_link);
|
|
- free((char *)entry->ev_var);
|
|
|
|
- free(entry);
|
|
|
|
|
|
+ g_free((char *)entry->ev_var);
|
|
|
|
+ g_free(entry);
|
|
|
|
|
|
envlist->el_count--;
|
|
envlist->el_count--;
|
|
}
|
|
}
|
|
@@ -212,12 +205,12 @@ envlist_unsetenv(envlist_t *envlist, const char *env)
|
|
/*
|
|
/*
|
|
* Returns given envlist as array of strings (in same form that
|
|
* Returns given envlist as array of strings (in same form that
|
|
* global variable environ is). Caller must free returned memory
|
|
* global variable environ is). Caller must free returned memory
|
|
- * by calling free(3) for each element and for the array. Returned
|
|
|
|
- * array and given envlist are not related (no common references).
|
|
|
|
|
|
+ * by calling g_free for each element and the array.
|
|
|
|
+ * Returned array and given envlist are not related (no common
|
|
|
|
+ * references).
|
|
*
|
|
*
|
|
* If caller provides count pointer, number of items in array is
|
|
* If caller provides count pointer, number of items in array is
|
|
- * stored there. In case of error, NULL is returned and no memory
|
|
|
|
- * is allocated.
|
|
|
|
|
|
+ * stored there.
|
|
*/
|
|
*/
|
|
char **
|
|
char **
|
|
envlist_to_environ(const envlist_t *envlist, size_t *count)
|
|
envlist_to_environ(const envlist_t *envlist, size_t *count)
|
|
@@ -225,13 +218,11 @@ envlist_to_environ(const envlist_t *envlist, size_t *count)
|
|
struct envlist_entry *entry;
|
|
struct envlist_entry *entry;
|
|
char **env, **penv;
|
|
char **env, **penv;
|
|
|
|
|
|
- penv = env = malloc((envlist->el_count + 1) * sizeof (char *));
|
|
|
|
- if (env == NULL)
|
|
|
|
- return (NULL);
|
|
|
|
|
|
+ penv = env = g_malloc((envlist->el_count + 1) * sizeof(char *));
|
|
|
|
|
|
for (entry = envlist->el_entries.lh_first; entry != NULL;
|
|
for (entry = envlist->el_entries.lh_first; entry != NULL;
|
|
entry = entry->ev_link.le_next) {
|
|
entry = entry->ev_link.le_next) {
|
|
- *(penv++) = strdup(entry->ev_var);
|
|
|
|
|
|
+ *(penv++) = g_strdup(entry->ev_var);
|
|
}
|
|
}
|
|
*penv = NULL; /* NULL terminate the list */
|
|
*penv = NULL; /* NULL terminate the list */
|
|
|
|
|