r11304: Add support back in for loading shared modules (not used yet)
authorJelmer Vernooij <jelmer@samba.org>
Wed, 26 Oct 2005 15:07:13 +0000 (15:07 +0000)
committerGerald (Jerry) Carter <jerry@samba.org>
Wed, 10 Oct 2007 18:45:16 +0000 (13:45 -0500)
(This used to be commit 90f49b6f70c4aaf0e4ab4fad2e6f9caeb0f6f3a6)

source4/build/m4/public.m4
source4/lib/basic.mk
source4/lib/ldb/config.m4
source4/lib/module.c [new file with mode: 0644]
source4/lib/registry/config.m4
source4/lib/tdb/config.m4

index c70514bdb67ab476517054f3a3d2fa0289d0bb33..69bce86f4d6199f0b67def8e037d6259e696dce5 100644 (file)
@@ -16,8 +16,6 @@ dnl SMB_EXT_LIB_FROM_PKGCONFIG(name,pkg-config name)
 dnl
 dnl SMB_EXT_LIB(name,libs,cflags,cppflags,ldflags)
 dnl
-dnl SMB_LIBRARY_ENABLE(name,default_build)
-dnl
 dnl SMB_BINARY_ENABLE(name,default_build)
 dnl
 dnl #######################################################
@@ -150,13 +148,6 @@ LDFLAGS = $5
 "
 ])
 
-dnl SMB_LIBRARY_ENABLE(name,default_build)
-AC_DEFUN([SMB_LIBRARY_ENABLE],
-[
-SMB_INFO_ENABLES="$SMB_INFO_ENABLES
-\$enabled{$1} = \"$2\";"
-])
-
 dnl SMB_BINARY_ENABLE(name,default_build)
 AC_DEFUN([SMB_BINARY_ENABLE],
 [
index 3ed538190873aea09fb817b06eaa4a8955d6abb8..6debed79c9ca3da9fd45c3248b9d43d2b08b4224 100644 (file)
@@ -55,6 +55,9 @@ INIT_OBJ_FILES = \
 OBJ_FILES = \
                gencache.o \
 
+[SUBSYSTEM::MODULE]
+OBJ_FILES = module.o
+
 ##############################
 # Start SUBSYSTEM LIBBASIC
 [SUBSYSTEM::LIBBASIC]
index 2b251befbbb313ad60d95738c6a6c15330f9ad06..551bacf5c9a2d0d04d1d6fd713b87d9bca8c9488 100644 (file)
@@ -2,8 +2,3 @@ SMB_MODULE_DEFAULT(libldb_sqlite3,NOT)
 if test x"$with_sqlite3_support" = x"yes"; then
     SMB_MODULE_DEFAULT(libldb_sqlite3,STATIC)
 fi
-
-SMB_LIBRARY_ENABLE(libldb,NO)
-if test x"$experimental" = x"yes"; then
-       SMB_LIBRARY_ENABLE(libldb,YES)
-fi
diff --git a/source4/lib/module.c b/source4/lib/module.c
new file mode 100644 (file)
index 0000000..b46d2b3
--- /dev/null
@@ -0,0 +1,93 @@
+/* 
+   Unix SMB/CIFS implementation.
+
+   Copyright (C) Jelmer Vernooij 2005
+   
+   This program is free software; you can redistribute it and/or modify
+   it under the terms of the GNU General Public License as published by
+   the Free Software Foundation; either version 2 of the License, or
+   (at your option) any later version.
+   
+   This program is distributed in the hope that it will be useful,
+   but WITHOUT ANY WARRANTY; without even the implied warranty of
+   MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
+   GNU General Public License for more details.
+   
+   You should have received a copy of the GNU General Public License
+   along with this program; if not, write to the Free Software
+   Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA.
+*/
+
+#include "includes.h"
+#include "dynconfig.h"
+#include "system/dir.h"
+
+static BOOL load_module(TALLOC_CTX *mem_ctx, const char *dir, const char *name)
+{
+       char *path;
+       void *handle;
+       BOOL (*init_module_fn) (void);
+       BOOL ret;
+
+       path = talloc_asprintf(mem_ctx, "%s/%s", dir, name);
+
+       handle = dlopen(path, 0);
+       if (handle == NULL) {
+               DEBUG(0, ("Unable to open %s: %s\n", path, dlerror()));
+               return False;
+       }
+
+       init_module_fn = dlsym(handle, "init_module");
+
+       if (init_module_fn == NULL) {
+               DEBUG(0, ("Unable to find init_module() in %s: %s\n", path, dlerror()));
+               return False;
+       }
+
+       ret = init_module_fn();
+       if (!ret) {
+               DEBUG(1, ("Loading module '%s' failed\n", path));
+       }
+
+       dlclose(handle);
+
+       talloc_free(path);
+
+       return ret;
+}
+
+BOOL load_modules(const char *subsystem)
+{
+       DIR *dir;
+       struct dirent *entry;
+       char *dir_path;
+       BOOL ret;
+       TALLOC_CTX *mem_ctx;
+       
+       mem_ctx = talloc_init(NULL);
+
+       dir_path = talloc_asprintf(mem_ctx, "%s/%s", dyn_LIBDIR, subsystem);
+       if (!dir_path) {
+               talloc_free(mem_ctx);
+               return False;
+       }
+
+       dir = opendir(subsystem);
+       if (dir == NULL) {
+               talloc_free(mem_ctx);
+               return False;
+       }
+
+       while((entry = readdir(dir))) {
+               if (!strcmp(entry->d_name, ".") || !strcmp(entry->d_name, ".."))
+                       continue;
+
+               ret &= load_module(mem_ctx, dir_path, entry->d_name);
+       }
+
+       closedir(dir);
+
+       talloc_free(mem_ctx);
+
+       return ret;
+}
index 27e55c63b4a39389e9c0a9dcae4026018d2e9cff..ffea96c82973a021280bef9e475255dfc5e04f08 100644 (file)
@@ -1,10 +1,4 @@
 # Registry backends
-                                                                                                                              
-if test t$BLDSHARED = ttrue; then
-    LIBWINREG_SHARED=bin/libwinregistry.$SHLIBEXT
-fi
-LIBWINREG=libwinregistry
-
 SMB_MODULE_DEFAULT(registry_gconf, NOT)
 
 SMB_EXT_LIB_FROM_PKGCONFIG(gconf, gconf-2.0)
@@ -16,7 +10,3 @@ AC_ARG_ENABLE(reg-gconf,
                SMB_MODULE_DEFAULT(registry_gconf, STATIC)
        fi
 ])
-
-if test x"$experimental" = x"yes"; then
-       SMB_LIBRARY_ENABLE(libwinregistry, YES)
-fi
index f1aa95df542a4543ebdeab6f6b6eb9ceb3e0a18f..bf3949790a70226e771d88b65a98fa7691d4c06b 100644 (file)
@@ -5,8 +5,3 @@ AC_DEFINE([_GNU_SOURCE],[],[Pull in GNU extensions])
 
 AC_HAVE_DECL(pread, [#include <unistd.h>])
 AC_HAVE_DECL(pwrite, [#include <unistd.h>])
-
-if test x"$experimental" = x"yes"; then
-       SMB_LIBRARY_ENABLE(libtdb,YES)
-fi
-