diff options
| author | Sumit Bose <sbose@redhat.com> | 2017-02-08 14:28:28 +0100 |
|---|---|---|
| committer | Sumit Bose <sbose@redhat.com> | 2017-02-13 17:09:06 +0100 |
| commit | a900fb16256367af2daceec381e1908ecf17c15e (patch) | |
| tree | d4cde2a6651e58250b9b8820ee092a9b7bf43b9b | |
| parent | a5ecc93abb01cece628fdef04ebad43bba267419 (diff) | |
| download | sssd-a900fb16256367af2daceec381e1908ecf17c15e.tar.gz sssd-a900fb16256367af2daceec381e1908ecf17c15e.tar.xz sssd-a900fb16256367af2daceec381e1908ecf17c15e.zip | |
split_on_separator: move to a separate file
To be able to include split_on_separator() without additional
dependencies (only talloc), it is moved into a separate file.
| -rw-r--r-- | Makefile.am | 30 | ||||
| -rw-r--r-- | src/util/util.c | 93 | ||||
| -rw-r--r-- | src/util/util_ext.c | 121 |
3 files changed, 144 insertions, 100 deletions
diff --git a/Makefile.am b/Makefile.am index 2304b39c7..a3965ec00 100644 --- a/Makefile.am +++ b/Makefile.am @@ -957,6 +957,7 @@ libsss_util_la_SOURCES = \ src/sbus/sssd_dbus_common_signals.c \ src/sbus/sssd_dbus_utils.c \ src/util/util.c \ + src/util/util_ext.c \ src/util/memory.c \ src/util/safe-format-string.c \ src/util/server.c \ @@ -2297,19 +2298,23 @@ test_authtok_SOURCES = \ src/tests/cmocka/test_authtok.c \ src/util/authtok.c \ src/util/authtok-utils.c \ - src/util/util.c + src/util/util.c \ + src/util/util_ext.c \ + $(NULL) test_authtok_CFLAGS = \ $(AM_CFLAGS) \ $(TALLOC_CFLAGS) \ $(POPT_CFLAGS) \ - $(DHASH_CFLAGS) + $(DHASH_CFLAGS) \ + $(NULL) test_authtok_LDADD = \ $(TALLOC_LIBS) \ $(CMOCKA_LIBS) \ $(DHASH_LIBS) \ $(POPT_LIBS) \ libsss_test_common.la \ - libsss_debug.la + libsss_debug.la \ + $(NULL) sss_nss_idmap_tests_SOURCES = \ src/tests/cmocka/sss_nss_idmap-tests.c @@ -2779,6 +2784,7 @@ test_child_common_SOURCES = \ src/util/atomic_io.c \ src/util/util_errors.c \ src/util/util.c \ + src/util/util_ext.c \ $(NULL) test_child_common_CFLAGS = \ $(AM_CFLAGS) \ @@ -3646,6 +3652,7 @@ krb5_child_SOURCES = \ src/util/authtok.c \ src/util/authtok-utils.c \ src/util/util.c \ + src/util/util_ext.c \ src/util/signal.c \ src/util/strtonum.c \ src/util/become_user.c \ @@ -3678,6 +3685,7 @@ ldap_child_SOURCES = \ src/util/authtok.c \ src/util/authtok-utils.c \ src/util/util.c \ + src/util/util_ext.c \ src/util/signal.c \ src/util/become_user.c \ $(NULL) @@ -3698,6 +3706,7 @@ selinux_child_SOURCES = \ src/util/sss_semanage.c \ src/util/atomic_io.c \ src/util/util.c \ + src/util/util_ext.c \ $(NULL) selinux_child_CFLAGS = \ $(AM_CFLAGS) \ @@ -3716,6 +3725,7 @@ gpo_child_SOURCES = \ src/providers/ad/ad_gpo_child.c \ src/util/atomic_io.c \ src/util/util.c \ + src/util/util_ext.c \ src/util/signal.c gpo_child_CFLAGS = \ $(AM_CFLAGS) \ @@ -3747,6 +3757,7 @@ p11_child_SOURCES = \ src/p11_child/p11_child_nss.c \ src/util/atomic_io.c \ src/util/util.c \ + src/util/util_ext.c \ $(NULL) p11_child_CFLAGS = \ $(AM_CFLAGS) \ @@ -3764,16 +3775,21 @@ p11_child_LDADD = \ memberof_la_SOURCES = \ src/ldb_modules/memberof.c \ - src/util/util.c + src/util/util.c \ + src/util/util_ext.c \ + $(NULL) memberof_la_CFLAGS = \ - $(AM_CFLAGS) + $(AM_CFLAGS) \ + $(NULL) memberof_la_LIBADD = \ libsss_debug.la \ $(LDB_LIBS) \ - $(DHASH_LIBS) + $(DHASH_LIBS) \ + $(NULL) memberof_la_LDFLAGS = \ -avoid-version \ - -module + -module \ + $(NULL) if BUILD_KRB5_LOCATOR_PLUGIN sssd_krb5_locator_plugin_la_SOURCES = \ diff --git a/src/util/util.c b/src/util/util.c index 885f67e66..52a7868c0 100644 --- a/src/util/util.c +++ b/src/util/util.c @@ -35,99 +35,6 @@ int socket_activated = 0; int dbus_activated = 0; -int split_on_separator(TALLOC_CTX *mem_ctx, const char *str, - const char sep, bool trim, bool skip_empty, - char ***_list, int *size) -{ - int ret; - const char *substr_end = str; - const char *substr_begin = str; - const char *sep_pos = NULL; - size_t substr_len; - char **list = NULL; - int num_strings = 0; - TALLOC_CTX *tmp_ctx = NULL; - - if (str == NULL || *str == '\0' || _list == NULL) { - return EINVAL; - } - - tmp_ctx = talloc_new(NULL); - if (tmp_ctx == NULL) { - return ENOMEM; - } - - do { - substr_len = 0; - - /* If this is not the first substring, then move from the separator. */ - if (sep_pos != NULL) { - substr_end = sep_pos + 1; - substr_begin = sep_pos + 1; - } - - /* Find end of the first substring */ - while (*substr_end != sep && *substr_end != '\0') { - substr_end++; - substr_len++; - } - - sep_pos = substr_end; - - if (trim) { - /* Trim leading whitespace */ - while (isspace(*substr_begin) && substr_begin < substr_end) { - substr_begin++; - substr_len--; - } - - /* Trim trailing whitespace */ - while (substr_end - 1 > substr_begin && isspace(*(substr_end-1))) { - substr_end--; - substr_len--; - } - } - - /* Copy the substring to the output list of strings */ - if (skip_empty == false || substr_len > 0) { - list = talloc_realloc(tmp_ctx, list, char*, num_strings + 2); - if (list == NULL) { - ret = ENOMEM; - goto done; - } - - /* empty string is stored for substr_len == 0 */ - list[num_strings] = talloc_strndup(list, substr_begin, substr_len); - if (list[num_strings] == NULL) { - ret = ENOMEM; - goto done; - } - num_strings++; - } - - } while (*sep_pos != '\0'); - - if (list == NULL) { - /* No allocations were done, make space for the NULL */ - list = talloc(tmp_ctx, char *); - if (list == NULL) { - ret = ENOMEM; - goto done; - } - } - list[num_strings] = NULL; - - if (size) { - *size = num_strings; - } - - *_list = talloc_steal(mem_ctx, list); - ret = EOK; -done: - talloc_free(tmp_ctx); - return ret; -} - static void free_args(char **args) { int i; diff --git a/src/util/util_ext.c b/src/util/util_ext.c new file mode 100644 index 000000000..fceb8c873 --- /dev/null +++ b/src/util/util_ext.c @@ -0,0 +1,121 @@ +/* + SSSD helper calls - can be used by libraries for external use as well + + Authors: + Simo Sorce <ssorce@redhat.com> + + Copyright (C) 2017 Red Hat + + This program is free software; you can redistribute it and/or modify + it under the terms of the GNU General Public License as published by + the Free Software Foundation; either version 3 of the License, or + (at your option) any later version. + + This program is distributed in the hope that it will be useful, + but WITHOUT ANY WARRANTY; without even the implied warranty of + MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the + GNU General Public License for more details. + + You should have received a copy of the GNU General Public License + along with this program. If not, see <http://www.gnu.org/licenses/>. +*/ + +#include <talloc.h> +#include <stdbool.h> +#include <errno.h> +#include <ctype.h> + +#define EOK 0 + +int split_on_separator(TALLOC_CTX *mem_ctx, const char *str, + const char sep, bool trim, bool skip_empty, + char ***_list, int *size) +{ + int ret; + const char *substr_end = str; + const char *substr_begin = str; + const char *sep_pos = NULL; + size_t substr_len; + char **list = NULL; + int num_strings = 0; + TALLOC_CTX *tmp_ctx = NULL; + + if (str == NULL || *str == '\0' || _list == NULL) { + return EINVAL; + } + + tmp_ctx = talloc_new(NULL); + if (tmp_ctx == NULL) { + return ENOMEM; + } + + do { + substr_len = 0; + + /* If this is not the first substring, then move from the separator. */ + if (sep_pos != NULL) { + substr_end = sep_pos + 1; + substr_begin = sep_pos + 1; + } + + /* Find end of the first substring */ + while (*substr_end != sep && *substr_end != '\0') { + substr_end++; + substr_len++; + } + + sep_pos = substr_end; + + if (trim) { + /* Trim leading whitespace */ + while (isspace(*substr_begin) && substr_begin < substr_end) { + substr_begin++; + substr_len--; + } + + /* Trim trailing whitespace */ + while (substr_end - 1 > substr_begin && isspace(*(substr_end-1))) { + substr_end--; + substr_len--; + } + } + + /* Copy the substring to the output list of strings */ + if (skip_empty == false || substr_len > 0) { + list = talloc_realloc(tmp_ctx, list, char*, num_strings + 2); + if (list == NULL) { + ret = ENOMEM; + goto done; + } + + /* empty string is stored for substr_len == 0 */ + list[num_strings] = talloc_strndup(list, substr_begin, substr_len); + if (list[num_strings] == NULL) { + ret = ENOMEM; + goto done; + } + num_strings++; + } + + } while (*sep_pos != '\0'); + + if (list == NULL) { + /* No allocations were done, make space for the NULL */ + list = talloc(tmp_ctx, char *); + if (list == NULL) { + ret = ENOMEM; + goto done; + } + } + list[num_strings] = NULL; + + if (size) { + *size = num_strings; + } + + *_list = talloc_steal(mem_ctx, list); + ret = EOK; +done: + talloc_free(tmp_ctx); + return ret; +} |
