diff options
-rw-r--r-- | source3/lib/idmap_cache.c | 22 |
1 files changed, 10 insertions, 12 deletions
diff --git a/source3/lib/idmap_cache.c b/source3/lib/idmap_cache.c index 8bad6e4eab..0d792d456c 100644 --- a/source3/lib/idmap_cache.c +++ b/source3/lib/idmap_cache.c @@ -37,7 +37,7 @@ bool idmap_cache_find_sid2unixid(const struct dom_sid *sid, struct unixid *id, { fstring sidstr; char *key; - char *value; + char *value = NULL; char *endptr; time_t timeout; bool ret; @@ -50,8 +50,7 @@ bool idmap_cache_find_sid2unixid(const struct dom_sid *sid, struct unixid *id, } ret = gencache_get(key, &value, &timeout); if (!ret) { - TALLOC_FREE(key); - return false; + goto done; } DEBUG(10, ("Parsing value for key [%s]: value=[%s]\n", key, value)); @@ -76,31 +75,28 @@ bool idmap_cache_find_sid2unixid(const struct dom_sid *sid, struct unixid *id, break; case '\0': - TALLOC_FREE(key); - SAFE_FREE(value); DEBUG(0, ("FAILED to parse value for key [%s] " "(id=[%llu], endptr=[%s]): " "no type character after colon\n", key, (unsigned long long)tmp_id.id, endptr)); - return false; + ret = false; + goto done; default: - TALLOC_FREE(key); - SAFE_FREE(value); DEBUG(0, ("FAILED to parse value for key [%s] " "(id=[%llu], endptr=[%s]): " "illegal type character '%c'\n", key, (unsigned long long)tmp_id.id, endptr, endptr[1])); - return false; + ret = false; + goto done; } if (endptr[2] != '\0') { - TALLOC_FREE(key); - SAFE_FREE(value); DEBUG(0, ("FAILED to parse value for key [%s] " "(id=[%llu], endptr=[%s]): " "more than 1 type character after colon\n", key, (unsigned long long)tmp_id.id, endptr)); - return false; + ret = false; + goto done; } *id = tmp_id; @@ -110,6 +106,8 @@ bool idmap_cache_find_sid2unixid(const struct dom_sid *sid, struct unixid *id, "colon missing after id=[%llu]\n", key, value, (unsigned long long)tmp_id.id)); } + +done: TALLOC_FREE(key); SAFE_FREE(value); return ret; |