From 46badf19089668e470e9bb5b2300017f8948b49e Mon Sep 17 00:00:00 2001 From: Jelmer Vernooij Date: Tue, 16 Nov 2004 21:07:08 +0000 Subject: r3790: use a registration function that is called from dcerpc_*_init functions rather then a large table in librpc/gen_ndr/tables.c. This will allow us to only link in only the required gen_ndr files (speeds up linking quite a bit, makes binaries smaller). Each gen_ndr_* file now has a init function that calls the init functions of the interfaces it contains. I did it this way to keep pidl's code simple, though it might hurt startup time a bit. I'd be happy to change it if people like one function better. (This used to be commit 3c436590ae95b58ad6d00e72d6fdd08a4d80f208) --- source4/rpc_server/remote/dcesrv_remote.c | 19 +++++++++---------- 1 file changed, 9 insertions(+), 10 deletions(-) (limited to 'source4/rpc_server/remote/dcesrv_remote.c') diff --git a/source4/rpc_server/remote/dcesrv_remote.c b/source4/rpc_server/remote/dcesrv_remote.c index 957f5aa1b2..1ea6c1e4ea 100644 --- a/source4/rpc_server/remote/dcesrv_remote.c +++ b/source4/rpc_server/remote/dcesrv_remote.c @@ -21,7 +21,6 @@ #include "includes.h" #include "rpc_server/dcerpc_server.h" -#include "librpc/gen_ndr/tables.h" struct dcesrv_remote_private { struct dcerpc_pipe *c_pipe; @@ -158,12 +157,12 @@ static BOOL remote_fill_interface(struct dcesrv_interface *iface, const struct d static BOOL remote_op_interface_by_uuid(struct dcesrv_interface *iface, const char *uuid, uint32_t if_version) { - int i; + struct dcerpc_interface_list *l; - for (i=0;dcerpc_pipes[i];i++) { - if (dcerpc_pipes[i]->if_version == if_version && - strcmp(dcerpc_pipes[i]->uuid, uuid)==0) { - return remote_fill_interface(iface, dcerpc_pipes[i]); + for (l=dcerpc_pipes;l;l=l->next) { + if (l->table->if_version == if_version && + strcmp(l->table->uuid, uuid)==0) { + return remote_fill_interface(iface, l->table); } } @@ -172,11 +171,11 @@ static BOOL remote_op_interface_by_uuid(struct dcesrv_interface *iface, const ch static BOOL remote_op_interface_by_name(struct dcesrv_interface *iface, const char *name) { - int i; + struct dcerpc_interface_list *l; - for (i=0;dcerpc_pipes[i];i++) { - if (strcmp(dcerpc_pipes[i]->name, name)==0) { - return remote_fill_interface(iface, dcerpc_pipes[i]); + for (l=dcerpc_pipes;l;l=l->next) { + if (strcmp(l->table->name, name)==0) { + return remote_fill_interface(iface, l->table); } } -- cgit