[Pkg-libvirt-commits] [libguestfs] 69/233: utils: Add utility function to split string into list of strings.
Hilko Bengen
bengen at moszumanska.debian.org
Wed Feb 19 21:10:56 UTC 2014
This is an automated email from the git hooks/post-receive script.
bengen pushed a commit to branch experimental
in repository libguestfs.
commit 89a617c07d83ac4517d62810c1eb597fa54a5d60
Author: Richard W.M. Jones <rjones at redhat.com>
Date: Sat Jan 18 15:25:26 2014 +0000
utils: Add utility function to split string into list of strings.
---
src/guestfs-internal-frontend.h | 1 +
src/utils.c | 56 +++++++++++++++++++++++++++++++++++++++++
2 files changed, 57 insertions(+)
diff --git a/src/guestfs-internal-frontend.h b/src/guestfs-internal-frontend.h
index e2cb0a5..3b0a480 100644
--- a/src/guestfs-internal-frontend.h
+++ b/src/guestfs-internal-frontend.h
@@ -97,6 +97,7 @@ extern size_t guestfs___count_strings (char *const *);
extern char *guestfs___concat_strings (char *const *);
extern char **guestfs___copy_string_list (char *const *);
extern char *guestfs___join_strings (const char *sep, char *const *);
+extern char **guestfs___split_string (char sep, const char *);
extern char *guestfs___exit_status_to_string (int status, const char *cmd_name, char *buffer, size_t buflen);
extern int guestfs___random_string (char *ret, size_t len);
extern char *guestfs___drive_name (size_t index, char *ret);
diff --git a/src/utils.c b/src/utils.c
index 3c30608..5eebdf6 100644
--- a/src/utils.c
+++ b/src/utils.c
@@ -127,6 +127,62 @@ guestfs___join_strings (const char *sep, char *const *argv)
return r;
}
+/* Split string at separator character 'sep', returning the list of
+ * strings. Returns NULL on memory allocation failure.
+ *
+ * Note (assuming sep is ':'):
+ * str == NULL => aborts
+ * str == "" => returns []
+ * str == "abc" => returns ["abc"]
+ * str == ":" => returns ["", ""]
+ */
+char **
+guestfs___split_string (char sep, const char *str)
+{
+ size_t i, n, c, len = strlen (str);
+ char reject[2] = { sep, '\0' };
+ char **ret;
+
+ /* We have to handle the empty string case differently else the code
+ * below will return [""].
+ */
+ if (str[0] == '\0') {
+ ret = malloc (1 * sizeof (char *));
+ if (!ret)
+ return NULL;
+ ret[0] = NULL;
+ return ret;
+ }
+
+ for (n = i = 0; i < len; ++i)
+ if (str[i] == sep)
+ n++;
+
+ /* We always return a list of length 1 + (# separator characters).
+ * We also have to add a trailing NULL.
+ */
+ ret = malloc ((n+2) * sizeof (char *));
+ if (!ret)
+ return NULL;
+ ret[n+1] = NULL;
+
+ for (n = i = 0; i <= len; ++i, ++n) {
+ c = strcspn (&str[i], reject);
+ ret[n] = strndup (&str[i], c);
+ if (ret[n] == NULL) {
+ for (i = 0; i < n; ++i)
+ free (ret[i]);
+ free (ret);
+ return NULL;
+ }
+ i += c;
+ if (str[i] == '\0') /* end of string? */
+ break;
+ }
+
+ return ret;
+}
+
/* Translate a wait/system exit status into a printable string. The
* string must be freed by the caller.
*/
--
Alioth's /usr/local/bin/git-commit-notice on /srv/git.debian.org/git/pkg-libvirt/libguestfs.git
More information about the Pkg-libvirt-commits
mailing list