return make_tdb_data((const uint8_t *)string, string ? strlen(string) + 1 : 0);
}
+TDB_DATA tdb_data_talloc_copy(TALLOC_CTX* mem_ctx, TDB_DATA data) {
+ TDB_DATA ret = {
+ .dptr = (uint8_t *)talloc_size(mem_ctx, data.dsize+1),
+ .dsize = data.dsize
+ };
+ if (ret.dptr == NULL) {
+ ret.dsize = 0;
+ } else {
+ memcpy(ret.dptr, data.dptr, data.dsize);
+ ret.dptr[ret.dsize] = '\0';
+ }
+ return ret;
+}
+
+
/****************************************************************************
Lock a chain by string. Return non-zero if lock failed.
****************************************************************************/
bool tdb_data_is_empty(TDB_DATA d);
TDB_DATA string_tdb_data(const char *string);
TDB_DATA string_term_tdb_data(const char *string);
+TDB_DATA tdb_data_talloc_copy(TALLOC_CTX* mem_ctx, TDB_DATA data);
/****************************************************************************
Lock a chain by string. Return non-zero if lock failed.
/* TDB_DATA *******************************************************************/
static char* print_data(TALLOC_CTX* mem_ctx, TDB_DATA d);
static TDB_DATA parse_data(TALLOC_CTX* mem_ctx, const char** ptr);
-static TDB_DATA talloc_copy(TALLOC_CTX* mem_ctx, TDB_DATA data);
/* record *********************************************************************/
diff = unpack_diff(recvalue);
talloc_free(diff.nval.dptr);
}
- diff.nval = talloc_copy(ctx->diff, value);
+ diff.nval = tdb_data_talloc_copy(ctx->diff, value);
DEBUG_DIFF(2, mem, "TDB DIFF", key, diff.oval, diff.nval);
if (NT_STATUS_IS_OK(status)) {
TDB_DATA_diff diff = unpack_diff(tmp);
- TDB_DATA ret = talloc_copy(mem_ctx, diff.nval);
+ TDB_DATA ret = tdb_data_talloc_copy(mem_ctx, diff.nval);
talloc_free(tmp.dptr);
return ret;
}
}
}
-TDB_DATA talloc_copy(TALLOC_CTX* mem_ctx, TDB_DATA data) {
- TDB_DATA ret = {
- .dptr = (uint8_t *)talloc_size(mem_ctx, data.dsize+1),
- .dsize = data.dsize
- };
- if (ret.dptr == NULL) {
- ret.dsize = 0;
- } else {
- memcpy(ret.dptr, data.dptr, data.dsize);
- ret.dptr[ret.dsize] = '\0';
- }
- return ret;
-}
-
static bool is_cstr(TDB_DATA str) {
return !tdb_data_is_empty(str) && str.dptr[str.dsize-1] == '\0';
}
DEBUG(0, ("Out of memory.\n"));
return NULL;
}
- ret->key = talloc_copy(ret, key);
- ret->val = talloc_copy(ret, val);
+ ret->key = tdb_data_talloc_copy(ret, key);
+ ret->val = tdb_data_talloc_copy(ret, val);
if ((ret->key.dptr == NULL && key.dptr != NULL) ||
(ret->val.dptr == NULL && val.dptr != NULL))
{