Code that was meant to trim trailing slashes from mkdir() paths
[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
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 $@ $< $(LIBS)
77
78Makefile: Makefile.in configure config.status
79 echo "WARNING: You need to run ./config.status --recheck"
80
81# don't actually run autoconf, just issue a warning
82configure: configure.in
83 echo "WARNING: you need to rerun autoconf"
84
85rsync.1: rsync.yo
86 yodl2man -o rsync.1 rsync.yo
87
88rsyncd.conf.5: rsyncd.conf.yo
89 yodl2man -o rsyncd.conf.5 rsyncd.conf.yo
90
91proto:
92 cat $(srcdir)/*.c $(srcdir)/lib/compat.c | awk -f $(srcdir)/mkproto.awk > $(srcdir)/proto.h
93
94clean: cleantests
95 rm -f *~ $(OBJS) rsync $(TLS_OBJ) tls getgroups
96
97cleantests:
98 rm -rf ./testtmp*
99
100# We try to delete built files from both the source and build
101# directories, just in case somebody previously configured things in
102# the source directory.
103distclean: clean
104 rm -f Makefile config.h config.status
105 rm -f $(srcdir)/Makefile $(srcdir)/config.h $(srcdir)/config.status
106
107 rm -f config.cache config.log
108 rm -f $(srcdir)/config.cache $(srcdir)/config.log
109
110 rm -f shconfig $(srcdir)/shconfig
111
112# this target is really just for my use. It only works on a limited
113# range of machines and is used to produce a list of potentially
114# dead (ie. unused) functions in the code. (tridge)
115finddead:
116 nm *.o */*.o |grep 'U ' | awk '{print $$2}' | sort -u > nmused.txt
117 nm *.o */*.o |grep 'T ' | awk '{print $$3}' | sort -u > nmfns.txt
118 comm -13 nmused.txt nmfns.txt
119
120# 'check' is the GNU name, 'test' is the name for everybody else :-)
121.PHONY: check test
122
123test: check
124
125
126# There seems to be no standard way to specify some variables as
127# exported from a Makefile apart from listing them like this.
128
129# TODO: Tests that depend on built test aide programs like tls need to
130# know where the build directory is.
131
132# This depends on building rsync; if we need any helper programs it
133# should depend on them too.
134
135# We try to run the scripts with POSIX mode on, in the hope that will
136# catch Bash-isms earlier even if we're running on GNU. Of course, we
137# might lose in the future where POSIX diverges from old sh.
138
139check: all $(CHECK_PROGS)
140 POSIXLY_CORRECT=1 TOOLDIR=`pwd` rsync_bin=`pwd`/rsync srcdir="$(srcdir)" $(srcdir)/runtests.sh
141
142# This does *not* depend on building or installing: you can use it to
143# check a version installed from a binary or some other source tree,
144# if you want.
145
146installcheck: $(CHECK_PROGS)
147 POSIXLY_CORRECT=1 TOOLDIR=`pwd` rsync_bin="$(bindir)/rsync" srcdir="$(srcdir)" $(srcdir)/runtests.sh
148
149# TODO: Add 'dist' target; need to know which files will be included
150
151# Run the SPLINT (Secure Programming Lint) tool. <www.splint.org>
152.PHONY: splint
153splint:
154 splint +unixlib +gnuextensions -weak rsync.c
155
156
157rsync.dvi: doc/rsync.texinfo
158 texi2dvi -o $@ $<
159
160rsync.ps: rsync.dvi
161 dvips -ta4 -o $@ $<
162
163rsync.pdf: doc/rsync.texinfo
164 texi2dvi -o $@ --pdf $<