Update materials for building rsync with mgear. master
authorMatt McCutchen <matt@mattmccutchen.net>
Thu, 25 Oct 2007 02:54:02 +0000 (22:54 -0400)
committerMatt McCutchen <matt@mattmccutchen.net>
Thu, 25 Oct 2007 02:54:02 +0000 (22:54 -0400)
experiments/rsync-Makefile.in [deleted file]
experiments/rsync-mgear.diff [new file with mode: 0644]

diff --git a/experiments/rsync-Makefile.in b/experiments/rsync-Makefile.in
deleted file mode 100644 (file)
index c693a90..0000000
+++ /dev/null
@@ -1,227 +0,0 @@
-# This is Makefile.in from rsync modified by Matt for use with mgear.
-# (Of course, config.status copies the above message to Makefile.)
-#
-# Follow these steps to build rsync with mgear:
-# 1. Check rsync out from CVS.
-# 2. Replace its Makefile.in with this file.  This file is based on revision
-#    1.138; merge as necessary if the CVS is now at a newer revision.
-# 3. Copy mgear.mk into the rsync source tree.
-# 4. If you wish, add the pattern *.g to the cvsignore files so you aren't
-#    continually bothered about the genfiles.
-# 5. ./configure, make as usual.
-#
-# It works for compiling the C files, and I demonstrated that warnings no longer
-# disappear from Eclipse, which is pretty cool.  However, not everything is
-# converted to use mgear yet.
-include mgear.mk
-
-# Makefile for rsync. This is processed by configure to produce the final
-# Makefile
-
-prefix=@prefix@
-datarootdir=@datarootdir@
-exec_prefix=@exec_prefix@
-bindir=@bindir@
-mandir=@mandir@
-
-LIBS=@LIBS@
-CC=@CC@
-CFLAGS=@CFLAGS@
-CPPFLAGS=@CPPFLAGS@
-EXEEXT=@EXEEXT@
-LDFLAGS=@LDFLAGS@
-
-INSTALLCMD=@INSTALL@
-INSTALLMAN=@INSTALL@
-
-srcdir=@srcdir@
-VPATH=$(srcdir)
-SHELL=/bin/sh
-
-VERSION=@VERSION@
-
-#.SUFFIXES:
-#.SUFFIXES: .c .o
-
-HEADERS=byteorder.h config.h errcode.h proto.h rsync.h lib/pool_alloc.h
-LIBOBJ=lib/wildmatch.o lib/compat.o lib/snprintf.o lib/mdfour.o lib/md5.o \
-       lib/permstring.o lib/pool_alloc.o lib/sysacls.o lib/sysxattrs.o @LIBOBJS@
-ZLIBOBJ=zlib/deflate.o zlib/inffast.o zlib/inflate.o zlib/inftrees.o \
-       zlib/trees.o zlib/zutil.o zlib/adler32.o zlib/compress.o zlib/crc32.o
-OBJS1=flist.o 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
-OBJS2=options.o io.o compat.o hlink.o token.o uidlist.o socket.o \
-       fileio.o batch.o clientname.o chmod.o acls.o xattrs.o
-OBJS3=progress.o pipe.o
-DAEMON_OBJ = params.o loadparm.o clientserver.o access.o connection.o authenticate.o
-popt_OBJS=popt/findme.o  popt/popt.o  popt/poptconfig.o \
-       popt/popthelp.o popt/poptparse.o
-OBJS=$(OBJS1) $(OBJS2) $(OBJS3) $(DAEMON_OBJ) $(LIBOBJ) $(ZLIBOBJ) @BUILD_POPT@
-
-TLS_OBJ = tls.o syscall.o lib/compat.o lib/snprintf.o lib/permstring.o lib/sysxattrs.o @BUILD_POPT@
-
-# Programs we must have to run the test cases
-CHECK_PROGS = rsync$(EXEEXT) tls$(EXEEXT) getgroups$(EXEEXT) getfsdev$(EXEEXT) \
-       trimslash$(EXEEXT) t_unsafe$(EXEEXT) wildtest$(EXEEXT)
-
-CHECK_SYMLINKS = testsuite/chown-fake.test testsuite/devices-fake.test
-
-# Objects for CHECK_PROGS to clean
-CHECK_OBJS=getgroups.o getfsdev.o t_stub.o t_unsafe.o trimslash.o wildtest.o
-
-# note that the -I. is needed to handle config.h when using VPATH
-## Matt removed @OBJ_SAVE@ and @OBJ_RESTORE@ because they got in the way.
-cmd-cc=$(CC) -I. -I$(srcdir) $(CFLAGS) $(CPPFLAGS) -c $< @CC_SHOBJ_FLAG@
-$(call mg-define-rule,%.o,%.c,cmd-cc)
-
-## Turn off the built-in implicit rule because it sometimes beats the mgear rule
-## because the mgear rule depends on a genfile that might not exist yet.
-## TODO: Find a better way to handle this.
-%.o: %.c
-
-all: rsync$(EXEEXT)
-
-install: all
-       -mkdir -p ${DESTDIR}${bindir}
-       ${INSTALLCMD} ${INSTALL_STRIP} -m 755 rsync$(EXEEXT) ${DESTDIR}${bindir}
-       -mkdir -p ${DESTDIR}${mandir}/man1
-       -mkdir -p ${DESTDIR}${mandir}/man5
-       ${INSTALLMAN} -m 644 $(srcdir)/rsync.1 ${DESTDIR}${mandir}/man1
-       ${INSTALLMAN} -m 644 $(srcdir)/rsyncd.conf.5 ${DESTDIR}${mandir}/man5
-
-install-strip:
-       $(MAKE) INSTALL_STRIP='-s' install
-
-cmd-exe=$(CC) $(CFLAGS) $(LDFLAGS) -o $@ $^ $(LIBS)
-
-$(call mg-define-rule,rsync$(EXEEXT),$(OBJS),cmd-exe)
-
-$(OBJS): $(HEADERS)
-
-flist.o: rounding.h
-
-cmd-rounding.h=./mkrounding$(EXEEXT) >$@
-$(call mg-define-rule,rounding.h,mkrounding$(EXEEXT),cmd-rounding.h)
-
-define cmd-mkrounding-exe
-sed '1,/^struct file_struct/d; /^}/,$$d' <$(srcdir)/rsync.h >mkrounding.h &&\
-$(CC) $(CFLAGS) $(LDFLAGS) -o $@ -I. $(srcdir)/mkrounding.c &&\
-rm mkrounding.h
-endef
-$(call mg-define-rule,mkrounding$(EXEEXT),mkrounding.c rsync.h,cmd-mkrounding-exe)
-
-$(call mg-define-rule,tls$(EXEEXT),$(TLS_OBJ),cmd-exe)
-
-$(call mg-define-rule,getgroups$(EXEEXT),getgroups.o,cmd-exe)
-
-$(call mg-define-rule,getfsdev$(EXEEXT),getfsdev.o,cmd-exe)
-
-TRIMSLASH_OBJ = trimslash.o syscall.o lib/compat.o lib/snprintf.o
-$(call mg-define-rule,trimslash$(EXEEXT),$(TRIMSLASH_OBJ),cmd-exe)
-
-T_UNSAFE_OBJ = t_unsafe.o syscall.o util.o t_stub.o lib/compat.o lib/snprintf.o
-$(call mg-define-rule,t_unsafe$(EXEEXT),$(T_UNSAFE_OBJ),cmd-exe)
-
-gen:
-       cd $(srcdir) && $(MAKE) -f prepare-source.mak gen
-
-man:
-       cd $(srcdir) && $(MAKE) -f prepare-source.mak man
-
-proto:
-       cd $(srcdir) && $(MAKE) -f prepare-source.mak proto.h
-
-## Let mgear do the cleaning.
-clean: cleantests
-#      rm -f *~ $(OBJS) $(TLS_OBJ) $(CHECK_PROGS) $(CHECK_OBJS) $(CHECK_SYMLINKS) \
-#              mkrounding mkrounding.h rounding.h
-       $(call mg-clean-cmd,.)
-
-cleantests:
-       rm -rf ./testtmp*
-
-# We try to delete built files from both the source and build
-# directories, just in case somebody previously configured things in
-# the source directory.
-distclean: clean
-       rm -f Makefile config.h config.status
-       rm -f $(srcdir)/Makefile $(srcdir)/config.h $(srcdir)/config.status
-
-       rm -f config.cache config.log
-       rm -f $(srcdir)/config.cache $(srcdir)/config.log
-
-       rm -f shconfig $(srcdir)/shconfig
-
-# this target is really just for my use. It only works on a limited
-# range of machines and is used to produce a list of potentially
-# dead (ie. unused) functions in the code. (tridge)
-finddead:
-       nm *.o */*.o |grep 'U ' | awk '{print $$2}' | sort -u > nmused.txt
-       nm *.o */*.o |grep 'T ' | awk '{print $$3}' | sort -u > nmfns.txt
-       comm -13 nmused.txt nmfns.txt
-
-# 'check' is the GNU name, 'test' is the name for everybody else :-)
-.PHONY: check test
-
-test: check
-
-# There seems to be no standard way to specify some variables as
-# exported from a Makefile apart from listing them like this.
-
-# This depends on building rsync; if we need any helper programs it
-# should depend on them too.
-
-# We try to run the scripts with POSIX mode on, in the hope that will
-# catch Bash-isms earlier even if we're running on GNU.  Of course, we
-# might lose in the future where POSIX diverges from old sh.
-
-check: all $(CHECK_PROGS) $(CHECK_SYMLINKS)
-       rsync_bin=`pwd`/rsync$(EXEEXT) $(srcdir)/runtests.sh
-
-check29: all $(CHECK_PROGS) $(CHECK_SYMLINKS)
-       rsync_bin=`pwd`/rsync$(EXEEXT) $(srcdir)/runtests.sh --protocol=29
-
-
-wildtest.o: wildtest.c lib/wildmatch.c rsync.h
-$(call mg-define-rule,wildtest$(EXEEXT),wildtest.o lib/compat.o lib/snprintf.o @BUILD_POPT@,cmd-exe)
-
-### Matt stopped here.
-
-testsuite/chown-fake.test:
-       ln -s chown.test $(srcdir)/testsuite/chown-fake.test
-
-testsuite/devices-fake.test:
-       ln -s devices.test $(srcdir)/testsuite/devices-fake.test
-
-# This does *not* depend on building or installing: you can use it to
-# check a version installed from a binary or some other source tree,
-# if you want.
-
-installcheck: $(CHECK_PROGS) $(CHECK_SYMLINKS)
-       POSIXLY_CORRECT=1 TOOLDIR=`pwd` rsync_bin="$(bindir)/rsync$(EXEEXT)" srcdir="$(srcdir)" $(srcdir)/runtests.sh
-
-# TODO: Add 'dist' target; need to know which files will be included
-
-# Run the SPLINT (Secure Programming Lint) tool.  <www.splint.org>
-.PHONY: splint
-splint:
-       splint +unixlib +gnuextensions -weak rsync.c
-
-
-rsync.dvi: doc/rsync.texinfo
-       texi2dvi -o $@ $<
-
-rsync.ps: rsync.dvi
-       dvips -ta4 -o $@ $<
-
-rsync.pdf: doc/rsync.texinfo
-       texi2dvi -o $@ --pdf $<
-
-
-doxygen:
-       cd $(srcdir) && rm dox/html/* && doxygen
-
-# for maintainers only
-doxygen-upload:
-       rsync -avzv $(srcdir)/dox/html/ --delete \
-       samba.org:/home/httpd/html/rsync/doxygen/head/
diff --git a/experiments/rsync-mgear.diff b/experiments/rsync-mgear.diff
new file mode 100644 (file)
index 0000000..cf603ff
--- /dev/null
@@ -0,0 +1,173 @@
+To build rsync with mgear:
+1. Apply this patch to the rsync source tree.
+2. Copy or symlink mgear.mk into the rsync source tree.
+3. "make" as usual.
+
+diff --git a/.cvsignore b/.cvsignore
+index aa946de..dd2de12 100644
+--- a/.cvsignore
++++ b/.cvsignore
+@@ -1,3 +1,4 @@
++*.g
+ ID
+ Makefile
+ autom4te*.cache
+diff --git a/Makefile.in b/Makefile.in
+index 499de47..8a75160 100644
+--- a/Makefile.in
++++ b/Makefile.in
+@@ -1,3 +1,11 @@
++# This is Makefile.in from rsync modified by Matt for use with mgear.
++# (Of course, config.status copies the above message to Makefile.)
++#
++# It works for compiling the C files, and I demonstrated that warnings no longer
++# disappear from Eclipse, which is pretty cool.  However, not everything is
++# converted to use mgear yet.
++include mgear.mk
++
+ # Makefile for rsync. This is processed by configure to produce the final
+ # Makefile
+@@ -23,8 +31,8 @@ SHELL=/bin/sh
+ VERSION=@VERSION@
+-.SUFFIXES:
+-.SUFFIXES: .c .o
++#.SUFFIXES:
++#.SUFFIXES: .c .o
+ HEADERS=byteorder.h config.h errcode.h proto.h rsync.h ifuncs.h lib/pool_alloc.h
+ LIBOBJ=lib/wildmatch.o lib/compat.o lib/snprintf.o lib/mdfour.o lib/md5.o \
+@@ -53,10 +61,14 @@ CHECK_SYMLINKS = testsuite/chown-fake.test testsuite/devices-fake.test
+ CHECK_OBJS=getgroups.o getfsdev.o t_stub.o t_unsafe.o trimslash.o wildtest.o
+ # note that the -I. is needed to handle config.h when using VPATH
+-.c.o:
+-@OBJ_SAVE@
+-      $(CC) -I. -I$(srcdir) $(CFLAGS) $(CPPFLAGS) -c $< @CC_SHOBJ_FLAG@
+-@OBJ_RESTORE@
++## Matt removed @OBJ_SAVE@ and @OBJ_RESTORE@ because they got in the way.
++cmd-cc=$(CC) -I. -I$(srcdir) $(CFLAGS) $(CPPFLAGS) -c $< @CC_SHOBJ_FLAG@
++$(call mg-define-rule,%.o,%.c,cmd-cc)
++
++## Turn off the built-in implicit rule because it sometimes beats the mgear rule
++## because the mgear rule depends on a genfile that might not exist yet.
++## TODO: Find a better way to handle this.
++%.o: %.c
+ all: rsync$(EXEEXT)
+@@ -71,37 +83,35 @@ install: all
+ install-strip:
+       $(MAKE) INSTALL_STRIP='-s' install
+-rsync$(EXEEXT): $(OBJS)
+-      $(CC) $(CFLAGS) $(LDFLAGS) -o $@ $(OBJS) $(LIBS)
++cmd-exe=$(CC) $(CFLAGS) $(LDFLAGS) -o $@ $^ $(LIBS)
++
++$(call mg-define-rule,rsync$(EXEEXT),$(OBJS),cmd-exe)
+ $(OBJS): $(HEADERS)
+ flist.o: rounding.h
+-rounding.h: mkrounding$(EXEEXT)
+-      ./mkrounding$(EXEEXT) >rounding.h
++cmd-rounding.h=./mkrounding$(EXEEXT) >$@
++$(call mg-define-rule,rounding.h,mkrounding$(EXEEXT),cmd-rounding.h)
+-mkrounding$(EXEEXT): mkrounding.c rsync.h
+-      @sed '1,/^struct file_struct/d; /^}/,$$d' <$(srcdir)/rsync.h >mkrounding.h
+-      $(CC) $(CFLAGS) $(LDFLAGS) -o $@ -I. $(srcdir)/mkrounding.c
+-      @rm mkrounding.h
++define cmd-mkrounding-exe
++sed '1,/^struct file_struct/d; /^}/,$$d' <$(srcdir)/rsync.h >mkrounding.h &&\
++$(CC) $(CFLAGS) $(LDFLAGS) -o $@ -I. $(srcdir)/mkrounding.c &&\
++rm mkrounding.h
++endef
++$(call mg-define-rule,mkrounding$(EXEEXT),mkrounding.c rsync.h,cmd-mkrounding-exe)
+-tls$(EXEEXT): $(TLS_OBJ)
+-      $(CC) $(CFLAGS) $(LDFLAGS) -o $@ $(TLS_OBJ) $(LIBS)
++$(call mg-define-rule,tls$(EXEEXT),$(TLS_OBJ),cmd-exe)
+-getgroups$(EXEEXT): getgroups.o
+-      $(CC) $(CFLAGS) $(LDFLAGS) -o $@ getgroups.o $(LIBS)
++$(call mg-define-rule,getgroups$(EXEEXT),getgroups.o,cmd-exe)
+-getfsdev$(EXEEXT): getfsdev.o
+-      $(CC) $(CFLAGS) $(LDFLAGS) -o $@ getfsdev.o $(LIBS)
++$(call mg-define-rule,getfsdev$(EXEEXT),getfsdev.o,cmd-exe)
+ TRIMSLASH_OBJ = trimslash.o syscall.o lib/compat.o lib/snprintf.o
+-trimslash$(EXEEXT): $(TRIMSLASH_OBJ)
+-      $(CC) $(CFLAGS) $(LDFLAGS) -o $@ $(TRIMSLASH_OBJ) $(LIBS)
++$(call mg-define-rule,trimslash$(EXEEXT),$(TRIMSLASH_OBJ),cmd-exe)
+ T_UNSAFE_OBJ = t_unsafe.o syscall.o util.o t_stub.o lib/compat.o lib/snprintf.o
+-t_unsafe$(EXEEXT): $(T_UNSAFE_OBJ)
+-      $(CC) $(CFLAGS) $(LDFLAGS) -o $@ $(T_UNSAFE_OBJ) $(LIBS)
++$(call mg-define-rule,t_unsafe$(EXEEXT),$(T_UNSAFE_OBJ),cmd-exe)
+ gen:
+       cd $(srcdir) && $(MAKE) -f prepare-source.mak gen
+@@ -112,9 +122,11 @@ man:
+ proto:
+       cd $(srcdir) && $(MAKE) -f prepare-source.mak proto.h
++## Let mgear do the cleaning.
+ clean: cleantests
+-      rm -f *~ $(OBJS) $(TLS_OBJ) $(CHECK_PROGS) $(CHECK_OBJS) $(CHECK_SYMLINKS) \
+-              mkrounding mkrounding.h rounding.h
++#     rm -f *~ $(OBJS) $(TLS_OBJ) $(CHECK_PROGS) $(CHECK_OBJS) $(CHECK_SYMLINKS) \
++#             mkrounding mkrounding.h rounding.h
++      $(call mg-clean-cmd,.)
+ cleantests:
+       rm -rf ./testtmp*
+@@ -160,9 +172,11 @@ check: all $(CHECK_PROGS) $(CHECK_SYMLINKS)
+ check29: all $(CHECK_PROGS) $(CHECK_SYMLINKS)
+       rsync_bin=`pwd`/rsync$(EXEEXT) $(srcdir)/runtests.sh --protocol=29
++
+ wildtest.o: wildtest.c lib/wildmatch.c rsync.h
+-wildtest$(EXEEXT): wildtest.o lib/compat.o lib/snprintf.o @BUILD_POPT@
+-      $(CC) $(CFLAGS) $(LDFLAGS) -o $@ wildtest.o lib/compat.o lib/snprintf.o @BUILD_POPT@ $(LIBS)
++$(call mg-define-rule,wildtest$(EXEEXT),wildtest.o lib/compat.o lib/snprintf.o @BUILD_POPT@,cmd-exe)
++
++### Matt stopped here.
+ testsuite/chown-fake.test:
+       ln -s chown.test $(srcdir)/testsuite/chown-fake.test
+diff --git a/doc/.cvsignore b/doc/.cvsignore
+index 82b2f29..40fcb95 100644
+--- a/doc/.cvsignore
++++ b/doc/.cvsignore
+@@ -1,2 +1,3 @@
++*.g
+ rsync.pdf
+ rsync.ps
+diff --git a/lib/.cvsignore b/lib/.cvsignore
+index 421376d..5f68c87 100644
+--- a/lib/.cvsignore
++++ b/lib/.cvsignore
+@@ -1 +1,2 @@
++*.g
+ dummy
+diff --git a/popt/.cvsignore b/popt/.cvsignore
+index 337b0d0..391f286 100644
+--- a/popt/.cvsignore
++++ b/popt/.cvsignore
+@@ -1,3 +1,4 @@
++*.g
+ ID
+ Makefile
+ config.cache
+diff --git a/zlib/.cvsignore b/zlib/.cvsignore
+index 421376d..5f68c87 100644
+--- a/zlib/.cvsignore
++++ b/zlib/.cvsignore
+@@ -1 +1,2 @@
++*.g
+ dummy