From d0d15d58c679d4a5ebbdf9a1dd5788782d4dc49d Mon Sep 17 00:00:00 2001 From: Ben Pfaff Date: Wed, 10 Feb 2010 15:54:43 -0800 Subject: [PATCH] uuid: New function uuid_from_string_prefix(). For use in an upcoming commit. --- lib/uuid.c | 20 ++++++++++++++++++-- lib/uuid.h | 1 + 2 files changed, 19 insertions(+), 2 deletions(-) diff --git a/lib/uuid.c b/lib/uuid.c index 620c039cb..9aaa91590 100644 --- a/lib/uuid.c +++ b/lib/uuid.c @@ -140,6 +140,22 @@ uuid_compare_3way(const struct uuid *a, const struct uuid *b) * be set to all-zero-bits. */ bool uuid_from_string(struct uuid *uuid, const char *s) +{ + if (!uuid_from_string_prefix(uuid, s)) { + return false; + } else if (s[UUID_LEN] != '\0') { + uuid_zero(uuid); + return false; + } else { + return true; + } +} + +/* Same as uuid_from_string() but s[UUID_LEN] is not required to be a null byte + * to succeed; that is, 's' need only begin with UUID syntax, not consist + * entirely of it. */ +bool +uuid_from_string_prefix(struct uuid *uuid, const char *s) { static const char template[] = "00000000-1111-1111-2222-222233333333"; const char *t; @@ -152,10 +168,10 @@ uuid_from_string(struct uuid *uuid, const char *s) goto error; } *part = (*part << 4) + hexit_value(*s); - } else if (*t != *s) { - goto error; } else if (*t == 0) { return true; + } else if (*t != *s) { + goto error; } } diff --git a/lib/uuid.h b/lib/uuid.h index 1059c26d1..815977995 100644 --- a/lib/uuid.h +++ b/lib/uuid.h @@ -77,5 +77,6 @@ void uuid_zero(struct uuid *); bool uuid_is_zero(const struct uuid *); int uuid_compare_3way(const struct uuid *, const struct uuid *); bool uuid_from_string(struct uuid *, const char *); +bool uuid_from_string_prefix(struct uuid *, const char *); #endif /* vswitchd/cfgdb.h */ -- 2.43.0