mirror of
https://github.com/PurpleI2P/i2pd.git
synced 2025-01-23 17:34:21 +00:00
compile with resources
This commit is contained in:
parent
4cfdc77015
commit
507093dbad
196
Makefile
196
Makefile
@ -1,95 +1,101 @@
|
|||||||
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
|
||||||
WINDIR := True
|
DAEMON_RC += Win32/Resource.rc
|
||||||
include Makefile.mingw
|
WINDIR := True
|
||||||
endif
|
include Makefile.mingw
|
||||||
|
endif
|
||||||
all: mk_build_dir $(ARLIB) $(ARLIB_CLIENT) $(I2PD)
|
|
||||||
|
all: mk_build_dir $(ARLIB) $(ARLIB_CLIENT) $(I2PD)
|
||||||
mk_build_dir:
|
|
||||||
mkdir -p obj
|
mk_build_dir:
|
||||||
ifeq ($(WINDIR),True)
|
mkdir -p obj
|
||||||
mkdir -p obj/Win32
|
ifeq ($(WINDIR),True)
|
||||||
endif
|
mkdir -p obj/Win32
|
||||||
|
endif
|
||||||
api: mk_build_dir $(SHLIB) $(ARLIB)
|
|
||||||
api_client: mk_build_dir $(SHLIB) $(ARLIB) $(SHLIB_CLIENT) $(ARLIB_CLIENT)
|
api: mk_build_dir $(SHLIB) $(ARLIB)
|
||||||
|
api_client: mk_build_dir $(SHLIB) $(ARLIB) $(SHLIB_CLIENT) $(ARLIB_CLIENT)
|
||||||
## 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.
|
## NOTE: The NEEDED_CXXFLAGS are here so that CXXFLAGS can be specified at build time
|
||||||
## For example, when adding 'hardening flags' to the build
|
## **without** overwriting the CXXFLAGS which we need in order to build.
|
||||||
## (e.g. -fstack-protector-strong -Wformat -Werror=format-security), we do not want to remove
|
## For example, when adding 'hardening flags' to the build
|
||||||
## -std=c++11. If you want to remove this variable please do so in a way that allows setting
|
## (e.g. -fstack-protector-strong -Wformat -Werror=format-security), we do not want to remove
|
||||||
## custom FLAGS to work at build-time.
|
## -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.
|
||||||
deps:
|
|
||||||
@mkdir -p obj
|
deps:
|
||||||
$(CXX) $(CXXFLAGS) $(NEEDED_CXXFLAGS) -MM *.cpp > $(DEPS)
|
@mkdir -p obj
|
||||||
@sed -i -e '/\.o:/ s/^/obj\//' $(DEPS)
|
$(CXX) $(CXXFLAGS) $(NEEDED_CXXFLAGS) -MM *.cpp > $(DEPS)
|
||||||
|
@sed -i -e '/\.o:/ s/^/obj\//' $(DEPS)
|
||||||
obj/%.o : %.cpp
|
|
||||||
@mkdir -p obj
|
obj/%.o : %.cpp
|
||||||
$(CXX) $(CXXFLAGS) $(NEEDED_CXXFLAGS) $(INCFLAGS) $(CPU_FLAGS) -c -o $@ $<
|
@mkdir -p obj
|
||||||
|
$(CXX) $(CXXFLAGS) $(NEEDED_CXXFLAGS) $(INCFLAGS) $(CPU_FLAGS) -c -o $@ $<
|
||||||
# '-' is 'ignore if missing' on first run
|
|
||||||
-include $(DEPS)
|
obj/%.o : %.rc
|
||||||
|
$(WINDRES) -i $< -o $@
|
||||||
$(I2PD): $(patsubst %.cpp,obj/%.o,$(DAEMON_SRC)) $(ARLIB) $(ARLIB_CLIENT)
|
|
||||||
$(CXX) -o $@ $^ $(LDLIBS) $(LDFLAGS)
|
# '-' is 'ignore if missing' on first run
|
||||||
|
-include $(DEPS)
|
||||||
$(SHLIB): $(patsubst %.cpp,obj/%.o,$(LIB_SRC))
|
|
||||||
ifneq ($(USE_STATIC),yes)
|
DAEMON_OBJS = $(patsubst %.cpp,obj/%.o,$(DAEMON_SRC))
|
||||||
$(CXX) $(LDFLAGS) $(LDLIBS) -shared -o $@ $^
|
DAEMON_RES_OBJS = $(patsubst %.rc,obj/%.o,$(DAEMON_RC))
|
||||||
endif
|
$(I2PD): $(DAEMON_OBJS) $(DAEMON_RES_OBJS) $(ARLIB) $(ARLIB_CLIENT)
|
||||||
|
$(CXX) -o $@ $^ $(LDLIBS) $(LDFLAGS)
|
||||||
$(SHLIB_CLIENT): $(patsubst %.cpp,obj/%.o,$(LIB_CLIENT_SRC))
|
|
||||||
$(CXX) $(LDFLAGS) $(LDLIBS) -shared -o $@ $^
|
$(SHLIB): $(patsubst %.cpp,obj/%.o,$(LIB_SRC))
|
||||||
|
ifneq ($(USE_STATIC),yes)
|
||||||
$(ARLIB): $(patsubst %.cpp,obj/%.o,$(LIB_SRC))
|
$(CXX) $(LDFLAGS) $(LDLIBS) -shared -o $@ $^
|
||||||
ar -r $@ $^
|
endif
|
||||||
|
|
||||||
$(ARLIB_CLIENT): $(patsubst %.cpp,obj/%.o,$(LIB_CLIENT_SRC))
|
$(SHLIB_CLIENT): $(patsubst %.cpp,obj/%.o,$(LIB_CLIENT_SRC))
|
||||||
ar -r $@ $^
|
$(CXX) $(LDFLAGS) $(LDLIBS) -shared -o $@ $^
|
||||||
|
|
||||||
clean:
|
$(ARLIB): $(patsubst %.cpp,obj/%.o,$(LIB_SRC))
|
||||||
rm -rf obj
|
ar -r $@ $^
|
||||||
$(RM) $(I2PD) $(SHLIB) $(ARLIB) $(SHLIB_CLIENT) $(ARLIB_CLIENT)
|
|
||||||
|
$(ARLIB_CLIENT): $(patsubst %.cpp,obj/%.o,$(LIB_CLIENT_SRC))
|
||||||
strip: $(I2PD) $(SHLIB_CLIENT) $(SHLIB)
|
ar -r $@ $^
|
||||||
strip $^
|
|
||||||
|
clean:
|
||||||
LATEST_TAG=$(shell git describe --tags --abbrev=0 master)
|
rm -rf obj
|
||||||
dist:
|
$(RM) $(I2PD) $(SHLIB) $(ARLIB) $(SHLIB_CLIENT) $(ARLIB_CLIENT)
|
||||||
git archive --format=tar.gz -9 --worktree-attributes \
|
|
||||||
--prefix=i2pd_$(LATEST_TAG)/ $(LATEST_TAG) -o i2pd_$(LATEST_TAG).tar.gz
|
strip: $(I2PD) $(SHLIB_CLIENT) $(SHLIB)
|
||||||
|
strip $^
|
||||||
.PHONY: all
|
|
||||||
.PHONY: clean
|
LATEST_TAG=$(shell git describe --tags --abbrev=0 master)
|
||||||
.PHONY: deps
|
dist:
|
||||||
.PHONY: dist
|
git archive --format=tar.gz -9 --worktree-attributes \
|
||||||
.PHONY: api
|
--prefix=i2pd_$(LATEST_TAG)/ $(LATEST_TAG) -o i2pd_$(LATEST_TAG).tar.gz
|
||||||
.PHONY: api_client
|
|
||||||
.PHONY: mk_build_dir
|
.PHONY: all
|
||||||
|
.PHONY: clean
|
||||||
|
.PHONY: deps
|
||||||
|
.PHONY: dist
|
||||||
|
.PHONY: api
|
||||||
|
.PHONY: api_client
|
||||||
|
.PHONY: mk_build_dir
|
||||||
|
@ -1,9 +1,10 @@
|
|||||||
CXX = g++
|
CXX = g++
|
||||||
|
WINDRES = windres
|
||||||
CXXFLAGS = -O2 -D_MT -DWIN32 -D_WINDOWS -DWIN32_LEAN_AND_MEAN
|
CXXFLAGS = -O2 -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 -L/usr/local/lib -L/c/dev/openssl -L/c/dev/boost/lib
|
LDFLAGS = -mwindows -Wl,-rpath,/usr/local/lib -L/usr/local/lib -L/c/dev/openssl -L/c/dev/boost/lib
|
||||||
LDLIBS = -Wl,-Bstatic -lboost_system$(BOOST_SUFFIX) -Wl,-Bstatic -lboost_date_time$(BOOST_SUFFIX) -Wl,-Bstatic -lboost_filesystem$(BOOST_SUFFIX) -Wl,-Bstatic -lboost_regex$(BOOST_SUFFIX) -Wl,-Bstatic -lboost_program_options$(BOOST_SUFFIX) -Wl,-Bstatic -lssl -Wl,-Bstatic -lcrypto -Wl,-Bstatic -lz -Wl,-Bstatic -lwsock32 -Wl,-Bstatic -lws2_32 -Wl,-Bstatic -lgdi32 -Wl,-Bstatic -liphlpapi -static-libgcc -static-libstdc++ -Wl,-Bstatic -lstdc++ -Wl,-Bstatic -lpthread
|
LDLIBS = -Wl,-Bstatic -lboost_system$(BOOST_SUFFIX) -Wl,-Bstatic -lboost_date_time$(BOOST_SUFFIX) -Wl,-Bstatic -lboost_filesystem$(BOOST_SUFFIX) -Wl,-Bstatic -lboost_regex$(BOOST_SUFFIX) -Wl,-Bstatic -lboost_program_options$(BOOST_SUFFIX) -Wl,-Bstatic -lssl -Wl,-Bstatic -lcrypto -Wl,-Bstatic -lz -Wl,-Bstatic -lwsock32 -Wl,-Bstatic -lws2_32 -Wl,-Bstatic -lgdi32 -Wl,-Bstatic -liphlpapi -static-libgcc -static-libstdc++ -Wl,-Bstatic -lstdc++ -Wl,-Bstatic -lpthread
|
||||||
|
|
||||||
ifeq ($(USE_AESNI),1)
|
ifeq ($(USE_AESNI),1)
|
||||||
|
Loading…
x
Reference in New Issue
Block a user