mirror of https://github.com/PurpleI2P/i2pd.git
hagen
9 years ago
2 changed files with 134 additions and 135 deletions
@ -1,91 +1,91 @@ |
|||||||
UNAME := $(shell uname -s) |
UNAME := $(shell uname -s) |
||||||
SHLIB := libi2pd.so |
SHLIB := libi2pd.so |
||||||
ARLIB := libi2pd.a |
ARLIB := libi2pd.a |
||||||
SHLIB_CLIENT := libi2pdclient.so |
SHLIB_CLIENT := libi2pdclient.so |
||||||
ARLIB_CLIENT := libi2pdclient.a |
ARLIB_CLIENT := libi2pdclient.a |
||||||
I2PD := i2pd |
I2PD := i2pd |
||||||
GREP := fgrep |
GREP := fgrep |
||||||
DEPS := obj/make.dep |
DEPS := obj/make.dep |
||||||
|
|
||||||
include filelist.mk |
include filelist.mk |
||||||
|
|
||||||
USE_AESNI := yes |
USE_AESNI := yes |
||||||
USE_STATIC := no |
USE_STATIC := no |
||||||
|
|
||||||
ifeq ($(UNAME),Darwin) |
ifeq ($(UNAME),Darwin) |
||||||
DAEMON_SRC += DaemonLinux.cpp |
DAEMON_SRC += DaemonLinux.cpp |
||||||
include Makefile.osx |
include Makefile.osx |
||||||
else ifeq ($(shell echo $(UNAME) | $(GREP) -c FreeBSD),1) |
else ifeq ($(shell echo $(UNAME) | $(GREP) -c FreeBSD),1) |
||||||
DAEMON_SRC += DaemonLinux.cpp |
DAEMON_SRC += DaemonLinux.cpp |
||||||
include Makefile.bsd |
include Makefile.bsd |
||||||
else ifeq ($(UNAME),Linux) |
else ifeq ($(UNAME),Linux) |
||||||
DAEMON_SRC += DaemonLinux.cpp |
DAEMON_SRC += DaemonLinux.cpp |
||||||
include Makefile.linux |
include Makefile.linux |
||||||
else # win32 mingw
|
else # win32 mingw
|
||||||
DAEMON_SRC += DaemonWin32.cpp Win32/Win32Service.cpp Win32/Win32App.cpp |
DAEMON_SRC += DaemonWin32.cpp Win32/Win32Service.cpp Win32/Win32App.cpp |
||||||
include Makefile.mingw |
include Makefile.mingw |
||||||
endif |
endif |
||||||
|
|
||||||
all: mk_obj_dir $(ARLIB) $(ARLIB_CLIENT) $(I2PD) |
all: mk_obj_dir $(ARLIB) $(ARLIB_CLIENT) $(I2PD) |
||||||
|
|
||||||
mk_obj_dir: |
mk_obj_dir: |
||||||
@mkdir -p obj |
@mkdir -p obj |
||||||
@mkdir -p obj/Win32 |
@mkdir -p obj/Win32 |
||||||
|
|
||||||
api: mk_obj_dir $(SHLIB) $(ARLIB) |
api: mk_obj_dir $(SHLIB) $(ARLIB) |
||||||
api_client: mk_obj_dir $(SHLIB) $(ARLIB) $(SHLIB_CLIENT) $(ARLIB_CLIENT) |
api_client: mk_obj_dir $(SHLIB) $(ARLIB) $(SHLIB_CLIENT) $(ARLIB_CLIENT) |
||||||
|
|
||||||
## NOTE: The NEEDED_CXXFLAGS are here so that CXXFLAGS can be specified at build time
|
## NOTE: The NEEDED_CXXFLAGS are here so that CXXFLAGS can be specified at build time
|
||||||
## **without** overwriting the CXXFLAGS which we need in order to build.
|
## **without** overwriting the CXXFLAGS which we need in order to build.
|
||||||
## For example, when adding 'hardening flags' to the build
|
## For example, when adding 'hardening flags' to the build
|
||||||
## (e.g. -fstack-protector-strong -Wformat -Werror=format-security), we do not want to remove
|
## (e.g. -fstack-protector-strong -Wformat -Werror=format-security), we do not want to remove
|
||||||
## -std=c++11. If you want to remove this variable please do so in a way that allows setting
|
## -std=c++11. If you want to remove this variable please do so in a way that allows setting
|
||||||
## custom FLAGS to work at build-time.
|
## custom FLAGS to work at build-time.
|
||||||
|
|
||||||
deps: mk_obj_dir |
deps: mk_obj_dir |
||||||
$(CXX) $(CXXFLAGS) $(NEEDED_CXXFLAGS) -MM *.cpp > $(DEPS) |
$(CXX) $(CXXFLAGS) $(NEEDED_CXXFLAGS) -MM *.cpp > $(DEPS) |
||||||
@sed -i -e '/\.o:/ s/^/obj\//' $(DEPS) |
@sed -i -e '/\.o:/ s/^/obj\//' $(DEPS) |
||||||
|
|
||||||
obj/%.o: %.cpp |
obj/%.o: %.cpp |
||||||
$(CXX) $(CXXFLAGS) $(NEEDED_CXXFLAGS) $(INCFLAGS) $(CPU_FLAGS) -c -o $@ $< |
$(CXX) $(CXXFLAGS) $(NEEDED_CXXFLAGS) $(INCFLAGS) $(CPU_FLAGS) -c -o $@ $< |
||||||
|
|
||||||
# '-' is 'ignore if missing' on first run
|
# '-' is 'ignore if missing' on first run
|
||||||
-include $(DEPS) |
-include $(DEPS) |
||||||
|
|
||||||
DAEMON_OBJS += $(patsubst %.cpp,obj/%.o,$(DAEMON_SRC)) |
DAEMON_OBJS += $(patsubst %.cpp,obj/%.o,$(DAEMON_SRC)) |
||||||
$(I2PD): $(DAEMON_OBJS) $(ARLIB) $(ARLIB_CLIENT) |
$(I2PD): $(DAEMON_OBJS) $(ARLIB) $(ARLIB_CLIENT) |
||||||
$(CXX) -o $@ $^ $(LDLIBS) $(LDFLAGS) |
$(CXX) -o $@ $^ $(LDLIBS) $(LDFLAGS) |
||||||
|
|
||||||
$(SHLIB): $(patsubst %.cpp,obj/%.o,$(LIB_SRC)) |
$(SHLIB): $(patsubst %.cpp,obj/%.o,$(LIB_SRC)) |
||||||
ifneq ($(USE_STATIC),yes) |
ifneq ($(USE_STATIC),yes) |
||||||
$(CXX) $(LDFLAGS) $(LDLIBS) -shared -o $@ $^ |
$(CXX) $(LDFLAGS) $(LDLIBS) -shared -o $@ $^ |
||||||
endif |
endif |
||||||
|
|
||||||
$(SHLIB_CLIENT): $(patsubst %.cpp,obj/%.o,$(LIB_CLIENT_SRC)) |
$(SHLIB_CLIENT): $(patsubst %.cpp,obj/%.o,$(LIB_CLIENT_SRC)) |
||||||
$(CXX) $(LDFLAGS) $(LDLIBS) -shared -o $@ $^ |
$(CXX) $(LDFLAGS) $(LDLIBS) -shared -o $@ $^ |
||||||
|
|
||||||
$(ARLIB): $(patsubst %.cpp,obj/%.o,$(LIB_SRC)) |
$(ARLIB): $(patsubst %.cpp,obj/%.o,$(LIB_SRC)) |
||||||
ar -r $@ $^ |
ar -r $@ $^ |
||||||
|
|
||||||
$(ARLIB_CLIENT): $(patsubst %.cpp,obj/%.o,$(LIB_CLIENT_SRC)) |
$(ARLIB_CLIENT): $(patsubst %.cpp,obj/%.o,$(LIB_CLIENT_SRC)) |
||||||
ar -r $@ $^ |
ar -r $@ $^ |
||||||
|
|
||||||
clean: |
clean: |
||||||
rm -rf obj |
rm -rf obj |
||||||
$(RM) $(I2PD) $(SHLIB) $(ARLIB) $(SHLIB_CLIENT) $(ARLIB_CLIENT) |
$(RM) $(I2PD) $(SHLIB) $(ARLIB) $(SHLIB_CLIENT) $(ARLIB_CLIENT) |
||||||
|
|
||||||
strip: $(I2PD) $(SHLIB_CLIENT) $(SHLIB) |
strip: $(I2PD) $(SHLIB_CLIENT) $(SHLIB) |
||||||
strip $^ |
strip $^ |
||||||
|
|
||||||
LATEST_TAG=$(shell git describe --tags --abbrev=0 master) |
LATEST_TAG=$(shell git describe --tags --abbrev=0 master) |
||||||
dist: |
dist: |
||||||
git archive --format=tar.gz -9 --worktree-attributes \
|
git archive --format=tar.gz -9 --worktree-attributes \
|
||||||
--prefix=i2pd_$(LATEST_TAG)/ $(LATEST_TAG) -o i2pd_$(LATEST_TAG).tar.gz |
--prefix=i2pd_$(LATEST_TAG)/ $(LATEST_TAG) -o i2pd_$(LATEST_TAG).tar.gz |
||||||
|
|
||||||
.PHONY: all |
.PHONY: all |
||||||
.PHONY: clean |
.PHONY: clean |
||||||
.PHONY: deps |
.PHONY: deps |
||||||
.PHONY: dist |
.PHONY: dist |
||||||
.PHONY: api |
.PHONY: api |
||||||
.PHONY: api_client |
.PHONY: api_client |
||||||
.PHONY: mk_obj_dir |
.PHONY: mk_obj_dir |
||||||
|
@ -1,44 +1,43 @@ |
|||||||
USE_WIN32_APP=yes |
USE_WIN32_APP=yes |
||||||
CXX = g++ |
CXX = g++ |
||||||
WINDRES = windres |
WINDRES = windres |
||||||
CXXFLAGS = -Os -D_MT -DWIN32 -D_WINDOWS -DWIN32_LEAN_AND_MEAN |
CXXFLAGS = -Os -D_MT -DWIN32 -D_WINDOWS -DWIN32_LEAN_AND_MEAN |
||||||
NEEDED_CXXFLAGS = -std=c++11 |
NEEDED_CXXFLAGS = -std=c++11 |
||||||
BOOST_SUFFIX = -mt |
BOOST_SUFFIX = -mt |
||||||
INCFLAGS = -I/usr/include/ -I/usr/local/include/ |
INCFLAGS = -I/usr/include/ -I/usr/local/include/ |
||||||
LDFLAGS = -Wl,-rpath,/usr/local/lib \
|
LDFLAGS = -Wl,-rpath,/usr/local/lib \
|
||||||
-L/usr/local/lib \
|
-L/usr/local/lib \
|
||||||
-L/c/dev/openssl \
|
-L/c/dev/openssl \
|
||||||
-L/c/dev/boost/lib |
-L/c/dev/boost/lib |
||||||
LDLIBS = \
|
LDLIBS = \
|
||||||
-Wl,-Bstatic -lboost_system$(BOOST_SUFFIX) \
|
-Wl,-Bstatic -lboost_system$(BOOST_SUFFIX) \
|
||||||
-Wl,-Bstatic -lboost_date_time$(BOOST_SUFFIX) \
|
-Wl,-Bstatic -lboost_date_time$(BOOST_SUFFIX) \
|
||||||
-Wl,-Bstatic -lboost_filesystem$(BOOST_SUFFIX) \
|
-Wl,-Bstatic -lboost_filesystem$(BOOST_SUFFIX) \
|
||||||
-Wl,-Bstatic -lboost_regex$(BOOST_SUFFIX) \
|
-Wl,-Bstatic -lboost_regex$(BOOST_SUFFIX) \
|
||||||
-Wl,-Bstatic -lboost_program_options$(BOOST_SUFFIX) \
|
-Wl,-Bstatic -lboost_program_options$(BOOST_SUFFIX) \
|
||||||
-Wl,-Bstatic -lssl \
|
-Wl,-Bstatic -lssl \
|
||||||
-Wl,-Bstatic -lcrypto \
|
-Wl,-Bstatic -lcrypto \
|
||||||
-Wl,-Bstatic -lz \
|
-Wl,-Bstatic -lz \
|
||||||
-Wl,-Bstatic -lwsock32 \
|
-Wl,-Bstatic -lwsock32 \
|
||||||
-Wl,-Bstatic -lws2_32 \
|
-Wl,-Bstatic -lws2_32 \
|
||||||
-Wl,-Bstatic -lgdi32 \
|
-Wl,-Bstatic -lgdi32 \
|
||||||
-Wl,-Bstatic -liphlpapi \
|
-Wl,-Bstatic -liphlpapi \
|
||||||
-static-libgcc -static-libstdc++ \
|
-static-libgcc -static-libstdc++ \
|
||||||
-Wl,-Bstatic -lstdc++ \
|
-Wl,-Bstatic -lstdc++ \
|
||||||
-Wl,-Bstatic -lpthread |
-Wl,-Bstatic -lpthread |
||||||
|
|
||||||
ifeq ($(USE_WIN32_APP), yes) |
ifeq ($(USE_WIN32_APP), yes) |
||||||
CXXFLAGS += -DWIN32_APP |
CXXFLAGS += -DWIN32_APP |
||||||
LDFLAGS += -mwindows -s |
LDFLAGS += -mwindows -s |
||||||
DAEMON_RC += Win32/Resource.rc |
DAEMON_RC += Win32/Resource.rc |
||||||
DAEMON_OBJS += $(patsubst %.rc,obj/%.o,$(DAEMON_RC)) |
DAEMON_OBJS += $(patsubst %.rc,obj/%.o,$(DAEMON_RC)) |
||||||
endif |
endif |
||||||
|
|
||||||
ifeq ($(USE_AESNI),1) |
ifeq ($(USE_AESNI),1) |
||||||
CPU_FLAGS = -maes -DAESNI |
CPU_FLAGS = -maes -DAESNI |
||||||
else |
else |
||||||
CPU_FLAGS = -msse |
CPU_FLAGS = -msse |
||||||
endif |
endif |
||||||
|
|
||||||
obj/%.o : %.rc |
obj/%.o : %.rc |
||||||
$(WINDRES) -i $< -o $@ |
$(WINDRES) -i $< -o $@ |
||||||
|
|
||||||
|
Loading…
Reference in new issue