X-Git-Url: http://git.ozlabs.org/?a=blobdiff_plain;f=ccan%2Ftal%2Ftal.h;h=548b9274f700c0b9978b9126fd0c8261dbf2b5a3;hb=f14e4e974f7641262de3fe10c09c984c51a69dd7;hp=3da1e4203d8edcb332e4701d876c05091977acbc;hpb=0112c6a13f4bab7f794e6e2bde397738b8d2b540;p=ccan diff --git a/ccan/tal/tal.h b/ccan/tal/tal.h index 3da1e420..548b9274 100644 --- a/ccan/tal/tal.h +++ b/ccan/tal/tal.h @@ -256,13 +256,13 @@ const char *tal_name(const tal_t *ptr); * tal_count - get the count of objects in a tal_arr. * @ptr: The tal allocated object array. * - * Returns 0 if @ptr has no length property, but we aware that that is + * Returns 0 if @ptr has no length property, but be aware that that is * also a valid size! */ size_t tal_count(const tal_t *ptr); /** - * tal_first - get the first tal object child. + * tal_first - get the first immediate tal object child. * @root: The tal allocated object to start with, or NULL. * * Returns NULL if there are no children. @@ -270,15 +270,13 @@ size_t tal_count(const tal_t *ptr); tal_t *tal_first(const tal_t *root); /** - * tal_next - get the next tal object child. - * @root: The tal allocated object to start with, or NULL. + * tal_next - get the next immediate tal object child. * @prev: The return value from tal_first or tal_next. * - * Returns NULL if there are no more children. This should be safe to - * call on an altering tree unless @prev is no longer a descendent of - * @root. + * Returns NULL if there are no more immediate children. This should be safe to + * call on an altering tree unless @prev is no longer valid. */ -tal_t *tal_next(const tal_t *root, const tal_t *prev); +tal_t *tal_next(const const tal_t *prev); /** * tal_parent - get the parent of a tal object. @@ -289,14 +287,25 @@ tal_t *tal_next(const tal_t *root, const tal_t *prev); tal_t *tal_parent(const tal_t *ctx); /** - * tal_dup - duplicate an array. + * tal_dup - duplicate an object. + * @ctx: The tal allocated object to be parent of the result (may be NULL). + * @type: the type (should match type of @p!) + * @p: the object to copy (or reparented if take()) + */ +#define tal_dup(ctx, type, p) \ + ((type *)tal_dup_((ctx), tal_typechk_(p, type *), \ + sizeof(type), 1, 0, \ + false, TAL_LABEL(type, ""))) + +/** + * tal_dup_arr - duplicate an array. * @ctx: The tal allocated object to be parent of the result (may be NULL). * @type: the type (should match type of @p!) * @p: the array to copy (or resized & reparented if take()) * @n: the number of sizeof(type) entries to copy. * @extra: the number of extra sizeof(type) entries to allocate. */ -#define tal_dup(ctx, type, p, n, extra) \ +#define tal_dup_arr(ctx, type, p, n, extra) \ ((type *)tal_dup_((ctx), tal_typechk_(p, type *), \ sizeof(type), (n), (extra), \ true, TAL_LABEL(type, "[]")))