summaryrefslogtreecommitdiffstats
path: root/server/util
diff options
context:
space:
mode:
authorJakub Hrozek <jhrozek@redhat.com>2009-12-09 04:00:09 +0100
committerStephen Gallagher <sgallagh@redhat.com>2009-12-10 17:20:20 -0500
commite8498810dc7eb20ea4a652b75e2da194b604f740 (patch)
tree7b8c6736c9f57252f9b0da23d1784d893dd79783 /server/util
parent51a52431ed52e0312c680e52371882088482071f (diff)
downloadsssd-e8498810dc7eb20ea4a652b75e2da194b604f740.tar.gz
sssd-e8498810dc7eb20ea4a652b75e2da194b604f740.tar.xz
sssd-e8498810dc7eb20ea4a652b75e2da194b604f740.zip
Consolidate code for splitting strings by separator
There were two functions for parsing strings by a separator. This patch consolidates on the one previously used in confdb. This also allows stripping the tokens of whitespace. Fixes: #319
Diffstat (limited to 'server/util')
-rw-r--r--server/util/util.c141
-rw-r--r--server/util/util.h5
2 files changed, 99 insertions, 47 deletions
diff --git a/server/util/util.c b/server/util/util.c
index 9049602c4..57ceb597f 100644
--- a/server/util/util.c
+++ b/server/util/util.c
@@ -18,68 +18,121 @@
along with this program. If not, see <http://www.gnu.org/licenses/>.
*/
+#include <ctype.h>
+
#include "talloc.h"
#include "util/util.h"
-/* Split string in a list using a set of legal seprators */
-
-int sss_split_list(TALLOC_CTX *memctx, const char *string,
- const char *sep, char ***_list, int *c)
+/* split a string into an allocated array of strings.
+ * the separator is a string, and is case-sensitive.
+ * optionally single values can be trimmed of of spaces and tabs */
+int split_on_separator(TALLOC_CTX *mem_ctx, const char *str,
+ const char sep, bool trim, char ***_list, int *size)
{
- const char *p;
- const char *s;
- char **list;
- char **t;
- int i;
+ const char *t, *p, *n;
+ size_t l, len;
+ char **list, **r;
+ const char sep_str[2] = { sep, '\0'};
+
+ if (!str || !*str || !_list) return EINVAL;
+
+ t = str;
- /* split server parm into a list */
list = NULL;
- s = string;
- i = 0;
-
- while (s) {
- p = strpbrk(s, sep);
- if (p) {
- if (p - s == 1) {
- s++;
- continue;
- }
+ l = 0;
- t = talloc_realloc(memctx, list, char *, i + 1);
- if (!t) {
- talloc_zfree(list);
- return ENOMEM;
+ /* trim leading whitespace */
+ if (trim)
+ while (isspace(*t)) t++;
+
+ /* find substrings separated by the separator */
+ while (t && (p = strpbrk(t, sep_str))) {
+ len = p - t;
+ n = p + 1; /* save next string starting point */
+ if (trim) {
+ /* strip whitespace after the separator
+ * so it's not in the next token */
+ while (isspace(*t)) {
+ t++;
+ len--;
+ if (len == 0) break;
}
- list = t;
- list[i] = talloc_asprintf(list, "%.*s", (int)(p - s), s);
- if (!list[i]) {
- talloc_zfree(list);
- return ENOMEM;
+ p--;
+ /* strip whitespace before the separator
+ * so it's not in the current token */
+ while (len > 0 && (isspace(*p))) {
+ len--;
+ p--;
}
- i++;
+ }
+
+ /* Add the token to the array, +2 b/c of the trailing NULL */
+ r = talloc_realloc(mem_ctx, list, char *, l + 2);
+ if (!r) {
+ talloc_free(list);
+ return ENOMEM;
+ } else {
+ list = r;
+ }
- s = p + 1;
+ if (len == 0) {
+ list[l] = talloc_strdup(list, "");
+ } else {
+ list[l] = talloc_strndup(list, t, len);
+ }
+ if (!list[l]) {
+ talloc_free(list);
+ return ENOMEM;
+ }
+ l++;
+
+ t = n; /* move to next string */
+ }
+
+ /* Handle the last remaining token */
+ if (t) {
+ r = talloc_realloc(mem_ctx, list, char *, l + 2);
+ if (!r) {
+ talloc_free(list);
+ return ENOMEM;
+ } else {
+ list = r;
}
- else {
- t = talloc_realloc(memctx, list, char *, i + 1);
- if (!t) {
- talloc_zfree(list);
- return ENOMEM;
+ if (trim) {
+ /* trim leading whitespace */
+ len = strlen(t);
+ while (isspace(*t)) {
+ t++;
+ len--;
+ if (len == 0) break;
}
- list = t;
- list[i] = talloc_strdup(list, s);
- if (!list[i]) {
- talloc_zfree(list);
- return ENOMEM;
+ /* trim trailing whitespace */
+ p = t + len - 1;
+ while (len > 0 && (isspace(*p))) {
+ len--;
+ p--;
}
- i++;
- s = NULL;
+ if (len == 0) {
+ list[l] = talloc_strdup(list, "");
+ } else {
+ list[l] = talloc_strndup(list, t, len);
+ }
+ } else {
+ list[l] = talloc_strdup(list, t);
+ }
+ if (!list[l]) {
+ talloc_free(list);
+ return ENOMEM;
}
+ l++;
}
+ list[l] = NULL; /* terminate list */
+
+ if (size) *size = l + 1;
*_list = list;
- *c = i;
+
return EOK;
}
diff --git a/server/util/util.h b/server/util/util.h
index 1c583e231..a639b1927 100644
--- a/server/util/util.h
+++ b/server/util/util.h
@@ -229,7 +229,6 @@ errno_t check_and_open_readonly(const char *filename, int *fd, const uid_t uid,
const gid_t gid, const mode_t mode);
/* from util.c */
-int sss_split_list(TALLOC_CTX *memctx, const char *string,
- const char *sep, char ***_list, int *c);
-
+int split_on_separator(TALLOC_CTX *mem_ctx, const char *str,
+ const char sep, bool trim, char ***_list, int *size);
#endif /* __SSSD_UTIL_H__ */