]> git.saurik.com Git - redis.git/blobdiff - Makefile
Merge branch 'unstable' of github.com:antirez/redis into unstable
[redis.git] / Makefile
index 34b35f5767c188b63b8fe9e342bf8d3335a6be98..44df36f5e35038de0b8cf958d0f4d99f3a345e5e 100644 (file)
--- a/Makefile
+++ b/Makefile
@@ -1,84 +1,23 @@
-# Redis Makefile
-# Copyright (C) 2009 Salvatore Sanfilippo <antirez at gmail dot com>
-# This file is released under the BSD license, see the COPYING file
+# Top level makefile, the real shit is at src/Makefile
 
-uname_S := $(shell sh -c 'uname -s 2>/dev/null || echo not')
-ifeq ($(uname_S),SunOS)
-  CFLAGS?= -std=c99 -pedantic -O2 -Wall -W -D__EXTENSIONS__ -D_XPG6
-  CCLINK?= -ldl -lnsl -lsocket -lm
-else
-  CFLAGS?= -std=c99 -pedantic -O2 -Wall -W $(ARCH) $(PROF)
-  CCLINK?= -lm
-endif
-CCOPT= $(CFLAGS) $(CCLINK) $(ARCH) $(PROF)
-DEBUG?= -g -rdynamic -ggdb 
+TARGETS=32bit noopt test
 
-OBJ = adlist.o ae.o anet.o dict.o redis.o sds.o zmalloc.o lzf_c.o lzf_d.o pqsort.o
-BENCHOBJ = ae.o anet.o benchmark.o sds.o adlist.o zmalloc.o
-CLIOBJ = anet.o sds.o adlist.o redis-cli.o zmalloc.o
+all:
+       cd src && $(MAKE) $@
 
-PRGNAME = redis-server
-BENCHPRGNAME = redis-benchmark
-CLIPRGNAME = redis-cli
-
-all: redis-server redis-benchmark redis-cli
-
-# Deps (use make dep to generate this)
-adlist.o: adlist.c adlist.h zmalloc.h
-ae.o: ae.c ae.h zmalloc.h ae_select.c ae_epoll.c
-ae_select.o: ae_select.c
-anet.o: anet.c fmacros.h anet.h
-benchmark.o: benchmark.c fmacros.h ae.h anet.h sds.h adlist.h zmalloc.h
-dict.o: dict.c fmacros.h dict.h zmalloc.h
-lzf_c.o: lzf_c.c lzfP.h
-lzf_d.o: lzf_d.c lzfP.h
-pqsort.o: pqsort.c
-redis-cli.o: redis-cli.c fmacros.h anet.h sds.h adlist.h zmalloc.h
-redis.o: redis.c fmacros.h config.h redis.h ae.h sds.h anet.h dict.h \
-  adlist.h zmalloc.h lzf.h pqsort.h staticsymbols.h
-sds.o: sds.c sds.h zmalloc.h
-zmalloc.o: zmalloc.c config.h
-
-redis-server: $(OBJ)
-       $(CC) -o $(PRGNAME) $(CCOPT) $(DEBUG) $(OBJ)
-       @echo ""
-       @echo "Hint: To run the test-redis.tcl script is a good idea."
-       @echo "Launch the redis server with ./redis-server, then in another"
-       @echo "terminal window enter this directory and run 'make test'."
-       @echo ""
-
-redis-benchmark: $(BENCHOBJ)
-       $(CC) -o $(BENCHPRGNAME) $(CCOPT) $(DEBUG) $(BENCHOBJ)
-
-redis-cli: $(CLIOBJ)
-       $(CC) -o $(CLIPRGNAME) $(CCOPT) $(DEBUG) $(CLIOBJ)
-
-.c.o:
-       $(CC) -c $(CFLAGS) $(DEBUG) $(COMPILE_TIME) $<
+install: dummy
+       cd src && $(MAKE) $@
 
 clean:
-       rm -rf $(PRGNAME) $(BENCHPRGNAME) $(CLIPRGNAME) *.o
-
-dep:
-       $(CC) -MM *.c
-
-staticsymbols:
-       tclsh utils/build-static-symbols.tcl > staticsymbols.h
-
-test:
-       tclsh test-redis.tcl
-
-bench:
-       ./redis-benchmark
-
-log:
-       git log '--pretty=format:%ad %s' --date=short > Changelog
+       cd src && $(MAKE) $@
+       cd deps/hiredis && $(MAKE) $@
+       cd deps/linenoise && $(MAKE) $@
+       -(cd deps/jemalloc && $(MAKE) distclean)
 
-32bit:
-       make ARCH="-arch i386"
+$(TARGETS):
+       cd src && $(MAKE) $@
 
-gprof:
-       make PROF="-pg"
+src/help.h:
+       @./utils/generate-command-help.rb > $@
 
-32bitgprof:
-       make PROF="-pg" ARCH="-arch i386"
+dummy: