4fcf2c15bdaea64e30ed13ae073921c30df4c428
[rsync/rsync.git] / Makefile.in
1 # Makefile for rsync. This is processed by configure to produce the final
2 # Makefile
3
4 prefix=@prefix@
5 exec_prefix=@exec_prefix@
6 bindir=@bindir@
7 mandir=@mandir@
8
9 LIBS=@LIBS@
10 CC=@CC@
11 CFLAGS=@CFLAGS@
12 LDFLAGS=@LDFLAGS@
13
14 INSTALLCMD=@INSTALL@
15 INSTALLMAN=@INSTALL@
16
17 srcdir=@srcdir@
18 VPATH=$(srcdir)
19 SHELL=/bin/sh
20
21 VERSION=@VERSION@
22
23 .SUFFIXES:
24 .SUFFIXES: .c .o
25
26 LIBOBJ=lib/fnmatch.o lib/compat.o lib/snprintf.o lib/mdfour.o \
27         lib/permstring.o \
28         @LIBOBJS@
29 ZLIBOBJ=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 
32 OBJS1=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
33 OBJS2=options.o flist.o io.o compat.o hlink.o token.o uidlist.o socket.o fileio.o batch.o \
34         clientname.o
35 DAEMON_OBJ = params.o loadparm.o clientserver.o access.o connection.o authenticate.o
36 popt_OBJS=popt/findme.o  popt/popt.o  popt/poptconfig.o \
37         popt/popthelp.o popt/poptparse.o
38 OBJS=$(OBJS1) $(OBJS2) $(DAEMON_OBJ) $(LIBOBJ) $(ZLIBOBJ) @BUILD_POPT@
39
40 TLS_OBJ = tls.o syscall.o lib/permstring.o 
41
42 # Programs we must have to run the test cases
43 CHECK_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
51 all: rsync
52
53 man: rsync.1 rsyncd.conf.5
54
55 install: 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
63 install-strip:
64         $(MAKE) STRIP='-s' install
65
66 rsync: $(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
72 tls: $(TLS_OBJ)
73         $(CC) $(CFLAGS) $(LDFLAGS) -o $@ $(TLS_OBJ) $(LIBS)
74
75 getgroups: getgroups.o
76         $(CC) $(CFLAGS) $(LDFLAGS) -o $@ getgroups.o $(LIBS)
77
78 TRIMSLASH_OBJ = trimslash.o syscall.o
79 trimslash: $(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
94 rsync.1: rsync.yo
95         yodl2man -o rsync.1 rsync.yo
96
97 rsyncd.conf.5: rsyncd.conf.yo
98         yodl2man -o rsyncd.conf.5 rsyncd.conf.yo
99
100 proto:
101         cat $(srcdir)/*.c $(srcdir)/lib/compat.c | awk -f $(srcdir)/mkproto.awk > $(srcdir)/proto.h
102
103 clean: cleantests
104         rm -f *~ $(OBJS) rsync $(TLS_OBJ) $(CHECK_PROGS)
105
106 cleantests:
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.
112 distclean: 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)
124 finddead:
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
132 test: 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
148 check: 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
155 installcheck: $(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
162 splint: 
163         splint +unixlib +gnuextensions -weak rsync.c
164
165
166 rsync.dvi: doc/rsync.texinfo
167         texi2dvi -o $@ $<
168
169 rsync.ps: rsync.dvi     
170         dvips -ta4 -o $@ $<
171
172 rsync.pdf: doc/rsync.texinfo
173         texi2dvi -o $@ --pdf $<