DataMuseum.dk

Presents historical artifacts from the history of:

DKUUG/EUUG Conference tapes

This is an automatic "excavation" of a thematic subset of
artifacts from Datamuseum.dk's BitArchive.

See our Wiki for more about DKUUG/EUUG Conference tapes

Excavated with: AutoArchaeologist - Free & Open Source Software.


top - metrics - download
Index: M T

⟦c13a5f57a⟧ TextFile

    Length: 4316 (0x10dc)
    Types: TextFile
    Names: »Makefile«

Derivation

└─⟦9ae75bfbd⟧ Bits:30007242 EUUGD3: Starter Kit
    └─⟦eed978cbf⟧ »EurOpenD3/utils/dbz.tar.Z« 
        └─⟦0be62e539⟧ 
            └─⟦this⟧ »dbz/Makefile« 

TextFile

COPTS = -O
FLAGS = -I.
# -lc before libcnews.a so we get fread etc. from system
DBMLIBS =
RFC =
DEBUG = -DDBZDEBUG
CFLAGS = $(COPTS) $(FLAGS)
LINTFLAGS = -h $(FLAGS) $(DEBUG) $(RFC)
LDFLAGS =

# database sizes for performance tests, regression, and regression prime-find
TSIZE=12007
RSIZE=4019
RPSIZE=3012

# history files for regression and performance tests
RHIST=hist3.3
R2HIST=hist10
THIST=hist13

it:	dbz.o

all:	dbz.o dbz

u:	dbz.o
	ar ruv ../libcnews.a dbz.o
	cmp dbz.h ../h/dbz.h

t:	tdbz fake

lint:
	lint $(LINTFLAGS) dbzmain.c dbz.c

rdbz.o:	dbz.c
	cp dbz.c rdbz.c
	$(CC) $(CFLAGS) $(DEBUG) -DDEFSIZE=$(RSIZE) -c rdbz.c
	rm rdbz.c

rdbzmain.o:	dbzmain.c
	cp dbzmain.c rdbzmain.c
	$(CC) $(CFLAGS) $(RFC) -c rdbzmain.c
	rm rdbzmain.c

tdbz.o:	dbz.c
	cp dbz.c tdbz.c
	$(CC) $(CFLAGS) -DDEFSIZE=$(TSIZE) -c tdbz.c
	rm tdbz.c

dbz:	dbzmain.o dbz.o
	$(CC) $(CFLAGS) $(LDFLAGS) dbzmain.o dbz.o -o $@

tdbz:	dbzmain.o tdbz.o
	$(CC) $(CFLAGS) $(LDFLAGS) dbzmain.o tdbz.o -o $@

rdbz:	rdbzmain.o rdbz.o
	$(CC) $(CFLAGS) $(LDFLAGS) rdbzmain.o rdbz.o $(DBMLIBS) -o $@

fake:	fake.o random.o
	$(CC) $(CFLAGS) $(LDFLAGS) fake.o random.o -o $@

byteflip:	byteflip.o
	$(CC) $(CFLAGS) $(LDFLAGS) byteflip.o -o $@

hist10:	fake
	fake -t -e 75 10000 >$@

hist3.3:	fake
	fake -t -e 75 3300 >$@

hist13:	fake
	fake -t -e 75 13000 >$@

r:	rdbz $(RHIST) $(R2HIST) byteflip getmap revbytes altbytes
	: 'WARNING:  creates about 2MB of debris; do "make rclean" afterward'
	rm -f dbase dbase[23] dbase.* dbase[23].*
	test ! -d xx || rmdir xx
	: crude check of synthetic history file
	( sed 25q $(RHIST) ; tail -25 $(RHIST) ) >histjunk
	cmp histjunk firstlast25
	rm histjunk
	: basic tests, exercising as many options as possible
	cp $(RHIST) dbase
	mkdir xx
	chmod -w xx
	rdbz -E 1000 -0 -M -i -S -u -U -C xx dbase
	rmdir xx
	sed '/>	0/d' $(RHIST) >dbase.used
	test "`cat dbase.used | wc -l`" -eq "`sed -n '2s/ .*//p' dbase.dir`" ;
	cp $(RHIST) dbase2
	rdbz -E 1000 -0 -p $(RPSIZE) -t '	' dbase2
	cmp $(RHIST) dbase
	cmp dbase dbase2
	cmp dbase.dir dbase2.dir
	cmp dbase.pag dbase2.pag
	rdbz -E 1000 -0 -c dbase
	rdbz -E 1000 -0 -c -i -q -M -U dbase
	: build a database and then add to it
	sed 1000q $(RHIST) >dbase2
	sed 1,1000d $(RHIST) >dbase2.add
	rdbz -E 1000 -0 dbase2
	rdbz -E 1000 -0 -a dbase2 dbase2.add
	cmp dbase dbase2
	cmp dbase.dir dbase2.dir
	cmp dbase.pag dbase2.pag
	: build based on existing one, test extraction and readonly files
	rdbz -E 1000 -0 -f dbase dbase2
	test "`cat dbase.used | wc -l`" -eq "`awk 'NR==2{print $$1}' dbase2.dir`" ;
	test "`cat dbase.used | wc -l`" -eq "`awk 'NR==2{print $$2}' dbase2.dir`" ;
	chmod -w dbase2.dir dbase2.pag
	rdbz -E 1000 -x dbase2 dbase >dbase.temp
	cmp dbase.used dbase.temp
	: try some small case perversions
	sed 's/\(@[^ 	]*\)A/\1a/' dbase >dbase.ick
	rdbz -E 1000 -x dbase2 dbase.ick >dbase.temp
	cmp dbase.used dbase.temp
	sed -n 's/A\([^ 	]*@\)/a\1/p' dbase >dbase.ick
	rdbz -x dbase2 dbase.ick >dbase.temp
	test ! -s dbase.temp ;
	rm -f dbase2.dir dbase2.pag
	: try it without tags, case-insensitive, with case perversions
	rdbz -E 1000 -0 -p '0 b 1' dbase2
	tr '[A-M][n-z]' '[a-m][N-Z]' <dbase2 >dbase.ick
	rdbz -E 1000 -x dbase2 dbase.ick >dbase.temp
	cmp dbase.used dbase.temp
	rm -f dbase.temp dbase.ick
	: test various perversions of byte ordering
	awk -f revbytes dbase.dir >dbase2.dir
	chmod +x getmap
	byteflip `getmap dbase.dir` `getmap dbase2.dir` <dbase.pag >dbase2.pag
	cp dbase dbase2
	rdbz -E 1000 -0 -c dbase2
	awk -f altbytes dbase.dir >dbase2.dir
	dd conv=swab <dbase.pag >dbase2.pag
	rdbz -E 1000 -0 -c dbase2
	cp dbase2 dbase3
	rdbz -E 1000 -0 -f dbase2 dbase3
	rdbz -E 1000 -0 -c dbase3
	test " `getmap dbase2.dir`" = " `getmap dbase3.dir`" ;
	: test massive overflow, throw in case sensitivity and tag mask
	cp $(R2HIST) dbase
	rdbz -E 1000 -0 -p '0 0 7ff00000' dbase
	rdbz -E 1000 -0 -cq dbase
	sed 100q dbase | egrep '[aA].*	' | tr aA Aa >dbase.ick
	rdbz -x dbase dbase.ick >dbase.temp
	test ! -s dbase.temp ;
	: success!

rclean:
	rm -f dbase dbase[23] dbase.* dbase[23].* fake fake.o random.o
	rm -f rdbz rdbz.o rdbzmain.o $(RHIST) $(R2HIST) byteflip byteflip.o
	rm -f histjunk core
	test ! -d xx || rmdir xx

clean:	rclean
	rm -f *.o dbz [a-z]dbz [a-z][a-z]dbz junk* PostScript.out
	rm -f hist* dbase* *.bak mon.out gmon.out core dbm.h