Codebase list datefudge / debian/wheezy Makefile
debian/wheezy

Tree @debian/wheezy (Download .tar.gz)

Makefile @debian/wheezyraw · history · blame

# $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`;