From 3865746d3c0db2978134470fde6cfcd734abfef7 Mon Sep 17 00:00:00 2001
From: wangzhengquan <wangzhengquan85@126.com>
Date: 星期六, 10 十月 2020 16:42:59 +0800
Subject: [PATCH] update
---
src/Makefile | 89 ++++++++++++++++++++++++++------------------
1 files changed, 53 insertions(+), 36 deletions(-)
diff --git a/src/Makefile b/src/Makefile
index df65135..9039e9c 100644
--- a/src/Makefile
+++ b/src/Makefile
@@ -1,65 +1,82 @@
#
# Makefile for common library.
#
-ROOT=..
-#LDLIBS+=-Wl,-rpath=$(ROOT)/lib
-# 寮�婧愬伐鍏峰寘璺緞
-#LDDIR += -L$(ROOT)/lib
-
-# 寮�婧愬伐鍏峰寘
-LDLIBS += -lusgcommon
-
-MINCLUDE := -I./queue -I./queue/include -I./socket -I./socket/include -I./util -I./util/include
-INCLUDE += $(MINCLUDE)
-
+ROOT := ..
PLATFORM=$(shell $(ROOT)/systype.sh)
include $(ROOT)/Make.defines.$(PLATFORM)
+
+PREFIX = $(DEST)
LIBSQUEUE = libshm_queue.a
DLIBSQUEUE = libshm_queue.so
-SOURCES := $(wildcard *.c ./queue/*.c ./socket/*.c ./util/*.c)
-OBJS = $(patsubst %.c, %.o, $(SOURCES))
-MYLIBS = $(LIBSQUEUE) $(DLIBSQUEUE)
+# 寮�婧愬伐鍏峰寘
+LDLIBS += -lusgcommon
-PREFIX = $(ROOT)/build
+INCLUDES += -I./queue -I./socket -I./util -I$(ROOT)/include/usgcommon
+
+SOURCES := $(wildcard *.c ./**/*.c)
+OBJS = $(patsubst %.c, $(DEST)/%.o, $(SOURCES))
+DEPENDENCES = $(patsubst %.c, $(DEST)/%.d, $(SOURCES))
+
+# MYLIBS = $(LIBCOMMON) $(DLIBCOMMON)
ifeq ($(DEBUG),y)
- MYLIBS = $(LIBSQUEUE) $(DLIBSQUEUE)
+ MYLIBS = $(LIBSQUEUE)
else
MYLIBS = $(LIBSQUEUE) $(DLIBSQUEUE)
endif
-
-all: install
-
-
-build: $(MYLIBS)
-
-#static lib
-$(LIBSQUEUE): $(OBJS)
- $(AR) rv $@ $?
- $(RANLIB) $@
-
-#dynamic lib
-$(DLIBSQUEUE): $(SOURCES)
- rm -f *.o
- $(CC) -fPIC -shared $(CFLAGS) $^ -o $@ $(LDFLAGS) $(LDLIBS)
-
#PREFIX is environment variable, but if it is not set, then set default value
ifeq ($(PREFIX),)
PREFIX := /usr/local
endif
+all: install
+
+
+.PHONY: build
+build: prebuild $(MYLIBS)
+
+.PHONY: prebuild
+prebuild:
+ @test -d $(DEST) || mkdir $(DEST)
+
+#static lib
+$(LIBSQUEUE): $(OBJS)
+ @echo '>>>>>>' generating $@ ...
+ @$(AR) rv $@ $?
+ @$(RANLIB) $@
+
+#dynamic lib
+$(DLIBSQUEUE): $(SOURCES)
+ @echo '>>>>>>' generating $@ ...
+ $(CC) -fPIC -shared $(CPPFLAGS) $(CFLAGS) $(LDFLAGS) $^ -o $@
+
+
+
# 浣跨敤鏂瑰紡锛� g++ test1.c -lcommon
+.PHONY: install
install: $(MYLIBS)
+ @echo '>>>>>>' installing $^ ...
install -d $(PREFIX)/lib/
install -m 644 $^ $(PREFIX)/lib/
- install -d $(PREFIX)/include/
- install -m 644 ./*.h ./queue/include/* ./socket/include/* ./util/include/* $(PREFIX)/include/
+ install -d $(PREFIX)/include/shmqueue
+ install -m 644 ./*.h ./queue/*.h ./socket/*.h ./util/*.h $(PREFIX)/include/shmqueue
+
+.PHONY: uninstall
+uninstall:
+ @echo '>>>>>>' uninstalling ...
+ rm -rf $(PREFIX)/include/shmqueue
+ rm -f $(PREFIX)/lib/shmqueue.*
+
+
+.PHONY: clean
clean:
- rm -f $(TEMPFILES)
+ rm -f $(OBJS) $(MYLIBS) $(DEPENDENCES) $(TEMPFILES)
-.PHONY: build clean install
+
+-include $(DEPENDENCES)
+include $(ROOT)/Make.common.inc
--
Gitblit v1.8.0