aboutsummaryrefslogtreecommitdiff
path: root/Makefile
diff options
context:
space:
mode:
authorRobin Krahl <me@robin-krahl.de>2017-03-27 23:36:28 +0200
committerRobin Krahl <me@robin-krahl.de>2017-03-27 23:36:28 +0200
commitc57df190537a73d0cb784bfe149ff22aca884db0 (patch)
tree24476573a16c0c05312df966fa226ada39721d4b /Makefile
parentbdaf2194e083f691e468a560fd5934576dbb8221 (diff)
downloadsqlitepp-c57df190537a73d0cb784bfe149ff22aca884db0.tar.gz
sqlitepp-c57df190537a73d0cb784bfe149ff22aca884db0.tar.bz2
Add version information to the Makefile and to sqlitepp.h
Diffstat (limited to 'Makefile')
-rw-r--r--Makefile15
1 files changed, 12 insertions, 3 deletions
diff --git a/Makefile b/Makefile
index b3ad02f..a905f08 100644
--- a/Makefile
+++ b/Makefile
@@ -11,7 +11,8 @@ SOURCE_NAMES_LIB := sqlitepp.cpp
SOURCE_NAMES_TEST := sqlitepp_test.cpp
TARGET_NAME_LIB := sqlitepp
-TARGET_LIB := $(LIBRARY_DIR)/lib$(TARGET_NAME_LIB).so
+TARGET_LIB_BASE := $(LIBRARY_DIR)/lib$(TARGET_NAME_LIB).so
+TARGET_LIB := $(TARGET_LIB_BASE).$(VERSION_MAJOR).$(VERSION_MINOR).$(VERSION_PATCH)
SOURCES_LIB := $(foreach source,$(SOURCE_NAMES_LIB),$(SOURCE_DIR)/$(source))
OBJECTS_LIB := $(SOURCES_LIB:$(SOURCE_DIR)/%.cpp=$(OBJECT_DIR)/%.o)
DEPENDS_LIB := $(OBJECTS_LIB:.o=.d)
@@ -21,14 +22,18 @@ SOURCES_TEST := $(foreach source,$(SOURCE_NAMES_TEST),$(SOURCE_DIR)/$(source))
OBJECTS_TEST := $(SOURCES_TEST:$(SOURCE_DIR)/%.cpp=$(OBJECT_DIR)/%.o)
DEPENDS_TEST := $(OBJECTS_TEST:.o=.d)
-TARGETS := $(TARGET_LIB) $(TARGET_TEST)
+TARGETS := $(TARGET_LIB) $(TARGET_LIB_BASE) $(TARGET_TEST)
INCLUDES := $(INCLUDE_DIR)/sqlitepp/sqlitepp.h
OBJECTS := $(OBJECTS_LIB) $(OBJECTS_TEST)
DEPENDS := $(DEPENDS_LIB) $(DEPENDS_TEST)
CPPFLAGS += -MMD -MP -I$(INCLUDE_DIR)
+CPPFLAGS += -DSQLITEPP_VERSION_MAJOR=$(VERSION_MAJOR) \
+ -DSQLITEPP_VERSION_MINOR=$(VERSION_MINOR) \
+ -DSQLITEPP_VERSION_PATCH=$(VERSION_PATCH)
CXXFLAGS += -fPIC
LDFLAGS += $(LDFLAGS_SQLITE3)
+LDFLAGS_LIB += -Wl,-soname,lib$(TARGET_NAME_LIB).so.$(VERSION_MAJOR)
LDFLAGS_TEST += -L$(LIBRARY_DIR) -l$(TARGET_NAME_LIB) $(LDFLAGS_GTEST) -Wl,-rpath,$(LIBRARY_DIR)
ifdef VERBOSE
@@ -60,12 +65,16 @@ memcheck: $(TARGET_TEST)
test: $(TARGET_TEST)
./$(TARGET_TEST)
+$(TARGET_LIB_BASE): $(TARGET_LIB)
+ $(info (LN) $@)
+ $(QUIET)ln -sr $^ $@
+
$(TARGET_LIB): $(OBJECTS_LIB)
$(info (CXX) $@)
$(QUIET)mkdir -p $(LIBRARY_DIR)
$(QUIET)$(CXX) -shared $(LDFLAGS) $(LDFLAGS_LIB) -o $@ $^
-$(TARGET_TEST): $(OBJECTS_TEST) $(TARGET_LIB)
+$(TARGET_TEST): $(OBJECTS_TEST) $(TARGET_LIB) $(TARGET_LIB_BASE)
$(info (CXX) $@)
$(QUIET)mkdir -p $(BINARY_DIR)
$(QUIET)$(CXX) $(LDFLAGS) $(LDFLAGS_TEST) $(OBJECTS_TEST) -o $@