# $Id: Makefile 19 2011-02-14 22:21:52Z robert $
VERSION := $(shell dpkg-parsechangelog | sed -n 's/^Version: //p')
CC = gcc
CFLAGS += -Wall -Wextra -D_REENTRANT -fpic
ifeq (,$(INSTALL_PROGRAM))
INSTALL_PROGRAM := "install"
endif
compile all: datefudge datefudge.so
install: datefudge datefudge.so datefudge.1
install -d $(DESTDIR)/usr/lib/datefudge/
$(INSTALL_PROGRAM) -o root -g root -m 644 datefudge.so $(DESTDIR)/usr/lib/datefudge/datefudge.so
install -d $(DESTDIR)/usr/bin/
$(INSTALL_PROGRAM) -o root -g root -m 755 datefudge $(DESTDIR)/usr/bin
install -d $(DESTDIR)/usr/share/man/man1
install -o root -g root -m 644 datefudge.1 $(DESTDIR)/usr/share/man/man1
datefudge: datefudge.sh
sed -e 's,@VERSION@,$(VERSION),g' < $< > $@
datefudge.so: datefudge.o
$(CC) $(LDFLAGS) -o $@ -shared $< -ldl -lc
datefudge.o: datefudge.c
$(CC) $(CFLAGS) -c -o $@ $<
datefudge.1: datefudge.man
sed -e 's,@VERSION@,$(VERSION),g' < $< > $@
clean:
rm -f datefudge.o datefudge.so datefudge datefudge.1
# The first run may possibly fail when it's around midnight, that's why it's run twice.
test: compile
@echo -n "Running a simple date test... " ;\
export TZ=UTC ;\
ret1=1; ret2=1 ;\
for i in 1 2; do \
export DATEFUDGE=`LC_ALL=C date --date='yesterday 0:00' +%s` ;\
dt=`LC_ALL=C LD_PRELOAD=$(CURDIR)/datefudge.so date --date=12:15 +%F.%T` ;\
exp="1970-01-02.12:15:00" ;\
[ "$$dt" != "$$exp" ] || { echo "OK"; ret1=0; break; } ;\
echo "failed: expected: $$exp, actual: $$dt" ;\
[ $$i = 2 ] || { echo -n " retrying... "; sleep 2; } ;\
done ;\
echo -n "Running a simple perl localtime() test... " ;\
pscr='@t=localtime(time);$$t[5]+=1900;$$t[4]++;printf "%04d-%02d-%02d\n",$$t[5],$$t[4],$$t[3];';\
for i in 1 2; do \
export DATEFUDGE=`LC_ALL=C date --date='yesterday 0:00' +%s` ;\
dt=`LD_PRELOAD=$(CURDIR)/datefudge.so perl -e "$$pscr"` ;\
exp="1970-01-02" ;\
[ "$$dt" != "$$exp" ] || { echo "OK"; ret2=0; break; } ;\
echo "failed: expected: $$exp, actual: $$dt" ;\
[ $$i = 2 ] || { echo -n " retrying... "; sleep 2; } ;\
done ;\
exit `expr $$ret1 + $$ret2`;