]> git.sur5r.net Git - openldap/blobdiff - servers/slapd/Makefile.in
ITS5282 fix for 2.3
[openldap] / servers / slapd / Makefile.in
index 4bc2c7314241f495a271a496f06d05e9f0260748..472d0d201a4c5a5de7d0bbfc227b449d571a3c53 100644 (file)
@@ -1,54 +1,80 @@
+## Makefile.in for slapd
 # $OpenLDAP$
+## This work is part of OpenLDAP Software <http://www.openldap.org/>.
 ##
-## Makefile.in for slapd
+## Copyright 1998-2007 The OpenLDAP Foundation.
+## All rights reserved.
+##
+## Redistribution and use in source and binary forms, with or without
+## modification, are permitted only as authorized by the OpenLDAP
+## Public License.
 ##
-PROGRAMS=slapd
-XPROGRAMS=sslapd libbackends.a .backend
+## A copy of this license is available in the file LICENSE in the
+## top-level directory of the distribution or, alternatively, at
+## <http://www.OpenLDAP.org/license.html>.
+
+SLAPTOOLS=slapadd slapcat slapdn slapindex slappasswd slaptest slapauth slapacl
+PROGRAMS=slapd $(SLAPTOOLS)
+XPROGRAMS=sslapd libbackends.a .backend liboverlays.a
 XSRCS=version.c
 
+SUBDIRS=back-* shell-backends slapi overlays
+
 NT_SRCS = nt_svc.c
 NT_OBJS = nt_svc.o ../../libraries/liblutil/slapdmsg.res
 
-SRCS   = main.c daemon.c connection.c search.c filter.c add.c cr.c \
-               attr.c entry.c config.c backend.c result.c operation.c \
+SRCS   = main.c globals.c bconfig.c config.c daemon.c \
+               connection.c search.c filter.c add.c cr.c \
+               attr.c entry.c backend.c result.c operation.c \
                dn.c compare.c modify.c delete.c modrdn.c ch_malloc.c \
                value.c ava.c bind.c unbind.c abandon.c filterentry.c \
                phonetic.c acl.c str2filter.c aclparse.c init.c user.c \
                repl.c lock.c controls.c extended.c kerberos.c passwd.c \
                schema.c schema_check.c schema_init.c schema_prep.c \
                schemaparse.c ad.c at.c mr.c syntax.c oc.c saslauthz.c \
-               oidm.c starttls.c index.c sets.c referral.c \
-               root_dse.c sasl.c module.c suffixalias.c mra.c mods.c \
-               limits.c backglue.c operational.c matchedValues.c \
+               oidm.c starttls.c index.c sets.c referral.c root_dse.c \
+               sasl.c module.c mra.c mods.c sl_malloc.c zn_malloc.c limits.c \
+               operational.c matchedValues.c cancel.c syncrepl.c \
+               backglue.c backover.c ctxcsn.c ldapsync.c frontend.c \
+               slapadd.c slapcat.c slapcommon.c slapdn.c slapindex.c \
+               slappasswd.c slaptest.c slapauth.c slapacl.c component.c \
+               aci.c alock.c \
                $(@PLAT@_SRCS)
 
-OBJS   = main.o daemon.o connection.o search.o filter.o add.o cr.o \
-               attr.o entry.o config.o backend.o result.o operation.o \
+OBJS   = main.o globals.o bconfig.o config.o daemon.o \
+               connection.o search.o filter.o add.o cr.o \
+               attr.o entry.o backend.o backends.o result.o operation.o \
                dn.o compare.o modify.o delete.o modrdn.o ch_malloc.o \
                value.o ava.o bind.o unbind.o abandon.o filterentry.o \
                phonetic.o acl.o str2filter.o aclparse.o init.o user.o \
                repl.o lock.o controls.o extended.o kerberos.o passwd.o \
                schema.o schema_check.o schema_init.o schema_prep.o \
                schemaparse.o ad.o at.o mr.o syntax.o oc.o saslauthz.o \
-               oidm.o starttls.o index.o sets.o referral.o \
-               root_dse.o sasl.o module.o suffixalias.o mra.o mods.o \
-               limits.o backglue.o operational.o matchedValues.o \
+               oidm.o starttls.o index.o sets.o referral.o root_dse.o \
+               sasl.o module.o mra.o mods.o sl_malloc.o zn_malloc.o limits.o \
+               operational.o matchedValues.o cancel.o syncrepl.o \
+               backglue.o backover.o ctxcsn.o ldapsync.o frontend.o \
+               slapadd.o slapcat.o slapcommon.o slapdn.o slapindex.o \
+               slappasswd.o slaptest.o slapauth.o slapacl.o component.o \
+               aci.o alock.o \
                $(@PLAT@_OBJS)
 
-LDAP_INCDIR= ../../include -Islapi
+LDAP_INCDIR= ../../include -I$(srcdir) -I$(srcdir)/slapi -I.
 LDAP_LIBDIR= ../../libraries
 
 SLAP_DIR=
-SLAPD_STATIC_DEPENDS=@SLAPD_SLAPI_DEPEND@ @SLAPD_NO_STATIC@ libbackends.a
+SLAPD_STATIC_DEPENDS=@SLAPD_NO_STATIC@ libbackends.a liboverlays.a
 SLAPD_STATIC_BACKENDS=@SLAPD_STATIC_BACKENDS@
 SLAPD_DYNAMIC_BACKENDS=@SLAPD_DYNAMIC_BACKENDS@
 
+SLAPI_LIBS=@LIBSLAPI@ @SLAPI_LIBS@
+
 XDEFS = $(MODULES_CPPFLAGS)
 XLDFLAGS = $(MODULES_LDFLAGS)
 
-XLIBS = $(SLAPD_STATIC_DEPENDS) $(SLAPD_L)
-XXLIBS = $(LDBM_LIBS) $(SLAPD_LIBS) $(SECURITY_LIBS) $(LDIF_LIBS) $(LUTIL_LIBS)
-XXXLIBS = $(LTHREAD_LIBS) $(MODULES_LIBS) $(SLAPI_LIBS)
+XLIBS = $(SLAPD_STATIC_DEPENDS) $(SLAPD_L) $(MODULES_LIBS) 
+XXLIBS = $(SLAPD_LIBS) $(SECURITY_LIBS) $(LUTIL_LIBS)
+XXXLIBS = $(LTHREAD_LIBS) $(SLAPI_LIBS)
 
 BUILD_OPT = "--enable-slapd"
 BUILD_SRV = @BUILD_SLAPD@
@@ -77,7 +103,7 @@ SLAPD_OBJECTS = $(@PLAT@_SLAPD_OBJECTS)
 # we want to export EVERY global symbol that it knows about (NOT including
 # symbols that are imported from other DLLs). The set of symbols to
 # export INCLUDES symbols from all static libraries that slapd gets
-# linked with, e.g. avl, ldbm, ldif, lunicode, lutil, etc. This list
+# linked with, e.g. avl, ldbm, lunicode, lutil, etc. This list
 # will also include liblber and libldap_r if they were built as static
 # libraries. ALSO included will be symbols from other STATIC libraries
 # outside the domain of the OpenLDAP source tree, e.g. regex, ltdl,
@@ -128,7 +154,7 @@ SLAPD_OBJECTS = $(@PLAT@_SLAPD_OBJECTS)
 # Thus, we do the best we can by depending on version.o, which depends
 # on its own very long list of dependencies.
 #
-slapd.def: libbackends.a version.o
+slapd.def: libbackends.a liboverlays.a version.o
        @for i in $(LDFLAGS) ; do \
            path=`expr "$$i" : "-L\(.*\)"`; \
            if test $$? != 0; then continue; fi; \
@@ -142,7 +168,7 @@ slapd.def: libbackends.a version.o
                    done="" ;\
                    base=`expr "$$i" : "-l\(.*\)"`; \
                    for p in $$paths ; do \
-                       for ext in la dll a ; do \
+                       for ext in la dll dll.a a ; do \
                            path=$$p/lib$$base.$$ext; \
                            test ! -f $$path && continue; \
                            if test $$ext = la ; then \
@@ -165,6 +191,15 @@ slapd.def: libbackends.a version.o
                    done; \
                    test -z "$$obj" && continue; \
                    ;; \
+               *.la) \
+                   if test -n "$(LTSTATIC)"; then \
+                           base=`expr "$$i" : ".*/\(.*\).la"`; \
+                           path=`expr "$$i" : "\(.*/\).*"`; \
+                           obj=$$path.libs/$$base.a; \
+                   fi; \
+                   ;; \
+               *.dll.a) \
+                   ;; \
                *.o | *.a) \
                    obj=$$i; \
            esac; \
@@ -224,25 +259,30 @@ slapd.exp: libslapd.a
        dlltool --dllname slapd.exe --input-def slapd.def \
                --base-file slapd.base --output-exp $@
 
-.slapi: FORCE
+slapi/.libs/libslapi.a: FORCE
        (cd slapi; $(MAKE) $(MFLAGS) all)
 
-libslapi.a: .slapi
-       $(AR) ruv slapi/libtmpslapd.a $(OBJS)
+libslapi.a: slapi/.libs/libslapi.a
        cp slapi/.libs/libslapi.a .
 
-slapd: $(SLAPD_DEPENDS)
+slapd: $(SLAPD_DEPENDS) @LIBSLAPI@
        $(LTLINK) -o $@ $(SLAPD_OBJECTS) $(LIBS) \
-               libslapi.a slapi/libtmpslapd.a \
                $(WRAP_LIBS)
+       $(RM) $(SLAPTOOLS)
+       for i in $(SLAPTOOLS); do \
+               $(LN_S) slapd$(EXEEXT) $$i$(EXEEXT); done
+
 
 sslapd: version.o
        $(LTLINK) -static -o $@ $(OBJS) version.o $(LIBS) $(WRAP_LIBS)
 
-tools $(SLAPD_DYNAMIC_BACKENDS): slapd
+dummy $(SLAPD_DYNAMIC_BACKENDS): slapd
        cd $@; $(MAKE) $(MFLAGS) all
        @touch $@
 
+dynamic_overlays: slapd
+       cd overlays; $(MAKE) $(MFLAGS) dynamic
+
 #
 # In Windows, dynamic backends have to be built after slapd. For this
 # reason, we only build static backends now and dynamic backends later.
@@ -284,13 +324,20 @@ libbackends.a: .backend
        fi
        @ls -l libbackends.a; echo ""
 
-version.c: $(OBJS) $(SLAPD_LIBDEPEND) 
+liboverlays.a: FORCE
+       cd overlays; $(MAKE) $(MFLAGS) static
+
+version.c: Makefile
        @-$(RM) $@
        $(MKVERSION) -s -n Versionstr slapd > $@
 
+version.o: version.c $(OBJS) $(SLAPD_LIBDEPEND) 
+
+backends.o: backends.c $(srcdir)/slap.h
+
 depend-local-srv: FORCE
-       @for i in back-* shell-backends slapi tools; do \
-               if test -d $$i -a -f $$i/Makefile ; then \
+       @for i in $(SUBDIRS); do \
+               if test -d $$i && test -f $$i/Makefile ; then \
                        echo; echo "  cd $$i; $(MAKE) $(MFLAGS) depend"; \
                        ( cd $$i; $(MAKE) $(MFLAGS) depend ); \
                        if test $$? != 0 ; then exit 1; fi ; \
@@ -299,42 +346,46 @@ depend-local-srv: FORCE
        @echo ""
 
 clean-local:
-       rm -f *.exp *.def *.base *.a *.objs symdummy.c
+       $(RM) *.exp *.def *.base *.a *.objs symdummy.c
+
+veryclean-local:
+       $(RM) backends.c
 
 clean-local-srv: FORCE
-       @for i in back-* shell-backends slapi tools; do \
-               if test -d $$i -a -f $$i/Makefile ; then \
+       @for i in $(SUBDIRS); do \
+               if test -d $$i && test -f $$i/Makefile ; then \
                        echo; echo "  cd $$i; $(MAKE) $(MFLAGS) clean"; \
                        ( cd $$i; $(MAKE) $(MFLAGS) clean ); \
                        if test $$? != 0 ; then exit 1; fi ; \
                fi; \
        done
-       rm -f *.tmp all-cffiles
+       $(RM) *.tmp all-cffiles
 
 veryclean-local-srv: FORCE
-       @for i in back-* shell-backends slapi tools; do \
-               if test -d $$i -a -f $$i/Makefile ; then \
+       @for i in $(SUBDIRS); do \
+               if test -d $$i && test -f $$i/Makefile ; then \
                        echo; echo "  cd $$i; $(MAKE) $(MFLAGS) clean"; \
                        ( cd $$i; $(MAKE) $(MFLAGS) veryclean ); \
                fi; \
        done
 
-install-local-srv: install-slapd install-conf install-schema install-tools
+install-local-srv: install-slapd install-tools \
+       install-conf install-db-config install-schema install-tools
 
 install-slapd: FORCE
        -$(MKDIR) $(DESTDIR)$(libexecdir)
-       -$(MKDIR) $(DESTDIR)$(localstatedir)
-       $(LTINSTALL) $(INSTALLFLAGS) -s -m 755 \
+       -$(MKDIR) $(DESTDIR)$(localstatedir)/run
+       $(LTINSTALL) $(INSTALLFLAGS) $(STRIP) -m 755 \
                slapd$(EXEEXT) $(DESTDIR)$(libexecdir)
-       @for i in back-* shell-backends slapi tools; do \
-           if test -d $$i -a -f $$i/Makefile ; then \
+       @for i in $(SUBDIRS); do \
+           if test -d $$i && test -f $$i/Makefile ; then \
                echo; echo "  cd $$i; $(MAKE) $(MFLAGS) install"; \
                ( cd $$i; $(MAKE) $(MFLAGS) install ); \
                if test $$? != 0 ; then exit 1; fi ; \
            fi; \
        done
 
-all-cffiles: slapd $(SLAPD_DYNAMIC_BACKENDS) tools
+all-cffiles: slapd $(SLAPD_DYNAMIC_BACKENDS) dynamic_overlays
        @if test $(PLAT) = NT; then \
            sysconfdir=`cygpath -w $(sysconfdir) | \
                $(SED) -e 's/\\\\/\\\\\\\\\\\\\\\\/g'`; \
@@ -354,23 +405,20 @@ all-cffiles: slapd $(SLAPD_DYNAMIC_BACKENDS) tools
        touch all-cffiles
 
 install-schema: FORCE
-       @-$(MKDIR) $(DESTDIR)$(schemadir)
-       for i in $(srcdir)/schema/*.schema ; do \
-               SF=`basename $$i` ; \
-               SD="$(DESTDIR)$(schemadir)/$$SF" ; \
-               if test ! -f $$SD ; then \
-                       echo "installing $$SF in $(schemadir)" ; \
-                       echo $(INSTALL) $(INSTALLFLAGS) -m 444 $$i $$SD ; \
-                       $(INSTALL) $(INSTALLFLAGS) -m 444 $$i $$SD ; \
-               else \
-                       echo "PRESERVING EXISTING SCHEMA FILE $$SD" ; \
-               fi ; \
-               $(INSTALL) $(INSTALLFLAGS) -m 444 $$i $$SD.default ; \
+       @if test -d $(DESTDIR)$(schemadir) ; then \
+               echo "MOVING EXISTING SCHEMA DIR to $(DESTDIR)$(schemadir).$$$$" ; \
+               mv $(DESTDIR)$(schemadir) $(DESTDIR)$(schemadir).$$$$ ; \
+       fi
+       $(MKDIR) $(DESTDIR)$(schemadir)
+       @SD=$(DESTDIR)$(schemadir) ; \
+       files=`cd $(srcdir)/schema ; echo README *.ldif *.schema` ; \
+       for i in $$files ; do \
+               echo $(INSTALL) $(INSTALLFLAGS) -m 444 schema/$$i $$SD/$$i ; \
+               $(INSTALL) $(INSTALLFLAGS) -m 444 $(srcdir)/schema/$$i $$SD/$$i ; \
        done
 
 install-conf: FORCE
        @-$(MKDIR) $(DESTDIR)$(sysconfdir)
-       @-$(INSTALL) -m 700 -d $(DESTDIR)$(localstatedir)/openldap-data
        $(INSTALL) $(INSTALLFLAGS) -m 600 slapd.conf.tmp $(DESTDIR)$(sysconfdir)/slapd.conf.default
        if test ! -f $(DESTDIR)$(sysconfdir)/slapd.conf; then \
                echo "installing slapd.conf in $(sysconfdir)"; \
@@ -380,7 +428,18 @@ install-conf: FORCE
                echo "PRESERVING EXISTING CONFIGURATION FILE $(DESTDIR)$(sysconfdir)/slapd.conf" ; \
        fi
 
+install-db-config: FORCE
+       @-$(MKDIR) $(DESTDIR)$(localstatedir) $(DESTDIR)$(sysconfdir)
+       @-$(INSTALL) -m 700 -d $(DESTDIR)$(localstatedir)/openldap-data
+       $(INSTALL) $(INSTALLFLAGS) -m 600 $(srcdir)/DB_CONFIG \
+               $(DESTDIR)$(localstatedir)/openldap-data/DB_CONFIG.example
+       $(INSTALL) $(INSTALLFLAGS) -m 600 $(srcdir)/DB_CONFIG \
+               $(DESTDIR)$(sysconfdir)/DB_CONFIG.example
+
 install-tools: FORCE
-       @-$(MKDIR) $(DESTDIR)$(sbindir)
-       (cd tools; $(MAKE) $(MFLAGS) install)
+       -$(MKDIR) $(DESTDIR)$(sbindir)
+       for i in $(SLAPTOOLS); do \
+               $(RM) $(DESTDIR)$(sbindir)/$$i$(EXEEXT); \
+               $(LN_S) -f $(DESTDIR)$(libexecdir)/slapd$(EXEEXT) $(DESTDIR)$(sbindir)/$$i$(EXEEXT); \
+       done