]> git.sur5r.net Git - openldap/blobdiff - servers/slapd/Makefile.in
Per ITS#419, don't require SLAPD_RLOOKUPS when HAVE_TCPD
[openldap] / servers / slapd / Makefile.in
index 6def4530b9ad951ebcea76594c189286a958db15..bef40b837332320187844a04889990749deca1c6 100644 (file)
@@ -1,47 +1,96 @@
+# $OpenLDAP$
 ##
 ## Makefile.in for slapd
 ##
 PROGRAMS=slapd
-XPROGRAMS=libbackends.a .backend
+XPROGRAMS=sslapd libbackends.a .backend
+XSRCS=version.c
+
+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 charray.c \
                attr.c entry.c config.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 \
-               detach.c strdup.c tempnam.c repl.c lock.c \
-               schema.c schemaparse.c monitor.c configinfo.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 schemaparse.c monitor.c configinfo.c starttls.c \
+               root_dse.c sasl.c module.c suffixalias.c $(@PLAT@_SRCS)
+
 OBJS   = main.o daemon.o connection.o search.o filter.o add.o charray.o \
                attr.o entry.o config.o backend.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 \
-               detach.o strdup.o tempnam.o repl.o lock.o \
-               schema.o schemaparse.o monitor.o configinfo.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 schemaparse.o monitor.o configinfo.o starttls.o \
+               root_dse.o sasl.o module.o suffixalias.o $(@PLAT@_OBJS)
+
+LDAP_INCDIR= ../../include
+LDAP_LIBDIR= ../../libraries
+
+SLAP_DIR=
+SLAPD_MODULES=@SLAPD_MODULES_LIST@
+XDEFS = $(MODULES_CPPFLAGS)
+XLDFLAGS = $(MODULES_LDFLAGS) $(SLAPD_MODULES)
+
+# $(LTHREAD_LIBS) must be last
+XLIBS = libbackends.a -lavl -lldbm -lldif -llutil -lldap_r -llber
+XXLIBS = $(LDBM_LIBS) $(SLAPD_LIBS) \
+       $(SLAPD_PERL_LDFLAGS) $(SECURITY_LIBS) \
+       $(LDIF_LIBS) $(LUTIL_LIBS)
+XXXLIBS = $(LTHREAD_LIBS) $(MODULES_LIBS)
 
 BUILD_OPT = "--enable-slapd"
 BUILD_SRV = @BUILD_SLAPD@
 
-all-srv: FORCE
-       $(MAKE) $(MFLAGS) backendslib
-       $(MAKE) $(MFLAGS) slapd
-       (cd tools; $(MAKE) $(MFLAGS) all)
+all-local-srv: all-cffiles
+
+NT_DYN_DEFS  = -DLIBLBER_DECL=dllimport -DLIBLDAP_DECL=dllimport
+
+DEFINES = $(@PLAT@_@LIB_LINKAGE@_DEFS)
+
+slapd.def: slapd.syms
+       (                                                       \
+           echo EXPORTS > $@;                                  \
+           _hint=1;                                            \
+           for symbol in `cat $<`; do                          \
+               echo " $$symbol @ $$_hint ; " >> $@;            \
+               _hint=`expr 1 + $$_hint`;                       \
+           done                                                \
+       )
 
-XDEFS = @SLAPD_DEFS@ @LDBM_DEFS@ @LTHREAD_DEFS@
-XLIBS = @SLAPD_LIBS@ libbackends.a \
-       -lavl -llutil -lldbm @LDBM_LIBS@ -llthread @LTHREAD_LIBS@
+slapd.base: version.o
+       $(LTLINK) -o slapd $(OBJS) version.o $(LIBS) $(WRAP_LIBS) \
+           -Wl,--base-file,$@
+       rm -f slapd
 
-slapd: version.o
-       $(CC) $(LDFLGS) -o $@ $(OBJS) version.o $(LIBS)
+slapd.exp: slapd.def slapd.base
+       dlltool --dllname slapd.exe --def slapd.def --base-file slapd.base \
+           --output-exp $@
 
-backendslib:   FORCE
+libslapd.a: slapd.def
+       dlltool --dllname slapd.exe --def $< --output-lib $@
+
+NT_EXP = slapd.exp
+NT_IMP_LIB = libslapd.a
+
+slapd: $(@PLAT@_IMP_LIB) libbackends.a version.o $(@PLAT@_EXP)
+       $(LTLINK) -o $@ $(OBJS) version.o $(LIBS) $(WRAP_LIBS) $(@PLAT@_EXP)
+       (cd tools; $(MAKE) $(MFLAGS) all)
+
+sslapd: version.o
+       $(LTLINK) -static -o $@ $(OBJS) version.o $(LIBS) $(WRAP_LIBS)
+
+.backend: FORCE
        @for i in back-*; do \
                if [ -d $$i ]; then \
                        echo " "; echo "  cd $$i; $(MAKE) $(MFLAGS) all"; \
                        ( cd $$i; $(MAKE) $(MFLAGS) all ); \
                fi; \
        done; \
-       echo " "; \
-       $(MAKE) $(MFLAGS) libbackends.a
+       echo " "
 
 libbackends.a: .backend
        @$(RM) -r tmp
@@ -66,45 +115,100 @@ libbackends.a: .backend
        fi
        @ls -l libbackends.a
 
-version.c: libbackends.a $(OBJS) \
-               $(LDAP_LIBDIR)/liblber.a \
-               $(LDAP_LIBDIR)/liblldbm.a \
-               $(LDAP_LIBDIR)/liblavl.a \
-               $(LDAP_LIBDIR)/liblldif.a \
-               $(LDAP_LIBDIR)/liblthread.a 
-       $(RM) $@
-       (u=$${USER-root} v=`$(CAT) $(VERSIONFILE)` d=`$(PWD)` h=`$(HOSTNAME)` \
-       t=`$(DATE)`; $(SED) -e "s|%WHEN%|$${t}|" \
-       -e "s|%WHOANDWHERE%|$${u}@$${h}:$${d}|" \
-       -e "s|%VERSION%|$${v}|" \
-       < Version.c > $@)
-
-clean: FORCE
-       @for i in back-* tools; do \
-               if [ -d $$i ] ; then \
+version.c: libbackends.a $(OBJS) $(SLAPD_LIBDEPEND) 
+       @-$(RM) $@
+       $(MKVERSION) -s -n Versionstr slapd > $@
+
+depend-local-srv: FORCE
+       @for i in back-* shell-backends tools; do \
+               if [ -d $$i ]; then \
+                       echo; echo "  cd $$i; $(MAKE) $(MFLAGS) depend"; \
+                       ( cd $$i; $(MAKE) $(MFLAGS) depend ); \
+               fi; \
+       done
+       @echo ""
+
+clean-local:
+       rm -f *.exp *.def *.base *.a
+
+clean-local-srv: FORCE
+       @for i in back-* shell-backends tools; do \
+               if [ -d $$i ]; then \
                        echo; echo "  cd $$i; $(MAKE) $(MFLAGS) clean"; \
                        ( cd $$i; $(MAKE) $(MFLAGS) clean ); \
                fi; \
        done
+       rm -f *.tmp all-cffiles
+
+veryclean-local-srv: FORCE
+       @for i in back-* shell-backends tools; do \
+               if [ -d $$i ]; then \
+                       echo; echo "  cd $$i; $(MAKE) $(MFLAGS) clean"; \
+                       ( cd $$i; $(MAKE) $(MFLAGS) veryclean ); \
+               fi; \
+       done
 
-install: install-slapd install-conf install-tools
+install-local-srv: install-slapd install-conf install-schema install-tools
 
 install-slapd: FORCE
-       @-$(MKDIR) $(libexecdir)
-       $(INSTALL) $(INSTALLFLAGS) -m 755 slapd $(libexecdir)
+       -$(MKDIR) $(DESTDIR)$(libexecdir)
+       -$(MKDIR) $(DESTDIR)$(localstatedir)
+       $(LTINSTALL) $(INSTALLFLAGS) -m 755 slapd$(EXEEXT) \
+                                               $(DESTDIR)$(libexecdir)
+       @if [ ! -z "$(SLAPD_MODULES)" ]; then \
+           for i in back-* shell-backends tools; do \
+               if [ -d $$i ]; then \
+                       echo; echo "  cd $$i; $(MAKE) $(MFLAGS) install"; \
+                       ( cd $$i; $(MAKE) $(MFLAGS) install ); \
+               fi; \
+           done; \
+       fi
+
+
+CFFILES=slapd.conf slapd.at.conf slapd.oc.conf
+
+all-cffiles: slapd
+       @for i in $(CFFILES); do \
+               tmpcf=$$i.tmp; \
+               $(SED) -e 's;%SYSCONFDIR%;$(sysconfdir);' \
+                       -e 's;%LOCALSTATEDIR%;$(localstatedir);' \
+                       $(srcdir)/$$i > $$tmpcf ; \
+       done
+       touch all-cffiles
+
+install-schema: FORCE
+       @-$(MKDIR) $(DESTDIR)$(sysconfdir)/schema
+       @for i in schema/*.schema schema/*.conf ; do \
+               if test ! -f $(DESTDIR)$(sysconfdir)/$$i; then \
+                       echo "installing $$i in $(sysconfdir)"; \
+                       echo $(INSTALL) $(INSTALLFLAGS) $$i $(DESTDIR)$(sysconfdir)/$$i; \
+                       $(INSTALL) $(INSTALLFLAGS) $$i $(DESTDIR)$(sysconfdir)/$$i; \
+               else \
+                       echo "PRESERVING EXISTING SCHEMA FILE $(DESTDIR)$(sysconfdir)/$$i"; \
+               fi; \
+               $(INSTALL) $(INSTALLFLAGS) $$i $(DESTDIR)$(sysconfdir)/$$i.default ; \
+       done
 
 install-conf: FORCE
-       @-$(MKDIR) -p $(sysconfdir)
-       $(SED) -e 's;%SYSCONFDIR%;$(sysconfdir);' slapd.conf > /tmp/slapd.$$
-       -$(MV) $(sysconfdir)/slapd.conf $(sysconfdir)/slapd.conf-
-       $(INSTALL) $(INSTALLFLAGS) -m 644 /tmp/slapd.$$ $(sysconfdir)/slapd.conf
-       $(RM) -f /tmp/slapd.$$
-       -$(MV) $(sysconfdir)/slapd.at.conf $(sysconfdir)/slapd.at.conf-
-       $(INSTALL) $(INSTALLFLAGS) -m 644 slapd.at.conf $(sysconfdir)
-       -$(MV) $(sysconfdir)/slapd.oc.conf $(sysconfdir)/slapd.oc.conf-
-       $(INSTALL) $(INSTALLFLAGS) -m 644 slapd.oc.conf $(sysconfdir)
+       @-$(MKDIR) $(DESTDIR)$(sysconfdir)
+       @for i in $(CFFILES); do \
+               tmpcf=$$i.tmp ; \
+               if test $$i = slapd.conf ; then \
+                       mode=600 ; \
+               else \
+                       mode=644 ; \
+               fi ; \
+               if test ! -f $(DESTDIR)$(sysconfdir)/$$i; then \
+                       echo "installing $$i in $(sysconfdir)"; \
+                       echo "$(INSTALL) $(INSTALLFLAGS) -m $$mode $$tmpcf $(DESTDIR)$(sysconfdir)/$$i"; \
+                       $(INSTALL) $(INSTALLFLAGS) -m $$mode $$tmpcf $(DESTDIR)$(sysconfdir)/$$i; \
+               else \
+                       echo "PRESERVING EXISTING CONFIGURATION FILE $(DESTDIR)$(sysconfdir)/$$i" ; \
+               fi; \
+               $(INSTALL) $(INSTALLFLAGS) -m $$mode $$tmpcf $(DESTDIR)$(sysconfdir)/$$i.default ; \
+       done
 
 install-tools: FORCE
-       @-$(MKDIR) $(sbindir)
+       @-$(MKDIR) $(DESTDIR)$(sbindir)
        (cd tools; $(MAKE) $(MFLAGS) install)