Don't generate code for zlib and popt.
[rsync/rsync.git] / Makefile.in
... / ...
CommitLineData
1# Makefile for rsync. This is processed by configure to produce the final
2# Makefile
3
4prefix=@prefix@
5exec_prefix=@exec_prefix@
6bindir=@bindir@
7mandir=@mandir@
8
9LIBS=@LIBS@
10CC=@CC@
11CFLAGS=@CFLAGS@
12LDFLAGS=@LDFLAGS@
13
14INSTALLCMD=@INSTALL@
15INSTALLMAN=@INSTALL@
16
17srcdir=@srcdir@
18VPATH=$(srcdir)
19SHELL=/bin/sh
20
21VERSION=@VERSION@
22
23.SUFFIXES:
24.SUFFIXES: .c .o
25
26LIBOBJ=lib/fnmatch.o lib/compat.o lib/snprintf.o lib/mdfour.o \
27 lib/permstring.o \
28 @LIBOBJS@
29ZLIBOBJ=zlib/deflate.o zlib/infblock.o zlib/infcodes.o zlib/inffast.o \
30 zlib/inflate.o zlib/inftrees.o zlib/infutil.o zlib/trees.o \
31 zlib/zutil.o zlib/adler32.o
32OBJS1=rsync.o generator.o receiver.o cleanup.o sender.o exclude.o util.o main.o checksum.o match.o syscall.o log.o backup.o
33OBJS2=options.o flist.o io.o compat.o hlink.o token.o uidlist.o socket.o fileio.o batch.o \
34 clientname.o
35DAEMON_OBJ = params.o loadparm.o clientserver.o access.o connection.o authenticate.o
36popt_OBJS=popt/findme.o popt/popt.o popt/poptconfig.o \
37 popt/popthelp.o popt/poptparse.o
38OBJS=$(OBJS1) $(OBJS2) $(DAEMON_OBJ) $(LIBOBJ) $(ZLIBOBJ) @BUILD_POPT@
39
40TLS_OBJ = tls.o syscall.o lib/permstring.o
41
42# Programs we must have to run the test cases
43CHECK_PROGS = rsync tls getgroups trimslash
44
45# note that the -I. is needed to handle config.h when using VPATH
46.c.o:
47@OBJ_SAVE@
48 $(CC) -I. -I$(srcdir) $(CFLAGS) -c $< @CC_SHOBJ_FLAG@
49@OBJ_RESTORE@
50
51all: rsync
52
53man: rsync.1 rsyncd.conf.5
54
55install: all
56 -mkdir -p ${DESTDIR}${bindir}
57 ${INSTALLCMD} ${STRIP} -m 755 rsync ${DESTDIR}${bindir}
58 -mkdir -p ${DESTDIR}${mandir}/man1
59 -mkdir -p ${DESTDIR}${mandir}/man5
60 ${INSTALLMAN} -m 644 $(srcdir)/rsync.1 ${DESTDIR}${mandir}/man1
61 ${INSTALLMAN} -m 644 $(srcdir)/rsyncd.conf.5 ${DESTDIR}${mandir}/man5
62
63install-strip:
64 $(MAKE) STRIP='-s' install
65
66rsync: $(OBJS)
67 @echo "Please ignore warnings below about mktemp -- it is used in a safe way"
68 $(CC) $(CFLAGS) $(LDFLAGS) -o rsync $(OBJS) $(LIBS)
69
70$(OBJS): config.h
71
72tls: $(TLS_OBJ)
73 $(CC) $(CFLAGS) $(LDFLAGS) -o $@ $(TLS_OBJ) $(LIBS)
74
75getgroups: getgroups.o
76 $(CC) $(CFLAGS) $(LDFLAGS) -o $@ getgroups.o $(LIBS)
77
78TRIMSLASH_OBJ = trimslash.o syscall.o
79trimslash: $(TRIMSLASH_OBJ)
80 $(CC) $(CFLAGS) $(LDFLAGS) -o $@ $(TRIMSLASH_OBJ) $(LIBS)
81
82# I don't like these rules because CVS can skew the timestamps and
83# produce spurious warnings, and also make "make install" fail if the
84# source directory can no longer be found. Since we don't rebuild
85# automatically they're kind of lame anyhow.
86
87#Makefile: Makefile.in configure config.status
88# echo "WARNING: You need to run ./config.status --recheck"
89
90# don't actually run autoconf, just issue a warning
91#configure: configure.in
92# echo "WARNING: you need to rerun autoconf"
93
94rsync.1: rsync.yo
95 yodl2man -o rsync.1 rsync.yo
96
97rsyncd.conf.5: rsyncd.conf.yo
98 yodl2man -o rsyncd.conf.5 rsyncd.conf.yo
99
100proto:
101 cat $(srcdir)/*.c $(srcdir)/lib/compat.c | awk -f $(srcdir)/mkproto.awk > $(srcdir)/proto.h
102
103clean: cleantests
104 rm -f *~ $(OBJS) rsync $(TLS_OBJ) $(CHECK_PROGS)
105
106cleantests:
107 rm -rf ./testtmp*
108
109# We try to delete built files from both the source and build
110# directories, just in case somebody previously configured things in
111# the source directory.
112distclean: clean
113 rm -f Makefile config.h config.status
114 rm -f $(srcdir)/Makefile $(srcdir)/config.h $(srcdir)/config.status
115
116 rm -f config.cache config.log
117 rm -f $(srcdir)/config.cache $(srcdir)/config.log
118
119 rm -f shconfig $(srcdir)/shconfig
120
121# this target is really just for my use. It only works on a limited
122# range of machines and is used to produce a list of potentially
123# dead (ie. unused) functions in the code. (tridge)
124finddead:
125 nm *.o */*.o |grep 'U ' | awk '{print $$2}' | sort -u > nmused.txt
126 nm *.o */*.o |grep 'T ' | awk '{print $$3}' | sort -u > nmfns.txt
127 comm -13 nmused.txt nmfns.txt
128
129# 'check' is the GNU name, 'test' is the name for everybody else :-)
130.PHONY: check test
131
132test: check
133
134
135# There seems to be no standard way to specify some variables as
136# exported from a Makefile apart from listing them like this.
137
138# TODO: Tests that depend on built test aide programs like tls need to
139# know where the build directory is.
140
141# This depends on building rsync; if we need any helper programs it
142# should depend on them too.
143
144# We try to run the scripts with POSIX mode on, in the hope that will
145# catch Bash-isms earlier even if we're running on GNU. Of course, we
146# might lose in the future where POSIX diverges from old sh.
147
148check: all $(CHECK_PROGS)
149 POSIXLY_CORRECT=1 TOOLDIR=`pwd` rsync_bin=`pwd`/rsync srcdir="$(srcdir)" $(srcdir)/runtests.sh
150
151# This does *not* depend on building or installing: you can use it to
152# check a version installed from a binary or some other source tree,
153# if you want.
154
155installcheck: $(CHECK_PROGS)
156 POSIXLY_CORRECT=1 TOOLDIR=`pwd` rsync_bin="$(bindir)/rsync" srcdir="$(srcdir)" $(srcdir)/runtests.sh
157
158# TODO: Add 'dist' target; need to know which files will be included
159
160# Run the SPLINT (Secure Programming Lint) tool. <www.splint.org>
161.PHONY: splint
162splint:
163 splint +unixlib +gnuextensions -weak rsync.c
164
165
166rsync.dvi: doc/rsync.texinfo
167 texi2dvi -o $@ $<
168
169rsync.ps: rsync.dvi
170 dvips -ta4 -o $@ $<
171
172rsync.pdf: doc/rsync.texinfo
173 texi2dvi -o $@ --pdf $<