svn commit: samba r17317 - in branches/SAMBA_4_0/source/libcli/composite: .

metze at samba.org metze at samba.org
Sun Jul 30 16:48:41 GMT 2006


Author: metze
Date: 2006-07-30 16:48:41 +0000 (Sun, 30 Jul 2006)
New Revision: 17317

WebSVN: http://websvn.samba.org/cgi-bin/viewcvs.cgi?view=rev&root=samba&rev=17317

Log:
- add a composite_create() function that allocates and initialize
  the composite_context structue, we should try to convert all code
  to use this because there're a lot of places where the we have
  bugs with this task...
- add a composite_continue_smb2() helper

We should try to hide the internals of the composite code from the users
to avoid errors (and I found a lot of them... and will fix then step by step)

metze
Modified:
   branches/SAMBA_4_0/source/libcli/composite/composite.c
   branches/SAMBA_4_0/source/libcli/composite/composite.h


Changeset:
Modified: branches/SAMBA_4_0/source/libcli/composite/composite.c
===================================================================
--- branches/SAMBA_4_0/source/libcli/composite/composite.c	2006-07-30 16:36:56 UTC (rev 17316)
+++ branches/SAMBA_4_0/source/libcli/composite/composite.c	2006-07-30 16:48:41 UTC (rev 17317)
@@ -24,12 +24,30 @@
 #include "includes.h"
 #include "lib/events/events.h"
 #include "libcli/raw/libcliraw.h"
+#include "libcli/smb2/smb2.h"
 #include "libcli/composite/composite.h"
 #include "lib/messaging/irpc.h"
 #include "librpc/rpc/dcerpc.h"
 #include "libcli/nbt/libnbt.h"
 
 /*
+ create a new composite_context structure
+ and initialize it
+*/
+_PUBLIC_ struct composite_context *composite_create(TALLOC_CTX *mem_ctx,
+						    struct event_context *ev)
+{
+	struct composite_context *c;
+
+	c = talloc_zero(mem_ctx, struct composite_context);
+	if (!c) return NULL;
+	c->state = COMPOSITE_STATE_IN_PROGRESS;
+	c->event_ctx = ev;
+
+	return c;
+}
+
+/*
   block until a composite function has completed, then return the status
 */
 _PUBLIC_ NTSTATUS composite_wait(struct composite_context *c)
@@ -156,6 +174,16 @@
 	new_req->async.private = private_data;
 }
 
+_PUBLIC_ void composite_continue_smb2(struct composite_context *ctx,
+				      struct smb2_request *new_req,
+				      void (*continuation)(struct smb2_request *),
+				      void *private_data)
+{
+	if (composite_nomem(new_req, ctx)) return;
+	new_req->async.fn = continuation;
+	new_req->async.private = private_data;
+}
+
 _PUBLIC_ void composite_continue_nbt(struct composite_context *ctx,
 				     struct nbt_name_request *new_req,
 				     void (*continuation)(struct nbt_name_request *),

Modified: branches/SAMBA_4_0/source/libcli/composite/composite.h
===================================================================
--- branches/SAMBA_4_0/source/libcli/composite/composite.h	2006-07-30 16:36:56 UTC (rev 17316)
+++ branches/SAMBA_4_0/source/libcli/composite/composite.h	2006-07-30 16:48:41 UTC (rev 17317)
@@ -63,6 +63,7 @@
 
 struct irpc_request;
 struct smbcli_request;
+struct smb2_request;
 struct rpc_request;
 struct nbt_name_request;
 



More information about the samba-cvs mailing list