Build system: MT_LIBS includes XLIBS
[openafs.git] / src / tptserver / Makefile.in
index ae15595..cbde711 100644 (file)
@@ -7,23 +7,12 @@
 
 srcdir=@srcdir@
 include @TOP_OBJDIR@/src/config/Makefile.config
-INSTALL = @INSTALL@
-INSTALL_DATA = @INSTALL_DATA@
-INSTALL_PROGRAM = @INSTALL_PROGRAM@
-INSTALL_SCRIPT = @INSTALL_SCRIPT@
+include @TOP_OBJDIR@/src/config/Makefile.pthread
+
 HELPER_SPLINT=@HELPER_SPLINT@
 ENABLE_PTHREADED_UBIK=@ENABLE_PTHREADED_UBIK@
 
-CCRULE=${MT_CC} ${CFLAGS} ${MT_CFLAGS} -c $<
-
-RX=../rx
-UTIL=../util
-PTSERVER=../ptserver
-
-RXOBJS= rx_pthread.o rxkad_errs.o
-
-UTILOBJS=assert.o uuid.o serverLog.o fileutil.o netutils.o dirpath.o \
-     volparse.o flipbase64.o softsig.o hostparse.o snprintf.o pthread_glock.o
+PTSERVER=$(srcdir)/../ptserver
 
 INCLS=${TOP_INCDIR}/ubik.h \
        ${TOP_INCDIR}/lock.h  \
@@ -32,182 +21,146 @@ INCLS=${TOP_INCDIR}/ubik.h \
        ${TOP_INCDIR}/rx/xdr.h \
        ${TOP_INCDIR}/afs/keys.h \
        ${TOP_INCDIR}/afs/cellconfig.h \
-       ptint.h \
-       pterror.h
-
-LIBS=${RXOBJS} ${UTILOBJS}\
-       ${TOP_LIBDIR}/libubik_pthread.a \
-       ${TOP_LIBDIR}/libafsauthent.a \
-       ${TOP_LIBDIR}/libafsrpc.a \
-       ${TOP_LIBDIR}/libcmd.a \
-       ${TOP_LIBDIR}/libafsutil.a 
-
-PTOBJS=ptuser.o pterror.o ptint.cs.o ptint.xdr.o
+       ptint.h
+
+LIBS_common= \
+       $(top_builddir)/src/ubik/liboafs_ubik.la \
+       $(top_builddir)/src/sys/liboafs_sys.la \
+       $(top_builddir)/src/rx/liboafs_rx.la \
+       $(top_builddir)/src/rxstat/liboafs_rxstat.la \
+       $(top_builddir)/src/lwp/liboafs_lwpcompat.la \
+       $(top_builddir)/src/rxkad/liboafs_rxkad.la \
+       $(top_builddir)/src/cmd/liboafs_cmd.la \
+       $(top_builddir)/src/util/liboafs_util.la \
+       $(top_builddir)/src/opr/liboafs_opr.la
+
+LIBS_server= \
+       $(top_builddir)/src/audit/liboafs_audit.la \
+       $(LIBS_common)
+
+LIBS_client= \
+       $(top_builddir)/src/ptserver/liboafs_prot.la \
+       $(LIBS_common)
 
 all: ptserver pts pt_util db_verify \
        depinstall readgroup readpwd testpt
 
-depinstall: 
-
-#
-# Build targets
-#
+generated: \
+       pterror.h pterror.c
 
-rx_pthread.o: ${RX}/rx_pthread.c
-       ${CCRULE}
+depinstall:
 
-rxkad_errs.o: ../rxkad/rxkad_errs.c
-       ${CCRULE}
+# When supergroups is enabled, some parts of ptserver cast between
+# incompatible structs.
+CFLAGS_ptutils.o = @CFLAGS_NOSTRICT@
+CFLAGS_ptprocs.o = @CFLAGS_NOSTRICT@
 
 #
-# get the pthreaded util stuff compiled here.  we do this instead of
-# using the non-pthreaded libutil.a.  There probably should be a
-# pthreaded version of this library, as we are doing with ubik itself, but...
+# Build targets
 #
 
-assert.o: ${UTIL}/assert.c
-       ${CCRULE}
-
-uuid.o: ${UTIL}/uuid.c
-       ${CCRULE}
-
-serverLog.o: ${UTIL}/serverLog.c
-       ${CCRULE}
-
-fileutil.o: ${UTIL}/fileutil.c
-       ${CCRULE}
-
-volparse.o: ${UTIL}/volparse.c
-       ${CCRULE}
-
-flipbase64.o: ${UTIL}/flipbase64.c
-       ${CCRULE}
-
-netutils.o: ${UTIL}/netutils.c
-       ${CCRULE}
-
-dirpath.o: ${UTIL}/dirpath.c
-       ${CCRULE}
-
-softsig.o: ${UTIL}/softsig.c
-       ${CCRULE}
-
-hostparse.o: ${UTIL}/hostparse.c
-       ${CCRULE}
-
-snprintf.o: ${UTIL}/snprintf.c
-       ${CCRULE}
-
-pthread_glock.o: ${UTIL}/pthread_glock.c
-       ${CCRULE}
-
-
 ptserver.o: ${PTSERVER}/ptserver.c ${INCLS}
-       ${CCRULE}
+       $(AFS_CCRULE) $(PTSERVER)/ptserver.c
 
-ptutils.o: ${PTSERVER}/ptutils.c ${INCLS}
-       ${CCRULE}
+ptutils.o: ${PTSERVER}/ptutils.c ${INCLS} pterror.h
+       $(AFS_CCRULE) $(PTSERVER)/ptutils.c
 
 ptprocs.o: ${PTSERVER}/ptprocs.c ${INCLS}
-       ${CCRULE}
+       $(AFS_CCRULE) $(PTSERVER)/ptprocs.c
 
 utils.o: ${PTSERVER}/utils.c ${INCLS}
-       ${CCRULE}
+       $(AFS_CCRULE) $(PTSERVER)/utils.c
 
 map.o: ${PTSERVER}/map.c ${INCLS}
-       ${CCRULE}
-
-ptint.ss.o: ptint.ss.c
-       ${CCRULE}
-
-ptint.cs.o: ptint.cs.c
-       ${CCRULE}
-
-ptint.xdr.o: ptint.xdr.c
-       ${CCRULE}
-
-ptint.cs.c: ${PTSERVER}/ptint.xg
-       ${RXGEN} -A -x -C -u -o $@ ${srcdir}/${PTSERVER}/ptint.xg
+       $(AFS_CCRULE) $(PTSERVER)/map.c
 
 ptint.ss.c: ${PTSERVER}/ptint.xg
-       ${RXGEN} -A -x -S -o $@ ${srcdir}/${PTSERVER}/ptint.xg
+       ${RXGEN} -A -x -S -o $@ ${PTSERVER}/ptint.xg
 
 ptint.xdr.c: ${PTSERVER}/ptint.xg
-       ${RXGEN} -A -x -c -o $@ ${srcdir}/${PTSERVER}/ptint.xg
+       ${RXGEN} -A -x -c -o $@ ${PTSERVER}/ptint.xg
 
 ptint.h: ${PTSERVER}/ptint.xg
-       ${RXGEN} -A -x -h -u -o $@ ${srcdir}/${PTSERVER}/ptint.xg
+       ${RXGEN} -A -x -h -u -o $@ ${PTSERVER}/ptint.xg
 
-ptint.cs.c: ptint.h
 ptint.ss.c: ptint.h
 ptint.xdr.c: ptint.h
 
-Kptint.cs.c: ${PTSERVER}/ptint.xg Kptint.h
-       ${RXGEN} -A -x -k -C -o Kptint.cs.c ${srcdir}/${PTSERVER}/ptint.xg
-Kptint.xdr.c: ${PTSERVER}/ptint.xg
-       ${RXGEN} -A -x -k -c -o Kptint.xdr.c ${srcdir}/${PTSERVER}/ptint.xg
-Kptint.h: ${PTSERVER}/ptint.xg
-       ${RXGEN} -A -x -k -h -o Kptint.h ${srcdir}/${PTSERVER}/ptint.xg
-
-display.o: ${PTSERVER}/display.c ${INCLS}
-       ${CCRULE}
-
-ptserver: ptserver.o ptutils.o ptprocs.o ptint.ss.o ptint.xdr.o utils.o $(LIBS) ${TOP_LIBDIR}/libaudit.a map.o
-       ${CC} ${LDFLAGS} -o ptserver ptserver.o ptutils.o ptprocs.o ptint.ss.o ptint.xdr.o utils.o map.o $(LIBS) ${MT_LIBS} ${XLIBS} ${TOP_LIBDIR}/libaudit.a
+ptserver: ptserver.o ptutils.o ptprocs.o ptint.ss.o ptint.xdr.o utils.o map.o \
+         $(LIBS_server)
+       $(LT_LDRULE_static) ptserver.o ptutils.o ptprocs.o \
+               ptint.ss.o ptint.xdr.o utils.o map.o \
+               $(LIBS_server) \
+               $(LIB_hcrypto) $(LIB_roken) ${MT_LIBS}
 
 db_verify.o: ${PTSERVER}/db_verify.c ${INCLS}
-       ${CCRULE}
+       $(AFS_CCRULE) $(PTSERVER)/db_verify.c
 
-db_verify: db_verify.o pterror.o display.o $(LIBS)
-       $(CC) ${LDFLAGS} -o db_verify db_verify.o display.o pterror.o $(LIBS) ${MT_LIBS} ${XLIBS}
+db_verify: db_verify.o $(LIBS_client)
+       $(LT_LDRULE_static) db_verify.o \
+               $(LIBS_client) $(LIB_hcrypto) $(LIB_roken) ${MT_LIBS}
 
-ptclient: ptclient.o display.o ptuser.o pterror.o ptint.cs.o ptint.xdr.o AFS_component_version_number.o $(LIBS)
-       $(CC) ${LDFLAGS} -o ptclient ptclient.o display.o $(PTOBJS) $(LIBS) ${MT_LIBS} ${XLIBS}
+ptclient: ptclient.o AFS_component_version_number.o $(LIBS_client)
+       $(LT_LDRULE_static) ptclient.o \
+               $(LIBS_client) $(LIB_hcrypto) $(LIB_roken) ${MT_LIBS}
 
 ptclient.o: ${PTSERVER}/ptclient.c ${INCLS}
-       ${CCRULE}
-
-ptuser.o: ${PTSERVER}/ptuser.c ${INCLS}
-       ${CCRULE}
+       $(AFS_CCRULE) $(PTSERVER)/ptclient.c
 
-pterror.h pterror.c: ${PTSERVER}/pterror.et
-       $(RM) -f pterror.h pterror.c
-       ${COMPILE_ET} -p ${srcdir}/${PTSERVER} pterror
-
-pts: pts.o $(PTOBJS) ${TOP_LIBDIR}/libcmd.a $(LIBS) ${INCLS}
-       $(CC) ${LDFLAGS} -o pts pts.o ${TOP_LIBDIR}/libcmd.a $(PTOBJS) ${LIBS} ${MT_LIBS} ${XLIBS}
+pts: pts.o $(LIBS_client) ${INCLS}
+       $(LT_LDRULE_static) pts.o \
+               ${LIBS_client} $(LIB_hcrypto) $(LIB_roken) ${MT_LIBS}
 
 pts.o: ${PTSERVER}/pts.c
-       ${CCRULE}
+       $(AFS_CCRULE) $(PTSERVER)/pts.c
 
-readgroup: readgroup.o $(PTOBJS) $(LIBS)
-       $(CC) ${CFLAGS} -o readgroup readgroup.o $(PTOBJS) ${LIBS} ${MT_LIBS} ${XLIBS}
+readgroup: readgroup.o $(LIBS_client)
+       $(LT_LDRULE_static) readgroup.o \
+               $(LIBS_client) $(LIB_hcrypto) $(LIB_roken) ${MT_LIBS}
 
 readgroup.o: ${PTSERVER}/readgroup.c ${INCLS}
-       ${CCRULE}
+       $(AFS_CCRULE) $(PTSERVER)/readgroup.c
 
-readpwd: readpwd.o $(PTOBJS) $(LIBS)
-       $(CC) ${CFLAGS} -o readpwd readpwd.o $(PTOBJS) ${LIBS} ${MT_LIBS} ${XLIBS}
+readpwd: readpwd.o $(LIBS_client)
+       $(LT_LDRULE_static) readpwd.o \
+               $(LIBS_client) $(LIB_hcrypto) $(LIB_roken) ${MT_LIBS}
 
 readpwd.o: ${PTSERVER}/readpwd.c ${INCLS}
-       ${CCRULE}
+       $(AFS_CCRULE) $(PTSERVER)/readpwd.c
 
-testpt: testpt.o $(PTOBJS) ${TOP_LIBDIR}/libcmd.a $(LIBS)
-       $(CC) ${CFLAGS} -o testpt testpt.o -lm ${TOP_LIBDIR}/libcmd.a $(PTOBJS) $(LIBS) ${MT_LIBS} ${XLIBS}
+testpt: testpt.o $(LIBS_client)
+       $(LT_LDRULE_static) testpt.o -lm \
+               $(LIBS_client) $(LIB_hcrypto) $(LIB_roken) ${MT_LIBS}
 
 testpt.o: ${PTSERVER}/testpt.c ${INCLS}
-       ${CCRULE}
+       $(AFS_CCRULE) $(PTSERVER)/testpt.c
 
-pt_util: pt_util.o ptutils.o ubik.o utils.o map.o $(PTOBJS) $(LIBS)
-       $(CC) ${CFLAGS} -o pt_util pt_util.o ptutils.o ubik.o utils.o map.o $(PTOBJS) ${TOP_LIBDIR}/libcmd.a $(LIBS) ${MT_LIBS} ${XLIBS}
+pt_util: pt_util.o ptutils.o ptubik.o utils.o map.o $(LIBS_client)
+       $(LT_LDRULE_static) pt_util.o ptutils.o ptubik.o utils.o map.o \
+               $(LIBS_client) $(LIB_hcrypto) $(LIB_roken) ${MT_LIBS}
 
 pt_util.o: ${PTSERVER}/pt_util.c
-       ${CCRULE}
+       $(AFS_CCRULE) $(PTSERVER)/pt_util.c
+
+ptubik.o: ${PTSERVER}/ptubik.c ${INCLS}
+       $(AFS_CCRULE) $(PTSERVER)/ptubik.c
+
+pterror.c: ${PTSERVER}/pterror.et
+       ${COMPILE_ET_C} -p ${PTSERVER} pterror
+
+pterror.h: ${PTSERVER}/pterror.et
+       ${COMPILE_ET_H} -p ${PTSERVER} pterror
 
-ubik.o: ${PTSERVER}/ubik.c ${INCLS}
-       ${CCRULE}
+db_verify.o db_verify.lo: pterror.h
+ptclient.o ptclient.lo: pterror.h
+ptprocs.o ptprocs.lo: pterror.h
+pts.o pts.lo: pterror.h
+ptuser.o ptuser.lo: pterror.h
+pt_util.o pt_util.lo: pterror.h
+ptutils.o ptutils.lo: pterror.h
+readgroup.o readgroup.lo: pterror.h
+testpt.o testpt.lo: pterror.h
+utils.o utils.lo: pterror.h
 
 prerror.h: pterror.h
        ${INSTALL} $? $@
@@ -218,11 +171,13 @@ prerror.h: pterror.h
 #
 install: ptserver pts pt_util db_verify
        if [ "x$(ENABLE_PTHREADED_UBIK)" = "xyes" ] ; then \
-               ${INSTALL_PROGRAM} ptserver ${DESTDIR}${afssrvlibexecdir}/ptserver; \
-               ${INSTALL_PROGRAM} pts ${DESTDIR}${afssrvbindir}/pts; \
-               ${INSTALL_PROGRAM} pts ${DESTDIR}${bindir}/pts; \
-               ${INSTALL_PROGRAM} pt_util ${DESTDIR}${afssrvsbindir}/pt_util; \
-               ${INSTALL_PROGRAM} db_verify ${DESTDIR}${afssrvsbindir}/prdb_check; \
+               ${LT_INSTALL_PROGRAM} ptserver \
+                       ${DESTDIR}${afssrvlibexecdir}/ptserver; \
+               ${LT_INSTALL_PROGRAM} pts ${DESTDIR}${afssrvbindir}/pts; \
+               ${LT_INSTALL_PROGRAM} pts ${DESTDIR}${bindir}/pts; \
+               ${LT_INSTALL_PROGRAM} pt_util ${DESTDIR}${afssrvsbindir}/pt_util; \
+               ${LT_INSTALL_PROGRAM} db_verify \
+                       ${DESTDIR}${afssrvsbindir}/prdb_check; \
        fi
 
 dest: ptserver pts pt_util db_verify
@@ -238,6 +193,7 @@ dest: ptserver pts pt_util db_verify
 # Misc. targets
 #
 clean:
+       $(LT_CLEAN)
        $(RM) -f *.a *.o ptserver ptint.cs.c ptint.ss.c ptclient ptint.xdr.c ptint.h \
        pts readgroup readpwd db_verify testpt pt_util pterror.h pterror.c \
        core AFS_component_version_number.c Kptint.cs.c Kptint.h Kptint.xdr.c